Sample code for 30+ languages & platforms
PowerBuilder

Upload to Tumbleweed SecureTransport FTPS Server

See more FTP Examples

Demonstrates how to connect, authenticate, and upload file to a Tumbleweed Secure Transport SSL FTP Server. Instead of providing a login name and password, you pass the string "site-auth" for the username, and an empty string for the password. You must also provide a client-side digital certificate -- as the certificate's credentials and validity are used to authenticate.

Chilkat PowerBuilder Downloads

PowerBuilder
integer li_rc
integer li_Success
oleobject loo_Ftp
oleobject loo_CertStore
string ls_Password
oleobject loo_JsonCN
oleobject loo_Cert
string ls_LocalFilename
string ls_RemoteFilename

li_Success = 0

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

loo_Ftp = create oleobject
li_rc = loo_Ftp.ConnectToNewObject("Chilkat.Ftp2")
if li_rc < 0 then
    destroy loo_Ftp
    MessageBox("Error","Connecting to COM object failed")
    return
end if

// This code has been tested with the Tumbleweed server
// at sft.wellsfargo.com
loo_Ftp.Hostname = "sft.wellsfargo.com"

// Use these exact strings for the username and password:
loo_Ftp.Username = "site-auth"
loo_Ftp.Password = ""

// Establish an AUTH SSL secure channel after connecting.
// Your client-side certificate is used for authentication when
// the SSL channel is established.
loo_Ftp.AuthSsl = 1

// The Ssl property is for establishing an implicit SSL connection
// on port 990.  Do not set it.
loo_Ftp.Ssl = 0

// Load a certificate from a .pfx
// A PFX may contain several certs, including the certificates
// in a chain of authority.
loo_CertStore = create oleobject
li_rc = loo_CertStore.ConnectToNewObject("Chilkat.CertStore")

ls_Password = "***"
// Load the certs from a PFX into an in-memory certificate store:
li_Success = loo_CertStore.LoadPfxFile("my.pfx",ls_Password)
if li_Success <> 1 then
    Write-Debug loo_CertStore.LastErrorText
    destroy loo_Ftp
    destroy loo_CertStore
    return
end if

// Find the desired certificate.
loo_JsonCN = create oleobject
li_rc = loo_JsonCN.ConnectToNewObject("Chilkat.JsonObject")

loo_JsonCN.UpdateString("CN","cert common name")

loo_Cert = create oleobject
li_rc = loo_Cert.ConnectToNewObject("Chilkat.Cert")

li_Success = loo_CertStore.FindCert(loo_JsonCN,loo_Cert)
if li_Success = 0 then
    Write-Debug "Certificate not found!"
    destroy loo_Ftp
    destroy loo_CertStore
    destroy loo_JsonCN
    destroy loo_Cert
    return
end if

// Tell the Chilkat FTP2 component to use the client-side
// cert for the SSL connection:
li_Success = loo_Ftp.SetSslClientCert(loo_Cert)

// Connect and authenticate with the FTP server.
li_Success = loo_Ftp.Connect()
if li_Success <> 1 then
    Write-Debug loo_Ftp.LastErrorText
    destroy loo_Ftp
    destroy loo_CertStore
    destroy loo_JsonCN
    destroy loo_Cert
    return
else
    // LastErrorText contains information even when
    // successful. This allows you to visually verify
    // that the secure connection actually occurred.
    Write-Debug loo_Ftp.LastErrorText
end if

Write-Debug "Secure FTP Channel Established!"

// Change to the remote directory where the file will be
// uploaded.  If your file is to be uploaded to the FTP user 
// account's home directory, this is not necessary.
li_Success = loo_Ftp.ChangeRemoteDir("someSubDir")
if li_Success <> 1 then
    Write-Debug loo_Ftp.LastErrorText
    destroy loo_Ftp
    destroy loo_CertStore
    destroy loo_JsonCN
    destroy loo_Cert
    return
end if

// You may include an absolute or relative path with the 
// local filename.  If no path is included, the file should 
// be present in the current working directory of the calling
// process.
ls_LocalFilename = "someFile.dat"
ls_RemoteFilename = "someFile.dat"

// Upload the file.
li_Success = loo_Ftp.PutFile(ls_LocalFilename,ls_RemoteFilename)
if li_Success <> 1 then
    Write-Debug loo_Ftp.LastErrorText
    destroy loo_Ftp
    destroy loo_CertStore
    destroy loo_JsonCN
    destroy loo_Cert
    return
end if

li_Success = loo_Ftp.Disconnect()


destroy loo_Ftp
destroy loo_CertStore
destroy loo_JsonCN
destroy loo_Cert