Sample code for 30+ languages & platforms
VBScript

GeoOp - Find Client ID by Name

See more GeoOp Examples

Download the client JSON data and lookup a client ID by name.

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 and send the following GET request:

' GET /users HTTP/1.1
' Host: api.geoop.com
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")

responseBody = rest.FullRequestNoBody("GET","/clients")
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(rest.LastRequestStartLine)
    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.. (see below)
outFile.WriteLine(json.Emit())

' To find the client id for a given company name:
caseSensitive = 0
clientId = json.FindRecordString("clients","companyName","Miller Bakery",caseSensitive,"id")
If (json.LastMethodSuccess <> 1) Then
    outFile.WriteLine("Client not found.")
Else
    outFile.WriteLine("The client ID is: " & clientId)
End If

' Find the client ID for the 1st company matching "M*Bakery*"
clientId = json.FindRecordString("clients","companyName","M*Bakery*",caseSensitive,"id")
If (json.LastMethodSuccess <> 1) Then
    outFile.WriteLine("Client not found.")
Else
    outFile.WriteLine("The client ID is: " & clientId)
End If

' The full JSON response containing all client data:
' 
' 	{
' 	  "result": "success",
' 	  "clients": [
' 	    {
' 	      "id": 9555868,
' 	      "firstName": "[ Demo",
' 	      "lastName": "Client ]",
' 	      "companyName": "Miller Park Cafe",
' 	      "businessType": "Licensed Restaurant",
' 	      "leadSource": "",
' 	      "emailAddress": null,
' 	      "phoneNumber": null,
' 	      "mobileNumber": null,
' 	      "faxNumber": null,
' 	      "notes": "",
' 	      "deleted": false,
' 	      "hasRecentJobs": true,
' 	      "created": "2016-10-26T12:05:09+00:00",
' 	      "modified": "2016-10-26T12:05:09+00:00",
' 	      "billingClient": null,
' 	      "account": {
' 	        "id": 39409
' 	      },
' 	      "address": {
' 	        "line1": "1732 Pennsylvania Avenue NW",
' 	        "line2": "",
' 	        "city": "Washington",
' 	        "postcode": "20006",
' 	        "latitude": 38.899037,
' 	        "longitude": -77.040207
' 	      },
' 	      "mailingAddress": {}
' 	    },
' 	    {
' 	      "id": 9571176,
' 	      "firstName": "Mildred",
' 	      "lastName": "Vanildred",
' 	      "companyName": "Ice Cream Industries",
' 	      "businessType": "Ice Cream",
' 	      "leadSource": null,
' 	      "emailAddress": "milli@icecreamindustries.com",
' 	      "phoneNumber": "678-555-1012",
' 	      "mobileNumber": null,
' 	      "faxNumber": null,
' 	      "notes": "",
' 	      "deleted": false,
' 	      "hasRecentJobs": true,
' 	      "created": "2016-10-31T12:32:12+00:00",
' 	      "modified": "2016-10-31T12:32:13+00:00",
' 	      "billingClient": null,
' 	      "account": {
' 	        "id": 39409
' 	      },
' 	      "address": {
' 	        "line1": "2101 West Roosevelt Road",
' 	        "line2": null,
' 	        "city": "Wheaton",
' 	        "postcode": "60187",
' 	        "latitude": 41.8581778,
' 	        "longitude": -88.1380111
' 	      },
' 	      "mailingAddress": {
' 	        "line1": "2101 West Roosevelt Road",
' 	        "line2": null,
' 	        "city": "Wheaton"
' 	      }
' 	    },
' 	    {
' 	      "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": true,
' 	      "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": {
' 	    "page": 1,
' 	    "pagesCount": 1,
' 	    "recordsPerPage": 20,
' 	    "recordsCount": 3
' 	  }
' 	}
' 

outFile.Close