Sample code for 30+ languages & platforms
Visual Basic 6.0

Populi Search People

See more Populi Examples

Demonstrates the Populi searchPeople task.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

' First load the previously obtained API token.
' See Get Populi Access Token for sample code showing how to get the API token.
Dim xml As New ChilkatXml
success = xml.LoadXmlFile("qa_data/tokens/populi_token.xml")
Dim accessKey As String
accessKey = xml.GetChildContent("access_key")
If (xml.LastMethodSuccess <> 1) Then
    Debug.Print "Did not find the access_key"
    Exit Sub
End If

Dim rest As New ChilkatRest

' Connect using TLS.
' A single REST object, once connected, can be used for many Populi REST API calls.
' The auto-reconnect indicates that if the already-established HTTPS connection is closed,
' then it will be automatically re-established as needed.
Dim bAutoReconnect As Long
bAutoReconnect = 1
success = rest.Connect("yourcollege.populi.co",443,1,bAutoReconnect)
If (success <> 1) Then
    Debug.Print rest.LastErrorText
    Exit Sub
End If

rest.Authorization = accessKey

success = rest.AddQueryParam("task","searchPeople")
success = rest.AddQueryParam("search_term","Robert")
success = rest.AddQueryParam("limit","10")

Dim responseBody As String
responseBody = rest.FullRequestFormUrlEncoded("POST","/api/index.php")
If (rest.LastMethodSuccess <> 1) Then
    Debug.Print rest.LastErrorText
    Exit Sub
End If

' We should expect a 200 response if successful.
If (rest.ResponseStatusCode <> 200) Then
    Debug.Print "Request Header: "
    Debug.Print rest.LastRequestHeader
    Debug.Print "----"
    Debug.Print "Response StatusCode = " & rest.ResponseStatusCode
    Debug.Print "Response StatusLine: " & rest.ResponseStatusText
    Debug.Print "Response Header:"
    Debug.Print rest.ResponseHeader
    Debug.Print "Response Body:"
    Debug.Print responseBody
    Exit Sub
End If

success = xml.LoadXml(responseBody)
Debug.Print xml.GetXml()

' Sample response:
' Use this online tool to generate parsing code from sample XML: 
' Generate Parsing Code from XML

' <?xml version="1.0" encoding="UTF-8"?>
'  <response>
' 	<person>
' 		<id>11111</id>
' 		<first_name>Robert</first_name>
' 		<last_name>McStudent</last_name>
' 		<middle_name>Kensington</middle_name>
' 		<preferred_name>Bobby</preferred_name>
' 		<is_user>1</is_user>
' 		<primary_email>r.mcstudent@myschool.edu</primary_email>
' 	</person>
' 	<person>
' 		<id>2222</id>
' 		<first_name>Robert</first_name>
' 		<last_name>McBoardmember</last_name>
' 		<middle_name/>
' 		<preferred_name/>
' 		<is_user>0</is_user>
' 		<primary_email>robert@gmail.com</primary_email>
' 	</person>
' </response>

Dim i As Long
Dim count_i As Long
Dim id As Long
Dim first_name As String
Dim last_name As String
Dim middle_name As String
Dim preferred_name As String
Dim is_user As Long
Dim primary_email As String

i = 0
count_i = xml.NumChildrenHavingTag("person")
Do While i < count_i
    xml.I = i
    id = xml.GetChildIntValue("person[i]|id")
    first_name = xml.GetChildContent("person[i]|first_name")
    last_name = xml.GetChildContent("person[i]|last_name")
    middle_name = xml.GetChildContent("person[i]|middle_name")
    preferred_name = xml.GetChildContent("person[i]|preferred_name")
    is_user = xml.GetChildIntValue("person[i]|is_user")
    primary_email = xml.GetChildContent("person[i]|primary_email")
    i = i + 1
Loop