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
(AutoIt) GeoOp - Create JobCreate a new job.
; 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} $oJsonToken = ObjCreate("Chilkat_9_5_0.JsonObject") Local $bSuccess = $oJsonToken.LoadFile("qa_data/tokens/geoop.json") ; This example assumes we previously obtained an access token $oOauth2 = ObjCreate("Chilkat_9_5_0.OAuth2") $oOauth2.AccessToken = $oJsonToken.StringOf("access_token") $oRest = ObjCreate("Chilkat_9_5_0.Rest") ; Connect to GeoOp.. ; Note: The same REST object, once connected, can be used for many requests. ; The bAutoReconnect argument allows it to automatically reconnect as required for any subsequent request. Local $bAutoReconnect = True $bSuccess = $oRest.Connect("api.geoop.com",443,True,$bAutoReconnect) If ($bSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf ; Provide the authentication credentials (i.e. the access token) $oRest.SetAuthOAuth2($oOauth2) ; Set the X-Version header. $oRest.AddHeader("X-Version","1.0") ; To create a new user, we must build and send the following JSON: ; { ; "jobs": [ ; { ; "priority": 2, ; "title": "Deliver More Donuts", ; "description": "Deliver more donuts to the cafe.", ; "client": { ; "id": 9571218 ; }, ; "account": { ; "id": 39409 ; }, ; "status": { ; "id": 675900 ; }, ; "address": { ; "line1": "1732 Pennsylvania Avenue NW", ; "city": "Washington", ; "postcode": "20006", ; } ; } ; ] ; } ; $oJsonJob = ObjCreate("Chilkat_9_5_0.JsonObject") $oJsonJob.UpdateInt("jobs[0].priority",2) $oJsonJob.UpdateString("jobs[0].title","Deliver More Donuts") $oJsonJob.UpdateString("jobs[0].description","Deliver more donuts to the cafe.") $oJsonJob.UpdateInt("jobs[0].client.id",9571218) $oJsonJob.UpdateInt("jobs[0].account.id",39409) $oJsonJob.UpdateInt("jobs[0].status.id",675900) $oJsonJob.UpdateString("jobs[0].address.line1","1732 Pennsylvania Avenue NW") $oJsonJob.UpdateString("jobs[0].address.city","Washington") $oJsonJob.UpdateString("jobs[0].address.postcode","20006") ; Examine the JSON we're about to send... $oJsonJob.EmitCompact = False ConsoleWrite($oJsonJob.Emit() & @CRLF) $oRest.AddHeader("Content-Type","application/json") $oJsonJob.EmitCompact = True Local $sResponseBody = $oRest.FullRequestString("POST","/jobs",$oJsonJob.Emit()) If ($oRest.LastMethodSuccess <> True) Then ConsoleWrite($oRest.LastErrorText & @CRLF) Exit EndIf $oJson = ObjCreate("Chilkat_9_5_0.JsonObject") $oJson.EmitCompact = False ; If the response status code did not indicate success, then see what happened.. If ($oRest.ResponseStatusCode <> 200) Then ConsoleWrite("Request Header: " & @CRLF) ConsoleWrite($oRest.LastRequestHeader & @CRLF) ConsoleWrite("----" & @CRLF) ConsoleWrite("Response StatusCode = " & $oRest.ResponseStatusCode & @CRLF) ConsoleWrite("Response StatusLine: " & $oRest.ResponseStatusText & @CRLF) ConsoleWrite("Response Header:" & @CRLF) ConsoleWrite($oRest.ResponseHeader & @CRLF) $oJson.Load($sResponseBody) ConsoleWrite($oJson.Emit() & @CRLF) Exit EndIf $oJson.Load($sResponseBody) ; Show the full JSON response.. ConsoleWrite($oJson.Emit() & @CRLF) ; The success JSON looks like this: ; { ; "result": "success", ; "jobs": [ ; { ; "id": 17639811, ; "reference": "1001", ; "startTime": null, ; "endTime": null, ; "priority": 2, ; "title": "Deliver More Donuts", ; "description": "Deliver more donuts to the cafe.", ; "jobNumber": null, ; "deleted": false, ; "type": "normal", ; "created": "2016-10-31T13:36:47+00:00", ; "modified": "2016-10-31T13:36:47+00:00", ; "client": { ; "id": 9571218 ; }, ; "billingClient": null, ; "status": { ; "id": 675900 ; }, ; "account": { ; "id": 39409 ; }, ; "address": { ; "line1": "1732 Pennsylvania Avenue NW", ; "line2": "", ; "city": "Washington", ; "postcode": "20006", ; "latitude": 38.8990534, ; "longitude": -77.0401866 ; }, ; "metadata": { ; "visitsCount": 0, ; "assignedVisitsCount": 0, ; "unassignedVisitsCount": 0, ; "partsCount": 0, ; "chargesCount": 0, ; "timersCount": 0, ; "notesCount": 0, ; "parcelsCount": 0, ; "paymentsCount": 0, ; "documentsCount": 0 ; } ; } ; ], ; "metadata": { ; "receivedItemsCount": 1, ; "validItems": [ ; 0 ; ], ; "invalidItems": [ ; ] ; } ; } ; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.