C
C
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 C Downloads
#include <C_CkCert.h>
#include <C_CkPrivateKey.h>
#include <C_CkDkim.h>
void ChilkatSample(void)
{
BOOL success;
HCkCert cert;
HCkPrivateKey privKey;
HCkDkim dkim;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
cert = CkCert_Create();
// 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.
success = CkCert_LoadByCommonName(cert,"My Certificate ABC");
if (success == FALSE) {
printf("%s\n",CkCert_lastErrorText(cert));
CkCert_Dispose(cert);
return;
}
// 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)) {
printf("This certificate does not have a private key available.\n");
CkCert_Dispose(cert);
return;
}
privKey = CkPrivateKey_Create();
success = CkCert_GetPrivateKey(cert,privKey);
if (success == FALSE) {
printf("%s\n",CkCert_lastErrorText(cert));
CkCert_Dispose(cert);
CkPrivateKey_Dispose(privKey);
return;
}
dkim = CkDkim_Create();
// Load the private key into the DKIM object:
success = CkDkim_SetDkimPrivateKey(dkim,privKey);
if (success == FALSE) {
printf("%s\n",CkDkim_lastErrorText(dkim));
CkCert_Dispose(cert);
CkPrivateKey_Dispose(privKey);
CkDkim_Dispose(dkim);
return;
}
// The private key has been loaded into the DKIM object. See the other DKIM
// examples for guidance on how to create a DKIM signature...
CkCert_Dispose(cert);
CkPrivateKey_Dispose(privKey);
CkDkim_Dispose(dkim);
}