Unicode C
Unicode C
Send Email with a vCard
Demonstrates how to create a simple email, attach a vcard, and send it.Chilkat Unicode C Downloads
#include <C_CkMailManW.h>
#include <C_CkEmailW.h>
void ChilkatSample(void)
{
BOOL success;
HCkMailManW mailman;
HCkEmailW email;
const wchar_t *vcard;
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.
mailman = CkMailManW_Create();
// Set the SMTP server.
CkMailManW_putSmtpHost(mailman,L"smtp.chilkatsoft.com");
// Set the SMTP login/password (if required)
CkMailManW_putSmtpUsername(mailman,L"myUsername");
CkMailManW_putSmtpPassword(mailman,L"myPassword");
// Create a new email object
email = CkEmailW_Create();
CkEmailW_putSubject(email,L"This is a vcard test");
CkEmailW_putBody(email,L"This is a vcard test");
CkEmailW_putFrom(email,L"Chilkat Admin <admin@chilkatsoft.com>");
success = CkEmailW_AddTo(email,L"Chilkat Support",L"support@chilkatsoft.com");
// To add more recipients, call AddTo, AddCC, or AddBcc once per recipient.
// A vCard is an email attachment having a Content-Type = "text/x-vcard".
// Call AddStringAttachment to add a vcard from an in-memory string.
// The filename should have a ".vcf" file extension. Chilkat will automatically
// recognize it and set the content-type to "text/x-vcard";
// Your application is responsible for providing the vcard formatted string. For example:
// See http://en.wikipedia.org/wiki/VCard
//
// begin:vcard
// fn:Matt Smith
// n:Smith;Matt
// org:Chilkat Software, Inc.
// tel;work:630-784-9670
// url:http://www.chilkatsoft.com
// version:2.1
// end:vcard
vcard = L"begin:vcard ...";
success = CkEmailW_AddStringAttachment(email,L"admin.vcf",vcard);
if (success != TRUE) {
wprintf(L"%s\n",CkEmailW_lastErrorText(email));
CkMailManW_Dispose(mailman);
CkEmailW_Dispose(email);
return;
}
// Call SendEmail to connect to the SMTP server and send.
// The connection (i.e. session) to the SMTP server remains
// open so that subsequent SendEmail calls may use the
// same connection.
success = CkMailManW_SendEmail(mailman,email);
if (success != TRUE) {
wprintf(L"%s\n",CkMailManW_lastErrorText(mailman));
CkMailManW_Dispose(mailman);
CkEmailW_Dispose(email);
return;
}
// Some SMTP servers do not actually send the email until
// the connection is closed. In these cases, it is necessary to
// call CloseSmtpConnection for the mail to be sent.
// Most SMTP servers send the email immediately, and it is
// not required to close the connection. We'll close it here
// for the example:
success = CkMailManW_CloseSmtpConnection(mailman);
if (success != TRUE) {
wprintf(L"Connection to SMTP server not closed cleanly.\n");
}
wprintf(L"Mail with vCard Sent!\n");
CkMailManW_Dispose(mailman);
CkEmailW_Dispose(email);
}