AutoIt
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
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()