SFtp Ruby Reference Documentation
CkSFtp
Current Version: 11.1.0
SFTP implementation for file transfer and remote file management over SSH.
Object Creation
obj = Chilkat::CkSFtp.new()
Properties
AbortCurrent
boolVal = sFtp.get_AbortCurrent();
sFtp.put_AbortCurrent(boolVal);
When set to true, causes the currently running method to abort.  Methods that always finish quickly (i.e.have no length file operations or network communications) are not affected.  If no method is running, then this property is automatically reset to false when the next method is called.  When the abort occurs, this property is reset to false.  Both synchronous and asynchronous method calls can be aborted.  (A synchronous method call could be aborted by setting this property from a separate thread.)
AuthFailReason
intVal = sFtp.get_AuthFailReason();
Set to one of the following values if a call to AuthenticatePw, AuthenticatePk, or AuthenticatePwPk returns a failed status.
- 1: Transport failure. This is a failure to communicate with the server (i.e. the connection was lost, or a read or write failed or timed out).
- 2: Invalid key for public key authentication. The key was not a valid format, not a valid key, not a private key, or not the right type of key.
- 3: No matching authentication methods were available.
- 4: SSH authentication protocol error - an unexpected or invalid message was received.
- 5: The incorrect password or private key was provided.
- 6: Already authenticated. The SSH session is already authenticated.
- 7: Password change request: The server requires the password to be changed.
BandwidthThrottleDown
intVal = sFtp.get_BandwidthThrottleDown();
sFtp.put_BandwidthThrottleDown(intVal);
If non-zero, limits (throttles) the download bandwidth to approximately this maximum number of bytes per second. The default value of this property is 0.
topBandwidthThrottleUp
intVal = sFtp.get_BandwidthThrottleUp();
sFtp.put_BandwidthThrottleUp(intVal);
If non-zero, limits (throttles) the upload bandwidth to approximately this maximum number of bytes per second. The default value of this property is 0.
ClientIdentifier
# ckStr is a CkString
sFtp.get_ClientIdentifier(ckStr);
strVal = sFtp.clientIdentifier();
sFtp.put_ClientIdentifier(strVal);
The client-identifier string to be used when connecting to an SSH/SFTP server.  Starting in Chilkat v9.5.0.99, the default is SSH-2.0-Chilkat_ + the Chilkat version number, such as SSH-2.0-Chilkat_9.5.0.99.
Note: The client identifier should always begin with SSH-2.0-.  SSH servers may disconnect if it does not.
ClientIpAddress
# ckStr is a CkString
sFtp.get_ClientIpAddress(ckStr);
strVal = sFtp.clientIpAddress();
sFtp.put_ClientIpAddress(strVal);
The IP address to use for computers with multiple network interfaces or IP addresses. For computers with a single network interface (i.e. most computers), this property should not be set. For multihoming computers, the default IP address is automatically used if this property is not set.
The IP address is a string such as in dotted notation using numbers, not domain names, such as 165.164.55.124.
ConnectTimeoutMs
intVal = sFtp.get_ConnectTimeoutMs();
sFtp.put_ConnectTimeoutMs(intVal);
Maximum number of milliseconds to wait when connecting to an SSH server.
To clarify: This property determines how long to wait for the SSH server to accept the TCP connection. Once the connection is made, it is the IdleTimeoutMs property that applies to receiving data and responses.
topDebugLogFilePath
# ckStr is a CkString
sFtp.get_DebugLogFilePath(ckStr);
strVal = sFtp.debugLogFilePath();
sFtp.put_DebugLogFilePath(strVal);
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
DisconnectCode
intVal = sFtp.get_DisconnectCode();
If the SSH/SFTP server sent a DISCONNECT message when closing the connection, this property contains the reason code as specified in RFC 4253:
           Symbolic name                                reason code
           -------------                                -----------
      SSH_DISCONNECT_HOST_NOT_ALLOWED_TO_CONNECT             1
      SSH_DISCONNECT_PROTOCOL_ERROR                          2
      SSH_DISCONNECT_KEY_EXCHANGE_FAILED                     3
      SSH_DISCONNECT_RESERVED                                4
      SSH_DISCONNECT_MAC_ERROR                               5
      SSH_DISCONNECT_COMPRESSION_ERROR                       6
      SSH_DISCONNECT_SERVICE_NOT_AVAILABLE                   7
      SSH_DISCONNECT_PROTOCOL_VERSION_NOT_SUPPORTED          8
      SSH_DISCONNECT_HOST_KEY_NOT_VERIFIABLE                 9
      SSH_DISCONNECT_CONNECTION_LOST                        10
      SSH_DISCONNECT_BY_APPLICATION                         11
      SSH_DISCONNECT_TOO_MANY_CONNECTIONS                   12
      SSH_DISCONNECT_AUTH_CANCELLED_BY_USER                 13
      SSH_DISCONNECT_NO_MORE_AUTH_METHODS_AVAILABLE         14
      SSH_DISCONNECT_ILLEGAL_USER_NAME                      15
top
DisconnectReason
# ckStr is a CkString
sFtp.get_DisconnectReason(ckStr);
strVal = sFtp.disconnectReason();
If the SSH/SFTP server sent a DISCONNECT message when closing the connection, this property contains a descriptive string for the reason code as specified in RFC 4253.
EnableCache
boolVal = sFtp.get_EnableCache();
sFtp.put_EnableCache(boolVal);
Controls whether the component keeps an internal file size & attribute cache. The cache affects the following methods: GetFileSize32, GetFileSize64, GetFileSizeStr, GetFileCreateTimeStr, GetFileLastAccessStr, GetFileLastModifiedStr, GetFileOwner, GetFileGroup, and GetFilePermissions.
The file attribute cache exists to minimize communications with the SFTP server. If the cache is enabled, then a request for any single attribute will cause all of the attributes to be cached. A subsequent request for a different attribute of the same file will be fulfilled from cache, eliminating the need for a message to be sent to the SFTP server.
Note: Caching only occurs when filenames are used, not handles.
The default value is _false_
EnableCompression
boolVal = sFtp.get_EnableCompression();
sFtp.put_EnableCompression(boolVal);
Enables or disables the use of compression w/ the SSH connection.  The default value is  false.
Some older SSH servers have been found that claim to support compression, but actually fail when compression is used. PuTTY does not enable compression by default. If trouble is encountered where the SSH server disconnects immediately after the connection is seemingly established (i.e. during authentication), then check to see if disabling compression resolves the problem.
topFilenameCharset
# ckStr is a CkString
sFtp.get_FilenameCharset(ckStr);
strVal = sFtp.filenameCharset();
sFtp.put_FilenameCharset(strVal);
Automatically set during the InitializeSftp method if the server sends a filename-charset name-value extension.  Otherwise, may be set directly to the name of a charset, such as utf-8, iso-8859-1, windows-1252, etc.  (ansi is also a valid choice.)  Incoming filenames are interpreted as utf-8 if no FilenameCharset is set.  Outgoing filenames are sent using utf-8 by default.  Otherwise, incoming and outgoing filenames use the charset specified by this property.
ForceCipher
# ckStr is a CkString
sFtp.get_ForceCipher(ckStr);
strVal = sFtp.forceCipher();
sFtp.put_ForceCipher(strVal);
Set to one of the following encryption algorithms to force that cipher to be used.  By default, the component will automatically choose the first cipher supported by the server in the order listed here:  aes128-ctr, aes256-ctr, aes192-ctr, aes128-cbc, aes256-cbc, aes192-cbc, aes128-gcm@openssh.com, aes256-gcm@openssh.com, twofish256-cbc, twofish128-cbc, blowfish-cbc.   (If blowfish is chosen, the encryption strength is 128 bits.)     
Important: If this is property is set and the server does NOT support then encryption algorithm, then the Connect will fail.
Refer to the SetAllowedAlgorithms method for greater control over the permitted algorithms.
ForceV3
boolVal = sFtp.get_ForceV3();
sFtp.put_ForceV3(boolVal);
If set to true, forces the client to choose version 3 of the SFTP protocol, even if the server supports a higher version.  The default value of this property is true.
HostKeyAlg
# ckStr is a CkString
sFtp.get_HostKeyAlg(ckStr);
strVal = sFtp.hostKeyAlg();
sFtp.put_HostKeyAlg(strVal);
Indicates the preferred host key algorithm to be used in establishing the SSH secure connection.  The default is DSS.  It may be changed to RSA if needed.  Chilkat recommends not changing this unless a problem warrants the change.
HostKeyFingerprint
# ckStr is a CkString
sFtp.get_HostKeyFingerprint(ckStr);
strVal = sFtp.hostKeyFingerprint();
Returns the MD5 host key fingerprint of the server, which is automatically set after connecting to an SSH/SFTP server. Depending on the host key type, the format of the MD5 fingerprint looks like this:
ssh-rsa 2048 68:ff:d1:4e:6c:ff:d7:b0:d6:58:73:85:07:bc:2e:d5 ssh-dss 2048 68:ff:d1:4e:6c:ff:d7:b0:d6:58:73:85:07:bc:2e:d5 ssh-ed25519 68:ff:d1:4e:6c:ff:d7:b0:d6:58:73:85:07:bc:2e:d5 ecdsa-sha2-nistp256 256 a3:09:05:b5:81:79:5d:33:e1:1a:82:c7:cb:ba:93:ea
Note: To get the SHA256 host key fingerprint, use the GetHostKeyFP method (added in v9.5.0.92)
HttpProxyAuthMethod
# ckStr is a CkString
sFtp.get_HttpProxyAuthMethod(ckStr);
strVal = sFtp.httpProxyAuthMethod();
sFtp.put_HttpProxyAuthMethod(strVal);
If an HTTP proxy requiring authentication is to be used, set this property to the HTTP proxy authentication method name.  Valid choices are Basic or NTLM.
HttpProxyDomain
# ckStr is a CkString
sFtp.get_HttpProxyDomain(ckStr);
strVal = sFtp.httpProxyDomain();
sFtp.put_HttpProxyDomain(strVal);
The NTLM authentication domain (optional) if NTLM authentication is used w/ the HTTP proxy.
topHttpProxyHostname
# ckStr is a CkString
sFtp.get_HttpProxyHostname(ckStr);
strVal = sFtp.httpProxyHostname();
sFtp.put_HttpProxyHostname(strVal);
If an HTTP proxy is to be used, set this property to the HTTP proxy hostname or IPv4 address (in dotted decimal notation).
topHttpProxyPassword
# ckStr is a CkString
sFtp.get_HttpProxyPassword(ckStr);
strVal = sFtp.httpProxyPassword();
sFtp.put_HttpProxyPassword(strVal);
If an HTTP proxy requiring authentication is to be used, set this property to the HTTP proxy password.
topHttpProxyPort
intVal = sFtp.get_HttpProxyPort();
sFtp.put_HttpProxyPort(intVal);
If an HTTP proxy is to be used, set this property to the HTTP proxy port number. (Two commonly used HTTP proxy ports are 8080 and 3128.)
topHttpProxyUsername
# ckStr is a CkString
sFtp.get_HttpProxyUsername(ckStr);
strVal = sFtp.httpProxyUsername();
sFtp.put_HttpProxyUsername(strVal);
If an HTTP proxy requiring authentication is to be used, set this property to the HTTP proxy login name.
topIdleTimeoutMs
intVal = sFtp.get_IdleTimeoutMs();
sFtp.put_IdleTimeoutMs(intVal);
Causes SFTP operations to fail when progress for sending or receiving data halts for more than this number of milliseconds. Setting IdleTimeoutMs = 0 allows the application to wait indefinitely. The default value of this property is 30000 (which equals 30 seconds).
topIncludeDotDirs
boolVal = sFtp.get_IncludeDotDirs();
sFtp.put_IncludeDotDirs(boolVal);
If true, then the ReadDir method will include the . and .. directories in its results.  The default value of this property is false.
InitializeFailCode
intVal = sFtp.get_InitializeFailCode();
The InitializeSftp method call opens a channel for the SFTP session. If the request to open a channel fails, this property contains a code that identifies the reason for failure. The reason codes are defined in RFC 4254 and are reproduced here:
             Symbolic name                           reason code
             -------------                           -----------
            SSH_OPEN_ADMINISTRATIVELY_PROHIBITED          1
            SSH_OPEN_CONNECT_FAILED                       2
            SSH_OPEN_UNKNOWN_CHANNEL_TYPE                 3
            SSH_OPEN_RESOURCE_SHORTAGE                    4
