Sample code for 30+ languages & platforms
PowerShell

IMAP Download and Verify Signed (S/MIME) Email

See more IMAP Examples

Demonstrates how to download and verify digitally signed S/MIME email.

Chilkat PowerShell Downloads

PowerShell
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"

$success = $false

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

$imap = New-Object Chilkat.Imap

# Connect to an IMAP server.
# Use TLS
$imap.Ssl = $true
$imap.Port = 993
$success = $imap.Connect("imap.example.com")
if ($success -eq $false) {
    $($imap.LastErrorText)
    exit
}

$success = $imap.Login("myLogin","myPassword")
if ($success -eq $false) {
    $($imap.LastErrorText)
    exit
}

# Select an IMAP mailbox
$success = $imap.SelectMailbox("Inbox")
if ($success -eq $false) {
    $($imap.LastErrorText)
    exit
}

# We can choose to fetch UIDs or sequence numbers.
$fetchUids = $true

# Get the message IDs of all the emails in the mailbox
$messageSet = New-Object Chilkat.MessageSet
$success = $imap.QueryMbx("ALL",$fetchUids,$messageSet)
if ($success -eq $false) {
    $($imap.LastErrorText)
    exit
}

$email = New-Object Chilkat.Email
$cert = New-Object Chilkat.Cert

$i = 0
while ($i -lt $messageSet.Count) {

    $uid = $messageSet.GetId($i)
    $("uid: " + $uid)

    $success = $imap.FetchEmail($false,$uid,$true,$email)
    if ($success -eq $false) {
        $($imap.LastErrorText)
        exit
    }

    # The security layers of signed and/or encrypted emails
    # are automatically "unwrapped" when loaded into
    # a Chilkat email object.
    # An application only needs to check to see if an email
    # was received signed or encrypted, and then examine
    # the success/failure.  For example:
    if ($email.ReceivedSigned -eq $true) {

        $("This email was signed.")

        # Check to see if the signatures were verified.
        if ($email.SignaturesValid -eq $true) {
            $("Digital signature(s) verified.")
            $("Signer: " + $email.SignedBy)

            # Get the certificate used for signing.
            $success = $email.LastSignerCert(0,$cert)

            if ($success -eq $false) {
                $("Failed to get signing certificate object.")
            }
            else {
                $("Signing cert: " + $cert.SubjectCN)
            }

        }
        else {
            $("Digital signature verification failed.")
        }

    }

    $i = $i + 1
}

# Disconnect from the IMAP server.
$success = $imap.Disconnect()