Lianja
Lianja
GeoOp - Create Client
See more GeoOp Examples
Creates a new client.Chilkat Lianja Downloads
llSuccess = .F.
// 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}
loJsonToken = createobject("CkJsonObject")
llSuccess = loJsonToken.LoadFile("qa_data/tokens/geoop.json")
// This example assumes we previously obtained an access token
loOauth2 = createobject("CkOAuth2")
loOauth2.AccessToken = loJsonToken.StringOf("access_token")
loRest = createobject("CkRest")
// 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.
llBAutoReconnect = .T.
llSuccess = loRest.Connect("api.geoop.com",443,.T.,llBAutoReconnect)
if (llSuccess <> .T.) then
? loRest.LastErrorText
release loJsonToken
release loOauth2
release loRest
return
endif
// Provide the authentication credentials (i.e. the access token)
loRest.SetAuthOAuth2(loOauth2)
// Set the X-Version header.
loRest.AddHeader("X-Version","1.0")
// To create a new client, we can build and send the following JSON:
// {
// "clients": [
// {
// "firstName": "Joe",
// "lastName": "Miller",
// "companyName": "Miller Bakery",
// "businessType": "Licensed Bakery",
// "account": {
// "id": 39409
// },
// "address": {
// "line1": "1832 Pennsylvania Avenue NW",
// "city": "Washington",
// "postcode": "20006",
// }
// }
// }
loJsonClient = createobject("CkJsonObject")
loJsonClient.UpdateInt("clients[0].account.id",39409)
loJsonClient.UpdateString("clients[0].firstName","Joe")
loJsonClient.UpdateString("clients[0].lastName","Miller")
loJsonClient.UpdateString("clients[0].companyName","Miller Bakery")
loJsonClient.UpdateString("clients[0].businessType","Licensed Bakery")
loJsonClient.UpdateString("clients[0].address.line1","1832 Pennsylvania Avenue NW")
loJsonClient.UpdateString("clients[0].address.city","Washington")
loJsonClient.UpdateString("clients[0].address.postcode","20006")
// Examine the JSON we're about to send...
loJsonClient.EmitCompact = .F.
? loJsonClient.Emit()
loRest.AddHeader("Content-Type","application/json")
loJsonClient.EmitCompact = .T.
lcResponseBody = loRest.FullRequestString("POST","/clients",loJsonClient.Emit())
if (loRest.LastMethodSuccess <> .T.) then
? loRest.LastErrorText
release loJsonToken
release loOauth2
release loRest
release loJsonClient
return
endif
loJson = createobject("CkJsonObject")
loJson.EmitCompact = .F.
// If the response status code did not indicate success, then see what happened..
if (loRest.ResponseStatusCode <> 200) then
? "Request Header: "
? loRest.LastRequestHeader
? "----"
? "Response StatusCode = " + str(loRest.ResponseStatusCode)
? "Response StatusLine: " + loRest.ResponseStatusText
? "Response Header:"
? loRest.ResponseHeader
loJson.Load(lcResponseBody)
? loJson.Emit()
release loJsonToken
release loOauth2
release loRest
release loJsonClient
release loJson
return
endif
loJson.Load(lcResponseBody)
// Show the full JSON response..
? loJson.Emit()
// The success JSON looks like this:
// {
// "result": "success",
// "clients": [
// {
// "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": false,
// "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": {
// "receivedItemsCount": 1,
// "validItems": [
// 0
// ],
// "invalidItems": [
// ]
// }
// }
//
//
release loJsonToken
release loOauth2
release loRest
release loJsonClient
release loJson