Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Swift 3,4,5...) SFTP Sync Download Tree w/ Must-Match Filename ConstraintsDemonstrates how synchronize a directory tree in the download direction, but only download files matching a set of wildcard filenames. Note: This example requires Chilkat v9.5.0.76 or greater.
func chilkatTest() { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. let sftp = CkoSFtp()! var success: Bool = sftp.connect("my-ssh-server.com", port: 22) if success == true { success = sftp.authenticatePw("mySshLogin", password: "mySshPassword") } if success == true { success = sftp.initializeSftp() } if success != true { print("\(sftp.lastErrorText!)") return } // Possible synchronization modes 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. // This example will download all files, but only those files having filenames // that match *.gif and *.eml // Imagine our remote directory tree has these files and directories: // accentedLatin1.txt // accentedUtf8.txt // alice.key // anter_cert.pem // chiliPepper.gif // helloWorld.pdf // abc/chiliPepper.gif // abc/ghk/ // data/chiliPepper.gif // data/xyz/dkimHtmlBody.txt // data/xyz/dkimVerifyTest.eml // data/xyz/emailForCreateDsn.eml // text/frenchUtf8.txt // text/helloWorld.txt // text/PolishEmailBody.txt // text/something/ // Indicate that we only want to create auto-create local directories (if needed) // for the files that are actually downloaded. If SyncCreateAllLocalDirs remains // true, then the corresponding local directory is created for each remote directory // traversed regardless of whether files within are downloaded. sftp.syncCreateAllLocalDirs = false sftp.syncMustMatch = "*.eml; *.gif" var remoteDir: String? = "syncDownloadTest/someDir" var localDir: String? = "qa_output" var mode: Int = 0 var recursive: Bool = true success = sftp.syncTreeDownload(remoteDir, localRoot: localDir, mode: mode, recurse: recursive) if success != true { print("\(sftp.lastErrorText!)") return } // The following files were downloaded: // chiliPepper.gif // abc/chiliPepper.gif // data/chiliPepper.gif // data/xyz/dkimVerifyTest.eml // data/xyz/emailForCreateDsn.eml print("Success.") } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.