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 - Mark a User as DeletedMark one or more users as deleted.
integer li_rc oleobject loo_JsonToken integer li_Success oleobject loo_Oauth2 oleobject loo_Rest integer li_BAutoReconnect oleobject loo_JsonPostBody string ls_ResponseBody oleobject loo_Json // 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.. // 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. 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") // We'll send a POST that looks like this: // // PATCH /users HTTP/1.1 // Host: api.geoop.com // Authorization: Bearer oJ_7Hj.f-F3f.kL // Content-Type: application/json // X-Version: 1.0 // // { // "users": [ // { // "id": 115, // "deleted": true // }, // { // "id": 116, // "deleted": true // } // ] // } loo_JsonPostBody = create oleobject // Use "Chilkat_9_5_0.JsonObject" for versions of Chilkat < 10.0.0 li_rc = loo_JsonPostBody.ConnectToNewObject("Chilkat.JsonObject") loo_JsonPostBody.UpdateInt("users[0].id",115) loo_JsonPostBody.UpdateBool("users[0].deleted",1) loo_JsonPostBody.UpdateInt("users[1].id",116) loo_JsonPostBody.UpdateBool("users[1].deleted",1) // Continue adding more users as needed.. // Examine the JSON we're about to send... loo_JsonPostBody.EmitCompact = 0 Write-Debug loo_JsonPostBody.Emit() loo_Rest.AddHeader("Content-Type","application/json") loo_JsonPostBody.EmitCompact = 1 ls_ResponseBody = loo_Rest.FullRequestString("PATCH","/users",loo_JsonPostBody.Emit()) if loo_Rest.LastMethodSuccess <> 1 then Write-Debug loo_Rest.LastErrorText destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest destroy loo_JsonPostBody 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() // If a user ID does not exist, we'll get an error response body that looks like this: // { // "result": "failure", // "failures": [ // { // "rawData": { // "id": 115, // "deleted": true // }, // "errors": [ // { // "type": "client", // "code": 1012, // "message": "Item does not exist, or you do not have permission to access the item.", // "description": "Make certain that you specified the correct item ID, and that you have permission to access the item." // } // ] // } // ], // "metadata": { // "receivedItemsCount": 1, // "validItems": [ // ], // "invalidItems": [ // 0 // ] // } // } // destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest destroy loo_JsonPostBody destroy loo_Json return end if loo_Json.Load(ls_ResponseBody) // Show the full JSON response.. Write-Debug loo_Json.Emit() // The success JSON looks like this: // { // "result": "success", // "users": [ // { // "id": 984242, // "firstName": "John", // "lastName": "Doe", // "companyName": "Chilkat Software, inc.", // "email": "sales@chilkatsoft.com", // "phone": "", // "mobile": "2223334444", // "hourlyRate": 0, // "active": 1, // "deleted": true, // "colour": "#8162E7", // "created": "2016-10-26T17:52:30+00:00", // "modified": "2016-10-31T11:47:18+00:00", // "isAssignable": true, // "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984242.jpg", // "role": { // "id": 3 // }, // "account": { // "id": 39409 // }, // "status": { // "message": "", // "timestamp": "2016-10-26T17:52:30+00:00" // } // } // ], // "metadata": { // "receivedItemsCount": 1, // "validItems": [ // 0 // ], // "invalidItems": [ // ] // } // } // destroy loo_JsonToken destroy loo_Oauth2 destroy loo_Rest destroy loo_JsonPostBody destroy loo_Json |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.