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
(PureBasic) IMAP using SOCKS5, SOCKS4 ProxyDemonstrates how to connect to an IMAP server through a SOCKS5 or SOCKS4 proxy.
IncludeFile "CkImap.pb" IncludeFile "CkEmailBundle.pb" IncludeFile "CkMessageSet.pb" IncludeFile "CkEmail.pb" Procedure ChilkatExample() ; This example assumes the Chilkat API to have been previously unlocked. ; See Global Unlock Sample for sample code. imap.i = CkImap::ckCreate() If imap.i = 0 Debug "Failed to create object." ProcedureReturn EndIf ; To use a SOCKS4 or SOCKS5 proxy, simply set the following ; properties prior to connecting with the IMAP server: ; The SOCKS hostname may be a domain name or ; IP address: CkImap::setCkSocksHostname(imap, "www.mysocksproxyserver.com") CkImap::setCkSocksPort(imap, 1080) CkImap::setCkSocksUsername(imap, "myProxyLogin") CkImap::setCkSocksPassword(imap, "myProxyPassword") ; Set the SOCKS version to 4 or 5 based on the version ; of the SOCKS proxy server: CkImap::setCkSocksVersion(imap, 5) ; Note: SOCKS4 servers only support usernames without passwords. ; SOCKS5 servers support full login/password authentication. ; Connect to an IMAP server through the SOCKS proxy. ; Use TLS CkImap::setCkSsl(imap, 1) CkImap::setCkPort(imap, 993) success.i = CkImap::ckConnect(imap,"imap.someMailServer.com") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Login success = CkImap::ckLogin(imap,"myLogin","myPassword") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Select an IMAP mailbox success = CkImap::ckSelectMailbox(imap,"Inbox") If success <> 1 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf messageSet.i ; We can choose to fetch UIDs or sequence numbers. fetchUids.i = 1 ; Get the message IDs of all the emails in the mailbox messageSet = CkImap::ckSearch(imap,"ALL",fetchUids) If CkImap::ckLastMethodSuccess(imap) = 0 Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Fetch the emails into a bundle object: bundle.i bundle = CkImap::ckFetchBundle(imap,messageSet) If CkImap::ckLastMethodSuccess(imap) = 0 CkMessageSet::ckDispose(messageSet) Debug CkImap::ckLastErrorText(imap) CkImap::ckDispose(imap) ProcedureReturn EndIf ; Loop over the bundle and display the FROM and SUBJECT of each. i.i = 0 numEmails.i = CkEmailBundle::ckMessageCount(bundle) While i < numEmails email.i = CkEmailBundle::ckGetEmail(bundle,i) Debug CkEmail::ckFrom(email) Debug CkEmail::ckSubject(email) Debug "--" CkEmail::ckDispose(email) i = i + 1 Wend ; Disconnect from the IMAP server. success = CkImap::ckDisconnect(imap) CkMessageSet::ckDispose(messageSet) CkEmailBundle::ckDispose(bundle) CkImap::ckDispose(imap) ProcedureReturn EndProcedure |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.