top
InitializeFailReason
# ckStr is a CkString
sFtp.get_InitializeFailReason(ckStr);
strVal = sFtp.initializeFailReason();
The InitializeSftp method call opens a channel for the SFTP session. If the request to open a channel fails, this property contains a description of the reason for failure. (It contains descriptive text matching the InitializeFailCode property.)
topIsConnected
boolVal = sFtp.get_IsConnected();
Returns true if connected to the SSH server.  Note: This does not mean authentication has happened or InitializeSftp has already succeeded.  It only means that the connection has been established by calling Connect.
Understanding the IsConnected property: The IsConnected property is the last known state of the TCP connection (either connected or disconnected). This requires some explanation because most developer have incorrect assumptions about TCP connections.
- If a TCP connection is established, and neither side is reading or writing the socket (i.e. both sides are doing nothing), then you can disconnect the network cable from the computer for any length of time, and then re-connect, and the TCP connection is not affected.
- A TCP connection only becomes disconnected when an attempt is made to read/write while a network problem exists. If no attempts to read/write occur, a network problem may arise and then become resolved without affecting the TCP connection.
- If the peer chooses to close its side of the TCP connection, your application won't magically know about it until you try to do something with the TCP socket (such as read or write).
- A Chilkat API property (as opposed to a method) CANNOT and should not do something that would cause an application to timeout, hang, etc.  Therefore, it is not appropriate for  the IsConnected property to attempt any kind of socket operation (read/write/peek) on the socket.  It simply returns the last known state of the connection.  It may very well be that your network cable is unplugged and IsConnected returns truebecause technically, if neither peer is trying to read/write, the network cable could be plugged back in without affecting the connection. IsConnected could also returntrueif the peer has already closed its side of the connection, because the state of the connection is only updated after trying to read/write/peek.
- To truly know the current connected state (as opposed to the last known connection state), your application should attempt a network operation that is appropriate to the protocol. For SFTP, an application could call SendIgnore, and then check IsConnected.
KeepSessionLog
boolVal = sFtp.get_KeepSessionLog();
sFtp.put_KeepSessionLog(boolVal);
Controls whether communications to/from the SFTP server are saved to the SessionLog property.  The default value is false.   If this property is set to true, the contents of the SessionLog property will continuously grow as SFTP activity transpires.   The purpose of the KeepSessionLog / SessionLog properties is to help in debugging any future problems that may arise.
LastErrorHtml
# ckStr is a CkString
sFtp.get_LastErrorHtml(ckStr);
strVal = sFtp.lastErrorHtml();
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
# ckStr is a CkString
sFtp.get_LastErrorText(ckStr);
strVal = sFtp.lastErrorText();
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
# ckStr is a CkString
sFtp.get_LastErrorXml(ckStr);
strVal = sFtp.lastErrorXml();
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
boolVal = sFtp.get_LastMethodSuccess();
sFtp.put_LastMethodSuccess(boolVal);
Indicates the success or failure of the most recent method call: true means success, false means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.
LastStatusCode
intVal = sFtp.get_LastStatusCode();
Contains the numeric last status code received in an SSH_FXP_STATUS message received from the SFTP server. Status codes are defined in the SFTP protocol specification as follows:
(See https://tools.ietf.org/id/draft-ietf-secsh-filexfer-13.txt)
SSH_FX_OK 0 SSH_FX_EOF 1 SSH_FX_NO_SUCH_FILE 2 SSH_FX_PERMISSION_DENIED 3 SSH_FX_FAILURE 4 SSH_FX_BAD_MESSAGE 5 SSH_FX_NO_CONNECTION 6 SSH_FX_CONNECTION_LOST 7 SSH_FX_OP_UNSUPPORTED 8 SSH_FX_INVALID_HANDLE 9 SSH_FX_NO_SUCH_PATH 10 SSH_FX_FILE_ALREADY_EXISTS 11 SSH_FX_WRITE_PROTECT 12 SSH_FX_NO_MEDIA 13 SSH_FX_NO_SPACE_ON_FILESYSTEM 14 SSH_FX_QUOTA_EXCEEDED 15 SSH_FX_UNKNOWN_PRINCIPAL 16 SSH_FX_LOCK_CONFLICT 17 SSH_FX_DIR_NOT_EMPTY 18 SSH_FX_NOT_A_DIRECTORY 19 SSH_FX_INVALID_FILENAME 20 SSH_FX_LINK_LOOP 21 SSH_FX_CANNOT_DELETE 22 SSH_FX_INVALID_PARAMETER 23 SSH_FX_FILE_IS_A_DIRECTORY 24 SSH_FX_BYTE_RANGE_LOCK_CONFLICT 25 SSH_FX_BYTE_RANGE_LOCK_REFUSED 26 SSH_FX_DELETE_PENDING 27 SSH_FX_FILE_CORRUPT 28 SSH_FX_OWNER_INVALID 29 SSH_FX_GROUP_INVALID 30 SSH_FX_NO_MATCHING_BYTE_RANGE_LOCK 31top
LastStatusMessage
# ckStr is a CkString
sFtp.get_LastStatusMessage(ckStr);
strVal = sFtp.lastStatusMessage();
Contains the message text received in the last SSH_FXP_STATUS message received from the SFTP server. The actual text of the message can vary depending on the SFTP server implementation. The integer status code is available in the LastStatusCode property.
topMaxPacketSize
intVal = sFtp.get_MaxPacketSize();
sFtp.put_MaxPacketSize(intVal);
The maximum packet length to be used in the underlying SSH transport protocol. The default value is 32768. (This should generally be left unchanged.)
topPasswordChangeRequested
boolVal = sFtp.get_PasswordChangeRequested();
Set by the AuthenticatePw and AuthenticatePwPk methods.  If the authenticate  method returns a failed status, and this property is set to true, then it indicates the server requested a password change.  In this case, re-call the authenticate method, but provide both the old and new passwords in the following format, where vertical bar characters encapsulate the old and new passwords:  
|oldPassword|newPassword|top
PreferIpv6
boolVal = sFtp.get_PreferIpv6();
sFtp.put_PreferIpv6(boolVal);
If true, then use IPv6 over IPv4 when both are supported for a particular domain.   The default value of this property is false, which will choose IPv4 over IPv6.
PreserveDate
boolVal = sFtp.get_PreserveDate();
sFtp.put_PreserveDate(boolVal);
If true, then the file last-modified and create date/time will be preserved for downloaded and uploaded files.  The default value is false.
Note: It does not apply to uploads or downloads where the remote file is opened to obtain a handle, the data is uploaded/downloaded, and then the handle is closed.
topProtocolVersion
intVal = sFtp.get_ProtocolVersion();
The negotiated SFTP protocol version, which should be a value between 3 and 6 inclusive. When the InitializeSftp method is called, the Chilkat SFTP client sends it's highest supported protocol version to the server, and the server sends it's SFTP protocol version in response. The negotiated protocol (i.e. the protocol version used for the session) is the lower of the two numbers. If the SFTP server's protocol version is lower than 6, some file date/attributes are not supported because they are not supported by the earlier protocol version. These exceptions are noted throughout the reference documentation.
topReadDirMustMatch
# ckStr is a CkString
sFtp.get_ReadDirMustMatch(ckStr);
strVal = sFtp.readDirMustMatch();
sFtp.put_ReadDirMustMatch(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, *.xml; *.txt; *.csv.  If set, the ReadDir method will only return files that match any one of these patterns.
ReadDirMustNotMatch
# ckStr is a CkString
sFtp.get_ReadDirMustNotMatch(ckStr);
strVal = sFtp.readDirMustNotMatch();
sFtp.put_ReadDirMustNotMatch(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, *.xml; *.txt; *.csv.  If set, the ReadDir method will only return files that do not match any of these patterns.
ServerIdentifier
# ckStr is a CkString
sFtp.get_ServerIdentifier(ckStr);
strVal = sFtp.serverIdentifier();
The server-identifier string received from the server during connection establishment.  For example, a typical value would be similar to SSH-2.0-OpenSSH_7.2p2 Ubuntu-4ubuntu2.2.
SessionLog
Contains a log of the messages sent to/from the SFTP server.  To enable session logging, set the KeepSessionLog property = true.  Note: This property is not a filename -- it is a string property that contains the session log data.
SocksHostname
# ckStr is a CkString
sFtp.get_SocksHostname(ckStr);
strVal = sFtp.socksHostname();
sFtp.put_SocksHostname(strVal);
The SOCKS4/SOCKS5 hostname or IPv4 address (in dotted decimal notation). This property is only used if the SocksVersion property is set to 4 or 5).
topSocksPassword
# ckStr is a CkString
sFtp.get_SocksPassword(ckStr);
strVal = sFtp.socksPassword();
sFtp.put_SocksPassword(strVal);
The SOCKS5 password (if required). The SOCKS4 protocol does not include the use of a password, so this does not apply to SOCKS4.
topSocksPort
intVal = sFtp.get_SocksPort();
sFtp.put_SocksPort(intVal);
The SOCKS4/SOCKS5 proxy port. The default value is 1080. This property only applies if a SOCKS proxy is used (if the SocksVersion property is set to 4 or 5).
topSocksUsername
# ckStr is a CkString
sFtp.get_SocksUsername(ckStr);
strVal = sFtp.socksUsername();
sFtp.put_SocksUsername(strVal);
The SOCKS4/SOCKS5 proxy username. This property is only used if the SocksVersion property is set to 4 or 5).
topSocksVersion
intVal = sFtp.get_SocksVersion();
sFtp.put_SocksVersion(intVal);
SocksVersion May be set to one of the following integer values:
0 - No SOCKS proxy is used.  This is the default.
4 - Connect via a SOCKS4 proxy.
5 - Connect via a SOCKS5 proxy.
SoRcvBuf
intVal = sFtp.get_SoRcvBuf();
sFtp.put_SoRcvBuf(intVal);
Sets the receive buffer size socket option. Normally, this property should be left unchanged. The default value is 4194304.
This property can be increased if download performance seems slow. It is recommended to be a multiple of 4096.
SoSndBuf
intVal = sFtp.get_SoSndBuf();
sFtp.put_SoSndBuf(intVal);
Sets the send buffer size socket option. Normally, this property should be left unchanged. The default value is 262144.
This property can be increased if upload performance seems slow. It is recommended to be a multiple of 4096. Testing with sizes such as 512K and 1MB is reasonable.
SyncCreateAllLocalDirs
boolVal = sFtp.get_SyncCreateAllLocalDirs();
sFtp.put_SyncCreateAllLocalDirs(boolVal);
If true, then empty directories on the server are created locally when doing a download synchronization.  If false, then only directories containing files that are downloaded are auto-created.
The default value of this property is true.
SyncDirectives
# ckStr is a CkString
sFtp.get_SyncDirectives(ckStr);
strVal = sFtp.syncDirectives();
sFtp.put_SyncDirectives(strVal);
A property that can contain a list of comma-separated keywords to control certain aspects of an upload or download synchronization (for the SyncTreeUpload and SyncTreeDownload methods). At this time there is only one possible directive, but others may be added in the future.
Set this property to UploadIgnoreLocalOpenFailures to skip local files that cannot be opened.  A common reason for this would be if another process on the system has the file open for exclusive access.
SyncMustMatch
# ckStr is a CkString
sFtp.get_SyncMustMatch(ckStr);
strVal = sFtp.syncMustMatch();
sFtp.put_SyncMustMatch(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, *.xml; *.txt; *.csv.  If set, the SyncTreeUpload and SyncTreeDownload methods will only  transfer files that match any one of these patterns.  This property only applies to files.  It does not apply to sub-directory names when recursively traversing a directory tree.
SyncMustMatchDir
# ckStr is a CkString
sFtp.get_SyncMustMatchDir(ckStr);
strVal = sFtp.syncMustMatchDir();
sFtp.put_SyncMustMatchDir(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, xml; txt; data_*.  If set, the SyncTreeUpload and SyncTreeDownload methods will only enter directories that match any one of these patterns.
SyncMustNotMatch
# ckStr is a CkString
sFtp.get_SyncMustNotMatch(ckStr);
strVal = sFtp.syncMustNotMatch();
sFtp.put_SyncMustNotMatch(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, *.xml; *.txt; *.csv.  If set, the SyncTreeUpload  and SyncTreeDownload methods will not  transfer files that match any one of these patterns.  This property only applies to files.  It does not apply to sub-directory names when recursively traversing a directory tree.
SyncMustNotMatchDir
# ckStr is a CkString
sFtp.get_SyncMustNotMatchDir(ckStr);
strVal = sFtp.syncMustNotMatchDir();
sFtp.put_SyncMustNotMatchDir(strVal);
Can contain a wildcarded list of file patterns separated by semicolons.  For example, xml; txt; data_*.  If set, the SyncTreeUpload  and SyncTreeDownload methods will not enter directories that match any one of these patterns.
TcpNoDelay
boolVal = sFtp.get_TcpNoDelay();
sFtp.put_TcpNoDelay(boolVal);
This property controls the use of the internal TCP_NODELAY socket option (which disables the Nagle algorithm).  The default value of this property is false.  Setting this value to true disables the delay of sending successive small packets on the network.
UncommonOptions
# ckStr is a CkString
sFtp.get_UncommonOptions(ckStr);
strVal = sFtp.uncommonOptions();
sFtp.put_UncommonOptions(strVal);
This is a catch-all property to be used for uncommon needs. This property defaults to the empty string, and should typically remain empty.
Can be set to a list of the following comma separated keywords:
- ForceUserAuthRsaSha1 - Introduced in v9.5.0.98. When doing public-key authentication, forces rsa-sha1 to be used for the userauth algorithm even if the server supports rsa-sha2-256, rsa-sha2-512, but still requires SHA1 for the userauth algorithm. Make sure to set this option before connecting to the server.
- ProtectFromVpn - Introduced in v9.5.0.80. On Android systems, will bypass any VPN that may be installed or active.
- NoSyncDownloadEmptyFiles - Introduced in v9.5.0.80. Prevents empty files from being downloaded in SyncTreeDownload.
- no-weak-mac-algs - Introduced in v9.5.0.98. Removes all weaker MAC algorithms from the list offered to the SSH server when negotiating the connection parameters during a Connect. Specifically, removes hmac-sha1-96, hmac-sha1, hmac-md5, and hmac-ripemd160. Note: Stronger algorithms such as hmac-sha2-256, hmac-sha2-512, etc., will already be automatically chosen because they are given higher preference. The only way a weaker algorithm is chosen is if the SSH server ONLY supports weaker algorithms. This option would only be set if you explicitly want to avoid connecting to older SSH servers, or servers configured in some unusual way where only weaker algorithms are supported on the server (which is rare).
- +ssh-hmac-etm - Introduced in v9.5.0.97. Version 9.5.0.97 disabled the *-etm MAC algorithms to mitigate the Terrapin attack. Use this keyword to include the etm MAC algorithms.
- +chacha20-poly1305@openssh.com - Introduced in v9.5.0.97. To mitigate the Terrapin attack, chacha20-poly1305@openssh.com is no longer included by default. It can be re-added by adding this keyword.
UploadChunkSize
intVal = sFtp.get_UploadChunkSize();
sFtp.put_UploadChunkSize(intVal);
The chunk size to use when uploading files via the UploadFile or UploadFileByName methods.  The default value is 32000.   If an upload fails because WSAECONNABORTED An established connection was aborted by the software in your host machine., then try setting this property to a smaller value, such as 4096.  A smaller value will result in slower transfer rates, but may help avoid this problem.
UserAuthBanner
# ckStr is a CkString
sFtp.get_UserAuthBanner(ckStr);
strVal = sFtp.userAuthBanner();
sFtp.put_UserAuthBanner(strVal);
If a user authentication banner message is received during authentication, it will be made available here. An application can check to see if this property contains a banner string after calling StartKeyboardAuth. It is only possible for an application to display this message if it is doing keyboard-interactive authentication via the StartKeyboardAuth and ContinueKeyboardAuth methods.
topUtcMode
boolVal = sFtp.get_UtcMode();
sFtp.put_UtcMode(boolVal);
If true, then date/times are returned as UTC times.  If false (the default) then date/times are returned as local times.
VerboseLogging
boolVal = sFtp.get_VerboseLogging();
sFtp.put_VerboseLogging(boolVal);
If set to true, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is false.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
XferByteCount
intVal = sFtp.get_XferByteCount();
The current transfer byte count for an ongoing upload or download. Programs doing asynchronous uploads or downloads can read this property in real time during the upload. For SyncTreeUpload and SyncTreeDownload operations, this is the real-time cumulative number of bytes for all files uploaded or downloaded.
topXferByteCount64
int64Val = sFtp.get_XferByteCount64();
The current transfer byte count for an ongoing upload or download. Programs doing asynchronous uploads or downloads can read this property in real time during the upload. For SyncTreeUpload and SyncTreeDownload operations, this is the real-time cumulative number of bytes for all files uploaded or downloaded.
topMethods
AccumulateBytes
# maxBytes is an integer
retInt = sFtp.AccumulateBytes(handle, maxBytes);
Downloads bytes from an open file and appends them to the AccumulateBuffer. The handle is a file handle returned by the OpenFile method. The maxBytes is the maximum number of bytes to read. If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned.
Returns the number of bytes downloaded and appended to AccumulateBuffer. Returns -1 on error.
topAccumulateBytesAsync (1)
# handle is a string
# maxBytes is an integer
ret_task = sFtp.AccumulateBytesAsync(handle, maxBytes);
Creates an asynchronous task to call the AccumulateBytes method with the arguments provided.
Returns nil on failure
Add64
# n2 is a string
# outStr is a CkString (output)
status = sFtp.Add64(n1, n2, outStr);
retStr = sFtp.add64(n1, n2);
Convenience method for 64-bit addition. Allows for two 64-bit integers to be passed as decimal strings and returns the sum in a decimal sting.
Returns true for success, false for failure.
topAuthenticatePk
# privateKey is a CkSshKey
status = sFtp.AuthenticatePk(username, privateKey);
Authenticates with the SSH server using public-key authentication. The corresponding public key must have been installed on the SSH server for the username. Authentication will succeed if the matching privateKey is provided.
Important: When reporting problems, please send the full contents of the LastErrorText property to support@chilkatsoft.com.
Returns true for success, false for failure.
AuthenticatePkAsync (1)
# username is a string
# privateKey is a CkSshKey
ret_task = sFtp.AuthenticatePkAsync(username, privateKey);
Creates an asynchronous task to call the AuthenticatePk method with the arguments provided.
Returns nil on failure
AuthenticatePw
# password is a string
status = sFtp.AuthenticatePw(login, password);
Authenticates with the SSH server using a login and password.
An SFTP session always begins by first calling Connect to connect to the SSH server, then calling either AuthenticatePw or AuthenticatePk to login, and finally calling InitializeSftp.
Important: When reporting problems, please send the full contents of the LastErrorText property to support@chilkatsoft.com.
Note: To learn about how to handle password change requests, see the PasswordChangeRequested property (above).
Returns true for success, false for failure.
topAuthenticatePwAsync (1)
# login is a string
# password is a string
ret_task = sFtp.AuthenticatePwAsync(login, password);
Creates an asynchronous task to call the AuthenticatePw method with the arguments provided.
Returns nil on failure
AuthenticatePwPk
# password is a string
# privateKey is a CkSshKey
status = sFtp.AuthenticatePwPk(username, password, privateKey);
Authentication for SSH servers that require both a password and private key. (Most SSH servers are configured to require one or the other, but not both.)
Important: When reporting problems, please send the full contents of the LastErrorText property to support@chilkatsoft.com.
Returns true for success, false for failure.
AuthenticatePwPkAsync (1)
# username is a string
# password is a string
# privateKey is a CkSshKey
ret_task = sFtp.AuthenticatePwPkAsync(username, password, privateKey);
Creates an asynchronous task to call the AuthenticatePwPk method with the arguments provided.
Returns nil on failure
AuthenticateSecPw
# password is a CkSecureString
status = sFtp.AuthenticateSecPw(login, password);
The same as AuthenticatePw, but the login and password are passed in secure string objects.
Returns true for success, false for failure.
AuthenticateSecPwAsync (1)
# login is a CkSecureString
# password is a CkSecureString
ret_task = sFtp.AuthenticateSecPwAsync(login, password);
Creates an asynchronous task to call the AuthenticateSecPw method with the arguments provided.
Returns nil on failure
AuthenticateSecPwPk
# password is a CkSecureString
# privateKey is a CkSshKey
status = sFtp.AuthenticateSecPwPk(username, password, privateKey);
The same as AuthenticatePwPk, but the login and password are passed in secure string objects.
Returns true for success, false for failure.
topAuthenticateSecPwPkAsync (1)
# username is a CkSecureString
# password is a CkSecureString
# privateKey is a CkSshKey
ret_task = sFtp.AuthenticateSecPwPkAsync(username, password, privateKey);
Creates an asynchronous task to call the AuthenticateSecPwPk method with the arguments provided.
Returns nil on failure
ClearAccumulateBuffer
Clears the contents of the AccumulateBuffer property.
topClearCache
Clears the internal file attribute cache. (Please refer to the EnableCache property for more information about the file attribute cache.)
topClearSessionLog
Clears the contents of the SessionLog property.
topCloseHandle
status = sFtp.CloseHandle(handle);
Closes a file on the SSH/SFTP server. handle is a file handle returned from a previous call to OpenFile or OpenDir.
Returns true for success, false for failure.
CloseHandleAsync (1)
Creates an asynchronous task to call the CloseHandle method with the arguments provided.
Returns nil on failure
Connect
# port is an integer
status = sFtp.Connect(domainName, port);
Connects to an SSH/SFTP server. The domainName may be a domain name or an IP address (example: 192.168.1.10). Both IPv4 and IPv6 addresses are supported. The port is typically 22, which is the standard port for SSH servers.
An SFTP session always begins by first calling Connect to connect to the SSH server, then calling either AuthenticatePw or AuthenticatePk to login, and finally calling InitializeSftp.
Important: When reporting problems, please send the full contents of the LastErrorText property to support@chilkatsoft.com.
Important: All TCP-based Internet communications, regardless of the protocol (such as HTTP, FTP, SSH, IMAP, POP3, SMTP, etc.), and regardless of SSL/TLS, begin with establishing a TCP connection to a remote host:port. External security-related infrastructure such as software firewalls (Windows Firewall), hardware firewalls, anti-virus, at either source or destination (or both) can block the connection. If the connection fails, make sure to check all potential external causes of blockage.
The following algorithms are supported by Chilkat SSH/SFTP:
- Hostkey:
- ssh-ed25519
- rsa-sha2-256
- rsa-sha2-512
- ecdsa-sha2-nistp256
- ecdsa-sha2-nistp384
- ecdsa-sha2-nistp521
- ssh-rsa
- ssh-dss
 
- Key Exchange:
- curve25519-sha256
- curve25519-sha256@libssh.org
- ecdh-sha2-nistp256
- ecdh-sha2-nistp384
- ecdh-sha2-nistp521
- diffie-hellman-group14-sha256
- diffie-hellman-group1-sha1
- diffie-hellman-group14-sha1
- diffie-hellman-group16-sha512
- diffie-hellman-group18-sha512
- diffie-hellman-group-exchange-sha256
- diffie-hellman-group-exchange-sha1
 
- Ciphers:
- aes128-ctr
- aes256-ctr
- aes192-ctr
- aes128-cbc
- aes256-cbc
- aes192-cbc
- aes128-gcm@openssh.com
- aes256-gcm@openssh.com
- twofish256-cbc
- twofish128-cbc
- blowfish-cbc
- (also chacha20-poly1305@openssh.com if explicitly allowed by the application)
 
- MAC Algorithms:
- hmac-sha2-256
- hmac-sha2-512
- hmac-sha1
- hmac-ripemd160
- hmac-sha1-96
- hmac-md5
- (also the following etm algorithms if explicitly allowed)
- hmac-sha1-etm@openssh.com
- hmac-sha2-256-etm@openssh.com
- hmac-sha2-512-etm@openssh.com
 
- Compression:
- none
- zlib
- zlib@openssh.com
 
Returns true for success, false for failure.
topConnectAsync (1)
# domainName is a string
# port is an integer
ret_task = sFtp.ConnectAsync(domainName, port);
Creates an asynchronous task to call the Connect method with the arguments provided.
Returns nil on failure
ConnectThroughSsh
# hostname is a string
# port is an integer
status = sFtp.ConnectThroughSsh(sshConn, hostname, port);
Connects to an SSH/SFTP server through an existing SSH connection. The sshConn is an existing connected and authenticated SSH object. The connection to hostname:port is made through the existing SSH connection via port-forwarding. If successful, the connection is as follows: application => ServerSSH1 => ServerSSH2. (where ServerSSH1 is the sshConn and ServerSSH2 is the SSH server at hostname:port) Once connected in this way, all communications are routed through ServerSSH1 to ServerSSH2. This includes authentication -- which means the application must still call one of the Authenticate* methods to authenticate with ServerSSH2.
Returns true for success, false for failure.
ConnectThroughSshAsync (1)
# sshConn is a CkSsh
# hostname is a string
# port is an integer
ret_task = sFtp.ConnectThroughSshAsync(sshConn, hostname, port);
Creates an asynchronous task to call the ConnectThroughSsh method with the arguments provided.
Returns nil on failure
ContinueKeyboardAuth
# outStr is a CkString (output)
status = sFtp.ContinueKeyboardAuth(response, outStr);
retStr = sFtp.continueKeyboardAuth(response);
Continues keyboard-interactive authentication with the SSH server. The response is typically the password. If multiple responses are required (because there were multiple prompts in the infoRequest XML returned by StartKeyboardAuth), then the response should be formatted as XML (as shown below) otherwise the response simply contains the single response string.
<response>
    <response1>response to first prompt</response1>
    <response2>response to second prompt</response2>
    ...
    <responseN>response to Nth prompt</responseN>
</response>
If the interactive authentication completed with success or failure, the XML response will be:
<success>success_message</success> or <error>error_message</error>If additional steps are required to complete the interactive authentication, then an XML string that provides the name, instruction, and prompts is returned. The XML has the following format:
<infoRequest numPrompts="N"> <name>name_string</name> <instruction>instruction_string</instruction> <prompt1 echo="1_or_0">prompt_string</prompt1> ... <promptN echo="1_or_0">prompt_string</promptN> </infoRequest>
Returns true for success, false for failure.
topContinueKeyboardAuthAsync (1)
Creates an asynchronous task to call the ContinueKeyboardAuth method with the arguments provided.
Returns nil on failure
CopyFileAttr
# remoteFilename is a string
# isHandle is a boolean
status = sFtp.CopyFileAttr(localFilename, remoteFilename, isHandle);
Sets the date/time and other attributes of a remote file to be equal to that of a local file.
The attributes copied depend on the SFTP version of the server:
<b>SFTP v3 (and below)</b>
    Last-Modified Date/Time
    Last-Access Date/Time
<b>SFTP v4, v5</b>
    Last-Modified Date/Time
    Last-Access Date/Time
    Create Date/Time
<b>SFTP v6 (and above)</b>
    Last-Modified Date/Time
    Last-Access Date/Time
    Create Date/Time
    Read-Only Flag
    Hidden Flag
    Archive Flag
    Compressed Flag
    Encrypted Flag
Notes:(1) The Last-Access date/time may or may not be set. Chilkat has found that the Last-Access time is set to the current date/time, which is probably a result of the operating system setting it based on when the SFTP server is touching the file.
(2) At the time of this writing, it is unknown whether the compressed/encryption settings for a local file are transferred to the remote file. For example, does the remote file become compressed and/or encrypted just by setting the flags? It may depend on the SFTP server and/or the remote filesystem.
(3) Dates/times are sent in GMT. SFTP servers should convert GMT times to local time zones.
Returns true for success, false for failure.
topCopyFileAttrAsync (1)
# localFilename is a string
# remoteFilename is a string
# isHandle is a boolean
ret_task = sFtp.CopyFileAttrAsync(localFilename, remoteFilename, isHandle);
Creates an asynchronous task to call the CopyFileAttr method with the arguments provided.
Returns nil on failure
CreateDir
status = sFtp.CreateDir(path);
CreateDirAsync (1)
Creates an asynchronous task to call the CreateDir method with the arguments provided.
Returns nil on failure
Disconnect
Disconnects from the SSH server.
topDownloadBd
# binData is a CkBinData
status = sFtp.DownloadBd(remoteFilePath, binData);
Downloads the contents of a remote file to a BinData object. (Appends to the BinData.)
Returns true for success, false for failure.
DownloadBdAsync (1)
# remoteFilePath is a string
# binData is a CkBinData
ret_task = sFtp.DownloadBdAsync(remoteFilePath, binData);
Creates an asynchronous task to call the DownloadBd method with the arguments provided.
Returns nil on failure
DownloadFile
# toFilename is a string
status = sFtp.DownloadFile(handle, toFilename);
Downloads a file from the SSH server to the local filesystem. There are no limitations on file size and the data is streamed from SSH server to the local file. handle is a file handle returned by a previous call to OpenFile.
Returns true for success, false for failure.
topDownloadFileAsync (1)
# handle is a string
# toFilename is a string
ret_task = sFtp.DownloadFileAsync(handle, toFilename);
Creates an asynchronous task to call the DownloadFile method with the arguments provided.
Returns nil on failure
DownloadFileByName
# localFilePath is a string
status = sFtp.DownloadFileByName(remoteFilePath, localFilePath);
Simplified method for downloading files.
The last-modified date/time is only preserved when the PreserveDate property is set to true.  (The default value of PreserveDate is false.)
Important: If the remoteFilePath is an absolute path, then it is a path from the root of the server's filesystem.  For example, /home/joe/someFile.txt.   Use a relative path to specify a directory relative to the $HOME directory of the SSH user account.  For example, ./someFile.txt.
Returns true for success, false for failure.
DownloadFileByNameAsync (1)
# remoteFilePath is a string
# localFilePath is a string
ret_task = sFtp.DownloadFileByNameAsync(remoteFilePath, localFilePath);
Creates an asynchronous task to call the DownloadFileByName method with the arguments provided.
Returns nil on failure
DownloadSb
# charset is a string
# sb is a CkStringBuilder
status = sFtp.DownloadSb(remoteFilePath, charset, sb);
Downloads the contents of a remote file to a StringBuilder object. (Appends to the StringBuilder.)
Returns true for success, false for failure.
DownloadSbAsync (1)
# remoteFilePath is a string
# charset is a string
# sb is a CkStringBuilder
ret_task = sFtp.DownloadSbAsync(remoteFilePath, charset, sb);
Creates an asynchronous task to call the DownloadSb method with the arguments provided.
Returns nil on failure
Eof
retBool = sFtp.Eof(handle);
Returns true if the last read operation for a handle reached the end of file.  Otherwise returns false.
If an invalid handle is passed, a value of true is returned.
FileExists
# followLinks is a boolean
retInt = sFtp.FileExists(remotePath, followLinks);
Returns a value to indicate whether the remote file exists or not.  remotePath is the path of the remote file.  If followLinks is true, then symbolic links will be followed on the server.
This method returns one of the following possible values:
- -1: Unable to check. Examine the LastErrorText to determine the reason for failure.
- 0: File does not exist.
- 1: The regular file exists.
- 2: It exists, but it is a directory.
- 3: It exists, but it is a symlink (only possible if followLinks is false)
- 4: It exists, but it is a special filesystem entry type.
- 5: It exists, but it is an unkown filesystem entry type.
- 6: It exists, but it is an socket filesystem entry type.
- 7: It exists, but it is an char device entry type.
- 8: It exists, but it is an block device entry type.
- 9: It exists, but it is an FIFO entry type.
Note: The values greater than zero correspond to the possible values as specified in the SFTP protocol specification. A given value may not make sense on all operating systems.
FileExistsAsync (1)
# remotePath is a string
# followLinks is a boolean
ret_task = sFtp.FileExistsAsync(remotePath, followLinks);
Creates an asynchronous task to call the FileExists method with the arguments provided.
Returns nil on failure
Fsync
status = sFtp.Fsync(handle);
Causes the SFTP server to do an fsync on the open file. Specifically, this is directing the SFTP server to call fsync (https://linux.die.net/man/2/fsync) on the open file.
This method uses the fsync@openssh.com and only works for servers supporting the fsync@openssh.com extension.
Returns true for success, false for failure.
FsyncAsync (1)
Creates an asynchronous task to call the Fsync method with the arguments provided.
Returns nil on failure
GetFileCreateTimeStr
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileCreateTimeStr(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileCreateTimeStr(pathOrHandle, bFollowLinks, bIsHandle);
Returns the create date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Note: Servers running the SFTP v3 protocol or lower do not have the ability to return a file's creation date/time. The date/time is returned as an RFC822 formatted string.
Returns true for success, false for failure.
topGetFileCreateTimeStrAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileCreateTimeStrAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileCreateTimeStr method with the arguments provided.
Returns nil on failure
GetFileGroup
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileGroup(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileGroup(pathOrHandle, bFollowLinks, bIsHandle);
Returns the group of a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Note: Servers running the SFTP v3 protocol or lower do not have the ability to return a file's group name. Instead, the decimal GID of the file is returned.
Returns true for success, false for failure.
topGetFileGroupAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileGroupAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileGroup method with the arguments provided.
Returns nil on failure
GetFileLastAccessStr
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileLastAccessStr(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileLastAccessStr(pathOrHandle, bFollowLinks, bIsHandle);
Returns the last-access date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server. The date/time is returned as an RFC822 formatted string.
Returns true for success, false for failure.
topGetFileLastAccessStrAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileLastAccessStrAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileLastAccessStr method with the arguments provided.
Returns nil on failure
GetFileLastModifiedStr
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileLastModifiedStr(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileLastModifiedStr(pathOrHandle, bFollowLinks, bIsHandle);
Returns the last-modified date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server. The date/time is returned as an RFC822 formatted string.
Returns true for success, false for failure.
topGetFileLastModifiedStrAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileLastModifiedStrAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileLastModifiedStr method with the arguments provided.
Returns nil on failure
GetFileOwner
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileOwner(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileOwner(pathOrHandle, bFollowLinks, bIsHandle);
Returns the owner of a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Note: Servers running the SFTP v3 protocol or lower do not have the ability to return a file's owner name. Instead, the decimal UID of the file is returned.
Returns true for success, false for failure.
topGetFileOwnerAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileOwnerAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileOwner method with the arguments provided.
Returns nil on failure
GetFilePermissions
# bFollowLinks is a boolean
# bIsHandle is a boolean
retInt = sFtp.GetFilePermissions(pathOrHandle, bFollowLinks, bIsHandle);
Returns the access permisssions flags of a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
GetFilePermissionsAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFilePermissionsAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFilePermissions method with the arguments provided.
Returns nil on failure
GetFileSize32
# bFollowLinks is a boolean
# bIsHandle is a boolean
retInt = sFtp.GetFileSize32(pathOrHandle, bFollowLinks, bIsHandle);
Returns the size in bytes of a file on the SSH server.  If the file size exceeds what can be represented in 32-bits, a value of -1 is returned.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
GetFileSize32Async (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileSize32Async(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileSize32 method with the arguments provided.
Returns nil on failure
GetFileSize64
# bFollowLinks is a boolean
# bIsHandle is a boolean
retInt64 = sFtp.GetFileSize64(pathOrHandle, bFollowLinks, bIsHandle);
Returns a 64-bit integer containing the size (in bytes) of a file on the SSH server.   pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
GetFileSize64Async (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileSize64Async(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileSize64 method with the arguments provided.
Returns nil on failure
GetFileSizeStr
# bFollowLinks is a boolean
# bIsHandle is a boolean
# outStr is a CkString (output)
status = sFtp.GetFileSizeStr(pathOrHandle, bFollowLinks, bIsHandle, outStr);
retStr = sFtp.getFileSizeStr(pathOrHandle, bFollowLinks, bIsHandle);
Returns the size in bytes (in decimal string form) of a file on the SSH server.   pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.  
Note: This method exists for environments that do not have 64-bit integer support. The Add64 method is provided for 64-bit addition, and other methods such as ReadFileBytes64s allow for 64-bit values to be passed as strings.
Returns true for success, false for failure.
GetFileSizeStrAsync (1)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileSizeStrAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileSizeStr method with the arguments provided.
Returns nil on failure
GetHostKeyFP
# includeKeyType is a boolean
# includeHashName is a boolean
# outStr is a CkString (output)
status = sFtp.GetHostKeyFP(hashAlg, includeKeyType, includeHashName, outStr);
retStr = sFtp.getHostKeyFP(hashAlg, includeKeyType, includeHashName);
Returns the host key fingerprint of the server, which is automatically set after connecting to an SSH/SFTP server.  The hashAlg can be any hash algorithm supported by Chilkat, such as SHA256, SHA384, SHA512, SHA1, MD5, SHA3-224, SHA3-256, SHA3-384, SHA3-512, etc.
If both includeKeyType and includeHashName are true, then the fingerprint string is formatted like this:
ssh-rsa SHA256:L7sQgnpnoBwRoyIYXAFBs8SdSnwtyYmhXs1p/mQDK...If includeKeyType is
true and includeHashName is false:
ssh-rsa L7sQgnpnoBwRoyIYXAFBs8SdSnwtyYmhXs1p/mQDK...If includeKeyType is
false and includeHashName is true:
SHA256:L7sQgnpnoBwRoyIYXAFBs8SdSnwtyYmhXs1p/mQDK...If includeKeyType is
false and includeHashName is false:
L7sQgnpnoBwRoyIYXAFBs8SdSnwtyYmhXs1p/mQDK...
SSH host key types can be: ssh-rsa, ecdsa-*-* (such as ecdsa-sha2-nistp256), ssh-ed25519, and ssh-dss.
Returns true for success, false for failure.
GetLastJsonData
Provides information about what transpired in the last method called. For many methods, there is no information. For some methods, details about what transpired can be obtained via LastJsonData.
topGetSyncedFiles
Appends to strTab the paths of the files uploaded or downloaded in the last call to SyncTreeUpload or SyncTreeDownload. In both cases (for upload and download) each path is relative to the root synced directory.
Note: For SyncTreeDownload, some of entires can be the paths of local directories that were created.  Local directory paths will be terminated with a / char to disinguish a directory from an actual file.
HardLink
# newPath is a string
status = sFtp.HardLink(oldPath, newPath);
Creates a hard link on the server using the hardlink@openssh.com extension. This only works for SFTP servers that support the hardlink@openssh.com extension.
Returns true for success, false for failure.
HardLinkAsync (1)
# oldPath is a string
# newPath is a string
ret_task = sFtp.HardLinkAsync(oldPath, newPath);
Creates an asynchronous task to call the HardLink method with the arguments provided.
Returns nil on failure
InitializeSftp
Intializes the SFTP subsystem. This should be called after connecting and authenticating. An SFTP session always begins by first calling Connect to connect to the SSH server, then calling either AuthenticatePw or AuthenticatePk to login, and finally calling InitializeSftp.
Important: When reporting problems, please send the full contents of the LastErrorText property to support@chilkatsoft.com.
If this method fails, the reason may be present in the InitializeFailCode and InitializeFailReason properties (assuming the failure occurred when trying to open the SFTP session channel).
Returns true for success, false for failure.
InitializeSftpAsync (1)
Creates an asynchronous task to call the InitializeSftp method with the arguments provided.
Returns nil on failure
LastReadFailed
retBool = sFtp.LastReadFailed(handle);
Returns true if the last read on the specified handle failed.  Otherwise returns false.
LastReadNumBytes
retInt = sFtp.LastReadNumBytes(handle);
Returns the number of bytes received by the last read on a specified channel.
topLoadTaskCaller
OpenDir
# outStr is a CkString (output)
status = sFtp.OpenDir(path, outStr);
retStr = sFtp.openDir(path);
Opens a directory for reading. To get a directory listing, first open the directory by calling this method, then call ReadDir to read the directory, and finally call CloseHandle to close the directory.
The SFTP protocol represents file names as strings. File names are assumed to use the slash ('/') character as a directory separator.
   File names starting with a slash are absolute, and are relative to
   the root of the file system.  Names starting with any other character
   are relative to the user's default directory (home directory).  Note
   that identifying the user is assumed to take place outside of this
   protocol.
   Servers SHOULD interpret a path name component ..  as
   referring to the parent directory, and . as referring to the
   current directory.
An empty path name is valid, and it refers to the user's default directory (usually the user's home directory).
Please note: This method does NOT change the remote working directory.  It is only a method for opening a directory for the purpose of reading the directory listing.
SFTP is Secure File Transfer over SSH. It is not the FTP protocol. There is no similarity or relationship between FTP and SFTP. Therefore, concepts such as current remote directory that exist in FTP do not exist with SFTP. With the SFTP protocol, the current directory will always be the home directory of the user account used during SSH/SFTP authentication. You may pass relative or absolute directory/file paths. A relative path is always relative to the home directory of the SSH user account.
Returns true for success, false for failure.
OpenDirAsync (1)
Creates an asynchronous task to call the OpenDir method with the arguments provided.
Returns nil on failure
OpenFile
# access is a string
# createDisposition is a string
# outStr is a CkString (output)
status = sFtp.OpenFile(remotePath, access, createDisposition, outStr);
retStr = sFtp.openFile(remotePath, access, createDisposition);
Opens or creates a file on the remote system. Returns a handle which may be passed to methods for reading and/or writing the file. The remotePath is the remote file path (the path to the file on the server). When the application is finished with the handle, it should call CloseHandle(remotePath).
Important: If the remotePath is an absolute path, then it is a path from the root of the server's filesystem.  For example, /home/joe/someFile.txt.   Use a relative path to specify a directory relative to the $HOME directory of the SSH user account.  For example, ./someFile.txt.
access should be one of the following strings: readOnly, writeOnly, or readWrite.  
createDisposition is a comma-separated list of keywords to provide more control over how the file is opened or created.  One of the following keywords must be present: createNew, createTruncate, openExisting, openOrCreate, or truncateExisting.  All other keywords are optional.  The list of keywords and their meanings are shown here:
createNew
A new file is created; if the file already exists the method fails.
createTruncate
A new file is created; if the file already exists, it is opened and truncated.
openExisting
An existing file is opened.  If the file does not exist the method fails.
openOrCreate
If the file exists, it is opened.  If the file does not exist,
         it is created.
truncateExisting
An existing file is opened and truncated.  If the file does not
         exist the method fails.
appendData
Data is always written at the end of the file.  
      Data is not required to be appended atomically.  This means that
      if multiple writers attempt to append data simultaneously, data
      from the first may be lost. 
appendDataAtomic
Data is always written at the end of the file.
      Data MUST be written atomically so that there is no chance that
      multiple appenders can collide and result in data being lost.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
textMode
Indicates that the server should treat the file as text and
      convert it to the canonical newline convention in use.
      When a file is opened with this flag, data is always appended to the end of the file.
      Servers MUST process multiple, parallel reads and writes correctly
      in this mode.  
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
blockRead
The server MUST guarantee that no other handle has been opened
      with read access, and that no other handle will be
      opened with read access until the client closes the
      handle.  (This MUST apply both to other clients and to other
      processes on the server.)   In a nutshell, this opens the file 
in non-sharing mode.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
blockWrite
The server MUST guarantee that no other handle has been opened
      with write access, and that no other
      handle will be opened with write
      access until the client closes the handle.  (This MUST apply both
      to other clients and to other processes on the server.)
In a nutshell, this opens the file 
in non-sharing mode.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
blockDelete
The server MUST guarantee that the
      file itself is not deleted in any other way until the client
      closes the handle.  No other client or process is allowed to open the file with delete access.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
blockAdvisory
If set, the above block modes are advisory.  In
      advisory mode, only other accesses that specify a block mode need
      be considered when determining whether the block can be granted,
      and the server need not prevent I/O operations that violate the
      block mode.
      The server MAY perform mandatory locking even if the
      blockAdvisory flag is set.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
noFollow
If the final component of the path is a symlink, then the open
      MUST fail.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
deleteOnClose
The file should be deleted when the last handle to it is closed.
      (The last handle may not be an sftp-handle.)  This MAY be emulated
      by a server if the OS doesn't support it by deleting the file when
      this handle is closed.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
accessAuditAlarmInfo
The client wishes the server to enable any privileges or extra
      capabilities that the user may have in to allow the reading and
      writing of AUDIT or ALARM access control entries.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
accessBackup
The client wishes the server to enable any privileges or extra
      capabilities that the user may have in order to bypass normal
      access checks for the purpose of backing up or restoring files.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
backupStream
This flag indicates that the client wishes to read or write a
      backup stream.  A backup stream is a system dependent structured
      data stream that encodes all the information that must be
      preserved in order to restore the file from backup medium.
      The only well defined use for backup stream data read in this
      fashion is to write it to the same server to a file also opened
      using the backupStream flag.  However, if the server has a well
      defined backup stream format, there may be other uses for this
      data outside the scope of this protocol.
(Only supported in SFTP protocol versions 5 and later.  See the note below.)
IMPORANT: If remotePath is a filename with no path, such as test.txt, and the server responds with a Folder not found error, then try prepending ./ to the remotePath.  For example, instead of passing test.txt, try ./test.txt.
IMPORTANT note about createDisposition: Many of the options, such as textMode, are not implemented in the SFTP protocol versions 3 and 4. Only SFTP servers at protocol version 5 or later support these options.  You can find out the protocol version of your server by examining the value of the ProtocolVersion property after calling InitializeSftp.  Also, make sure the ForceV3 property is set to false (the default value is true)
Returns true for success, false for failure.
OpenFileAsync (1)
# remotePath is a string
# access is a string
# createDisposition is a string
ret_task = sFtp.OpenFileAsync(remotePath, access, createDisposition);
Creates an asynchronous task to call the OpenFile method with the arguments provided.
Returns nil on failure
ReadDirListing
Reads the contents of a directory and returns the directory listing in dirObj.  The handle returned by OpenDir should be passed to this method.
Returns true for success, false for failure.
topReadDirListingAsync (1)
# handle is a string
# dirObj is a CkSFtpDir
ret_task = sFtp.ReadDirListingAsync(handle, dirObj);
Creates an asynchronous task to call the ReadDirListing method with the arguments provided.
Returns nil on failure
ReadFileBd
# numBytes is an integer
# bd is a CkBinData
retBool = sFtp.ReadFileBd(handle, numBytes, bd);
Reads file data from a remote file on the SSH server. The handle is a file handle returned by the OpenFile method. The numBytes is the maximum number of bytes to read. If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned. The received bytes are appended to the contents of bd.
To read an entire file, one may call ReadFileBd repeatedly until Eof(handle) returns true.
ReadFileBdAsync (1)
# handle is a string
# numBytes is an integer
# bd is a CkBinData
ret_task = sFtp.ReadFileBdAsync(handle, numBytes, bd);
Creates an asynchronous task to call the ReadFileBd method with the arguments provided.
Returns nil on failure
ReadFileText
# numBytes is an integer
# charset is a string
# outStr is a CkString (output)
status = sFtp.ReadFileText(handle, numBytes, charset, outStr);
retStr = sFtp.readFileText(handle, numBytes, charset);
This method is identical to ReadFileBytes except for one thing: The bytes are interpreted according to the specified charset (i.e. the character encoding) and returned as a string. A list of supported charset values may be found on this page: Supported Charsets.
Note: If the charset is an encoding where a single character might be represented in multiple bytes (such as utf-8, Shift_JIS, etc.) then there is a risk that the very last character may be partially read. This is because the method specifies the number of bytes to read, not the number of characters. This is never a problem with character encodings that use a single byte per character, such as all of the iso-8859-* encodings, or the Windows-* encodings.
To read an entire file, one may call ReadFileText repeatedly until Eof(handle) returns true.
Returns true for success, false for failure.
topReadFileTextAsync (1)
# handle is a string
# numBytes is an integer
# charset is a string
ret_task = sFtp.ReadFileTextAsync(handle, numBytes, charset);
Creates an asynchronous task to call the ReadFileText method with the arguments provided.
Returns nil on failure
ReadFileText32
# offset is an integer
# numBytes is an integer
# charset is a string
# outStr is a CkString (output)
status = sFtp.ReadFileText32(handle, offset, numBytes, charset, outStr);
retStr = sFtp.readFileText32(handle, offset, numBytes, charset);
This method is identical to ReadFileBytes32 except for one thing: The bytes are interpreted according to the specified charset (i.e. the character encoding) and returned as a string. A list of supported charset values may be found on this page: Supported Charsets.
Note: If the charset is an encoding where a single character might be represented in multiple bytes (such as utf-8, Shift_JIS, etc.) then there is a risk that the very last character may be partially read. This is because the method specifies the number of bytes to read, not the number of characters. This is never a problem with character encodings that use a single byte per character, such as all of the iso-8859-* encodings, or the Windows-* encodings.
Returns true for success, false for failure.
topReadFileText32Async (1)
# handle is a string
# offset is an integer
# numBytes is an integer
# charset is a string
ret_task = sFtp.ReadFileText32Async(handle, offset, numBytes, charset);
Creates an asynchronous task to call the ReadFileText32 method with the arguments provided.
Returns nil on failure
ReadFileText64
# offset is a 64-bit integer
# numBytes is an integer
# charset is a string
# outStr is a CkString (output)
status = sFtp.ReadFileText64(handle, offset, numBytes, charset, outStr);
retStr = sFtp.readFileText64(handle, offset, numBytes, charset);
This method is identical to ReadFileBytes64 except for one thing: The bytes are interpreted according to the specified charset (i.e. the character encoding) and returned as a string. A list of supported charset values may be found on this page: Supported Charsets.
Note: If the charset is an encoding where a single character might be represented in multiple bytes (such as utf-8, Shift_JIS, etc.) then there is a risk that the very last character may be partially read. This is because the method specifies the number of bytes to read, not the number of characters. This is never a problem with character encodings that use a single byte per character, such as all of the iso-8859-* encodings, or the Windows-* encodings.
Returns true for success, false for failure.
topReadFileText64Async (1)
# handle is a string
# offset is a 64-bit integer
# numBytes is an integer
# charset is a string
ret_task = sFtp.ReadFileText64Async(handle, offset, numBytes, charset);
Creates an asynchronous task to call the ReadFileText64 method with the arguments provided.
Returns nil on failure
ReadFileText64s
# offset is a string
# numBytes is an integer
# charset is a string
# outStr is a CkString (output)
status = sFtp.ReadFileText64s(handle, offset, numBytes, charset, outStr);
retStr = sFtp.readFileText64s(handle, offset, numBytes, charset);
This method is identical to ReadFileBytes64s except for one thing: The bytes are interpreted according to the specified charset (i.e. the character encoding) and returned as a string. A list of supported charset values may be found on this page: Supported Charsets.
Note: If the charset is an encoding where a single character might be represented in multiple bytes (such as utf-8, Shift_JIS, etc.) then there is a risk that the very last character may be partially read. This is because the method specifies the number of bytes to read, not the number of characters. This is never a problem with character encodings that use a single byte per character, such as all of the iso-8859-* encodings, or the Windows-* encodings.
Returns true for success, false for failure.
topReadFileText64sAsync (1)
# handle is a string
# offset is a string
# numBytes is an integer
# charset is a string
ret_task = sFtp.ReadFileText64sAsync(handle, offset, numBytes, charset);
Creates an asynchronous task to call the ReadFileText64s method with the arguments provided.
Returns nil on failure
ReadLink
# outStr is a CkString (output)
status = sFtp.ReadLink(path, outStr);
retStr = sFtp.readLink(path);
Returns the target of a symbolic link on the server. The path is the path of the symbolic link on the server.
Returns true for success, false for failure.
ReadLinkAsync (1)
Creates an asynchronous task to call the ReadLink method with the arguments provided.
Returns nil on failure
RealPath
# composePath is a string
# outStr is a CkString (output)
status = sFtp.RealPath(originalPath, composePath, outStr);
retStr = sFtp.realPath(originalPath, composePath);
This method can be used to have the server
   canonicalize any given path name to an absolute path.  This is useful
   for converting path names containing .. components or relative
   pathnames without a leading slash into absolute paths.   The absolute path is returned by this method.
originalPath is the first component of the path which the client wishes resolved into a absolute canonical path. This may be the entire path.
The composePath is a path which the client wishes the server to compose with the original path to form the new path. This field is optional and may be set to a zero-length string.
The server will take the originalPath and apply the composePath as a modification to it. composePath may be relative to originalPath or may be an absolute path, in which case originalPath will be discarded. The composePath may be zero length.
Note: Servers running SFTP v4 and below do not support composePath.
Returns true for success, false for failure.
topRealPathAsync (1)
# originalPath is a string
# composePath is a string
ret_task = sFtp.RealPathAsync(originalPath, composePath);
Creates an asynchronous task to call the RealPath method with the arguments provided.
Returns nil on failure
RemoveDir
status = sFtp.RemoveDir(path);
Deletes a directory on the remote server. Most (if not all) SFTP servers require that the directorybe empty of files before it may be deleted.
Returns true for success, false for failure.
topRemoveDirAsync (1)
Creates an asynchronous task to call the RemoveDir method with the arguments provided.
Returns nil on failure
RemoveFile
status = sFtp.RemoveFile(filename);
Deletes a file on the SFTP server.
Returns true for success, false for failure.
RemoveFileAsync (1)
Creates an asynchronous task to call the RemoveFile method with the arguments provided.
Returns nil on failure
RenameFileOrDir
# newPath is a string
status = sFtp.RenameFileOrDir(oldPath, newPath);
Renames a file or directory on the SFTP server.  This is the equivalent of moving a file.   To move a file from one directory to another, call this method where oldPath is the path of the existing file, and newPath is the path where the file is to be moved.  For example, rename a file from someDirA/filename to someDirB/abc/xyz/filename.
Returns true for success, false for failure.
topRenameFileOrDirAsync (1)
# oldPath is a string
# newPath is a string
ret_task = sFtp.RenameFileOrDirAsync(oldPath, newPath);
Creates an asynchronous task to call the RenameFileOrDir method with the arguments provided.
Returns nil on failure
ResumeDownloadFileByName
# localFilePath is a string
status = sFtp.ResumeDownloadFileByName(remoteFilePath, localFilePath);
Resumes an SFTP download.  The size of the localFilePath is checked and the download begins at the appropriate position in the remoteFilePath.  If localFilePath is empty or non-existent, then this method is identical to DownloadFileByName.  If the localFilePath is already fully downloaded, then no additional data is downloaded and the method will return true.
Returns true for success, false for failure.
ResumeDownloadFileByNameAsync (1)
# remoteFilePath is a string
# localFilePath is a string
ret_task = sFtp.ResumeDownloadFileByNameAsync(remoteFilePath, localFilePath);
Creates an asynchronous task to call the ResumeDownloadFileByName method with the arguments provided.
Returns nil on failure
ResumeUploadFileByName
# localFilePath is a string
status = sFtp.ResumeUploadFileByName(remoteFilePath, localFilePath);
Resumes a file upload to the SFTP/SSH server.  The size of the remoteFilePath is first checked to determine the starting offset for the upload.  If remoteFilePath is empty or does not exist, this method is equivalent to UploadFileByName.  If remoteFilePath is already fully uploaded (i.e. it's size is equal to localFilePath), then no additional bytes are uploaded and true is returned.
Returns true for success, false for failure.
ResumeUploadFileByNameAsync (1)
# remoteFilePath is a string
# localFilePath is a string
ret_task = sFtp.ResumeUploadFileByNameAsync(remoteFilePath, localFilePath);
Creates an asynchronous task to call the ResumeUploadFileByName method with the arguments provided.
Returns nil on failure
SendIgnore
Sends an IGNORE message to the SSH server. This is one way of verifying that the connection to the SSH server is open and valid. The SSH server does not respond to an IGNORE message. It simply ignores it. IGNORE messages are not associated with a channel (i.e., you do not need to first open a channel prior to sending an IGNORE message).
Returns true for success, false for failure.
topSendIgnoreAsync (1)
Creates an asynchronous task to call the SendIgnore method with the arguments provided.
Returns nil on failure
SetAllowedAlgorithms
Provides a way to specific the exact set of algorithms allowed for the connection.
Returns true for success, false for failure.
SetCreateDt
# isHandle is a boolean
# createDateTime is a CkDateTime
status = sFtp.SetCreateDt(pathOrHandle, isHandle, createDateTime);
Sets the create date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  isHandle should be set to true if the pathOrHandle is a handle, otherwise set isHandle to false.
Note: Servers running version 3 or lower of the SFTP protocol do not support setting the create date/time.
Returns true for success, false for failure.
topSetCreateDtAsync (1)
# pathOrHandle is a string
# isHandle is a boolean
# createDateTime is a CkDateTime
ret_task = sFtp.SetCreateDtAsync(pathOrHandle, isHandle, createDateTime);
Creates an asynchronous task to call the SetCreateDt method with the arguments provided.
Returns nil on failure
SetCreateTimeStr
# bIsHandle is a boolean
# dateTimeStr is a string
status = sFtp.SetCreateTimeStr(pathOrHandle, bIsHandle, dateTimeStr);
Sets the create date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  bIsHandle should be set to true if the pathOrHandle is a handle, otherwise set bIsHandle to false.
Note: Servers running version 3 or lower of the SFTP protocol do not support setting the create date/time. The date/time is passed as an RFC822 formatted string.
Returns true for success, false for failure.
topSetCreateTimeStrAsync (1)
# pathOrHandle is a string
# bIsHandle is a boolean
# dateTimeStr is a string
ret_task = sFtp.SetCreateTimeStrAsync(pathOrHandle, bIsHandle, dateTimeStr);
Creates an asynchronous task to call the SetCreateTimeStr method with the arguments provided.
Returns nil on failure
SetLastAccessDt
# isHandle is a boolean
# accessDateTime is a CkDateTime
status = sFtp.SetLastAccessDt(pathOrHandle, isHandle, accessDateTime);
Sets the last-access date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  isHandle should be set to true if the pathOrHandle is a handle, otherwise set isHandle to false.
Returns true for success, false for failure.
topSetLastAccessDtAsync (1)
# pathOrHandle is a string
# isHandle is a boolean
# accessDateTime is a CkDateTime
ret_task = sFtp.SetLastAccessDtAsync(pathOrHandle, isHandle, accessDateTime);
Creates an asynchronous task to call the SetLastAccessDt method with the arguments provided.
Returns nil on failure
SetLastAccessTimeStr
# bIsHandle is a boolean
# dateTimeStr is a string
status = sFtp.SetLastAccessTimeStr(pathOrHandle, bIsHandle, dateTimeStr);
Sets the last-access date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  bIsHandle should be set to true if the pathOrHandle is a handle, otherwise set bIsHandle to false. The date/time is passed as an RFC822 formatted string.
Returns true for success, false for failure.
topSetLastAccessTimeStrAsync (1)
# pathOrHandle is a string
# bIsHandle is a boolean
# dateTimeStr is a string
ret_task = sFtp.SetLastAccessTimeStrAsync(pathOrHandle, bIsHandle, dateTimeStr);
Creates an asynchronous task to call the SetLastAccessTimeStr method with the arguments provided.
Returns nil on failure
SetLastModifiedDt
# isHandle is a boolean
# modifiedDateTime is a CkDateTime
status = sFtp.SetLastModifiedDt(pathOrHandle, isHandle, modifiedDateTime);
Sets the last-modified date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  isHandle should be set to true if the pathOrHandle is a handle, otherwise set isHandle to false.
Returns true for success, false for failure.
topSetLastModifiedDtAsync (1)
# pathOrHandle is a string
# isHandle is a boolean
# modifiedDateTime is a CkDateTime
ret_task = sFtp.SetLastModifiedDtAsync(pathOrHandle, isHandle, modifiedDateTime);
Creates an asynchronous task to call the SetLastModifiedDt method with the arguments provided.
Returns nil on failure
SetLastModifiedTimeStr
# bIsHandle is a boolean
# dateTimeStr is a string
status = sFtp.SetLastModifiedTimeStr(pathOrHandle, bIsHandle, dateTimeStr);
Sets the last-modified date/time for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  bIsHandle should be set to true if the pathOrHandle is a handle, otherwise set bIsHandle to false. The date/time is passed as an RFC822 formatted string.
Returns true for success, false for failure.
topSetLastModifiedTimeStrAsync (1)
# pathOrHandle is a string
# bIsHandle is a boolean
# dateTimeStr is a string
ret_task = sFtp.SetLastModifiedTimeStrAsync(pathOrHandle, bIsHandle, dateTimeStr);
Creates an asynchronous task to call the SetLastModifiedTimeStr method with the arguments provided.
Returns nil on failure
SetOwnerAndGroup
# isHandle is a boolean
# owner is a string
# group is a string
status = sFtp.SetOwnerAndGroup(pathOrHandle, isHandle, owner, group);
Sets the owner and group for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  isHandle should be set to true if the pathOrHandle is a handle, otherwise set isHandle to false.
Note: Servers running version 3 or lower of the SFTP protocol do not support setting the owner and group.
Returns true for success, false for failure.
topSetOwnerAndGroupAsync (1)
# pathOrHandle is a string
# isHandle is a boolean
# owner is a string
# group is a string
ret_task = sFtp.SetOwnerAndGroupAsync(pathOrHandle, isHandle, owner, group);
Creates an asynchronous task to call the SetOwnerAndGroup method with the arguments provided.
Returns nil on failure
SetPermissions
# isHandle is a boolean
# permissions is an integer
status = sFtp.SetPermissions(pathOrHandle, isHandle, permissions);
Sets the permissions for a file on the server.  The pathOrHandle may be a filepath or the handle of a currently open file.  isHandle should be set to true if the pathOrHandle is a handle, otherwise set isHandle to false.
Returns true for success, false for failure.
SetPermissionsAsync (1)
# pathOrHandle is a string
# isHandle is a boolean
# permissions is an integer
ret_task = sFtp.SetPermissionsAsync(pathOrHandle, isHandle, permissions);
Creates an asynchronous task to call the SetPermissions method with the arguments provided.
Returns nil on failure
StartKeyboardAuth
# outStr is a CkString (output)
status = sFtp.StartKeyboardAuth(login, outStr);
retStr = sFtp.startKeyboardAuth(login);
Begins keyboard-interactive authentication with the SSH server. Returns an XML string providing the name, instruction, and prompts. The XML has the following format:
<infoRequest numPrompts="N"> <name>name_string</name> <instruction>instruction_string</instruction> <prompt1 echo="1_or_0">prompt_string</prompt1> ... <promptN echo="1_or_0">prompt_string</promptN> </infoRequest>
If the authentication immediately succeeds because no password is required, or immediately fails, the XML response can be:
<success>success_message</success> or <error>error_message</error>
Returns true for success, false for failure.
topStartKeyboardAuthAsync (1)
Creates an asynchronous task to call the StartKeyboardAuth method with the arguments provided.
Returns nil on failure
SymLink
# newPath is a string
status = sFtp.SymLink(oldPath, newPath);
Create a symbolic link from oldpath to newpath on the server filesystem.
Returns true for success, false for failure.
SymLinkAsync (1)
# oldPath is a string
# newPath is a string
ret_task = sFtp.SymLinkAsync(oldPath, newPath);
Creates an asynchronous task to call the SymLink method with the arguments provided.
Returns nil on failure
SyncTreeDownload
# localRoot is a string
# mode is an integer
# recurse is a boolean
status = sFtp.SyncTreeDownload(remoteRoot, localRoot, mode, recurse);
Downloads files from the SFTP server to a local directory tree. Synchronization modes include:
mode=0: Download all files
mode=1: Download all files that do not exist on the local filesystem.
mode=2: Download newer or non-existant files.
mode=3: Download only newer files. If a file does not already exist on the local filesystem, it is not downloaded from the server.
mode=5: Download only missing files or files with size differences.
mode=6: Same as mode 5, but also download newer files.
mode=99: Do not download files, but instead delete remote files that do not exist locally.
If recurse is false, then the remotel directory tree is not recursively descended.
Important: If the remoteRoot is an absolute path, then it is a path from the root of the server's filesystem.  For example, /home/joe/sourceDir.   Use a relative path to specify a directory relative to the $HOME directory of the SSH user account.  For example, ./sourceDir.
Note: After this method returns, the paths of the downloaded files are available in the SyncedFiles property.
Returns true for success, false for failure.
SyncTreeDownloadAsync (1)
# remoteRoot is a string
# localRoot is a string
# mode is an integer
# recurse is a boolean
ret_task = sFtp.SyncTreeDownloadAsync(remoteRoot, localRoot, mode, recurse);
Creates an asynchronous task to call the SyncTreeDownload method with the arguments provided.
Returns nil on failure
SyncTreeUpload
# remoteBaseDir is a string
# mode is an integer
# bRecurse is a boolean
status = sFtp.SyncTreeUpload(localBaseDir, remoteBaseDir, mode, bRecurse);
Uploads a directory tree from the local filesystem to the SFTP server. Synchronization modes include:
mode=0: Upload all filesIf bRecurse is
mode=1: Upload all files that do not exist on the server.
mode=2: Upload newer or non-existant files.
mode=3: Upload only newer files. If a file does not already exist on the server, it is not uploaded.
mode=4: transfer missing files or files with size differences.
mode=5: same as mode 4, but also newer files.
false, then the local directory tree is not recursively descended.
Important: If the remoteBaseDir is an absolute path, then it is a path from the root of the server's filesystem.  For example, /home/joe/targetDir.   Use a relative path to specify a directory relative to the $HOME directory of the SSH user account.  For example, ./targetDir.
Note: After this method returns, the paths of the downloaded files are available in the SyncedFiles property.
Returns true for success, false for failure.
SyncTreeUploadAsync (1)
# localBaseDir is a string
# remoteBaseDir is a string
# mode is an integer
# bRecurse is a boolean
ret_task = sFtp.SyncTreeUploadAsync(localBaseDir, remoteBaseDir, mode, bRecurse);
Creates an asynchronous task to call the SyncTreeUpload method with the arguments provided.
Returns nil on failure
UploadBd
# remoteFilePath is a string
status = sFtp.UploadBd(binData, remoteFilePath);
Uploads the contents of a BinData to a remote file.
Returns true for success, false for failure.
UploadBdAsync (1)
# binData is a CkBinData
# remoteFilePath is a string
ret_task = sFtp.UploadBdAsync(binData, remoteFilePath);
Creates an asynchronous task to call the UploadBd method with the arguments provided.
Returns nil on failure
UploadFile
# fromLocalFilePath is a string
status = sFtp.UploadFile(handle, fromLocalFilePath);
Uploads a file from the local filesystem to the SFTP server. handle is a handle of a currently open file (obtained by calling the OpenFile method). fromLocalFilePath is the local file path of the file to be uploaded.
Returns true for success, false for failure.
UploadFileAsync (1)
# handle is a string
# fromLocalFilePath is a string
ret_task = sFtp.UploadFileAsync(handle, fromLocalFilePath);
Creates an asynchronous task to call the UploadFile method with the arguments provided.
Returns nil on failure
UploadFileByName
# localFilePath is a string
status = sFtp.UploadFileByName(remoteFilePath, localFilePath);
Simplified method for uploading a file to the SFTP/SSH server.
The last-modified date/time is only preserved if the PreserveDate property is set to true.  This behavior of maintaining the last-mod date/time was introduced in v9.5.0.40.
Important: If the remoteFilePath is an absolute path, then it is a path from the root of the server's filesystem.  For example, /home/joe/someFile.txt.   Use a relative path to specify a directory relative to the $HOME directory of the SSH user account.  For example, ./someFile.txt.
Returns true for success, false for failure.
UploadFileByNameAsync (1)
# remoteFilePath is a string
# localFilePath is a string
ret_task = sFtp.UploadFileByNameAsync(remoteFilePath, localFilePath);
Creates an asynchronous task to call the UploadFileByName method with the arguments provided.
Returns nil on failure
UploadSb
# remoteFilePath is a string
# charset is a string
# includeBom is a boolean
status = sFtp.UploadSb(sb, remoteFilePath, charset, includeBom);
Uploads the contents of a StringBuilder to a remote file.
Returns true for success, false for failure.
UploadSbAsync (1)
# sb is a CkStringBuilder
# remoteFilePath is a string
# charset is a string
# includeBom is a boolean
ret_task = sFtp.UploadSbAsync(sb, remoteFilePath, charset, includeBom);
Creates an asynchronous task to call the UploadSb method with the arguments provided.
Returns nil on failure
WriteFileBd
Appends the contents of bd to an open file. The handle is a file handle returned by the OpenFile method.
Returns true for success, false for failure.
WriteFileBdAsync (1)
# handle is a string
# bd is a CkBinData
ret_task = sFtp.WriteFileBdAsync(handle, bd);
Creates an asynchronous task to call the WriteFileBd method with the arguments provided.
Returns nil on failure
WriteFileText
# charset is a string
# textData is a string
status = sFtp.WriteFileText(handle, charset, textData);
Appends character data to an open file.  The handle is a file handle returned by the OpenFile method.  charset is a character encoding and is typically set to values such as ansi, utf-8, windows-1252, etc. 
A list of supported character encodings is found on this page: Supported Charsets.
Note: It is necessary to specify the character encoding because in many programming languages, strings are represented as Unicode (2 bytes/char) and in most cases one does not wish to write Unicode chars to a text file (although it is possible by setting charset = Unicode).
Returns true for success, false for failure.
topWriteFileTextAsync (1)
# handle is a string
# charset is a string
# textData is a string
ret_task = sFtp.WriteFileTextAsync(handle, charset, textData);
Creates an asynchronous task to call the WriteFileText method with the arguments provided.
Returns nil on failure
WriteFileText32
# offset32 is an integer
# charset is a string
# textData is a string
status = sFtp.WriteFileText32(handle, offset32, charset, textData);
Writes character data to an open file at a specific offset from the beginning of the file.  The handle is a file handle returned by the OpenFile method.  charset is a character encoding and is typically set to values such as ansi, utf-8, windows-1252, etc. 
A list of supported character encodings is found on this page: Supported Charsets.
Returns true for success, false for failure.
topWriteFileText32Async (1)
# handle is a string
# offset32 is an integer
# charset is a string
# textData is a string
ret_task = sFtp.WriteFileText32Async(handle, offset32, charset, textData);
Creates an asynchronous task to call the WriteFileText32 method with the arguments provided.
Returns nil on failure
WriteFileText64
# offset64 is a 64-bit integer
# charset is a string
# textData is a string
status = sFtp.WriteFileText64(handle, offset64, charset, textData);
Writes character data to an open file at a specific offset from the beginning of the file.  The handle is a file handle returned by the OpenFile method.  charset is a character encoding and is typically set to values such as ansi, utf-8, windows-1252, etc. 
A list of supported character encodings is found on this page: Supported Charsets.
Returns true for success, false for failure.
topWriteFileText64Async (1)
# handle is a string
# offset64 is a 64-bit integer
# charset is a string
# textData is a string
ret_task = sFtp.WriteFileText64Async(handle, offset64, charset, textData);
Creates an asynchronous task to call the WriteFileText64 method with the arguments provided.
Returns nil on failure
WriteFileText64s
# offset64 is a string
# charset is a string
# textData is a string
status = sFtp.WriteFileText64s(handle, offset64, charset, textData);
Writes character data to an open file at a specific offset from the beginning of the file.  The handle is a file handle returned by the OpenFile method.  The offset64 is an offset (in decimal string format) from the beginning of the file.    charset is a character encoding and is typically set to values such as ansi, utf-8, windows-1252, etc. 
A list of supported character encodings is found on this page: Supported Charsets.
Returns true for success, false for failure.
topWriteFileText64sAsync (1)
# handle is a string
# offset64 is a string
# charset is a string
# textData is a string
ret_task = sFtp.WriteFileText64sAsync(handle, offset64, charset, textData);
Creates an asynchronous task to call the WriteFileText64s method with the arguments provided.
Returns nil on failure
Deprecated
GetFileCreateDt
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_ckDateTime = sFtp.GetFileCreateDt(pathOrHandle, bFollowLinks, bIsHandle);
Applications should instead use the GetFileCreateTimeStr method.
Returns the create date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Note: Servers running the SFTP v3 protocol or lower do not have the ability to return a file's creation date/time.
Returns nil on failure
GetFileCreateDtAsync (1) (2)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileCreateDtAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileCreateDt method with the arguments provided.
Returns nil on failure
GetFileLastAccessDt
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_ckDateTime = sFtp.GetFileLastAccessDt(pathOrHandle, bFollowLinks, bIsHandle);
Applications should instead use the GetFileLastAccessStr method.
Returns the last-access date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Returns nil on failure
GetFileLastAccessDtAsync (1) (2)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileLastAccessDtAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileLastAccessDt method with the arguments provided.
Returns nil on failure
GetFileLastModifiedDt
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_ckDateTime = sFtp.GetFileLastModifiedDt(pathOrHandle, bFollowLinks, bIsHandle);
Applications should instead use the GetFileLastModifiedStr method.
Returns the last-modified date/time for a file.  pathOrHandle may be a remote filepath or an open handle string as returned by OpenFile.  If pathOrHandle is a handle, then bIsHandle must be set to true, otherwise it should be false.  If bFollowLinks is true, then symbolic links will be followed on the server.
Returns nil on failure
GetFileLastModifiedDtAsync (1) (2)
# pathOrHandle is a string
# bFollowLinks is a boolean
# bIsHandle is a boolean
ret_task = sFtp.GetFileLastModifiedDtAsync(pathOrHandle, bFollowLinks, bIsHandle);
Creates an asynchronous task to call the GetFileLastModifiedDt method with the arguments provided.
Returns nil on failure
LastJsonData
This method is deprecated. Call GetLastJsonData instead.
Provides information about what transpired in the last method called. For many methods, there is no information. For some methods, details about what transpired can be obtained via LastJsonData.
Returns nil on failure
ReadDir
Applications should instead call ReadDirListing.
Reads the contents of a directory and returns the directory listing (as an object). The handle returned by OpenDir should be passed to this method.
Returns nil on failure
ReadDirAsync (1) (2)
Creates an asynchronous task to call the ReadDir method with the arguments provided.
Returns nil on failure
ReadFileBytes Deprecated
# numBytes is an integer
# outBytes is a CkByteData (output)
status = sFtp.ReadFileBytes(handle, numBytes, outData);
Reads file data from a remote file on the SSH server. The handle is a file handle returned by the OpenFile method. The numBytes is the maximum number of bytes to read. If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned.
To read an entire file, one may call ReadFileBytes repeatedly until Eof(handle) returns true.
Returns true for success, false for failure.
topReadFileBytesAsync Deprecated (1)
# handle is a string
# numBytes is an integer
ret_task = sFtp.ReadFileBytesAsync(handle, numBytes);
Creates an asynchronous task to call the ReadFileBytes method with the arguments provided.
Returns nil on failure
ReadFileBytes32 Deprecated
# offset is an integer
# numBytes is an integer
# outBytes is a CkByteData (output)
status = sFtp.ReadFileBytes32(handle, offset, numBytes, outData);
Reads file data from a remote file on the SSH server.  The handle is a file handle returned by the OpenFile method.  The offset is measured in bytes relative to the beginning of the file.  (64-bit offsets are supported via the ReadFileBytes64 and ReadFileBytes64s methods.)  The offset is ignored if the textMode flag was specified during the OpenFile.  The numBytes is the maximum number of bytes to read.  If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned.
Returns true for success, false for failure.
topReadFileBytes32Async Deprecated (1)
# handle is a string
# offset is an integer
# numBytes is an integer
ret_task = sFtp.ReadFileBytes32Async(handle, offset, numBytes);
Creates an asynchronous task to call the ReadFileBytes32 method with the arguments provided.
Returns nil on failure
ReadFileBytes64 Deprecated
# offset is a 64-bit integer
# numBytes is an integer
# outBytes is a CkByteData (output)
status = sFtp.ReadFileBytes64(handle, offset, numBytes, outData);
Reads file data from a remote file on the SSH server.  The handle is a file handle returned by the OpenFile method.  The offset is a 64-bit integer measured in bytes relative to the beginning of the file.  The offset is ignored if the textMode flag was specified during the OpenFile.  The numBytes is the maximum number of bytes to read.  If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned.
Returns true for success, false for failure.
topReadFileBytes64Async Deprecated (1)
# handle is a string
# offset is a 64-bit integer
# numBytes is an integer
ret_task = sFtp.ReadFileBytes64Async(handle, offset, numBytes);
Creates an asynchronous task to call the ReadFileBytes64 method with the arguments provided.
Returns nil on failure
ReadFileBytes64s Deprecated
# offset is a string
# numBytes is an integer
# outBytes is a CkByteData (output)
status = sFtp.ReadFileBytes64s(handle, offset, numBytes, outData);
(This method exists for systems that do not support 64-bit integers. The 64-bit integer offset is passed as a decimal string instead.)
Reads file data from a remote file on the SSH server.  The handle is a file handle returned by the OpenFile method.  The offset is a 64-bit integer represented as a decimal string.  It represents an offset in bytes from the beginning of the file.  The offset is ignored if the textMode flag was specified during the OpenFile.  The numBytes is the maximum number of bytes to read.  If the end-of-file is reached prior to reading the number of requested bytes, then fewer bytes may be returned.
Returns true for success, false for failure.
topReadFileBytes64sAsync Deprecated (1)
# handle is a string
# offset is a string
# numBytes is an integer
ret_task = sFtp.ReadFileBytes64sAsync(handle, offset, numBytes);
Creates an asynchronous task to call the ReadFileBytes64s method with the arguments provided.
Returns nil on failure
WriteFileBytes Deprecated
Appends byte data to an open file. The handle is a file handle returned by the OpenFile method.
Returns true for success, false for failure.
topWriteFileBytesAsync Deprecated (1)
# handle is a string
# byteData is a CkByteData
ret_task = sFtp.WriteFileBytesAsync(handle, byteData);
Creates an asynchronous task to call the WriteFileBytes method with the arguments provided.
Returns nil on failure
WriteFileBytes32 Deprecated
# offset is an integer
# data is a CkByteData
status = sFtp.WriteFileBytes32(handle, offset, data);
Writes data to an open file at a specific offset from the beginning of the file. The handle is a file handle returned by the OpenFile method. The offset is an offset from the beginning of the file.
Returns true for success, false for failure.
topWriteFileBytes32Async Deprecated (1)
# handle is a string
# offset is an integer
# data is a CkByteData
ret_task = sFtp.WriteFileBytes32Async(handle, offset, data);
Creates an asynchronous task to call the WriteFileBytes32 method with the arguments provided.
Returns nil on failure
WriteFileBytes64 Deprecated
# offset64 is a 64-bit integer
# data is a CkByteData
status = sFtp.WriteFileBytes64(handle, offset64, data);
Writes data to an open file at a specific offset from the beginning of the file. The handle is a file handle returned by the OpenFile method. The offset64 is an offset from the beginning of the file.
Returns true for success, false for failure.
topWriteFileBytes64Async Deprecated (1)
# handle is a string
# offset64 is a 64-bit integer
# data is a CkByteData
ret_task = sFtp.WriteFileBytes64Async(handle, offset64, data);
Creates an asynchronous task to call the WriteFileBytes64 method with the arguments provided.
Returns nil on failure
WriteFileBytes64s Deprecated
# offset64 is a string
# data is a CkByteData
status = sFtp.WriteFileBytes64s(handle, offset64, data);
Writes data to an open file at a specific offset from the beginning of the file. The handle is a file handle returned by the OpenFile method. The offset64 is an offset (in decimal string format) from the beginning of the file.
Returns true for success, false for failure.
topWriteFileBytes64sAsync Deprecated (1)
# handle is a string
# offset64 is a string
# data is a CkByteData
ret_task = sFtp.WriteFileBytes64sAsync(handle, offset64, data);
Creates an asynchronous task to call the WriteFileBytes64s method with the arguments provided.
Returns nil on failure