Move SetPassword and SetUser implementations to wxProtocol to avoid code redundancy Make const-correct various getters Reorganize wxFTP docs Move wxStringToStringHashMap to hashmap.h and document its existance git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@58137 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			177 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        ftp.h
 | |
| // Purpose:     FTP protocol
 | |
| // Author:      Vadim Zeitlin
 | |
| // Modified by: Mark Johnson, wxWindows@mj10777.de
 | |
| //              20000917 : RmDir, GetLastResult, GetList
 | |
| // Created:     07/07/1997
 | |
| // RCS-ID:      $Id$
 | |
| // Copyright:   (c) 1997, 1998 Guilhem Lavaux
 | |
| // Licence:     wxWindows licence
 | |
| /////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef __WX_FTP_H__
 | |
| #define __WX_FTP_H__
 | |
| 
 | |
| #include "wx/defs.h"
 | |
| 
 | |
| #if wxUSE_PROTOCOL_FTP
 | |
| 
 | |
| #include "wx/sckaddr.h"
 | |
| #include "wx/protocol/protocol.h"
 | |
| #include "wx/url.h"
 | |
| 
 | |
| class WXDLLIMPEXP_NET wxFTP : public wxProtocol
 | |
| {
 | |
| public:
 | |
|     enum TransferMode
 | |
|     {
 | |
|         NONE,       // not set by user explicitly
 | |
|         ASCII,
 | |
|         BINARY
 | |
|     };
 | |
| 
 | |
|     wxFTP();
 | |
|     virtual ~wxFTP();
 | |
| 
 | |
|     // Connecting and disconnecting
 | |
|     bool Connect(const wxSockAddress& addr, bool wait = true);
 | |
|     bool Connect(const wxString& host);
 | |
| 
 | |
|     // disconnect
 | |
|     virtual bool Close();
 | |
| 
 | |
|     // Parameters set up
 | |
| 
 | |
|     // set transfer mode now
 | |
|     void SetPassive(bool pasv) { m_bPassive = pasv; }
 | |
|     bool SetBinary() { return SetTransferMode(BINARY); }
 | |
|     bool SetAscii() { return SetTransferMode(ASCII); }
 | |
|     bool SetTransferMode(TransferMode mode);
 | |
| 
 | |
|     // Generic FTP interface
 | |
| 
 | |
|     // FTP doesn't know the MIME type of the last downloaded/uploaded file
 | |
|     virtual wxString GetContentType() const { return wxEmptyString; }
 | |
| 
 | |
|     // the last FTP server reply
 | |
|     const wxString& GetLastResult() const { return m_lastResult; }
 | |
| 
 | |
|     // send any FTP command (should be full FTP command line but without
 | |
|     // trailing "\r\n") and return its return code
 | |
|     char SendCommand(const wxString& command);
 | |
| 
 | |
|     // check that the command returned the given code
 | |
|     bool CheckCommand(const wxString& command, char expectedReturn)
 | |
|     {
 | |
|         // SendCommand() does updates m_lastError
 | |
|         return SendCommand(command) == expectedReturn;
 | |
|     }
 | |
| 
 | |
|     // Filesystem commands
 | |
|     bool ChDir(const wxString& dir);
 | |
|     bool MkDir(const wxString& dir);
 | |
|     bool RmDir(const wxString& dir);
 | |
|     wxString Pwd();
 | |
|     bool Rename(const wxString& src, const wxString& dst);
 | |
|     bool RmFile(const wxString& path);
 | |
| 
 | |
|     // Get the size of a file in the current dir.
 | |
|     // this function tries its best to deliver the size in bytes using BINARY
 | |
|     // (the SIZE command reports different sizes depending on whether
 | |
|     // type is set to ASCII or BINARY)
 | |
|     // returns -1 if file is non-existant or size could not be found
 | |
|     int GetFileSize(const wxString& fileName);
 | |
| 
 | |
|        // Check to see if a file exists in the current dir
 | |
|     bool FileExists(const wxString& fileName);
 | |
| 
 | |
|     // Download methods
 | |
|     bool Abort();
 | |
| 
 | |
|     virtual wxInputStream *GetInputStream(const wxString& path);
 | |
|     virtual wxOutputStream *GetOutputStream(const wxString& path);
 | |
| 
 | |
|     // Directory listing
 | |
| 
 | |
|     // get the list of full filenames, the format is fixed: one file name per
 | |
|     // line
 | |
|     bool GetFilesList(wxArrayString& files,
 | |
|                       const wxString& wildcard = wxEmptyString)
 | |
|     {
 | |
|         return GetList(files, wildcard, false);
 | |
|     }
 | |
| 
 | |
|     // get a directory list in server dependent format - this can be shown
 | |
|     // directly to the user
 | |
|     bool GetDirList(wxArrayString& files,
 | |
|                     const wxString& wildcard = wxEmptyString)
 | |
|     {
 | |
|         return GetList(files, wildcard, true);
 | |
|     }
 | |
| 
 | |
|     // equivalent to either GetFilesList() (default) or GetDirList()
 | |
|     bool GetList(wxArrayString& files,
 | |
|                  const wxString& wildcard = wxEmptyString,
 | |
|                  bool details = false);
 | |
| 
 | |
| protected:
 | |
|     // this executes a simple ftp command with the given argument and returns
 | |
|     // true if it its return code starts with '2'
 | |
|     bool DoSimpleCommand(const wxChar *command,
 | |
|                          const wxString& arg = wxEmptyString);
 | |
| 
 | |
|     // get the server reply, return the first character of the reply code,
 | |
|     // '1'..'5' for normal FTP replies, 0 (*not* '0') if an error occurred
 | |
|     char GetResult();
 | |
| 
 | |
|     // check that the result is equal to expected value
 | |
|     bool CheckResult(char ch) { return GetResult() == ch; }
 | |
| 
 | |
|     // return the socket to be used, Passive/Active versions are used only by
 | |
|     // GetPort()
 | |
|     wxSocketBase *GetPort();
 | |
|     wxSocketBase *GetPassivePort();
 | |
|     wxSocketBase *GetActivePort();
 | |
| 
 | |
|     // helper for GetPort()
 | |
|     wxString GetPortCmdArgument(const wxIPV4address& Local, const wxIPV4address& New);
 | |
| 
 | |
|     // accept connection from server in active mode, returns the same socket as
 | |
|     // passed in in passive mode
 | |
|     wxSocketBase *AcceptIfActive(wxSocketBase *sock);
 | |
| 
 | |
| 
 | |
|     // internal variables:
 | |
| 
 | |
|     wxString        m_lastResult;
 | |
| 
 | |
|     // true if there is an FTP transfer going on
 | |
|     bool            m_streaming;
 | |
| 
 | |
|     // although this should be set to ASCII by default according to STD9,
 | |
|     // we will use BINARY transfer mode by default for backwards compatibility
 | |
|     TransferMode    m_currentTransfermode;
 | |
| 
 | |
|     bool            m_bPassive;
 | |
| 
 | |
|     // following is true when  a read or write times out, we then assume
 | |
|     // the connection is dead and abort. we avoid additional delays this way
 | |
|     bool            m_bEncounteredError;
 | |
| 
 | |
| 
 | |
|     friend class wxInputFTPStream;
 | |
|     friend class wxOutputFTPStream;
 | |
| 
 | |
|     DECLARE_DYNAMIC_CLASS_NO_COPY(wxFTP)
 | |
|     DECLARE_PROTOCOL(wxFTP)
 | |
| };
 | |
| 
 | |
| // the trace mask used by assorted wxLogTrace() in ftp code, do
 | |
| // wxLog::AddTraceMask(FTP_TRACE_MASK) to see them in output
 | |
| #define FTP_TRACE_MASK _T("ftp")
 | |
| 
 | |
| #endif // wxUSE_PROTOCOL_FTP
 | |
| 
 | |
| #endif // __WX_FTP_H__
 |