Sample code for 30+ languages & platforms
Visual Basic 6.0

Amazon Cognito - List Users

See more Amazon Cognito Examples

Lists the users in the Amazon Cognito user pool.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

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

Dim rest As New ChilkatRest

Dim authAws As New ChilkatAuthAws
authAws.AccessKey = "AWS_ACCESS_KEY"
authAws.SecretKey = "AWS_SECRET_KEY"
' Don't forget to change the region to your particular region. (Also make the same change in the call to Connect below.)
authAws.Region = "us-west-2"
authAws.ServiceName = "cognito-idp"
' SetAuthAws causes Chilkat to automatically add the following headers: Authorization, X-Amz-Date
success = rest.SetAuthAws(authAws)

' URL: https://cognito-idp.us-west-2.amazonaws.com/
Dim bTls As Long
bTls = 1
Dim port As Long
port = 443
Dim bAutoReconnect As Long
bAutoReconnect = 1
' Use the same region as specified above.
success = rest.Connect("cognito-idp.us-west-2.amazonaws.com",port,bTls,bAutoReconnect)
If (success <> 1) Then
    Debug.Print "ConnectFailReason: " & rest.ConnectFailReason
    Debug.Print rest.LastErrorText
    Exit Sub
End If

' Note: The above code does not need to be repeatedly called for each REST request.
' The rest object can be setup once, and then many requests can be sent.  Chilkat will automatically
' reconnect within a FullRequest* method as needed.  It is only the very first connection that is explicitly
' made via the Connect method.

' The following JSON is sent in the request body.

' {
'     "UserPoolId": "us-west-2_yt6WzO3SA"
' }
' 

Dim json As New ChilkatJsonObject
success = json.UpdateString("UserPoolId","us-west-2_yt6WzO3SA")

success = rest.AddHeader("Content-Type","application/x-amz-json-1.0")
success = rest.AddHeader("X-Amz-Target","AWSCognitoIdentityProviderService.ListUsers")
success = rest.AddHeader("Accept-Encoding","identity")

Dim sbRequestBody As New ChilkatStringBuilder
success = json.EmitSb(sbRequestBody)
Dim sbResponseBody As New ChilkatStringBuilder
success = rest.FullRequestSb("POST","/",sbRequestBody,sbResponseBody)
If (success <> 1) Then
    Debug.Print rest.LastErrorText
    Exit Sub
End If

Dim respStatusCode As Long
respStatusCode = rest.ResponseStatusCode
Debug.Print "response status code = " & respStatusCode
If (respStatusCode <> 200) Then
    Debug.Print "Response Status Code = " & respStatusCode
    Debug.Print "Response Header:"
    Debug.Print rest.ResponseHeader
    Debug.Print "Response Body:"
    Debug.Print sbResponseBody.GetAsString()
    Exit Sub
End If

Dim jsonResponse As New ChilkatJsonObject
success = jsonResponse.LoadSb(sbResponseBody)

jsonResponse.EmitCompact = 0
Debug.Print jsonResponse.Emit()

' Sample JSON response:
' (Sample code for parsing the JSON response is shown below)

' Use this online tool to generate parsing code from sample JSON: 
' Generate Parsing Code from JSON

' {
'   "Users": [
'     {
'       "Attributes": [
'         {
'           "Name": "sub",
'           "Value": "1874cf28-00d3-4ac1-a24a-68dcb0cecf09"
'         },
'         {
'           "Name": "email_verified",
'           "Value": "true"
'         },
'         {
'           "Name": "phone_number_verified",
'           "Value": "true"
'         },
'         {
'           "Name": "phone_number",
'           "Value": "+16302581871"
'         },
'         {
'           "Name": "email",
'           "Value": "admin@chilkatsoft.com"
'         }
'       ],
'       "Enabled": true,
'       "UserCreateDate": 1.636404386657E9,
'       "UserLastModifiedDate": 1.636404386657E9,
'       "UserStatus": "FORCE_CHANGE_PASSWORD",
'       "Username": "matt"
'     },
'     {
' 	. . .
'     }
'   ]
' }

Dim Enabled As Long
Dim UserCreateDate As String
Dim UserLastModifiedDate As String
Dim UserStatus As String
Dim Username As String
Dim j As Long
Dim count_j As Long
Dim Name As String
Dim Value As String

Dim i As Long
i = 0
Dim count_i As Long
count_i = jsonResponse.SizeOfArray("Users")
Do While i < count_i
    jsonResponse.I = i
    Enabled = jsonResponse.BoolOf("Users[i].Enabled")
    UserCreateDate = jsonResponse.StringOf("Users[i].UserCreateDate")
    UserLastModifiedDate = jsonResponse.StringOf("Users[i].UserLastModifiedDate")
    UserStatus = jsonResponse.StringOf("Users[i].UserStatus")
    Username = jsonResponse.StringOf("Users[i].Username")
    j = 0
    count_j = jsonResponse.SizeOfArray("Users[i].Attributes")
    Do While j < count_j
        jsonResponse.J = j
        Name = jsonResponse.StringOf("Users[i].Attributes[j].Name")
        Value = jsonResponse.StringOf("Users[i].Attributes[j].Value")
        j = j + 1
    Loop
    i = i + 1
Loop