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
(Unicode C) GeoOp - Create a New UserCreate a new GeoOp user.
#include <C_CkJsonObjectW.h> #include <C_CkOAuth2W.h> #include <C_CkRestW.h> void ChilkatSample(void) { HCkJsonObjectW jsonToken; BOOL success; HCkOAuth2W oauth2; HCkRestW rest; BOOL bAutoReconnect; HCkJsonObjectW jsonUser; const wchar_t *responseBody; HCkJsonObjectW json; // 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} jsonToken = CkJsonObjectW_Create(); success = CkJsonObjectW_LoadFile(jsonToken,L"qa_data/tokens/geoop.json"); // This example assumes we previously obtained an access token oauth2 = CkOAuth2W_Create(); CkOAuth2W_putAccessToken(oauth2,CkJsonObjectW_stringOf(jsonToken,L"access_token")); rest = CkRestW_Create(); // 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. bAutoReconnect = TRUE; success = CkRestW_Connect(rest,L"api.geoop.com",443,TRUE,bAutoReconnect); if (success != TRUE) { wprintf(L"%s\n",CkRestW_lastErrorText(rest)); CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); return; } // Provide the authentication credentials (i.e. the access token) CkRestW_SetAuthOAuth2(rest,oauth2); // Set the X-Version header. CkRestW_AddHeader(rest,L"X-Version",L"1.0"); // To create a new user, we must build and send the following JSON: // { // "users": [ // { // "account": { // "id": 39409 <--- This account ID must be one that already exists. // }, // "firstName": "Geoff", // "lastName": "Wirtz", // "companyName": "Sample Company", // "phone": "+12349282001", // "mobile": "+12349332744", // "email": "gwirtz@example2.com", // "login": "gwirtz_sample2", // "newPassword": "pa$$wordz", // "newPasswordConfirm": "pa$$wordz" // } // ] // } jsonUser = CkJsonObjectW_Create(); CkJsonObjectW_UpdateInt(jsonUser,L"users[0].account.id",39409); CkJsonObjectW_UpdateString(jsonUser,L"users[0].firstName",L"Geoff"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].lastName",L"Wirtz"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].companyName",L"Sample Company"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].phone",L"+12349282001"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].mobile",L"+12349332744"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].email",L"gwirtz@example2.com"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].login",L"gwirtz_sample2"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].newPassword",L"pa$$wordz"); CkJsonObjectW_UpdateString(jsonUser,L"users[0].newPasswordConfirm",L"pa$$wordz"); // Examine the JSON we're about to send... CkJsonObjectW_putEmitCompact(jsonUser,FALSE); wprintf(L"%s\n",CkJsonObjectW_emit(jsonUser)); CkRestW_AddHeader(rest,L"Content-Type",L"application/json"); CkJsonObjectW_putEmitCompact(jsonUser,TRUE); responseBody = CkRestW_fullRequestString(rest,L"POST",L"/users",CkJsonObjectW_emit(jsonUser)); if (CkRestW_getLastMethodSuccess(rest) != TRUE) { wprintf(L"%s\n",CkRestW_lastErrorText(rest)); CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); CkJsonObjectW_Dispose(jsonUser); return; } // If the response status code did not indicate success, then see what happened.. if (CkRestW_getResponseStatusCode(rest) != 200) { wprintf(L"Request Header: \n"); wprintf(L"%s\n",CkRestW_lastRequestHeader(rest)); wprintf(L"----\n"); wprintf(L"Response StatusCode = %d\n",CkRestW_getResponseStatusCode(rest)); wprintf(L"Response StatusLine: %s\n",CkRestW_responseStatusText(rest)); wprintf(L"Response Header:\n"); wprintf(L"%s\n",CkRestW_responseHeader(rest)); wprintf(L"%s\n",responseBody); CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); CkJsonObjectW_Dispose(jsonUser); return; } json = CkJsonObjectW_Create(); CkJsonObjectW_putEmitCompact(json,FALSE); CkJsonObjectW_Load(json,responseBody); // Show the full JSON response.. wprintf(L"%s\n",CkJsonObjectW_emit(json)); // The success JSON looks like this: // { // "result": "success", // "users": [ // { // "id": 984244, // "firstName": "Geoff", // "lastName": "Wirtz", // "companyName": "Sample Company", // "email": "gwirtz@example2.com", // "phone": "+12349282001", // "mobile": "+12349332744", // "hourlyRate": 0, // "active": 1, // "deleted": false, // "colour": "#000000", // "created": "2016-10-26T18:03:59+00:00", // "modified": "2016-10-26T18:03:59+00:00", // "isAssignable": true, // "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984244.jpg", // "role": { // "id": 2 // }, // "account": { // "id": 39409 // }, // "status": {} // } // ], // "metadata": { // "receivedItemsCount": 1, // "validItems": [ // 0 // ], // "invalidItems": [ // ] // } // } // CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); CkJsonObjectW_Dispose(jsonUser); CkJsonObjectW_Dispose(json); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.