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 all JobsGets all information about all jobs.
#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","/jobs"); if (rest.get_LastMethodSuccess() != true) { strOut.append(rest.lastErrorText()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); 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) { 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"); json.Load(responseBody); strOut.append(json.emit()); strOut.append("\r\n"); SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); return; } json.Load(responseBody); // Show the full JSON response.. (see below) 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 job and get information.. int numRecords = json.SizeOfArray("jobs"); int i = 0; while (i < numRecords) { json.put_I(i); strOut.append("job id: "); strOut.append(json.stringOf("jobs[i].id")); strOut.append("\r\n"); strOut.append("client id: "); strOut.append(json.stringOf("jobs[i].client.id")); strOut.append("\r\n"); strOut.append("account id: "); strOut.append(json.stringOf("jobs[i].account.id")); strOut.append("\r\n"); strOut.append("address line1: "); strOut.append(json.stringOf("jobs[i].address.line1")); strOut.append("\r\n"); dtime.SetFromTimestamp(json.stringOf("jobs[i].startTime")); 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; } // A sample jobs listing response: // // { // "result": "success", // "jobs": [ // { // "id": 17580761, // "reference": "1000", // "startTime": "2016-10-26T02:10:00+00:00", // "endTime": "2016-10-28T02:40:00+00:00", // "priority": 2, // "title": "[ Demo Job ]", // "description": "", // "jobNumber": null, // "deleted": false, // "type": "demo", // "created": "2015-09-03T02:11:32+00:00", // "modified": "2016-10-26T12:05:09+00:00", // "client": { // "id": 9555868 // }, // "billingClient": null, // "status": { // "id": 675900 // }, // "account": { // "id": 39409 // }, // "address": { // "line1": "21462 New York Avenue NW", // "line2": null, // "city": "Washington", // "postcode": "20005", // "latitude": 38.903959, // "longitude": -77.02137 // }, // "metadata": { // "visitsCount": 3, // "assignedVisitsCount": 3, // "unassignedVisitsCount": 0, // "partsCount": 1, // "chargesCount": 1, // "timersCount": 0, // "notesCount": 0, // "parcelsCount": 0, // "paymentsCount": 0, // "documentsCount": 1 // } // }, // { // "id": 17639295, // "reference": "1000", // "startTime": "2016-10-31T12:00:00+00:00", // "endTime": "2016-10-31T12:30:00+00:00", // "priority": 2, // "title": "Deliver Donuts", // "description": "Deliver donuts to the cafe.", // "jobNumber": "21122", // "deleted": false, // "type": "normal", // "created": "2016-10-31T12:07:14+00:00", // "modified": "2016-10-31T12:07:14+00:00", // "client": { // "id": 9555868 // }, // "billingClient": null, // "status": { // "id": 675900 // }, // "account": { // "id": 39409 // }, // "address": { // "line1": "1732 Pennsylvania Avenue NW", // "line2": null, // "city": "Washington", // "postcode": "20006", // "latitude": 38.8990534, // "longitude": -77.0401866 // }, // "metadata": { // "visitsCount": 1, // "assignedVisitsCount": 0, // "unassignedVisitsCount": 1, // "partsCount": 0, // "chargesCount": 0, // "timersCount": 0, // "notesCount": 0, // "parcelsCount": 0, // "paymentsCount": 0, // "documentsCount": 0 // } // } // ], // "metadata": { // "page": 1, // "pagesCount": 1, // "recordsPerPage": 20, // "recordsCount": 2 // } // } // SetDlgItemText(IDC_EDIT1,strOut.getUnicode()); } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.