VBScript
VBScript
GeoOp - Create Client
See more GeoOp Examples
Creates a new client.Chilkat VBScript Downloads
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)
success = 0
' 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}
set jsonToken = CreateObject("Chilkat.JsonObject")
success = jsonToken.LoadFile("qa_data/tokens/geoop.json")
' This example assumes we previously obtained an access token
set oauth2 = CreateObject("Chilkat.OAuth2")
oauth2.AccessToken = jsonToken.StringOf("access_token")
set rest = CreateObject("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.
bAutoReconnect = 1
success = rest.Connect("api.geoop.com",443,1,bAutoReconnect)
If (success <> 1) Then
outFile.WriteLine(rest.LastErrorText)
WScript.Quit
End If
' Provide the authentication credentials (i.e. the access token)
success = rest.SetAuthOAuth2(oauth2)
' Set the X-Version header.
success = rest.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",
' }
' }
' }
set jsonClient = CreateObject("Chilkat.JsonObject")
success = jsonClient.UpdateInt("clients[0].account.id",39409)
success = jsonClient.UpdateString("clients[0].firstName","Joe")
success = jsonClient.UpdateString("clients[0].lastName","Miller")
success = jsonClient.UpdateString("clients[0].companyName","Miller Bakery")
success = jsonClient.UpdateString("clients[0].businessType","Licensed Bakery")
success = jsonClient.UpdateString("clients[0].address.line1","1832 Pennsylvania Avenue NW")
success = jsonClient.UpdateString("clients[0].address.city","Washington")
success = jsonClient.UpdateString("clients[0].address.postcode","20006")
' Examine the JSON we're about to send...
jsonClient.EmitCompact = 0
outFile.WriteLine(jsonClient.Emit())
success = rest.AddHeader("Content-Type","application/json")
jsonClient.EmitCompact = 1
responseBody = rest.FullRequestString("POST","/clients",jsonClient.Emit())
If (rest.LastMethodSuccess <> 1) Then
outFile.WriteLine(rest.LastErrorText)
WScript.Quit
End If
set json = CreateObject("Chilkat.JsonObject")
json.EmitCompact = 0
' If the response status code did not indicate success, then see what happened..
If (rest.ResponseStatusCode <> 200) Then
outFile.WriteLine("Request Header: ")
outFile.WriteLine(rest.LastRequestHeader)
outFile.WriteLine("----")
outFile.WriteLine("Response StatusCode = " & rest.ResponseStatusCode)
outFile.WriteLine("Response StatusLine: " & rest.ResponseStatusText)
outFile.WriteLine("Response Header:")
outFile.WriteLine(rest.ResponseHeader)
success = json.Load(responseBody)
outFile.WriteLine(json.Emit())
WScript.Quit
End If
success = json.Load(responseBody)
' Show the full JSON response..
outFile.WriteLine(json.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": [
' ]
' }
' }
'
'
outFile.Close