Sample code for 30+ languages & platforms
Tcl

DKIM Signature using Windows Current User Certificate Store

See more DKIM / DomainKey Examples

This is a Windows-specific example to load a certificate from the Current User (registry-based) certificate store, and then use the certificate's associated private key for a DKIM signature.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

set cert [new_CkCert]

# The LoadByCommonName method searches the Windows Local Machine and Current User 
# registry-based certificate stores for a certificate having the common name specified. 
# If found, the certificate is loaded and ready for use.
set success [CkCert_LoadByCommonName $cert "My Certificate ABC"]
if {$success == 0} then {
    puts [CkCert_lastErrorText $cert]
    delete_CkCert $cert
    exit
}

# The certificate must have an associated private key installed, and it must be a
# private key that has been marked "exportable" when it was originally installed.
if {![CkCert_HasPrivateKey $cert]} then {
    puts "This certificate does not have a private key available."
    delete_CkCert $cert
    exit
}

set privKey [new_CkPrivateKey]

set success [CkCert_GetPrivateKey $cert $privKey]
if {$success == 0} then {
    puts [CkCert_lastErrorText $cert]
    delete_CkCert $cert
    delete_CkPrivateKey $privKey
    exit
}

set dkim [new_CkDkim]

# Load the private key into the DKIM object:
set success [CkDkim_SetDkimPrivateKey $dkim $privKey]
if {$success == 0} then {
    puts [CkDkim_lastErrorText $dkim]
    delete_CkCert $cert
    delete_CkPrivateKey $privKey
    delete_CkDkim $dkim
    exit
}

# The private key has been loaded into the DKIM object.  See the other DKIM
# examples for guidance on how to create a DKIM signature...

delete_CkCert $cert
delete_CkPrivateKey $privKey
delete_CkDkim $dkim