Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(MFC) Constant Contact - Add Contacts to ListDemonstrates a call to add five existing contacts to two lists. For more information, see https://v3.developer.constantcontact.com/api_guide/lists_overview.html#example-request----post-add_list_membership
#include <CkHttp.h> #include <CkJsonObject.h> #include <CkHttpResponse.h> #include <CkStringBuilder.h> void ChilkatSample(void) { CkString strOut; // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http; bool success; // Implements the following CURL command: // curl -X POST \ // https://api.cc.email/v3/activities/add_list_memberships \ // -H 'Accept: application/json' \ // -H 'Authorization: Bearer {access_token}' \ // -H 'cache-control: no-cache' \ // -H 'content-type: application/json' \ // -d '{ // "source": { // "contact_ids": [ // "{contact_id1}", // "{contact_id2}", // "{contact_id3}", // "{contact_id4}", // "{contact_id5}", // "{contact_id6}" // ] // }, // "list_ids": [ // "{list_id1}", // "{list_id2}" // ] // }' // Use the following online tool to generate HTTP code from a CURL command // Convert a cURL Command to HTTP Source Code // Use this online tool to generate code from sample JSON: // Generate Code to Create JSON // The following JSON is sent in the request body. // { // "source": { // "contact_ids": [ // "{contact_id1}", // "{contact_id2}", // "{contact_id3}", // "{contact_id4}", // "{contact_id5}", // "{contact_id6}" // ] // }, // "list_ids": [ // "{list_id1}", // "{list_id2}" // ] // } CkJsonObject json; json.UpdateString("source.contact_ids[0]","{contact_id1}"); json.UpdateString("source.contact_ids[1]","{contact_id2}"); json.UpdateString("source.contact_ids[2]","{contact_id3}"); json.UpdateString("source.contact_ids[3]","{contact_id4}"); json.UpdateString("source.contact_ids[4]","{contact_id5}"); json.UpdateString("source.contact_ids[5]","{contact_id6}"); json.UpdateString("list_ids[0]","{list_id1}"); json.UpdateString("list_ids[1]","{list_id2}"); // Adds the "Authorization: Bearer ACCESS_TOKEN" header. http.put_AuthToken("ACCESS_TOKEN"); http.SetRequestHeader("content-type","application/json"); http.SetRequestHeader("Accept","application/json"); http.SetRequestHeader("cache-control","no-cache"); CkHttpResponse *resp = http.PostJson3("https://api.cc.email/v3/activities/add_list_memberships","application/json",json); if (http.get_LastMethodSuccess() == false) { strOut.append(http.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkStringBuilder sbResponseBody; resp->GetBodySb(sbResponseBody); CkJsonObject jResp; jResp.LoadSb(sbResponseBody); jResp.put_EmitCompact(false); strOut.append("Response Body:"); strOut.append("\r\n"); strOut.append(jResp.emit()); strOut.append("\r\n"); int respStatusCode = resp->get_StatusCode(); strOut.append("Response Status Code = "); strOut.appendInt(respStatusCode); strOut.append("\r\n"); if (respStatusCode >= 400) { strOut.append("Response Header:"); strOut.append("\r\n"); strOut.append(resp->header()); strOut.append("\r\n"); strOut.append("Failed."); strOut.append("\r\n"); delete resp; SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } delete resp; // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "activity_id": "activity_id", // "state": "initialized", // "created_at": "2018-02-28T13:49:41-05:00", // "updated_at": "2018-02-28T13:49:41-05:00", // "percent_done": 1, // "activity_errors": [ // ], // "status": { // "list_count": 2 // }, // "_links": { // "self": { // "href": "/v3/activities/activity_id" // } // } // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON // Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat. // See this example explaining how this memory should be used: const char * functions. const char *activity_id = jResp.stringOf("activity_id"); const char *state = jResp.stringOf("state"); const char *created_at = jResp.stringOf("created_at"); const char *updated_at = jResp.stringOf("updated_at"); int percent_done = jResp.IntOf("percent_done"); int statusList_count = jResp.IntOf("status.list_count"); const char *v_linksSelfHref = jResp.stringOf("_links.self.href"); int i = 0; int count_i = jResp.SizeOfArray("activity_errors"); while (i < count_i) { jResp.put_I(i); const char *errMsg = jResp.stringOf("activity_errors[i]"); i = i + 1; } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.