Sample code for 30+ languages & platforms
VBScript

GeoOp - Create Client

See more GeoOp Examples

Creates a new client.

Chilkat VBScript Downloads

VBScript
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