Class wwSftpClient

This class provides SFTP (Secure FTP over SSH) support for connecting to SFTP servers.

foxpro
foxpro
DO wwSftpClient DO wwutils && for UI helpers only *** Using Rebex Tiny SFTP Server for local testing lcServer = "127.0.0.1" lnPort = 23 lcUsername = "tester" lcPassword = "password" CLEAR ? "*** wwSftpClient Test***" loFtp = CREATEOBJECT("wwsFtpClient") loFtp.cLogFile = "c:\temp\ftp.log" && verbose log - leave empty loFtp.lIgnoreCertificateErrors = .T. && self-signed cert not installed loFtp.cServer = lcServer loFtp.nPort = lnPort loFtp.cUsername = lcUsername loFtp.cPassword = lcPassword *** Optional Progress Events - clas below loFtp.oProgressEventObject = CREATEOBJECT("SFtpClientProgressEvents") IF !loFtp.Connect() ? loFtp.cErrorMsg RETURN ENDIF ? "Connected to " + lcServer IF !loFtp.DownloadFile("SubFolder/Sail-Big.jpg", "c:\temp\Sail-Big.jpg") ? loFtp.cErrorMsg RETURN ENDIF ? "Downloaded " + "SubFolder/Sail-Big.jpg" lcUploadFile = "SubFolder/Sail-Big-UPLOADED" + SYS(2015) + ".jpg" IF !loFtp.UploadFile("c:\temp\Sail-Big.jpg", lcUploadFile) ? loFtp.cErrorMsg RETURN ENDIF ? "Uploaded " + lcuploadFile *** provide a folder name (no wildcards) loCol = loFtp.ListFiles("/SubFolder") IF ISNULL(loCol) ? loFtp.cErrorMsg RETURN ENDIF ? TRANSFORM(loCol.Count ) + " matching file(s)" ? loFtp.cErrorMsg FOR EACH loFile IN loCol FOXOBJECT ? loFile.Name IF ( AT("Sail-Big-UPLOADED",loFile.Name) = 1) *? loFtp.oBridge.ToJson(loFile) && for kicks print out as json IF loFtp.DeleteFile(loFile.FullName) ? "*** Deleted " + loFile.FullName ENDIF ENDIF ENDFOR loFtp.Close() RETURN DEFINE class SFtpClientProgressEvents as Custom *** You can set this to .T. to abort an upload or download lCancelDownload = .F. FUNCTION OnFtpBufferUpdate(lnPercent, lnDownloadedBytes, lcRemotePath, lcMode) lcMsg = lcMode + ": " + TRANSFORM(lnPercent) + "% complete. " + lcRemotePath + " - " + TRANSFORM(lnDownloadedBytes) + " bytes" ? "*** " + lcMsg ENDFUNC ENDDEFINE

Remarks

Dependencies

This API uses a .NET library to provide FTP functionality.

  • wwIpstuff.dll
  • wwDotnetBridge.dll
  • Renci.sshNet.dll

Class Members

MemberDescription
ChangeDirectory Changes the active directory on the FTP server. This affects how relative paths are handled. > We recommend that you don't mess with this and instead use absolute server relative paths to specify…
o.ChangeDirectory(lcFtpPath)
Close Closes the FTP connections. Also called when the wwFtpClient instance is destroyed.
o.Close()
Connect This establishes the initial connection to the server. The connection needs to stay open for any of the FTP operation commands. > You should always check the return value from the connect request…
o.Connect(lcServer, lcUsername, lcPassword)
CreateDirectory Creates a new directory on the server.
o.CreateDirectory(lcFtpPath)
DeleteDirectory Deletes a directory from the FTP server.
o.DeleteDirectory(lcFtpPath)
DeleteFile Deletes a file from the server.
o.DeleteFile(lcFile)
DownloadFile Downloads a file from the FTP server to a local file.
o.DownloadFile(lcFtpPath, lcTargetFile)
ExecuteCommand FtpCommand Function: Issue an arbitrary FTP Command Assume: Connection must exist with FtpOpen Pass: Return:
o.ExecuteCommand(lcCommand)
ExecuteDownloadCommand ExecuteDownloadCommand Function: Issue an arbitrary FTP Command Assume: Connection must exist with FtpOpen Pass: Return:
o.ExecuteDownloadCommand(lcCommand)
Exists Checks to see if a remote file exists.
o.Exists(lcRemoteFile)
ListFiles Retrieves a directory listing from the server with all files returned as a collection. The file object returned includes the following properties: * **FullName** - full remote path * **Name** - the…
o.ListFiles(lcFtpPath)
RenameFile Renames a file on the server which allows for fast copying.
o.RenameFile(lcOldName, lcNewName)
UploadFile Uploads a file to the server from a local file.
o.UploadFile(lcLocalFile, lcFtpPath)
OnFtpBufferUpdate OnFtpBufferUpdate Function: Event that fires whenever the buffer is updated by downloadfile or uploadfile. Pass: Return: lcMode: upload download
cErrorMsg Error message set after a method call that fails
cftpserver The FTP server to connect to
cftpsource The Source file to upload from the client or download from the server.
cftptarget The file to download to from the server or upload to on the server.
cHttpProxyByPass
cHttpProxyName
cHttpProxyPassword
cHttpProxyPort
cHttpProxyUsername
cLogFile Optional log file that receives ftp log output
cPassword Password for the connection
cPrivateKeyFile Optional Private key file for sign on
cPrivateKeyFilePassword Optional Private key file password for sign on
cUsername Username for the connection
lcanceldownload Cancel flag that can be set in OnFTPBufferUpdate to let wwFTP know to stop downloading a file from the Internet.
lEnableProgressEvents
lIgnoreCertificateErrors Allows you to ignore certificate errors **NOT RECOMMENDED: Fix your Certs!**
lpassiveftp Flag that sets whether to use passive FTP.
lUseTls Tsl used for this request (FTPS protocol: FTP over TLS)
nftpworkbuffersize
nPort The port to run the FTP connection on
nTimeout Connection timeout in seconds
oBridge wwDotnetBridge instance
oFtpClient .NET wwFtpClient instance
oProgressEventObject

Assembly: wwsftpclient.prg



© West Wind Technologies, 2025 • Updated: 2025-03-12
Comment or report problem with topic