Sample code for 30+ languages & platforms
AutoIt

Using Client Certificate w/ IMAP SSL

Demonstrates how to use a client-side certificate with an IMAP SSL connection. The SetSslClientCert method is called to specify a certificate to be used for the SSL connection.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

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

$oImap = ObjCreate("Chilkat.Imap")

; To use a secure SSL connection, set SSL and the port:
$oImap.Ssl = True
; The typical port for IMAP SSL is 993
$oImap.Port = 993

; Load a certificate from a PFX file and use it.
; Note: Other methods are available to load pre-installed
; certificates from registry-based certificate stores.

; Create an instance of a certificate store object, load a PFX file,
; locate the certificate we need, and use it for signing.
; (a PFX file may contain more than one certificate.)
$oCertStore = ObjCreate("Chilkat.CertStore")
; The 1st argument is the filename, the 2nd arg is the 
; PFX file's password:
$bSuccess = $oCertStore.LoadPfxFile("myCertWithPrivateKey.pfx","secret")
If ($bSuccess = False) Then
    ConsoleWrite($oCertStore.LastErrorText & @CRLF)
    Exit
EndIf

; Find the certificate by the subject common name:
$oJsonCN = ObjCreate("Chilkat.JsonObject")
$oJsonCN.UpdateString("CN","cert common name")

$oCert = ObjCreate("Chilkat.Cert")
$bSuccess = $oCertStore.FindCert($oJsonCN,$oCert)
If ($bSuccess = False) Then
    ConsoleWrite($oCertStore.LastErrorText & @CRLF)
    Exit
EndIf

; If a PFX file is known to contain a single certificate,
; you may load it directly into a Chilkat certificate object.
; This snippet of source code shows how:
$oCert2 = ObjCreate("Chilkat.Cert")
; The 1st argument is the filename, the 2nd arg is the 
; PFX file's password:
$bSuccess = $oCert2.LoadPfxFile("myClientCert.pfx","secret")
If ($bSuccess = False) Then
    ConsoleWrite($oCert.LastErrorText & @CRLF)
    Exit
EndIf

; Use the cert:
$bSuccess = $oImap.SetSslClientCert($oCert)

; Connect to an IMAP server.
$bSuccess = $oImap.Connect("imap.example.com")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Login
$bSuccess = $oImap.Login("myLogin","myPassword")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Select an IMAP mailbox
$bSuccess = $oImap.SelectMailbox("Inbox")
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Get the message IDs of all the emails in the mailbox
Local $bFetchUids = True
$oMessageSet = ObjCreate("Chilkat.MessageSet")
$bSuccess = $oImap.QueryMbx("ALL",$bFetchUids,$oMessageSet)
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Fetch the emails into a bundle object:
$oBundle = ObjCreate("Chilkat.EmailBundle")
Local $bHeadersOnly = False
$bSuccess = $oImap.FetchMsgSet($bHeadersOnly,$oMessageSet,$oBundle)
If ($bSuccess = False) Then
    ConsoleWrite($oImap.LastErrorText & @CRLF)
    Exit
EndIf

; Loop over the bundle and display the FROM and SUBJECT of each.
$oEmail = ObjCreate("Chilkat.Email")
Local $i = 0
Local $iNumEmails = $oBundle.MessageCount
While $i < $iNumEmails
    $oBundle.EmailAt($i,$oEmail)

    ConsoleWrite($oEmail.From & @CRLF)
    ConsoleWrite($oEmail.Subject & @CRLF)
    ConsoleWrite("--" & @CRLF)
    $i = $i + 1
Wend

; Disconnect from the IMAP server.
$bSuccess = $oImap.Disconnect()