Sample code for 30+ languages & platforms
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

Unicode C++
#include <CkEmailW.h>
#include <CkStringBuilderW.h>
#include <CkJsonObjectW.h>
#include <CkHttpW.h>
#include <CkHttpResponseW.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.

    // Use the Chilkat Email API to create or load an email.
    CkEmailW email;

    // The From name/address don't need to be specified. 
    // GMail will automatically use your Gmail address if the following 2 lines are omitted.
    email.put_FromName(L"My Name");
    email.put_FromAddress(L"my_account_name@gmail.com");

    email.AddTo(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:
    email.put_UncommonOptions(L"UseBccHeader");
    email.AddBcc(L"Joe",L"joe@example.com");
    email.AddBcc(L"Dave",L"dave@example.com");
    // ...
    // -----------------------------------------------------------------------------------------

    email.put_Subject(L"This is a test GMail email created using Chilkat.");
    email.put_Charset(L"utf-8");
    email.AddPlainTextAlternativeBody(L"This is a test");

    // Create an HTML email body with an embedded image.
    const wchar_t *cid = email.addRelatedFile(L"qa_data/jpg/starfish.jpg");
    CkStringBuilderW sbHtml;
    sbHtml.Append(L"<html><body>This is a <b>test</b><br><img src=\"cid:STARFISH_CID\"/></body></html>");
    int numReplacements = sbHtml.Replace(L"STARFISH_CID",cid);

    email.AddHtmlAlternativeBody(sbHtml.getAsString());

    // 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.
    CkStringBuilderW sbMime;
    email.GetMimeSb(sbMime);
    sbMime.Encode(L"base64url",L"utf-8");

    // The body of the HTTP request will be JSON..
    CkJsonObjectW json;
    json.UpdateSb(L"raw",sbMime);

    // Send the email...
    CkHttpW http;
    http.put_AuthToken(L"GMAIL-ACCESS-TOKEN");

    const wchar_t *url = L"https://www.googleapis.com/gmail/v1/users/me/messages/send";
    CkHttpResponseW resp;
    success = http.HttpJson(L"POST",url,json,L"application/json",resp);
    if (success == false) {
        wprintf(L"%s\n",http.lastErrorText());
        return;
    }

    // A status code of 200 indicates success.
    wprintf(L"Response status code: %d\n",resp.get_StatusCode());
    wprintf(L"Response body:\n");
    wprintf(L"%s\n",resp.bodyStr());

    // 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"
    //  ]
    // }
    }