Sample code for 30+ languages & platforms
Classic ASP

Amazon Cognito - List Users

See more Amazon Cognito Examples

Lists the users in the Amazon Cognito user pool.

Chilkat Classic ASP Downloads

Classic ASP
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head>
<body>
<%
success = 0

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

set rest = Server.CreateObject("Chilkat.Rest")

set authAws = Server.CreateObject("Chilkat.AuthAws")
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/
bTls = 1
port = 443
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
    Response.Write "<pre>" & Server.HTMLEncode( "ConnectFailReason: " & rest.ConnectFailReason) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
    Response.End
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"
' }
' 

set json = Server.CreateObject("Chilkat.JsonObject")
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")

set sbRequestBody = Server.CreateObject("Chilkat.StringBuilder")
success = json.EmitSb(sbRequestBody)
set sbResponseBody = Server.CreateObject("Chilkat.StringBuilder")
success = rest.FullRequestSb("POST","/",sbRequestBody,sbResponseBody)
If (success <> 1) Then
    Response.Write "<pre>" & Server.HTMLEncode( rest.LastErrorText) & "</pre>"
    Response.End
End If

respStatusCode = rest.ResponseStatusCode
Response.Write "<pre>" & Server.HTMLEncode( "response status code = " & respStatusCode) & "</pre>"
If (respStatusCode <> 200) Then
    Response.Write "<pre>" & Server.HTMLEncode( "Response Status Code = " & respStatusCode) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Response Header:") & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( rest.ResponseHeader) & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( "Response Body:") & "</pre>"
    Response.Write "<pre>" & Server.HTMLEncode( sbResponseBody.GetAsString()) & "</pre>"
    Response.End
End If

set jsonResponse = Server.CreateObject("Chilkat.JsonObject")
success = jsonResponse.LoadSb(sbResponseBody)

jsonResponse.EmitCompact = 0
Response.Write "<pre>" & Server.HTMLEncode( jsonResponse.Emit()) & "</pre>"

' 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"
'     },
'     {
' 	. . .
'     }
'   ]
' }

i = 0
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

%>
</body>
</html>