Class FTPTask
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.apache.tools.ant.taskdefs.optional.net.FTPTask
- All Implemented Interfaces:
java.lang.Cloneable
public class FTPTask extends Task
Basic FTP client. Performs the following actions:
- send - send files to a remote server. This is the default action.
- get - retrieve files from a remote server.
- del - delete files from a remote server.
- list - create a file listing.
- chmod - change unix file permissions.
- rmdir - remove directories, if empty, from a remote server.
- Since:
- Ant 1.3
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
FTPTask.Action
an action to perform, one of "send", "put", "recv", "get", "del", "delete", "list", "mkdir", "chmod", "rmdir"static class
FTPTask.FTPSystemType
one of the valid system type keys recognized by the systemTypeKey attribute.static class
FTPTask.Granularity
represents one of the valid timestamp adjustment values recognized by thetimestampGranularity
attribute. -
Field Summary
Fields Modifier and Type Field Description static java.lang.String[]
ACTION_STRS
static java.lang.String[]
ACTION_TARGET_STRS
static int
CHMOD
static java.lang.String[]
COMPLETED_ACTION_STRS
static int
DEFAULT_FTP_PORT
Default port for FTPstatic int
DEL_FILES
static int
GET_FILES
static int
LIST_FILES
static int
MK_DIR
static int
RM_DIR
static int
SEND_FILES
static int
SITE_CMD
-
Constructor Summary
Constructors Constructor Description FTPTask()
-
Method Summary
Modifier and Type Method Description void
addFileset(FileSet set)
A set of files to upload or downloadprotected void
checkAttributes()
Checks to see that all required parameters are set.Path
createClasspath()
void
execute()
Runs the task.java.lang.String
getAccount()
int
getAction()
java.lang.String
getChmod()
java.lang.String
getDefaultDateFormatConfig()
boolean
getEnableRemoteVerification()
java.util.Vector<FileSet>
getFilesets()
long
getGranularityMillis()
java.lang.String
getInitialSiteCommand()
java.io.File
getListing()
java.lang.String
getPassword()
int
getPort()
java.lang.String
getRecentDateFormatConfig()
java.lang.String
getRemotedir()
int
getRetriesAllowed()
java.lang.String
getSeparator()
java.lang.String
getServer()
java.lang.String
getServerLanguageCodeConfig()
java.lang.String
getServerTimeZoneConfig()
java.lang.String
getShortMonthNamesConfig()
java.lang.String
getSiteCommand()
java.lang.String
getSystemTypeKey()
long
getTimeDiffMillis()
FTPTask.Granularity
getTimestampGranularity()
java.lang.String
getUmask()
java.lang.String
getUserid()
boolean
isBinary()
boolean
isConfigurationSet()
boolean
isIgnoreNoncriticalErrors()
boolean
isNewer()
boolean
isPassive()
boolean
isPreserveLastModified()
boolean
isSkipFailedTransfers()
boolean
isTimeDiffAuto()
boolean
isVerbose()
void
log(java.lang.String msg, int level)
void
setAccount(java.lang.String pAccount)
Sets the login account to use on the specified server.void
setAction(java.lang.String action)
Deprecated.since 1.5.x.void
setAction(FTPTask.Action action)
Sets the FTP action to be taken.void
setBinary(boolean binary)
If true, uses binary mode, otherwise text mode (default is binary).void
setChmod(java.lang.String theMode)
Sets the file permission mode (Unix only) for files sent to the server.void
setDefaultDateFormatConfig(java.lang.String defaultDateFormat)
Sets the defaultDateFormatConfig attribute.void
setDepends(boolean depends)
Set to true to transmit only files that are new or changed from their remote counterparts.void
setEnableRemoteVerification(boolean b)
Whether to verify that data and control connections are connected to the same remote host.void
setGranularityMillis(long granularity)
void
setIgnoreNoncriticalErrors(boolean ignoreNoncriticalErrors)
set the flag to skip errors on directory creation.void
setInitialSiteCommand(java.lang.String initialCommand)
Sets the initialSiteCommand attribute.void
setListing(java.io.File listing)
The output file for the "list" action.void
setNewer(boolean newer)
A synonym fordepends
.void
setPassive(boolean passive)
Specifies whether to use passive mode.void
setPassword(java.lang.String password)
Sets the login password for the given user id.void
setPort(int port)
Sets the FTP port used by the remote server.void
setPreserveLastModified(boolean preserveLastModified)
Set to true to preserve modification times for "gotten" files.void
setRecentDateFormatConfig(java.lang.String recentDateFormat)
Sets the recentDateFormatConfig attribute.void
setRemotedir(java.lang.String dir)
Sets the remote directory where files will be placed.void
setRetriesAllowed(java.lang.String retriesAllowed)
Defines how many times to retry executing FTP command before giving up.void
setSeparator(java.lang.String separator)
Sets the remote file separator character.void
setServer(java.lang.String server)
Sets the FTP server to send files to.void
setServerLanguageCodeConfig(java.lang.String serverLanguageCode)
Sets the serverLanguageCode attribute.void
setServerTimeZoneConfig(java.lang.String serverTimeZoneId)
Sets the serverTimeZoneConfig attribute.void
setShortMonthNamesConfig(java.lang.String shortMonthNames)
Sets the shortMonthNamesConfig attributevoid
setSiteCommand(java.lang.String siteCommand)
Sets the siteCommand attribute.void
setSkipFailedTransfers(boolean skipFailedTransfers)
If true, enables unsuccessful file put, delete and get operations to be skipped with a warning and the remainder of the files still transferred.void
setSystemTypeKey(FTPTask.FTPSystemType systemKey)
Sets the systemTypeKey attribute.void
setTimeDiffAuto(boolean timeDiffAuto)
"true" to find out automatically the time difference between local and remote machine.void
setTimeDiffMillis(long timeDiffMillis)
number of milliseconds to add to the time on the remote machine to get the time on the local machine.void
setTimestampGranularity(FTPTask.Granularity timestampGranularity)
Sets the timestampGranularity attributevoid
setUmask(java.lang.String theUmask)
Sets the default mask for file creation on a unix server.protected void
setupFTPDelegate()
void
setUserid(java.lang.String userid)
Sets the login user id to use on the specified server.void
setVerbose(boolean verbose)
Set to true to receive notification about each file as it is transferred.Methods inherited from class org.apache.tools.ant.Task
bindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskType
Methods inherited from class org.apache.tools.ant.ProjectComponent
clone, getDescription, getLocation, getProject, setDescription, setLocation, setProject
-
Field Details
-
SEND_FILES
public static final int SEND_FILES- See Also:
- Constant Field Values
-
GET_FILES
public static final int GET_FILES- See Also:
- Constant Field Values
-
DEL_FILES
public static final int DEL_FILES- See Also:
- Constant Field Values
-
LIST_FILES
public static final int LIST_FILES- See Also:
- Constant Field Values
-
MK_DIR
public static final int MK_DIR- See Also:
- Constant Field Values
-
CHMOD
public static final int CHMOD- See Also:
- Constant Field Values
-
RM_DIR
public static final int RM_DIR- See Also:
- Constant Field Values
-
SITE_CMD
public static final int SITE_CMD- See Also:
- Constant Field Values
-
DEFAULT_FTP_PORT
public static final int DEFAULT_FTP_PORTDefault port for FTP- See Also:
- Constant Field Values
-
ACTION_STRS
public static final java.lang.String[] ACTION_STRS -
COMPLETED_ACTION_STRS
public static final java.lang.String[] COMPLETED_ACTION_STRS -
ACTION_TARGET_STRS
public static final java.lang.String[] ACTION_TARGET_STRS
-
-
Constructor Details
-
FTPTask
public FTPTask()
-
-
Method Details
-
setRemotedir
public void setRemotedir(java.lang.String dir)Sets the remote directory where files will be placed. This may be a relative or absolute path, and must be in the path syntax expected by the remote server. No correction of path syntax will be performed.- Parameters:
dir
- the remote directory name.
-
getRemotedir
public java.lang.String getRemotedir() -
setServer
public void setServer(java.lang.String server)Sets the FTP server to send files to.- Parameters:
server
- the remote server name.
-
getServer
public java.lang.String getServer() -
setPort
public void setPort(int port)Sets the FTP port used by the remote server.- Parameters:
port
- the port on which the remote server is listening.
-
getPort
public int getPort() -
setUserid
public void setUserid(java.lang.String userid)Sets the login user id to use on the specified server.- Parameters:
userid
- remote system userid.
-
getUserid
public java.lang.String getUserid() -
setPassword
public void setPassword(java.lang.String password)Sets the login password for the given user id.- Parameters:
password
- the password on the remote system.
-
getPassword
public java.lang.String getPassword() -
setAccount
public void setAccount(java.lang.String pAccount)Sets the login account to use on the specified server.- Parameters:
pAccount
- the account name on remote system- Since:
- Ant 1.7
-
getAccount
public java.lang.String getAccount() -
setBinary
public void setBinary(boolean binary)If true, uses binary mode, otherwise text mode (default is binary).- Parameters:
binary
- if true use binary mode in transfers.
-
isBinary
public boolean isBinary() -
setPassive
public void setPassive(boolean passive)Specifies whether to use passive mode. Set to true if you are behind a firewall and cannot connect without it. Passive mode is disabled by default.- Parameters:
passive
- true is passive mode should be used.
-
isPassive
public boolean isPassive() -
setVerbose
public void setVerbose(boolean verbose)Set to true to receive notification about each file as it is transferred.- Parameters:
verbose
- true if verbose notifications are required.
-
isVerbose
public boolean isVerbose() -
setNewer
public void setNewer(boolean newer)A synonym fordepends
. Set to true to transmit only new or changed files. See the related attributes timediffmillis and timediffauto.- Parameters:
newer
- if true only transfer newer files.
-
isNewer
public boolean isNewer() -
setTimeDiffMillis
public void setTimeDiffMillis(long timeDiffMillis)number of milliseconds to add to the time on the remote machine to get the time on the local machine. use in conjunction withnewer
- Parameters:
timeDiffMillis
- number of milliseconds- Since:
- ant 1.6
-
getTimeDiffMillis
public long getTimeDiffMillis() -
setTimeDiffAuto
public void setTimeDiffAuto(boolean timeDiffAuto)"true" to find out automatically the time difference between local and remote machine. This requires right to create and delete a temporary file in the remote directory.- Parameters:
timeDiffAuto
- true = find automatically the time diff- Since:
- ant 1.6
-
isTimeDiffAuto
public boolean isTimeDiffAuto() -
setPreserveLastModified
public void setPreserveLastModified(boolean preserveLastModified)Set to true to preserve modification times for "gotten" files.- Parameters:
preserveLastModified
- if true preserver modification times.
-
isPreserveLastModified
public boolean isPreserveLastModified() -
setDepends
public void setDepends(boolean depends)Set to true to transmit only files that are new or changed from their remote counterparts. The default is to transmit all files.- Parameters:
depends
- if true only transfer newer files.
-
setSeparator
public void setSeparator(java.lang.String separator)Sets the remote file separator character. This normally defaults to the Unix standard forward slash, but can be manually overridden using this call if the remote server requires some other separator. Only the first character of the string is used.- Parameters:
separator
- the file separator on the remote system.
-
getSeparator
public java.lang.String getSeparator() -
setChmod
public void setChmod(java.lang.String theMode)Sets the file permission mode (Unix only) for files sent to the server.- Parameters:
theMode
- unix style file mode for the files sent to the remote system.
-
getChmod
public java.lang.String getChmod() -
setUmask
public void setUmask(java.lang.String theUmask)Sets the default mask for file creation on a unix server.- Parameters:
theUmask
- unix style umask for files created on the remote server.
-
getUmask
public java.lang.String getUmask() -
addFileset
A set of files to upload or download- Parameters:
set
- the set of files to be added to the list of files to be transferred.
-
getFilesets
-
setAction
Deprecated.since 1.5.x. setAction(String) is deprecated and is replaced with setAction(FTP.Action) to make Ant's Introspection mechanism do the work and also to encapsulate operations on the type in its own class.Sets the FTP action to be taken. Currently accepts "put", "get", "del", "mkdir", "chmod", "list", and "site".- Parameters:
action
- the FTP action to be performed.- Throws:
BuildException
- if the action is not a valid action.
-
setAction
Sets the FTP action to be taken. Currently accepts "put", "get", "del", "mkdir", "chmod", "list", and "site".- Parameters:
action
- the FTP action to be performed.- Throws:
BuildException
- if the action is not a valid action.
-
getAction
public int getAction() -
setListing
public void setListing(java.io.File listing)The output file for the "list" action. This attribute is ignored for any other actions.- Parameters:
listing
- file in which to store the listing.
-
getListing
public java.io.File getListing() -
setSkipFailedTransfers
public void setSkipFailedTransfers(boolean skipFailedTransfers)If true, enables unsuccessful file put, delete and get operations to be skipped with a warning and the remainder of the files still transferred.- Parameters:
skipFailedTransfers
- true if failures in transfers are ignored.
-
isSkipFailedTransfers
public boolean isSkipFailedTransfers() -
setIgnoreNoncriticalErrors
public void setIgnoreNoncriticalErrors(boolean ignoreNoncriticalErrors)set the flag to skip errors on directory creation. (and maybe later other server specific errors)- Parameters:
ignoreNoncriticalErrors
- true if non-critical errors should not cause a failure.
-
isIgnoreNoncriticalErrors
public boolean isIgnoreNoncriticalErrors() -
isConfigurationSet
public boolean isConfigurationSet() -
setSystemTypeKey
Sets the systemTypeKey attribute. Method for settingFTPClientConfig
remote system key.- Parameters:
systemKey
- the key to be set - BUT if blank the default value of null (which signifies "autodetect") will be kept.- See Also:
FTPClientConfig
-
setDefaultDateFormatConfig
public void setDefaultDateFormatConfig(java.lang.String defaultDateFormat)Sets the defaultDateFormatConfig attribute.- Parameters:
defaultDateFormat
- configuration to be set, unless it is null or empty string, in which case ignored.- See Also:
FTPClientConfig
-
setRecentDateFormatConfig
public void setRecentDateFormatConfig(java.lang.String recentDateFormat)Sets the recentDateFormatConfig attribute.- Parameters:
recentDateFormat
- configuration to be set, unless it is null or empty string, in which case ignored.- See Also:
FTPClientConfig
-
setServerLanguageCodeConfig
public void setServerLanguageCodeConfig(java.lang.String serverLanguageCode)Sets the serverLanguageCode attribute.- Parameters:
serverLanguageCode
- configuration to be set, unless it is null or empty string, in which case ignored.- See Also:
FTPClientConfig
-
setServerTimeZoneConfig
public void setServerTimeZoneConfig(java.lang.String serverTimeZoneId)Sets the serverTimeZoneConfig attribute.- Parameters:
serverTimeZoneId
- configuration to be set, unless it is null or empty string, in which case ignored.- See Also:
FTPClientConfig
-
setShortMonthNamesConfig
public void setShortMonthNamesConfig(java.lang.String shortMonthNames)Sets the shortMonthNamesConfig attribute- Parameters:
shortMonthNames
- configuration to be set, unless it is null or empty string, in which case ignored.- See Also:
FTPClientConfig
-
setRetriesAllowed
public void setRetriesAllowed(java.lang.String retriesAllowed)Defines how many times to retry executing FTP command before giving up. Default is 0 - try once and if failure then give up.- Parameters:
retriesAllowed
- number of retries to allow. -1 means keep trying forever. "forever" may also be specified as a synonym for -1.
-
getRetriesAllowed
public int getRetriesAllowed() -
getSystemTypeKey
public java.lang.String getSystemTypeKey()- Returns:
- Returns the systemTypeKey.
-
getDefaultDateFormatConfig
public java.lang.String getDefaultDateFormatConfig()- Returns:
- Returns the defaultDateFormatConfig.
-
getRecentDateFormatConfig
public java.lang.String getRecentDateFormatConfig()- Returns:
- Returns the recentDateFormatConfig.
-
getServerLanguageCodeConfig
public java.lang.String getServerLanguageCodeConfig()- Returns:
- Returns the serverLanguageCodeConfig.
-
getServerTimeZoneConfig
public java.lang.String getServerTimeZoneConfig()- Returns:
- Returns the serverTimeZoneConfig.
-
getShortMonthNamesConfig
public java.lang.String getShortMonthNamesConfig()- Returns:
- Returns the shortMonthNamesConfig.
-
getTimestampGranularity
- Returns:
- Returns the timestampGranularity.
-
setTimestampGranularity
Sets the timestampGranularity attribute- Parameters:
timestampGranularity
- The timestampGranularity to set.
-
setSiteCommand
public void setSiteCommand(java.lang.String siteCommand)Sets the siteCommand attribute. This attribute names the command that will be executed if the action is "site".- Parameters:
siteCommand
- The siteCommand to set.
-
getSiteCommand
public java.lang.String getSiteCommand() -
setInitialSiteCommand
public void setInitialSiteCommand(java.lang.String initialCommand)Sets the initialSiteCommand attribute. This attribute names a site command that will be executed immediately after connection.- Parameters:
initialCommand
- The initialSiteCommand to set.
-
getInitialSiteCommand
public java.lang.String getInitialSiteCommand() -
getGranularityMillis
public long getGranularityMillis() -
setGranularityMillis
public void setGranularityMillis(long granularity) -
setEnableRemoteVerification
public void setEnableRemoteVerification(boolean b)Whether to verify that data and control connections are connected to the same remote host.- Parameters:
b
- boolean- Since:
- Ant 1.8.0
-
getEnableRemoteVerification
public boolean getEnableRemoteVerification() -
checkAttributes
Checks to see that all required parameters are set.- Throws:
BuildException
- if the configuration is not valid.
-
execute
Runs the task.- Overrides:
execute
in classTask
- Throws:
BuildException
- if the task fails or is not configured correctly.
-
createClasspath
-
setupFTPDelegate
protected void setupFTPDelegate() -
log
public abstract void log(java.lang.String msg, int level)
-