Unicode C
Unicode C
Send GMail with BCC Recipients using REST API
See more GMail REST API Examples
Demonstrates how to send an email with BCC recipients using the GMail REST API.Chilkat Unicode C Downloads
#include <C_CkEmailW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
BOOL success;
HCkEmailW email;
const wchar_t *cid;
HCkStringBuilderW sbHtml;
int numReplacements;
HCkStringBuilderW sbMime;
HCkJsonObjectW json;
HCkHttpW http;
const wchar_t *url;
HCkHttpResponseW resp;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// Use the Chilkat Email API to create or load an email.
email = CkEmailW_Create();
// The From name/address don't need to be specified.
// GMail will automatically use your Gmail address if the following 2 lines are omitted.
CkEmailW_putFromName(email,L"My Name");
CkEmailW_putFromAddress(email,L"my_account_name@gmail.com");
CkEmailW_AddTo(email,L"John Smith",L"somebody@somewhere.com");
// To add more recipients, make additional calls to AddTo or AddCC, one per recipient...
// -----------------------------------------------------------------------------------------
// This section of this example demonstrates how to add BCC recipients.
//
// Technically, an email should never contain a "Bcc" MIME header because it would
// effectively nullify the purpose of BCC -- which means "Blind Carbon Copy".
// Email recipients should not be able to see the BCC recipients.
// Chilkat never adds a "Bcc" header field.
// However.. in this case, the GMail REST server will look for the Bcc header field,
// and will include those email addresses when sending, and also removes the Bcc header
// from the email that is sent.
//
// Starting in Chilkat v9.5.0.91, we can tell the email object to add the Bcc header
// using the "UseBccHeader" UncommonOptions. For example:
CkEmailW_putUncommonOptions(email,L"UseBccHeader");
CkEmailW_AddBcc(email,L"Joe",L"joe@example.com");
CkEmailW_AddBcc(email,L"Dave",L"dave@example.com");
// ...
// -----------------------------------------------------------------------------------------
CkEmailW_putSubject(email,L"This is a test GMail email created using Chilkat.");
CkEmailW_putCharset(email,L"utf-8");
CkEmailW_AddPlainTextAlternativeBody(email,L"This is a test");
// Create an HTML email body with an embedded image.
cid = CkEmailW_addRelatedFile(email,L"qa_data/jpg/starfish.jpg");
sbHtml = CkStringBuilderW_Create();
CkStringBuilderW_Append(sbHtml,L"<html><body>This is a <b>test</b><br><img src=\"cid:STARFISH_CID\"/></body></html>");
numReplacements = CkStringBuilderW_Replace(sbHtml,L"STARFISH_CID",cid);
CkEmailW_AddHtmlAlternativeBody(email,CkStringBuilderW_getAsString(sbHtml));
// OK.. we now have an HTML email with an embedded JPG image
// We'll need to get the full MIME of the email encoded to a base64url string.
sbMime = CkStringBuilderW_Create();
CkEmailW_GetMimeSb(email,sbMime);
CkStringBuilderW_Encode(sbMime,L"base64url",L"utf-8");
// The body of the HTTP request will be JSON..
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateSb(json,L"raw",sbMime);
// Send the email...
http = CkHttpW_Create();
CkHttpW_putAuthToken(http,L"GMAIL-ACCESS-TOKEN");
url = L"https://www.googleapis.com/gmail/v1/users/me/messages/send";
resp = CkHttpResponseW_Create();
success = CkHttpW_HttpJson(http,L"POST",url,json,L"application/json",resp);
if (success == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkEmailW_Dispose(email);
CkStringBuilderW_Dispose(sbHtml);
CkStringBuilderW_Dispose(sbMime);
CkJsonObjectW_Dispose(json);
CkHttpW_Dispose(http);
CkHttpResponseW_Dispose(resp);
return;
}
// A status code of 200 indicates success.
wprintf(L"Response status code: %d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"Response body:\n");
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
// The response body contains JSON.
// Use the online tool at Generate JSON Parsing Code
// to generate JSON parsing code.
// A sample successful JSON response:
// {
// "id": "166f0d4ac39e50bf",
// "threadId": "166f0d4ac39e50bf",
// "labelIds": [
// "SENT"
// ]
// }
CkEmailW_Dispose(email);
CkStringBuilderW_Dispose(sbHtml);
CkStringBuilderW_Dispose(sbMime);
CkJsonObjectW_Dispose(json);
CkHttpW_Dispose(http);
CkHttpResponseW_Dispose(resp);
}