Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) IMAP Use Existing SSH TunnelDemonstrates how to connect to an IMAP server using an existing SSH tunnel. This creates a new channel within the SSH tunnel, which can be a TCP or TLS connection, and is connected to a remote IMAP server through port forwarding.
LOCAL loChilkatGlob LOCAL lnSuccess LOCAL loTunnel LOCAL lnSuccess LOCAL lcSshHostname LOCAL lnSshPort LOCAL loImap LOCAL lnMsgCount LOCAL lnUpperBound LOCAL i LOCAL lnBUid LOCAL loEmail * Starting in v9.5.0.49, all Chilkat classes can be unlocked at once at the beginning of a program * by calling UnlockBundle. It requires a Bundle unlock code. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Global') loChilkatGlob = CreateObject('Chilkat.Global') lnSuccess = loChilkatGlob.UnlockBundle("Anything for 30-day trial.") IF (lnSuccess <> 1) THEN ? loChilkatGlob.LastErrorText RELEASE loChilkatGlob CANCEL ENDIF * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Socket') loTunnel = CreateObject('Chilkat.Socket') lcSshHostname = "sftp.example.com" lnSshPort = 22 * Connect to an SSH server and establish the SSH tunnel: lnSuccess = loTunnel.SshOpenTunnel(lcSshHostname,lnSshPort) IF (lnSuccess <> 1) THEN ? loTunnel.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel CANCEL ENDIF * Authenticate with the SSH server via a login/password * or with a public key. * This example demonstrates SSH password authentication. * Note: This is not authenticating with the IMAP server, it is * for authenticating with the SSH server, which is separate. lnSuccess = loTunnel.SshAuthenticatePw("mySshLogin","mySshPassword") IF (lnSuccess <> 1) THEN ? loTunnel.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel CANCEL ENDIF * OK, the SSH tunnel is setup. Now open a channel within the tunnel. * Once the channel is obtained, the Socket API may * be used exactly the same as usual, except all communications * are sent through the channel in the SSH tunnel. * Any number of channels may be created from the same SSH tunnel. * Multiple channels may coexist at the same time. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Imap') loImap = CreateObject('Chilkat.Imap') * Let the IMAP object also use the SSH tunnel lnSuccess = loImap.UseSshTunnel(loTunnel) IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * Connect to an IMAP server via the already established SSH tunnel. * Because the SSH tunnel has been previously setup, * this does not establish a direct connection with the IMAP * server. It directs the SSH server to establish the connection. * In this example, the IMAP server requires SSL/TLS. The TLS connection * will be enclosed within the SSH tunnel. loImap.Ssl = 1 loImap.Port = 993 lnSuccess = loImap.Connect("imap.my-imap-server.com") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * Authenticate with the IMAP server via the SSH tunnel. lnSuccess = loImap.Login("myLogin","myPassword") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * Select an IMAP mailbox lnSuccess = loImap.SelectMailbox("Inbox") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * How many messages in Inbox? lnMsgCount = loImap.NumMessages IF (lnMsgCount = 0) THEN ? "No messages found." RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF lnUpperBound = 10 IF (lnMsgCount < lnUpperBound) THEN lnUpperBound = lnMsgCount ENDIF * Download up to the 1st 10 messages. lnBUid = 0 FOR i = 1 TO lnUpperBound loEmail = loImap.FetchSingle(i,lnBUid) IF (loImap.LastMethodSuccess = 0) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ELSE ? loEmail.From ? loEmail.Subject ? "----" RELEASE loEmail ENDIF NEXT * Disconnect from the IMAP server. * The SSH tunnel remains open. lnSuccess = loImap.Disconnect() IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * It is possible to re-use the existing SSH tunnel for the next connection: lnSuccess = loImap.Connect("imap.my-imap-server2.com") IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * Review the LastErrorText to see that the connection was made via the SSH tunnel: ? loImap.LastErrorText * This closes the SSH channel, which is the connection with the IMAP server. * It does not close the SSH tunnel lnSuccess = loImap.Disconnect() IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * Finally, close the SSH tunnel. * Note: If other objects are using the same SSH tunnel, the tunnel is not * actually closed. It is only closed when the last object using the tunnel closes it. * At this point, both the imap and tunnel objects have references to the internal * SSH tunnel. We need to close each. * This call doesn't actually close the tunnel yet, because the tunnel object still * holds an internal reference. lnSuccess = loImap.SshCloseTunnel() IF (lnSuccess <> 1) THEN ? loImap.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF * This actually closes the SSH tunnel because it's the last object using it. lnSuccess = loTunnel.SshCloseTunnel() IF (lnSuccess <> 1) THEN ? loTunnel.LastErrorText RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap CANCEL ENDIF ? "IMAP pre-existing SSH tunnel example completed." RELEASE loChilkatGlob RELEASE loTunnel RELEASE loImap |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.