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
(Delphi ActiveX) GeoOp - Get a list of all usersGets a list of all GeoOp users.
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB; ... procedure TForm1.Button1Click(Sender: TObject); var jsonToken: TChilkatJsonObject; success: Integer; oauth2: TChilkatOAuth2; rest: TChilkatRest; bAutoReconnect: Integer; responseBody: WideString; json: TChilkatJsonObject; dtime: TCkDateTime; bLocalTime: Integer; dt: IDtObj; numRecords: Integer; i: Integer; begin // 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 := TChilkatJsonObject.Create(Self); success := jsonToken.LoadFile('qa_data/tokens/geoop.json'); // This example assumes we previously obtained an access token oauth2 := TChilkatOAuth2.Create(Self); oauth2.AccessToken := jsonToken.StringOf('access_token'); rest := TChilkatRest.Create(Self); // Connect to GeoOp and send the following GET request: // GET /users HTTP/1.1 // Host: api.geoop.com bAutoReconnect := 1; success := rest.Connect('api.geoop.com',443,1,bAutoReconnect); if (success <> 1) then begin Memo1.Lines.Add(rest.LastErrorText); Exit; end; // Provide the authentication credentials (i.e. the access token) rest.SetAuthOAuth2(oauth2.ControlInterface); // Set the X-Version header. rest.AddHeader('X-Version','1.0'); responseBody := rest.FullRequestNoBody('GET','/users'); if (rest.LastMethodSuccess <> 1) then begin Memo1.Lines.Add(rest.LastErrorText); Exit; end; // If the response status code did not indicate success, then see what happened.. if (rest.ResponseStatusCode <> 200) then begin Memo1.Lines.Add('Request Header: '); Memo1.Lines.Add(rest.LastRequestHeader); Memo1.Lines.Add('----'); Memo1.Lines.Add('Response StatusCode = ' + IntToStr(rest.ResponseStatusCode)); Memo1.Lines.Add('Response StatusLine: ' + rest.ResponseStatusText); Memo1.Lines.Add('Response Header:'); Memo1.Lines.Add(rest.ResponseHeader); Memo1.Lines.Add(responseBody); Exit; end; json := TChilkatJsonObject.Create(Self); json.EmitCompact := 0; json.Load(responseBody); // Show the full JSON response.. Memo1.Lines.Add(json.Emit()); // These will be used for parsing date/time strings.. dtime := TCkDateTime.Create(Self); bLocalTime := 1; // Iterate over each user and get information from each. numRecords := json.SizeOfArray('users'); i := 0; while i < numRecords do begin json.I := i; Memo1.Lines.Add('id: ' + json.StringOf('users[i].id')); Memo1.Lines.Add('firstName: ' + json.StringOf('users[i].firstName')); Memo1.Lines.Add('lastName: ' + json.StringOf('users[i].lastName')); Memo1.Lines.Add('companyName: ' + json.StringOf('users[i].companyName')); Memo1.Lines.Add('active: ' + IntToStr(json.IntOf('users[i].active'))); Memo1.Lines.Add('isAssignable: ' + IntToStr(Ord(json.BoolOf('users[i].isAssignable')))); Memo1.Lines.Add('account id: ' + IntToStr(Ord(json.BoolOf('users[i].account.id')))); dtime.SetFromTimestamp(json.StringOf('users[i].created')); dt := dtime.GetDtObj(bLocalTime); Memo1.Lines.Add('created: ' + IntToStr(dt.Month) + '/' + IntToStr(dt.Day) + '/' + IntToStr(dt.Year) + ' ' + IntToStr(dt.Hour) + ':' + IntToStr(dt.Minute)); Memo1.Lines.Add('----'); i := i + 1; end; // 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 // } // } // // end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.