Sample code for 30+ languages & platforms
Visual Basic 6.0

Amazon Cognito - List User Pools

See more Amazon Cognito Examples

Lists the user pools associated with an AWS account.

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.

Dim json As New ChilkatJsonObject
success = json.UpdateInt("MaxResults",60)

success = rest.AddHeader("Content-Type","application/x-amz-json-1.0")
success = rest.AddHeader("X-Amz-Target","AWSCognitoIdentityProviderService.ListUserPools")
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

' {
'   "UserPools": [
'     {
'       "CreationDate": 1.636388909817E9,
'       "Id": "us-west-2_yt6WzO3SA",
'       "LambdaConfig": {},
'       "LastModifiedDate": 1.636388910377E9,
'       "Name": "chilkat"
'     }
'   ]
' }

Dim CreationDate As String
Dim Id As String
Dim LastModifiedDate As String
Dim Name As String

Dim i As Long
i = 0
Dim count_i As Long
count_i = jsonResponse.SizeOfArray("UserPools")
Do While i < count_i
    jsonResponse.I = i
    CreationDate = jsonResponse.StringOf("UserPools[i].CreationDate")
    Id = jsonResponse.StringOf("UserPools[i].Id")
    LastModifiedDate = jsonResponse.StringOf("UserPools[i].LastModifiedDate")
    Name = jsonResponse.StringOf("UserPools[i].Name")
    i = i + 1
Loop