Sample code for 30+ languages & platforms
Unicode C

Decrypt S/MIME and Verify S/MIME Signatures

See more MIME Examples

_LANGUAGE_ example to decrypt S/MIME and verify S/MIME signatures. The S/MIME is unwrapped to get the original MIME prior to signing/encrypting.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkMimeW.h>
#include <C_CkCertW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkMimeW mime;
    BOOL isEncrypted;
    BOOL isSigned;
    HCkCertW signerCert;
    HCkCertW decryptCert;

    success = FALSE;

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

    mime = CkMimeW_Create();

    // Load an S/MIME message from a file:
    success = CkMimeW_LoadMimeFile(mime,L"signedMime.txt");
    if (success == FALSE) {
        wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
        CkMimeW_Dispose(mime);
        return;
    }

    // The ContainsEncryptedParts/ContainsSignedParts methods
    // can be called to determine if the MIME is encrypted and/or signed:
    isEncrypted = CkMimeW_ContainsEncryptedParts(mime);
    isSigned = CkMimeW_ContainsSignedParts(mime);

    // We don't want the "unwrap extras".  You'll see what those
    // are in a few moments...
    CkMimeW_putUnwrapExtras(mime,FALSE);

    // To verify the signature, call UnwrapSecurity.  This will
    // verify the signature(s) and decrypt the S/MIME and restore
    // the MIME to the unsigned/unencrypted state.
    // The results of what was found are present in the MIME object's
    // properties, as well as extra header fields that are added
    // to the unwrapped MIME.
    success = CkMimeW_UnwrapSecurity(mime);
    if (success != TRUE) {
        // UnwrapSecurity returns TRUE if all signatures were
        // verified and all parts decrypted.
        wprintf(L"%s\n",CkMimeW_lastErrorText(mime));
        CkMimeW_Dispose(mime);
        return;
    }

    // The mime.UnwrapExtras property controls whether or not
    // these additional fields are added to the unwrapped MIME:
    // 
    // X-NumPartsSigned: 1
    // X-SignaturesValid: yes
    // X-NumPartsEncrypted: 1
    // X-Decrypted: no
    // 
    // The X-NumPartsSigned/X-SignaturesValid headers are added
    // if the MIME was signed.  
    // 
    // The X-NumPartsEncrypted/X-Decrypted headers are added
    // if the MIME was encrypted.
    // 

    // If the MIME was signed, get the certificate used for signing.
    if (isSigned == TRUE) {
        signerCert = CkCertW_Create();

        // The NumSignerCerts property indicates how many certificates
        // were used for signing.  This example will assume the value is 1.
        // To get the 1st signer cert, call LastSignerCert with an index of 0:
        success = CkMimeW_LastSignerCert(mime,0,signerCert);
        if (success == TRUE) {
            wprintf(L"**** Signer Cert: %s\n",CkCertW_subjectCN(signerCert));
        }

    }

    // If the MIME was encrypted, get the certificate used for decryption
    if (isEncrypted == TRUE) {
        // The NumDecryptCerts property indicates how many certificates
        // were used for decrypting.  This example will assume the value is 1.
        // To get the 1st decrypt cert, call LastDecryptCert with an index of 0:
        decryptCert = CkCertW_Create();
        success = CkMimeW_LastDecryptCert(mime,0,decryptCert);
        if (success == TRUE) {
            wprintf(L"**** Decrypt Cert: %s\n",CkCertW_subjectCN(decryptCert));
        }

    }

    // Display the unwrapped MIME:
    wprintf(L"%s\n",CkMimeW_getMime(mime));

    // Save the unwrapped MIME to a file:
    success = CkMimeW_SaveMime(mime,L"unwrappedMime.txt");


    CkMimeW_Dispose(mime);
    CkCertW_Dispose(signerCert);
    CkCertW_Dispose(decryptCert);

    }