PureBasic
PureBasic
SFTP Synchronize Directory Tree - Download
See more SFTP Examples
Demonstrates how to download files to synchronize a local directory tree with a remote directory tree. The SyncTreeDownload method recursively descends the remote directory tree and downloads files based on existence, last-mod date/time and/or size differences.Chilkat PureBasic Downloads
IncludeFile "CkSFtp.pb"
Procedure ChilkatExample()
success.i = 0
; This example requires the Chilkat API to have been previously unlocked.
; See Global Unlock Sample for sample code.
sftp.i = CkSFtp::ckCreate()
If sftp.i = 0
Debug "Failed to create object."
ProcedureReturn
EndIf
success = CkSFtp::ckConnect(sftp,"my-ssh-server.com",22)
If success = 1
success = CkSFtp::ckAuthenticatePw(sftp,"mySshLogin","mySshPassword")
EndIf
If success = 1
success = CkSFtp::ckInitializeSftp(sftp)
EndIf
If success <> 1
Debug CkSFtp::ckLastErrorText(sftp)
CkSFtp::ckDispose(sftp)
ProcedureReturn
EndIf
; Synchronize the remote directory tree rooted at "syncDownloadTest/xml"
; with the local directory tree rooted at "qa_output"
; Both directories are relative paths. The remote directory
; is relative to the HOME directory of the SSH user account.
; The local directory is relative to the current working directory of the process.
; It is also possible to use absolute paths.
remoteDir.s = "syncDownloadTest/xml"
localDir.s = "qa_output"
; Possible modes that can be passed to the SyncTreeDownload method are:
; 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.
; This example will use mode 6 to download missing, newer, or files with size differences.
mode.i = 6
; This example will turn on recursion to synchronize the entire tree.
; Recursion can be turned off to synchronize the files of a single directory.
recursive.i = 1
success = CkSFtp::ckSyncTreeDownload(sftp,remoteDir,localDir,mode,recursive)
If success <> 1
Debug CkSFtp::ckLastErrorText(sftp)
CkSFtp::ckDispose(sftp)
ProcedureReturn
EndIf
Debug "Success."
CkSFtp::ckDispose(sftp)
ProcedureReturn
EndProcedure