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) Upsert Catalog ObjectCreates or updates the target CatalogObject. For more information, see https://developer.squareup.com/reference/square/catalog-api/upsert-catalog-object
#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 https://connect.squareup.com/v2/catalog/object \ // -X POST \ // -H 'Square-Version: 2020-07-22' \ // -H 'Authorization: Bearer ACCESS_TOKEN' \ // -H 'Content-Type: application/json' \ // -d '{ // "idempotency_key": "af3d1afc-7212-4300-b463-0bfc5314a5ae", // "object": { // "type": "ITEM", // "id": "#Cocoa", // "item_data": { // "name": "Cocoa", // "description": "Hot chocolate", // "abbreviation": "Ch" // } // } // }' // 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. // { // "idempotency_key": "af3d1afc-7212-4300-b463-0bfc5314a5ae", // "object": { // "type": "ITEM", // "id": "#Cocoa", // "item_data": { // "name": "Cocoa", // "description": "Hot chocolate", // "abbreviation": "Ch" // } // } // } CkJsonObject json; json.UpdateString("idempotency_key","af3d1afc-7212-4300-b463-0bfc5314a5ae"); json.UpdateString("object.type","ITEM"); json.UpdateString("object.id","#Cocoa"); json.UpdateString("object.item_data.name","Cocoa"); json.UpdateString("object.item_data.description","Hot chocolate"); json.UpdateString("object.item_data.abbreviation","Ch"); // Adds the "Authorization: Bearer ACCESS_TOKEN" header. http.put_AuthToken("ACCESS_TOKEN"); http.SetRequestHeader("Square-Version","2020-07-22"); http.SetRequestHeader("Content-Type","application/json"); // This example uses the sandbox: connect.squareupsandbox.com // Production should use connect.squareup.com CkHttpResponse *resp = http.PostJson3("https://connect.squareupsandbox.com/v2/catalog/object","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) // { // "catalog_object": { // "type": "ITEM", // "id": "7SB3ZQYJ5GDMVFL7JK46JCHT", // "updated_at": "2016-11-16T22:32:42.996Z", // "version": 1479335562996, // "is_deleted": false, // "item_data": { // "name": "Cocoa", // "description": "Hot chocolate", // "abbreviation": "Ch" // } // }, // "id_mappings": [ // { // "client_object_id": "#Cocoa", // "object_id": "7SB3ZQYJ5GDMVFL7JK46JCHT" // } // ] // } // 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 *client_object_id = 0; const char *object_id = 0; const char *catalog_objectType = jResp.stringOf("catalog_object.type"); const char *catalog_objectId = jResp.stringOf("catalog_object.id"); const char *catalog_objectUpdated_at = jResp.stringOf("catalog_object.updated_at"); int catalog_objectVersion = jResp.IntOf("catalog_object.version"); bool catalog_objectIs_deleted = jResp.BoolOf("catalog_object.is_deleted"); const char *catalog_objectItem_dataName = jResp.stringOf("catalog_object.item_data.name"); const char *catalog_objectItem_dataDescription = jResp.stringOf("catalog_object.item_data.description"); const char *catalog_objectItem_dataAbbreviation = jResp.stringOf("catalog_object.item_data.abbreviation"); int i = 0; int count_i = jResp.SizeOfArray("id_mappings"); while (i < count_i) { jResp.put_I(i); client_object_id = jResp.stringOf("id_mappings[i].client_object_id"); object_id = jResp.stringOf("id_mappings[i].object_id"); i = i + 1; } SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.