DataFlex
DataFlex
GeoOp - Mark a User as Deleted
See more GeoOp Examples
Mark one or more users as deleted.Chilkat DataFlex Downloads
Use ChilkatAx-win32.pkg
Procedure Test
Boolean iSuccess
Handle hoJsonToken
Variant vOauth2
Handle hoOauth2
Handle hoRest
Boolean iBAutoReconnect
Handle hoJsonPostBody
String sResponseBody
Handle hoJson
String sTemp1
Integer iTemp1
Boolean bTemp1
Move False To iSuccess
// 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}
Get Create (RefClass(cComChilkatJsonObject)) To hoJsonToken
If (Not(IsComObjectCreated(hoJsonToken))) Begin
Send CreateComObject of hoJsonToken
End
Get ComLoadFile Of hoJsonToken "qa_data/tokens/geoop.json" To iSuccess
// This example assumes we previously obtained an access token
Get Create (RefClass(cComChilkatOAuth2)) To hoOauth2
If (Not(IsComObjectCreated(hoOauth2))) Begin
Send CreateComObject of hoOauth2
End
Get ComStringOf Of hoJsonToken "access_token" To sTemp1
Set ComAccessToken Of hoOauth2 To sTemp1
Get Create (RefClass(cComChilkatRest)) To hoRest
If (Not(IsComObjectCreated(hoRest))) Begin
Send CreateComObject of hoRest
End
// 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.
Move True To iBAutoReconnect
Get ComConnect Of hoRest "api.geoop.com" 443 True iBAutoReconnect To iSuccess
If (iSuccess <> True) Begin
Get ComLastErrorText Of hoRest To sTemp1
Showln sTemp1
Procedure_Return
End
// Provide the authentication credentials (i.e. the access token)
Get pvComObject of hoOauth2 to vOauth2
Get ComSetAuthOAuth2 Of hoRest vOauth2 To iSuccess
// Set the X-Version header.
Get ComAddHeader Of hoRest "X-Version" "1.0" To iSuccess
// 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
// }
// ]
// }
Get Create (RefClass(cComChilkatJsonObject)) To hoJsonPostBody
If (Not(IsComObjectCreated(hoJsonPostBody))) Begin
Send CreateComObject of hoJsonPostBody
End
Get ComUpdateInt Of hoJsonPostBody "users[0].id" 115 To iSuccess
Get ComUpdateBool Of hoJsonPostBody "users[0].deleted" True To iSuccess
Get ComUpdateInt Of hoJsonPostBody "users[1].id" 116 To iSuccess
Get ComUpdateBool Of hoJsonPostBody "users[1].deleted" True To iSuccess
// Continue adding more users as needed..
// Examine the JSON we're about to send...
Set ComEmitCompact Of hoJsonPostBody To False
Get ComEmit Of hoJsonPostBody To sTemp1
Showln sTemp1
Get ComAddHeader Of hoRest "Content-Type" "application/json" To iSuccess
Set ComEmitCompact Of hoJsonPostBody To True
Get ComEmit Of hoJsonPostBody To sTemp1
Get ComFullRequestString Of hoRest "PATCH" "/users" sTemp1 To sResponseBody
Get ComLastMethodSuccess Of hoRest To bTemp1
If (bTemp1 <> True) Begin
Get ComLastErrorText Of hoRest To sTemp1
Showln sTemp1
Procedure_Return
End
Get Create (RefClass(cComChilkatJsonObject)) To hoJson
If (Not(IsComObjectCreated(hoJson))) Begin
Send CreateComObject of hoJson
End
Set ComEmitCompact Of hoJson To False
// If the response status code did not indicate success, then see what happened..
Get ComResponseStatusCode Of hoRest To iTemp1
If (iTemp1 <> 200) Begin
Showln "Request Header: "
Get ComLastRequestHeader Of hoRest To sTemp1
Showln sTemp1
Showln "----"
Get ComResponseStatusCode Of hoRest To iTemp1
Showln "Response StatusCode = " iTemp1
Get ComResponseStatusText Of hoRest To sTemp1
Showln "Response StatusLine: " sTemp1
Showln "Response Header:"
Get ComResponseHeader Of hoRest To sTemp1
Showln sTemp1
Get ComLoad Of hoJson sResponseBody To iSuccess
Get ComEmit Of hoJson To sTemp1
Showln sTemp1
// 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
// ]
// }
// }
//
Procedure_Return
End
Get ComLoad Of hoJson sResponseBody To iSuccess
// Show the full JSON response..
Get ComEmit Of hoJson To sTemp1
Showln sTemp1
// 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": [
// ]
// }
// }
//
End_Procedure