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
(Perl) GeoOp - Mark a User as DeletedMark one or more users as deleted.
use chilkat(); # 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 = chilkat::CkJsonObject->new(); $success = $jsonToken->LoadFile("qa_data/tokens/geoop.json"); # This example assumes we previously obtained an access token $oauth2 = chilkat::CkOAuth2->new(); $oauth2->put_AccessToken($jsonToken->stringOf("access_token")); $rest = chilkat::CkRest->new(); # 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. $bAutoReconnect = 1; $success = $rest->Connect("api.geoop.com",443,1,$bAutoReconnect); if ($success != 1) { print $rest->lastErrorText() . "\r\n"; exit; } # Provide the authentication credentials (i.e. the access token) $rest->SetAuthOAuth2($oauth2); # Set the X-Version header. $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 # } # ] # } $jsonPostBody = chilkat::CkJsonObject->new(); $jsonPostBody->UpdateInt("users[0].id",115); $jsonPostBody->UpdateBool("users[0].deleted",1); $jsonPostBody->UpdateInt("users[1].id",116); $jsonPostBody->UpdateBool("users[1].deleted",1); # Continue adding more users as needed.. # Examine the JSON we're about to send... $jsonPostBody->put_EmitCompact(0); print $jsonPostBody->emit() . "\r\n"; $rest->AddHeader("Content-Type","application/json"); $jsonPostBody->put_EmitCompact(1); $responseBody = $rest->fullRequestString("PATCH","/users",$jsonPostBody->emit()); if ($rest->get_LastMethodSuccess() != 1) { print $rest->lastErrorText() . "\r\n"; exit; } $json = chilkat::CkJsonObject->new(); $json->put_EmitCompact(0); # If the response status code did not indicate success, then see what happened.. if ($rest->get_ResponseStatusCode() != 200) { print "Request Header: " . "\r\n"; print $rest->lastRequestHeader() . "\r\n"; print "----" . "\r\n"; print "Response StatusCode = " . $rest->get_ResponseStatusCode() . "\r\n"; print "Response StatusLine: " . $rest->responseStatusText() . "\r\n"; print "Response Header:" . "\r\n"; print $rest->responseHeader() . "\r\n"; $json->Load($responseBody); print $json->emit() . "\r\n"; # 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 # ] # } # } # exit; } $json->Load($responseBody); # Show the full JSON response.. print $json->emit() . "\r\n"; # 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": [ # ] # } # } # |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.