Sample code for 30+ languages & platforms
VBScript

GeoOp - Get a list of all users

See more GeoOp Examples

Gets a list of all GeoOp users.

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 = 0) 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","/users")
If (rest.LastMethodSuccess = 0) Then
    outFile.WriteLine(rest.LastErrorText)
    WScript.Quit
End If

' 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)
    outFile.WriteLine(responseBody)
    WScript.Quit
End If

set json = CreateObject("Chilkat.JsonObject")
json.EmitCompact = 0
success = json.Load(responseBody)
' Show the full JSON response..
outFile.WriteLine(json.Emit())

' These will be used for parsing date/time strings..
set dtime = CreateObject("Chilkat.CkDateTime")
bLocalTime = 1
set dt = CreateObject("Chilkat.DtObj")

' Iterate over each user and get information from each.
numRecords = json.SizeOfArray("users")
i = 0
Do While i < numRecords

    json.I = i
    outFile.WriteLine("id: " & json.StringOf("users[i].id"))
    outFile.WriteLine("firstName: " & json.StringOf("users[i].firstName"))
    outFile.WriteLine("lastName: " & json.StringOf("users[i].lastName"))
    outFile.WriteLine("companyName: " & json.StringOf("users[i].companyName"))
    outFile.WriteLine("active: " & json.IntOf("users[i].active"))
    outFile.WriteLine("isAssignable: " & json.BoolOf("users[i].isAssignable"))
    outFile.WriteLine("account id: " & json.BoolOf("users[i].account.id"))

    success = dtime.SetFromTimestamp(json.StringOf("users[i].created"))
    dtime.ToDtObj bLocalTime,dt

    outFile.WriteLine("created: " & dt.Month & "/" & dt.Day & "/" & dt.Year & "  " & dt.Hour & ":" _
         & dt.Minute)

    outFile.WriteLine("----")
    i = i + 1
Loop

' The responseJson looks like this:
' {
'   "result": "success",
'   "users": [
'     {
'       "id": 984236,
'       "firstName": "Joe",
'       "lastName": "Smith",
'       "companyName": "Chilkat Software, Inc.",
'       "email": "support@chilkatsoft.com",
'       "phone": "",
'       "mobile": "1-630-555-5555",
'       "hourlyRate": 0,
'       "active": 1,
'       "deleted": false,
'       "colour": "#D2BC14",
'       "created": "2016-10-26T12:05:09+00:00",
'       "modified": "2016-10-26T12:05:09+00:00",
'       "isAssignable": true,
'       "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984236.jpg",
'       "role": {
'         "id": 1
'       },
'       "account": {
'         "id": 39409
'       },
'       "status": {}
'     },
'     {
'       "id": 984237,
'       "firstName": "Demo",
'       "lastName": "Employee",
'       "companyName": "",
'       "email": "",
'       "phone": "",
'       "mobile": "58458458475854758",
'       "hourlyRate": 0,
'       "active": 0,
'       "deleted": true,
'       "colour": "#4C4CFF",
'       "created": "2015-09-03T01:56:17+00:00",
'       "modified": "2016-06-14T20:20:58+00:00",
'       "isAssignable": true,
'       "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984237.jpg",
'       "role": {
'         "id": 2
'       },
'       "account": {
'         "id": 39409
'       },
'       "status": {
'         "message": null,
'         "timestamp": "2015-09-03T01:57:45+00:00"
'       }
'     }
'   ],
'   "metadata": {
'     "page": 1,
'     "pagesCount": 1,
'     "recordsPerPage": 20,
'     "recordsCount": 2
'   }
' }
' 
' 

outFile.Close