Documentation of SFML 2.6.0

Warning: this page refers to an old version of SFML. Click here to switch to the latest version.
Loading...
Searching...
No Matches
Ftp.hpp
1
2//
3// SFML - Simple and Fast Multimedia Library
4// Copyright (C) 2007-2023 Laurent Gomila (laurent@sfml-dev.org)
5//
6// This software is provided 'as-is', without any express or implied warranty.
7// In no event will the authors be held liable for any damages arising from the use of this software.
8//
9// Permission is granted to anyone to use this software for any purpose,
10// including commercial applications, and to alter it and redistribute it freely,
11// subject to the following restrictions:
12//
13// 1. The origin of this software must not be misrepresented;
14// you must not claim that you wrote the original software.
15// If you use this software in a product, an acknowledgment
16// in the product documentation would be appreciated but is not required.
17//
18// 2. Altered source versions must be plainly marked as such,
19// and must not be misrepresented as being the original software.
20//
21// 3. This notice may not be removed or altered from any source distribution.
22//
24
25#ifndef SFML_FTP_HPP
26#define SFML_FTP_HPP
27
29// Headers
31#include <SFML/Network/Export.hpp>
32#include <SFML/Network/TcpSocket.hpp>
33#include <SFML/System/NonCopyable.hpp>
34#include <SFML/System/Time.hpp>
35#include <string>
36#include <vector>
37
38
39namespace sf
40{
41class IpAddress;
42
47class SFML_NETWORK_API Ftp : NonCopyable
48{
49public:
50
56 {
59 Ebcdic
60 };
61
66 class SFML_NETWORK_API Response
67 {
68 public:
69
74 enum Status
75 {
76 // 1xx: the requested action is being initiated,
77 // expect another reply before proceeding with a new command
78 RestartMarkerReply = 110,
79 ServiceReadySoon = 120,
80 DataConnectionAlreadyOpened = 125,
81 OpeningDataConnection = 150,
82
83 // 2xx: the requested action has been successfully completed
84 Ok = 200,
85 PointlessCommand = 202,
86 SystemStatus = 211,
87 DirectoryStatus = 212,
88 FileStatus = 213,
89 HelpMessage = 214,
90 SystemType = 215,
91 ServiceReady = 220,
92 ClosingConnection = 221,
93 DataConnectionOpened = 225,
94 ClosingDataConnection = 226,
95 EnteringPassiveMode = 227,
96 LoggedIn = 230,
97 FileActionOk = 250,
98 DirectoryOk = 257,
99
100 // 3xx: the command has been accepted, but the requested action
101 // is dormant, pending receipt of further information
102 NeedPassword = 331,
103 NeedAccountToLogIn = 332,
104 NeedInformation = 350,
105
106 // 4xx: the command was not accepted and the requested action did not take place,
107 // but the error condition is temporary and the action may be requested again
108 ServiceUnavailable = 421,
109 DataConnectionUnavailable = 425,
110 TransferAborted = 426,
111 FileActionAborted = 450,
112 LocalError = 451,
113 InsufficientStorageSpace = 452,
114
115 // 5xx: the command was not accepted and
116 // the requested action did not take place
117 CommandUnknown = 500,
118 ParametersUnknown = 501,
119 CommandNotImplemented = 502,
120 BadCommandSequence = 503,
121 ParameterNotImplemented = 504,
122 NotLoggedIn = 530,
123 NeedAccountToStore = 532,
124 FileUnavailable = 550,
125 PageTypeUnknown = 551,
126 NotEnoughMemory = 552,
127 FilenameNotAllowed = 553,
128
129 // 10xx: SFML custom codes
130 InvalidResponse = 1000,
131 ConnectionFailed = 1001,
132 ConnectionClosed = 1002,
133 InvalidFile = 1003
134 };
135
146 explicit Response(Status code = InvalidResponse, const std::string& message = "");
147
157 bool isOk() const;
158
166
173 const std::string& getMessage() const;
174
175 private:
176
178 // Member data
180 Status m_status;
181 std::string m_message;
182 };
183
188 class SFML_NETWORK_API DirectoryResponse : public Response
189 {
190 public:
191
198 DirectoryResponse(const Response& response);
199
206 const std::string& getDirectory() const;
207
208 private:
209
211 // Member data
213 std::string m_directory;
214 };
215
216
221 class SFML_NETWORK_API ListingResponse : public Response
222 {
223 public:
224
232 ListingResponse(const Response& response, const std::string& data);
233
240 const std::vector<std::string>& getListing() const;
241
242 private:
243
245 // Member data
247 std::vector<std::string> m_listing;
248 };
249
250
259
281 Response connect(const IpAddress& server, unsigned short port = 21, Time timeout = Time::Zero);
282
292
303
316 Response login(const std::string& name, const std::string& password);
317
328
341
357 ListingResponse getDirectoryListing(const std::string& directory = "");
358
371 Response changeDirectory(const std::string& directory);
372
382
396 Response createDirectory(const std::string& name);
397
413 Response deleteDirectory(const std::string& name);
414
429 Response renameFile(const std::string& file, const std::string& newName);
430
446 Response deleteFile(const std::string& name);
447
468 Response download(const std::string& remoteFile, const std::string& localPath, TransferMode mode = Binary);
469
491 Response upload(const std::string& localFile, const std::string& remotePath, TransferMode mode = Binary, bool append = false);
492
509 Response sendCommand(const std::string& command, const std::string& parameter = "");
510
511private:
512
522 Response getResponse();
523
529 class DataChannel;
530
531 friend class DataChannel;
532
534 // Member data
536 TcpSocket m_commandSocket;
537 std::string m_receiveBuffer;
538};
539
540} // namespace sf
541
542
543#endif // SFML_FTP_HPP
544
545
Specialization of FTP response returning a directory.
Definition: Ftp.hpp:189
DirectoryResponse(const Response &response)
Default constructor.
const std::string & getDirectory() const
Get the directory returned in the response.
Specialization of FTP response returning a filename listing.
Definition: Ftp.hpp:222
const std::vector< std::string > & getListing() const
Return the array of directory/file names.
ListingResponse(const Response &response, const std::string &data)
Default constructor.
Define a FTP response.
Definition: Ftp.hpp:67
bool isOk() const
Check if the status code means a success.
Status getStatus() const
Get the status code of the response.
const std::string & getMessage() const
Get the full message contained in the response.
Response(Status code=InvalidResponse, const std::string &message="")
Default constructor.
Status
Status codes possibly returned by a FTP response.
Definition: Ftp.hpp:75
A FTP client.
Definition: Ftp.hpp:48
Response upload(const std::string &localFile, const std::string &remotePath, TransferMode mode=Binary, bool append=false)
Upload a file to the server.
TransferMode
Enumeration of transfer modes.
Definition: Ftp.hpp:56
@ Binary
Binary mode (file is transfered as a sequence of bytes)
Definition: Ftp.hpp:57
@ Ascii
Text mode using ASCII encoding.
Definition: Ftp.hpp:58
Response download(const std::string &remoteFile, const std::string &localPath, TransferMode mode=Binary)
Download a file from the server.
Response createDirectory(const std::string &name)
Create a new directory.
Response deleteDirectory(const std::string &name)
Remove an existing directory.
~Ftp()
Destructor.
Response sendCommand(const std::string &command, const std::string &parameter="")
Send a command to the FTP server.
Response login()
Log in using an anonymous account.
DirectoryResponse getWorkingDirectory()
Get the current working directory.
Response changeDirectory(const std::string &directory)
Change the current working directory.
Response deleteFile(const std::string &name)
Remove an existing file.
ListingResponse getDirectoryListing(const std::string &directory="")
Get the contents of the given directory.
Response renameFile(const std::string &file, const std::string &newName)
Rename an existing file.
Response login(const std::string &name, const std::string &password)
Log in using a username and a password.
Response keepAlive()
Send a null command to keep the connection alive.
Response disconnect()
Close the connection with the server.
Response parentDirectory()
Go to the parent directory of the current one.
Response connect(const IpAddress &server, unsigned short port=21, Time timeout=Time::Zero)
Connect to the specified FTP server.
Encapsulate an IPv4 network address.
Definition: IpAddress.hpp:45
Utility class that makes any derived class non-copyable.
Definition: NonCopyable.hpp:42
Specialized socket using the TCP protocol.
Definition: TcpSocket.hpp:47
Represents a time value.
Definition: Time.hpp:41