Documentation ¶
Overview ¶
Package ftp implements an FTP client.
Package ftp implements an FTP client.
Index ¶
- Constants
- Variables
- func Dial(network, addr string) (net.Conn, error)
- func TrimBytes(b []byte) []byte
- func TrimString(s string) string
- type Callback
- type CallbackInfo
- type Error
- type FTP
- func (ftp *FTP) Abort() (response *Response, err error)
- func (ftp *FTP) Acct() (response *Response, err error)
- func (ftp *FTP) Connect(host string, port int, socks5ProxyUrl string) (resp *Response, err error)
- func (ftp *FTP) Cwd(dirname string) (response *Response, err error)
- func (ftp *FTP) Delete(filename string) (response *Response, err error)
- func (ftp *FTP) Dir(params ...string) (filelist []string, err error)
- func (ftp *FTP) DownloadFile(remotename string, localpath string, useLineMode bool) (err error)
- func (ftp *FTP) DownloadResumeFile(remotename string, localpath string, useLineMode bool) (err error)
- func (ftp *FTP) Feat(params ...string) (fts []string, err error)
- func (ftp *FTP) GetBytes(cmd FtpCmd, writer io.Writer, blocksize int, params ...string) (err error)
- func (ftp *FTP) GetLines(cmd FtpCmd, writer io.Writer, params ...string) (err error)
- func (ftp *FTP) Login(username, password string, acct string) (response *Response, err error)
- func (ftp *FTP) Mkd(dirname string) (dname string, err error)
- func (ftp *FTP) Mlsd(path string, facts []string) (ls []*NameFactsLine, err error)
- func (ftp *FTP) NewConn(addr string) error
- func (ftp *FTP) Nlst(params ...string) (filelist []string, err error)
- func (ftp *FTP) Opts(params ...string) (response *Response, err error)
- func (ftp *FTP) Pwd() (dirname string, err error)
- func (ftp *FTP) Quit() (response *Response, err error)
- func (ftp *FTP) Read(cmd FtpCmd) (resp *Response, err error)
- func (ftp *FTP) RemoveRemoteDirTree(remoteDir string) (err error)
- func (ftp *FTP) Rename(fromname string, toname string) (response *Response, err error)
- func (ftp *FTP) ResumeFile(cmd FtpCmd, writer *os.File, offset int64, blocksize int, params ...string) (err error)
- func (ftp *FTP) Rmd(dirname string) (response *Response, err error)
- func (ftp *FTP) Send(cmd FtpCmd, params ...string) (err error)
- func (ftp *FTP) SendAndRead(cmd FtpCmd, params ...string) (response *Response, err error)
- func (ftp *FTP) SendPort(host string, port int) (response *Response, err error)
- func (ftp *FTP) SetFTPTimeout(timeout time.Duration) error
- func (ftp *FTP) SetPassive(ispassive bool)
- func (ftp *FTP) Size(filename string) (size int, err error)
- func (ftp *FTP) Stop()
- func (ftp *FTP) StoreBytes(cmd FtpCmd, reader io.Reader, blocksize int, remotename string, ...) (err error)
- func (ftp *FTP) StoreLines(cmd FtpCmd, reader io.Reader, remotename string, filename string, ...) (err error)
- func (ftp *FTP) UploadDirTree(localDir string, remoteRootDir string, maxSimultaneousConns int, ...) (n int, err error)
- func (ftp *FTP) UploadFile(remotename string, localpath string, useLineMode bool, callback Callback) (err error)
- type FtpCmd
- type NameFactsLine
- type ProtocolError
- type Response
Constants ¶
const ( DefaultFtpPort = 21 DefaultTimeoutInMsec = 20 * time.Second CRLF = "\r\n" BLOCK_SIZE = 8192 )
The default constants
const ( StatusInitiating = 100 StatusRestartMarker = 110 StatusReadyMinute = 120 StatusAlreadyOpen = 125 StatusAboutToSend = 150 StatusCommandOK = 200 StatusCommandNotImplemented = 202 StatusSystem = 211 StatusDirectory = 212 StatusFile = 213 StatusHelp = 214 StatusName = 215 StatusReady = 220 StatusClosing = 221 StatusDataConnectionOpen = 225 StatusClosingDataConnection = 226 StatusPassiveMode = 227 StatusLongPassiveMode = 228 StatusExtendedPassiveMode = 229 StatusLoggedIn = 230 StatusLoggedOut = 231 StatusLogoutAck = 232 StatusRequestedFileActionOK = 250 StatusPathCreated = 257 StatusUserOK = 331 StatusLoginNeedAccount = 332 StatusRequestFilePending = 350 StatusNotAvailable = 421 StatusCanNotOpenDataConnection = 425 StatusTransfertAborted = 426 StatusInvalidCredentials = 430 StatusFileActionIgnored = 450 StatusActionAborted = 451 Status452 = 452 StatusBadCommand = 500 StatusBadArguments = 501 StatusNotImplemented = 502 StatusBadSequence = 503 StatusNotImplementedParameter = 504 StatusNotLoggedIn = 530 StatusStorNeedAccount = 532 StatusPageTypeUnknown = 551 StatusExceededStorage = 552 StatusBadFileName = 553 )
FTP status codes, defined in RFC 959
const (
BYTE_BLK = 1024
)
const MSG_OOB = 0x1 //Process data out of band
Variables ¶
var ( NewErrReply = func(error error) error { return errors.New("Reply error: " + error.Error()) } NewErrTemp = func(error error) error { return errors.New("Temporary error: " + error.Error()) } NewErrPerm = func(error error) error { return errors.New("Permanent error: " + error.Error()) } NewErrProto = func(error error) error { return errors.New("Protocol error: " + error.Error()) } NewErrStop = fmt.Errorf("Stop by human behavior: call FTP.Stop()") )
var DIRECTORY_NON_EXISTENT = errors.New("The folder does not exist and can not be removed")
Functions ¶
func Dial ¶
Dial connects to the given address on the given network using net.Dial and then returns a new Conn for the connection.
func TrimString ¶
TrimString returns s without leading and trailing ASCII space.
Types ¶
type Callback ¶
type Callback func(info *CallbackInfo)
type CallbackInfo ¶
type FTP ¶
The FTP client structure containing: - host, user, password, acct, timeout
func NewFTP ¶
NewFTP creates a new FTP client using a debug level, default is 0, which is disabled. The FTP server uses the passive tranfer mode by default.
Debuglevel: 0 -> disabled 1 -> information 2 -> verbose
func (*FTP) Abort ¶
Abort interrupts a file transfer, which uses out-of-band data. This does not follow the procedure from the RFC to send Telnet IP and Synch; that does not seem to work with all servers. Instead just send the ABOR command as OOB data.
func (*FTP) Connect ¶
Connect connects to the host by using the specified port or the default one if the value is <=0.
func (*FTP) DownloadFile ¶
DownloadFile downloads a file and stores it locally. There are two modes: - binary, useLineMode = false - line by line (text), useLineMode = true
func (*FTP) DownloadResumeFile ¶
func (*FTP) Feat ¶
Feat lists all new FTP features that the server supports beyond those described in RFC 959.
func (*FTP) GetBytes ¶
GetBytes retrieves data in binary mode. Args:
cmd: A RETR command. callback: A single parameter callable to be called on each block of data read. blocksize: The maximum number of bytes to read from the socket at one time. [default: 8192]
Returns:
The response code.
func (*FTP) GetLines ¶
GetLines retrieves data in line mode. Args:
cmd: A RETR, LIST, NLST, or MLSD command. writer: of interface type io.Writer that is called for each line with the trailing CRLF stripped.
returns:
The response code.
func (*FTP) Mlsd ¶
func (ftp *FTP) Mlsd(path string, facts []string) (ls []*NameFactsLine, err error)
Mlsd lists a directory in a standardized format by using MLSD command (RFC-3659). If path is omitted the current directory is assumed. "facts" is a list of strings representing the type of information desired (e.g. ["type", "size", "perm"]). Return a generator object yielding a tuple of two elements for every file found in path. First element is the file name, the second one is a dictionary including a variable number of "facts" depending on the server and whether "facts" argument has been provided.
func (*FTP) RemoveRemoteDirTree ¶
RemoveRemoteDirTree removes a remote folder and all of its subfolders recursively. The current directory is then set to the orginal one before the operation or to the root of the deleted folder if it fails.
func (*FTP) ResumeFile ¶
func (*FTP) SendAndRead ¶
SendAndRead sends a command to the server and reads the response.
func (*FTP) SetFTPTimeout ¶
Set ftp dial timeout
func (*FTP) SetPassive ¶
SetPassive sets the mode to passive or active for data transfers. With a false statement use the normal PORT mode. With a true statement use the PASV command.
func (*FTP) StoreBytes ¶
func (ftp *FTP) StoreBytes(cmd FtpCmd, reader io.Reader, blocksize int, remotename string, filename string, callback Callback) (err error)
StoreBytes uploads bytes in chunks defined by the blocksize parameter. It uses an io.Reader to read the input data.
func (*FTP) StoreLines ¶
func (ftp *FTP) StoreLines(cmd FtpCmd, reader io.Reader, remotename string, filename string, callback Callback) (err error)
StoreLines stores a file in line mode.
Args: cmd: A STOR command. reader: A reader object with a ReadLine() method. callback: An optional single parameter callable that is called on on each line after it is sent. [default: None] Returns: The response code.
func (*FTP) UploadDirTree ¶
func (ftp *FTP) UploadDirTree(localDir string, remoteRootDir string, maxSimultaneousConns int, excludedDirs []string, callback Callback) (n int, err error)
UploadDirTree uploads a local directory and all of its subfolders localDir -> path to the local folder to upload along with all of its subfolders. remoteRootDir -> the root folder on the FTP server where to store the localDir tree. excludedDirs -> a slice of folder names to exclude from the uploaded directory tree. callback -> a callback function, which is called synchronously. Do remember to collect data in a go routine for instance if you do not want the upload to block. Returns the number of files uploaded and an error if any.
The current workding directory is set back to the initial value at the end.
func (*FTP) UploadFile ¶
func (ftp *FTP) UploadFile(remotename string, localpath string, useLineMode bool, callback Callback) (err error)
UploadFile uploads a file from a local path to the current folder (see Cwd too) on the FTP server. A remotename needs to be specified. There are two modes set via the useLineMode flag: - binary, useLineMode = false - line by line (text), useLineMode = true
type FtpCmd ¶
type FtpCmd int
FTP command strings
const ( NONE_FTP_CMD FtpCmd = 0 USER_FTP_CMD FtpCmd = 1 PASSWORD_FTP_CMD FtpCmd = 2 ACCT_FTP_CMD FtpCmd = 3 ABORT_FTP_CMD FtpCmd = 4 PORT_FTP_CMD FtpCmd = 5 PASV_FTP_CMD FtpCmd = 6 TYPE_A_FTP_CMD FtpCmd = 7 NLST_FTP_CMD FtpCmd = 8 LIST_FTP_CMD FtpCmd = 9 FEAT_FTP_CMD FtpCmd = 10 OPTS_FTP_CMD FtpCmd = 11 RETR_FTP_CMD FtpCmd = 12 TYPE_I_FTP_CMD FtpCmd = 13 STORE_FTP_CMD FtpCmd = 14 RENAMEFROM_FTP_CMD FtpCmd = 15 RENAMETO_FTP_CMD FtpCmd = 16 DELETE_FTP_CMD FtpCmd = 17 CWD_FTP_CMD FtpCmd = 18 SIZE_FTP_CMD FtpCmd = 19 MKDIR_FTP_CMD FtpCmd = 20 RMDIR_FTP_CMD FtpCmd = 21 PWDIR_FTP_CMD FtpCmd = 22 CDUP_FTP_CMD FtpCmd = 23 QUIT_FTP_CMD FtpCmd = 24 MLSD_FTP_CMD FtpCmd = 25 REST_FTP_CMD FtpCmd = 26 )
func (FtpCmd) AppendParameters ¶
type NameFactsLine ¶
type ProtocolError ¶
type ProtocolError string
A ProtocolError describes a protocol violation such as an invalid response or a hung-up connection.
func (ProtocolError) Error ¶
func (p ProtocolError) Error() string