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) GeoOp - Get a list of all usersGets a list of all GeoOp users.
#include <CkJsonObject.h> #include <CkOAuth2.h> #include <CkRest.h> #include <CkDateTime.h> #include <CkDtObj.h> void ChilkatSample(void) { CkString strOut; // 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 and send the following GET request: // GET /users HTTP/1.1 // Host: api.geoop.com bool bAutoReconnect = true; success = rest.Connect("api.geoop.com",443,true,bAutoReconnect); if (success != true) { strOut.append(rest.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // Provide the authentication credentials (i.e. the access token) rest.SetAuthOAuth2(oauth2); // Set the X-Version header. rest.AddHeader("X-Version","1.0"); const char *responseBody = rest.fullRequestNoBody("GET","/users"); if (rest.get_LastMethodSuccess() != true) { strOut.append(rest.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } // If the response status code did not indicate success, then see what happened.. if (rest.get_ResponseStatusCode() != 200) { strOut.append("Request Header: "); strOut.append("\r\n"); strOut.append(rest.lastRequestHeader()); strOut.append("\r\n"); strOut.append("----"); strOut.append("\r\n"); strOut.append("Response StatusCode = "); strOut.appendInt(rest.get_ResponseStatusCode()); strOut.append("\r\n"); strOut.append("Response StatusLine: "); strOut.append(rest.responseStatusText()); strOut.append("\r\n"); strOut.append("Response Header:"); strOut.append("\r\n"); strOut.append(rest.responseHeader()); strOut.append("\r\n"); strOut.append(responseBody); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } CkJsonObject json; json.put_EmitCompact(false); json.Load(responseBody); // Show the full JSON response.. strOut.append(json.emit()); strOut.append("\r\n"); // These will be used for parsing date/time strings.. CkDateTime dtime; bool bLocalTime = true; CkDtObj *dt = 0; // Iterate over each user and get information from each. int numRecords = json.SizeOfArray("users"); int i = 0; while (i < numRecords) { json.put_I(i); strOut.append("id: "); strOut.append(json.stringOf("users[i].id")); strOut.append("\r\n"); strOut.append("firstName: "); strOut.append(json.stringOf("users[i].firstName")); strOut.append("\r\n"); strOut.append("lastName: "); strOut.append(json.stringOf("users[i].lastName")); strOut.append("\r\n"); strOut.append("companyName: "); strOut.append(json.stringOf("users[i].companyName")); strOut.append("\r\n"); strOut.append("active: "); strOut.appendInt(json.IntOf("users[i].active")); strOut.append("\r\n"); strOut.append("isAssignable: "); strOut.appendInt(json.BoolOf("users[i].isAssignable")); strOut.append("\r\n"); strOut.append("account id: "); strOut.appendInt(json.BoolOf("users[i].account.id")); strOut.append("\r\n"); dtime.SetFromTimestamp(json.stringOf("users[i].created")); dt = dtime.GetDtObj(bLocalTime); strOut.append("created: "); strOut.appendInt(dt->get_Month()); strOut.append("/"); strOut.appendInt(dt->get_Day()); strOut.append("/"); strOut.appendInt(dt->get_Year()); strOut.append(" "); strOut.appendInt(dt->get_Hour()); strOut.append(":"); strOut.appendInt(dt->get_Minute()); strOut.append("\r\n"); delete dt; strOut.append("----"); strOut.append("\r\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 // } // } // // SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.