Unicode C++
Unicode C++
Send Signed and Encrypted EDI Email (EDIFACT)
Demonstrates how to send a signed and encrypted EDI email (EDIFACT email).Chilkat Unicode C++ Downloads
#include <CkMailManW.h>
#include <CkEmailW.h>
#include <CkCertW.h>
void ChilkatSample(void)
{
bool success = false;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// The mailman object is used for sending and receiving email.
CkMailManW mailman;
// Create a new email object
CkEmailW *email = 0;
// Build the basic EDI email where the body is the EDIFACT message:
const wchar_t *ediMsg = L"UNB+IATB:1+6XPPC ...";
const wchar_t *name = L"something";
const wchar_t *filename = L"something";
const wchar_t *charset = L"iso-8859-1";
email->SetEdifactBody(ediMsg,name,filename,charset);
email->put_Subject(L"This is the subject");
email->put_From(L"Chilkat Admin <admin@chilkatsoft.com>");
success = email->AddTo(L"Chilkat Support",L"support@chilkatsoft.com");
// Indicate that the email should be sent signed.
email->put_SendSigned(true);
// Tell the mailman to use a PFX file as a source for locating
// the certificate and private key required for signing.
// The certificate chosen for signing will be the one that
// matches the sender's email address, which also has
// a private key. All intermediate certs in the chain of
// authentication, up to and including the root, will
// be included in the signature.
success = mailman.AddPfxSourceFile(L"/pfx_files/myCertAndPrivateKey.pfx",L"secret");
if (success != true) {
wprintf(L"%s\n",mailman.lastErrorText());
return;
}
// Load the .cer file into a certificate object.
// When sending S/MIME encrypted email, it is the recipient's
// certificate that is used for encryption. Only the public key
// is needed to encrypt. The recipient is the only
// one possessing the private key, and therefore is the only
// one able to decrypt.
CkCertW *cert = 0;
success = cert->LoadFromFile(L"/certs/recipientCert.cer");
if (success != true) {
wprintf(L"%s\n",cert->lastErrorText());
return;
}
// Indicate that the email is to be sent encrypted.
email->put_SendEncrypted(true);
// Indicate that we want 192-bit 3DES encryption:
email->put_Pkcs7CryptAlg(L"3des");
email->put_Pkcs7KeyLength(192);
// Specify the certificate to be used for encryption.
success = email->SetEncryptCert(*cert);
// Tell the mailman to use an opaque signature (as opposed to a detached signature)
mailman.put_OpaqueSigning(true);
// SMTP server (use your settings and refer to the online
// reference documentation for more options)
mailman.put_SmtpHost(L"smtp.mymailserver.com");
mailman.put_SmtpUsername(L"myLogin");
mailman.put_SmtpPassword(L"myPassword");
mailman.put_SmtpPort(587);
mailman.put_StartTLS(true);
// Send the signed/encrypted EDI email
success = mailman.SendEmail(*email);
if (success != true) {
wprintf(L"%s\n",mailman.lastErrorText());
}
else {
wprintf(L"Mail Sent!\n");
}
}