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 - Get a list of all usersGets a list of all GeoOp users.
#include <C_CkJsonObjectW.h> #include <C_CkOAuth2W.h> #include <C_CkRestW.h> #include <C_CkDateTimeW.h> #include <C_CkDtObjW.h> void ChilkatSample(void) { HCkJsonObjectW jsonToken; BOOL success; HCkOAuth2W oauth2; HCkRestW rest; BOOL bAutoReconnect; const wchar_t *responseBody; HCkJsonObjectW json; HCkDateTimeW dtime; BOOL bLocalTime; HCkDtObjW dt; int numRecords; int i; // 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 and send the following GET request: // GET /users HTTP/1.1 // Host: api.geoop.com 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"); responseBody = CkRestW_fullRequestNoBody(rest,L"GET",L"/users"); if (CkRestW_getLastMethodSuccess(rest) != TRUE) { wprintf(L"%s\n",CkRestW_lastErrorText(rest)); CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); 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); return; } json = CkJsonObjectW_Create(); CkJsonObjectW_putEmitCompact(json,FALSE); CkJsonObjectW_Load(json,responseBody); // Show the full JSON response.. wprintf(L"%s\n",CkJsonObjectW_emit(json)); // These will be used for parsing date/time strings.. dtime = CkDateTimeW_Create(); bLocalTime = TRUE; // Iterate over each user and get information from each. numRecords = CkJsonObjectW_SizeOfArray(json,L"users"); i = 0; while (i < numRecords) { CkJsonObjectW_putI(json,i); wprintf(L"id: %s\n",CkJsonObjectW_stringOf(json,L"users[i].id")); wprintf(L"firstName: %s\n",CkJsonObjectW_stringOf(json,L"users[i].firstName")); wprintf(L"lastName: %s\n",CkJsonObjectW_stringOf(json,L"users[i].lastName")); wprintf(L"companyName: %s\n",CkJsonObjectW_stringOf(json,L"users[i].companyName")); wprintf(L"active: %d\n",CkJsonObjectW_IntOf(json,L"users[i].active")); wprintf(L"isAssignable: %d\n",CkJsonObjectW_BoolOf(json,L"users[i].isAssignable")); wprintf(L"account id: %d\n",CkJsonObjectW_BoolOf(json,L"users[i].account.id")); CkDateTimeW_SetFromTimestamp(dtime,CkJsonObjectW_stringOf(json,L"users[i].created")); dt = CkDateTimeW_GetDtObj(dtime,bLocalTime); wprintf(L"created: %d/%d/%d %d:%d\n",CkDtObjW_getMonth(dt),CkDtObjW_getDay(dt),CkDtObjW_getYear(dt),CkDtObjW_getHour(dt) ,CkDtObjW_getMinute(dt)); CkDtObjW_Dispose(dt); wprintf(L"----\n"); i = i + 1; } // The responseJson looks like this: // { // "result": "success", // "users": [ // { // "id": 984236, // "firstName": "Joe", // "lastName": "Smith", // "companyName": "Chilkat Software, Inc.", // "email": "support@chilkatsoft.com", // "phone": "", // "mobile": "1-630-555-5555", // "hourlyRate": 0, // "active": 1, // "deleted": false, // "colour": "#D2BC14", // "created": "2016-10-26T12:05:09+00:00", // "modified": "2016-10-26T12:05:09+00:00", // "isAssignable": true, // "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984236.jpg", // "role": { // "id": 1 // }, // "account": { // "id": 39409 // }, // "status": {} // }, // { // "id": 984237, // "firstName": "Demo", // "lastName": "Employee", // "companyName": "", // "email": "", // "phone": "", // "mobile": "58458458475854758", // "hourlyRate": 0, // "active": 0, // "deleted": true, // "colour": "#4C4CFF", // "created": "2015-09-03T01:56:17+00:00", // "modified": "2016-06-14T20:20:58+00:00", // "isAssignable": true, // "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984237.jpg", // "role": { // "id": 2 // }, // "account": { // "id": 39409 // }, // "status": { // "message": null, // "timestamp": "2015-09-03T01:57:45+00:00" // } // } // ], // "metadata": { // "page": 1, // "pagesCount": 1, // "recordsPerPage": 20, // "recordsCount": 2 // } // } // // CkJsonObjectW_Dispose(jsonToken); CkOAuth2W_Dispose(oauth2); CkRestW_Dispose(rest); CkJsonObjectW_Dispose(json); CkDateTimeW_Dispose(dtime); } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.