Class FTPClientWrapper
java.lang.Object
org.apache.commons.vfs2.provider.ftp.FTPClientWrapper
- All Implemented Interfaces:
FtpClient
A wrapper to the FTPClient to allow automatic reconnect on connection loss.
I decided to not to use eg. noop() to determine the state of the connection to avoid unnecessary server round-trips.
-
Field Summary
Fields -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotected
FTPClientWrapper
(GenericFileName rootFileName, FileSystemOptions fileSystemOptions) Constructs a new instance. -
Method Summary
Modifier and TypeMethodDescriptionboolean
abort()
Aborts the current operation.appendFileStream
(String relPath) Returns an OutputStream through which data can be written to append to a file on the server with the given name.boolean
There are a few FTPClient methods that do not complete the entire sequence of FTP commands to complete a transaction.protected org.apache.commons.net.ftp.FTPClient
createClient
(GenericFileName rootFileName, UserAuthenticationData authData) Creates an FTPClient.boolean
deleteFile
(String relPath) Deletes a file on the FTP server.void
Sends the FTP QUIT command to the server, receive the reply, and return the reply code.Gets the FileSystemOptions.int
Gets the integer value of the reply code of the last FTP reply.Gets the entire text of the last FTP server response exactly as it was received, including all end of line markers in NETASCII format.getRoot()
Gets the root file name.boolean
hasFeature
(String feature) Queries the server for a supported feature.boolean
Tests if the client is currently connected to a server.org.apache.commons.net.ftp.FTPFile[]
Using the default system autodetect mechanism, obtain a list of file information for the current working directory or for just a single file.boolean
makeDirectory
(String relPath) Creates a new subdirectory on the FTP server in the current directory (if a relative pathname is given) or where specified (if an absolute pathname is given).mdtmInstant
(String relPath) Sends the MDTM command to get a file's date and time information after file transfer.boolean
removeDirectory
(String relPath) Removes a directory on the FTP server (if empty).boolean
Renames a remote file.retrieveFileStream
(String relPath) Returns an InputStream from which a named file from the server can be read.retrieveFileStream
(String relPath, int bufferSize) Returns an InputStream from which a named file from the server can be read.retrieveFileStream
(String relPath, long restartOffset) Returns an InputStream from which a named file from the server can be read.void
setBufferSize
(int bufferSize) Sets the buffer size for buffered data streams.storeFileStream
(String relPath) Returns an OutputStream through which data can be written to store a file on the server using the given name.
-
Field Details
-
fileSystemOptions
Authentication options.
-
-
Constructor Details
-
FTPClientWrapper
protected FTPClientWrapper(GenericFileName rootFileName, FileSystemOptions fileSystemOptions) throws FileSystemException Constructs a new instance.- Parameters:
rootFileName
- the root file name.fileSystemOptions
- the file system options.- Throws:
FileSystemException
- if a file system error occurs.
-
-
Method Details
-
abort
Description copied from interface:FtpClient
Aborts the current operation.- Specified by:
abort
in interfaceFtpClient
- Returns:
- true if aborted.
- Throws:
IOException
- If an I/O error occurs
-
appendFileStream
Description copied from interface:FtpClient
Returns an OutputStream through which data can be written to append to a file on the server with the given name.- Specified by:
appendFileStream
in interfaceFtpClient
- Parameters:
relPath
- The name of the remote file.- Returns:
- An OutputStream through which the remote file can be appended.
- Throws:
IOException
- If an I/O error occurs.
-
completePendingCommand
Description copied from interface:FtpClient
There are a few FTPClient methods that do not complete the entire sequence of FTP commands to complete a transaction. These commands require some action by the programmer after the reception of a positive intermediate command. After the programmer's code completes its actions, it must call this method to receive the completion reply from the server and verify the success of the entire transaction.- Specified by:
completePendingCommand
in interfaceFtpClient
- Returns:
- true if successfully completed, false if not.
- Throws:
IOException
- If an I/O error occurs.
-
createClient
protected org.apache.commons.net.ftp.FTPClient createClient(GenericFileName rootFileName, UserAuthenticationData authData) throws FileSystemException Creates an FTPClient.- Parameters:
rootFileName
- the root file name.authData
- authentication data.- Returns:
- an FTPClient.
- Throws:
FileSystemException
- if a file system error occurs.
-
deleteFile
Description copied from interface:FtpClient
Deletes a file on the FTP server.- Specified by:
deleteFile
in interfaceFtpClient
- Parameters:
relPath
- The relPath of the file to be deleted.- Returns:
- true if successfully completed, false if not.
- Throws:
IOException
- If an I/O error occurs.
-
disconnect
Description copied from interface:FtpClient
Sends the FTP QUIT command to the server, receive the reply, and return the reply code.- Specified by:
disconnect
in interfaceFtpClient
- Throws:
IOException
- If an I/O error occurs.
-
getFileSystemOptions
Gets the FileSystemOptions.- Returns:
- the FileSystemOptions.
-
getReplyCode
Description copied from interface:FtpClient
Gets the integer value of the reply code of the last FTP reply.- Specified by:
getReplyCode
in interfaceFtpClient
- Returns:
- The integer value of the reply code of the last FTP reply.
- Throws:
IOException
- If an I/O error occurs.
-
getReplyString
Description copied from interface:FtpClient
Gets the entire text of the last FTP server response exactly as it was received, including all end of line markers in NETASCII format.- Specified by:
getReplyString
in interfaceFtpClient
- Returns:
- The entire text from the last FTP response as a String.
- Throws:
IOException
- If an I/O error occurs.
-
getRoot
Gets the root file name.- Returns:
- the root file name.
-
hasFeature
Queries the server for a supported feature.- Specified by:
hasFeature
in interfaceFtpClient
- Parameters:
feature
- the name of the feature, converted to upper case.- Returns:
true
if the feature is present,false
if the feature is not present or the FTP command failed.- Throws:
IOException
- If an I/O error occurs.
-
isConnected
Description copied from interface:FtpClient
Tests if the client is currently connected to a server.- Specified by:
isConnected
in interfaceFtpClient
- Returns:
- true if the client is currently connected to a server, false otherwise.
- Throws:
FileSystemException
- If an I/O error occurs.
-
listFiles
Description copied from interface:FtpClient
Using the default system autodetect mechanism, obtain a list of file information for the current working directory or for just a single file.TODO This interface should not leak Apache Commons NET types like FTPFile
- Specified by:
listFiles
in interfaceFtpClient
- Parameters:
relPath
- The file or directory to list.- Returns:
- an array of FTPFile.
- Throws:
IOException
- If an I/O error occurs.
-
makeDirectory
Description copied from interface:FtpClient
Creates a new subdirectory on the FTP server in the current directory (if a relative pathname is given) or where specified (if an absolute pathname is given).- Specified by:
makeDirectory
in interfaceFtpClient
- Parameters:
relPath
- The pathname of the directory to create.- Returns:
- true if successfully completed, false if not.
- Throws:
IOException
- If an I/O error occurs.
-
mdtmInstant
Sends the MDTM command to get a file's date and time information after file transfer. It is typically more accurate than the"LIST"
command response. Time values are always represented in UTC (GMT), and in the Gregorian calendar regardless of what calendar may have been in use at the date and time the file was last modified.NOTE: not all remote FTP servers support
MDTM
.- Specified by:
mdtmInstant
in interfaceFtpClient
- Parameters:
relPath
- The relative path of the file object to executeMDTM
command against- Returns:
- new
Instant
object containing theMDTM
timestamp. - Throws:
IOException
- If an I/O error occurs.
-
removeDirectory
Description copied from interface:FtpClient
Removes a directory on the FTP server (if empty).- Specified by:
removeDirectory
in interfaceFtpClient
- Parameters:
relPath
- The pathname of the directory to remove.- Returns:
- true if successfully completed, false if not.
- Throws:
IOException
- If an I/O error occurs.
-
rename
Description copied from interface:FtpClient
Renames a remote file.- Specified by:
rename
in interfaceFtpClient
- Parameters:
oldName
- The name of the remote file to rename.newName
- The new name of the remote file.- Returns:
- true if successfully completed, false if not.
- Throws:
IOException
- If an I/O error occurs.
-
retrieveFileStream
Description copied from interface:FtpClient
Returns an InputStream from which a named file from the server can be read.- Specified by:
retrieveFileStream
in interfaceFtpClient
- Parameters:
relPath
- The name of the remote file.- Returns:
- An InputStream from which the remote file can be read.
- Throws:
IOException
- If an I/O error occurs.
-
retrieveFileStream
Description copied from interface:FtpClient
Returns an InputStream from which a named file from the server can be read.- Specified by:
retrieveFileStream
in interfaceFtpClient
- Parameters:
relPath
- The name of the remote file.bufferSize
- buffer size.- Returns:
- An InputStream from which the remote file can be read.
- Throws:
IOException
- If an I/O error occurs.
-
retrieveFileStream
Description copied from interface:FtpClient
Returns an InputStream from which a named file from the server can be read.- Specified by:
retrieveFileStream
in interfaceFtpClient
- Parameters:
relPath
- The name of the remote file.restartOffset
- restart offset.- Returns:
- An InputStream from which the remote file can be read.
- Throws:
IOException
- If an I/O error occurs.
-
setBufferSize
Description copied from interface:FtpClient
Sets the buffer size for buffered data streams.- Specified by:
setBufferSize
in interfaceFtpClient
- Parameters:
bufferSize
- The size of the buffer.- Throws:
FileSystemException
- If an I/O error occurs.
-
storeFileStream
Description copied from interface:FtpClient
Returns an OutputStream through which data can be written to store a file on the server using the given name.- Specified by:
storeFileStream
in interfaceFtpClient
- Parameters:
relPath
- The name to give the remote file.- Returns:
- An OutputStream through which the remote file can be written.
- Throws:
IOException
- If an I/O error occurs.
-