Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(C++) GeoOp - Create ClientCreates a new client.
#include <CkJsonObject.h> #include <CkOAuth2.h> #include <CkRest.h> void ChilkatSample(void) { // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. // This example also assumes an OAuth2 access token was previously fetched. // and saved in a JSON file. // First get our previously obtained access token. // {"access_token":"e6dqdG....mzjpT04w==","token_type":"Bearer","expires_in":2592000,"owner_id":999236} CkJsonObject jsonToken; bool success = jsonToken.LoadFile("qa_data/tokens/geoop.json"); // This example assumes we previously obtained an access token CkOAuth2 oauth2; oauth2.put_AccessToken(jsonToken.stringOf("access_token")); CkRest rest; // Connect to GeoOp.. // Note: The same REST object, once connected, can be used for many requests. // The bAutoReconnect argument allows it to automatically reconnect as required for any subsequent request. bool bAutoReconnect = true; success = rest.Connect("api.geoop.com",443,true,bAutoReconnect); if (success != true) { std::cout << rest.lastErrorText() << "\r\n"; return; } // Provide the authentication credentials (i.e. the access token) rest.SetAuthOAuth2(oauth2); // Set the X-Version header. rest.AddHeader("X-Version","1.0"); // To create a new client, we can build and send the following JSON: // { // "clients": [ // { // "firstName": "Joe", // "lastName": "Miller", // "companyName": "Miller Bakery", // "businessType": "Licensed Bakery", // "account": { // "id": 39409 // }, // "address": { // "line1": "1832 Pennsylvania Avenue NW", // "city": "Washington", // "postcode": "20006", // } // } // } CkJsonObject jsonClient; jsonClient.UpdateInt("clients[0].account.id",39409); jsonClient.UpdateString("clients[0].firstName","Joe"); jsonClient.UpdateString("clients[0].lastName","Miller"); jsonClient.UpdateString("clients[0].companyName","Miller Bakery"); jsonClient.UpdateString("clients[0].businessType","Licensed Bakery"); jsonClient.UpdateString("clients[0].address.line1","1832 Pennsylvania Avenue NW"); jsonClient.UpdateString("clients[0].address.city","Washington"); jsonClient.UpdateString("clients[0].address.postcode","20006"); // Examine the JSON we're about to send... jsonClient.put_EmitCompact(false); std::cout << jsonClient.emit() << "\r\n"; rest.AddHeader("Content-Type","application/json"); jsonClient.put_EmitCompact(true); const char *responseBody = rest.fullRequestString("POST","/clients",jsonClient.emit()); if (rest.get_LastMethodSuccess() != true) { std::cout << rest.lastErrorText() << "\r\n"; return; } CkJsonObject json; json.put_EmitCompact(false); // If the response status code did not indicate success, then see what happened.. if (rest.get_ResponseStatusCode() != 200) { std::cout << "Request Header: " << "\r\n"; std::cout << rest.lastRequestHeader() << "\r\n"; std::cout << "----" << "\r\n"; std::cout << "Response StatusCode = " << rest.get_ResponseStatusCode() << "\r\n"; std::cout << "Response StatusLine: " << rest.responseStatusText() << "\r\n"; std::cout << "Response Header:" << "\r\n"; std::cout << rest.responseHeader() << "\r\n"; json.Load(responseBody); std::cout << json.emit() << "\r\n"; return; } json.Load(responseBody); // Show the full JSON response.. std::cout << json.emit() << "\r\n"; // The success JSON looks like this: // { // "result": "success", // "clients": [ // { // "id": 9571218, // "firstName": "Joe", // "lastName": "Miller", // "companyName": "Miller Bakery", // "businessType": "Licensed Bakery", // "leadSource": "", // "emailAddress": null, // "phoneNumber": null, // "mobileNumber": null, // "faxNumber": null, // "notes": "", // "deleted": false, // "hasRecentJobs": false, // "created": "2016-10-31T13:02:07+00:00", // "modified": "2016-10-31T13:02:07+00:00", // "billingClient": null, // "account": { // "id": 39409 // }, // "address": { // "line1": "1832 Pennsylvania Avenue NW", // "line2": "", // "city": "Washington", // "postcode": "20006", // "latitude": 0, // "longitude": 0 // }, // "mailingAddress": { // "line1": "", // "line2": "", // "city": "" // } // } // ], // "metadata": { // "receivedItemsCount": 1, // "validItems": [ // 0 // ], // "invalidItems": [ // ] // } // } // // } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.