Visual Basic 6.0
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
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