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
(PowerBuilder) GeoOp - Export Clients to CSVExport client data to a CSV.
integer li_rc oleobject loo_JsonToken integer li_Success oleobject loo_Oauth2 oleobject loo_Rest integer li_BAutoReconnect string ls_ResponseBody oleobject loo_Json oleobject loo_Csv integer li_NumRecords integer 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} loo_JsonToken = create oleobject // Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 li_rc = loo_JsonToken.ConnectToNewObject("Chilkat.JsonObject") if li_rc < 0 then destroy loo_JsonToken MessageBox("Error","Connecting to COM object failed") return end if li_Success = loo_JsonToken.LoadFile("qa_data/tokens/geoop.json") // This example assumes we previously obtained an access token loo_Oauth2 = create oleobject // Use "Chilkat_9_5_0.OAuth2" for versions of Chilkat < 10.0.0 li_rc = loo_Oauth2.ConnectToNewObject("Chilkat.OAuth2") loo_Oauth2.AccessToken = loo_JsonToken.StringOf("access_token") loo_Rest = create oleobject // Use "Chilkat_9_5_0.Rest" for versions of Chilkat < 10.0.0 li_rc = loo_Rest.ConnectToNewObject("Chilkat.Rest") // Connect to GeoOp and send the following GET request: // GET /users HTTP/1.1 // Host: api.geoop.com li_BAutoReconnect = 1 li_Success = loo_Rest.Connect("api.geoop.com",443,1,li_BAutoReconnect) if li_Success <> 1 then Write-Debug loo_Rest.LastErrorText destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest return end if // Provide the authentication credentials (i.e. the access token) loo_Rest.SetAuthOAuth2(loo_Oauth2) // Set the X-Version header. loo_Rest.AddHeader("X-Version","1.0") ls_ResponseBody = loo_Rest.FullRequestNoBody("GET","/clients") if loo_Rest.LastMethodSuccess <> 1 then Write-Debug loo_Rest.LastErrorText destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest return end if loo_Json = create oleobject // Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 li_rc = loo_Json.ConnectToNewObject("Chilkat.JsonObject") loo_Json.EmitCompact = 0 // If the response status code did not indicate success, then see what happened.. if loo_Rest.ResponseStatusCode <> 200 then Write-Debug "Request Header: " Write-Debug loo_Rest.LastRequestHeader Write-Debug "----" Write-Debug "Response StatusCode = " + string(loo_Rest.ResponseStatusCode) Write-Debug "Response StatusLine: " + loo_Rest.ResponseStatusText Write-Debug "Response Header:" Write-Debug loo_Rest.ResponseHeader loo_Json.Load(ls_ResponseBody) Write-Debug loo_Json.Emit() destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest destroy loo_Json return end if loo_Json.Load(ls_ResponseBody) // Show the full JSON response.. (see below) Write-Debug loo_Json.Emit() Write-Debug "---" loo_Csv = create oleobject // Use "Chilkat_9_5_0.Csv" for versions of Chilkat < 10.0.0 li_rc = loo_Csv.ConnectToNewObject("Chilkat.Csv") loo_Csv.HasColumnNames = 1 loo_Csv.SetColumnName(0,"id") loo_Csv.SetColumnName(1,"companyName") loo_Csv.SetColumnName(2,"businessType") loo_Csv.SetColumnName(3,"account_id") loo_Csv.SetColumnName(4,"address_line1") loo_Csv.SetColumnName(5,"address_city") loo_Csv.SetColumnName(6,"address_postcode") // Iterate over each client and populate the CSV... li_NumRecords = loo_Json.SizeOfArray("clients") i = 0 do while i < li_NumRecords loo_Json.I = i loo_Csv.SetCellByName(i,"id",loo_Json.StringOf("clients[i].id")) loo_Csv.SetCellByName(i,"companyName",loo_Json.StringOf("clients[i].companyName")) loo_Csv.SetCellByName(i,"businessType",loo_Json.StringOf("clients[i].businessType")) loo_Csv.SetCellByName(i,"account_id",loo_Json.StringOf("clients[i].account.id")) loo_Csv.SetCellByName(i,"address_line1",loo_Json.StringOf("clients[i].address.line1")) loo_Csv.SetCellByName(i,"address_city",loo_Json.StringOf("clients[i].address.city")) loo_Csv.SetCellByName(i,"address_postcode",loo_Json.StringOf("clients[i].address.postcode")) i = i + 1 loop // Show the CSV. Write-Debug loo_Csv.SaveToString() // Save the CSV. loo_Csv.SaveFile("qa_output/clients.csv") // --------------------------------------------------------------------- // The full JSON response containing all client data: // // { // "result": "success", // "clients": [ // { // "id": 9555868, // "firstName": "[ Demo", // "lastName": "Client ]", // "companyName": "Miller Park Cafe", // "businessType": "Licensed Restaurant", // "leadSource": "", // "emailAddress": null, // "phoneNumber": null, // "mobileNumber": null, // "faxNumber": null, // "notes": "", // "deleted": false, // "hasRecentJobs": true, // "created": "2016-10-26T12:05:09+00:00", // "modified": "2016-10-26T12:05:09+00:00", // "billingClient": null, // "account": { // "id": 39409 // }, // "address": { // "line1": "1732 Pennsylvania Avenue NW", // "line2": "", // "city": "Washington", // "postcode": "20006", // "latitude": 38.899037, // "longitude": -77.040207 // }, // "mailingAddress": {} // }, // { // "id": 9571176, // "firstName": "Mildred", // "lastName": "Vanildred", // "companyName": "Ice Cream Industries", // "businessType": "Ice Cream", // "leadSource": null, // "emailAddress": "milli@icecreamindustries.com", // "phoneNumber": "678-555-1012", // "mobileNumber": null, // "faxNumber": null, // "notes": "", // "deleted": false, // "hasRecentJobs": true, // "created": "2016-10-31T12:32:12+00:00", // "modified": "2016-10-31T12:32:13+00:00", // "billingClient": null, // "account": { // "id": 39409 // }, // "address": { // "line1": "2101 West Roosevelt Road", // "line2": null, // "city": "Wheaton", // "postcode": "60187", // "latitude": 41.8581778, // "longitude": -88.1380111 // }, // "mailingAddress": { // "line1": "2101 West Roosevelt Road", // "line2": null, // "city": "Wheaton" // } // }, // { // "id": 9571218, // "firstName": "Joe", // "lastName": "Miller", // "companyName": "Miller Bakery", // "businessType": "Licensed Bakery", // "leadSource": "", // "emailAddress": null, // "phoneNumber": null, // "mobileNumber": null, // "faxNumber": null, // "notes": "", // "deleted": false, // "hasRecentJobs": true, // "created": "2016-10-31T13:02:07+00:00", // "modified": "2016-10-31T13:02:07+00:00", // "billingClient": null, // "account": { // "id": 39409 // }, // "address": { // "line1": "1832 Pennsylvania Avenue NW", // "line2": "", // "city": "Washington", // "postcode": "20006", // "latitude": 0, // "longitude": 0 // }, // "mailingAddress": { // "line1": "", // "line2": "", // "city": "" // } // } // ], // "metadata": { // "page": 1, // "pagesCount": 1, // "recordsPerPage": 20, // "recordsCount": 3 // } // } // destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest destroy loo_Json destroy loo_Csv |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.