Amazon Cognito is a powerful service provided by AWS that allows you to manage user identities and authentication for your applications easily. In this short guide, I will walk you through the steps to create a Cognito User Pool, a fundamental component for handling user sign-ups, sign-ins, and identity management. Let’s get started!
Step One: Configure Sign-in Experience
- Go to the Amazon Cognito Console.
- Select User Pools and click on Create user pool.
- Under the Configure sign-in experience, check Federated Identity providers
- Check Email and Phone Number for Cognito User Pool Sign-in Options
- Under the Federated sign-in options, check the desired providers (e.g., Facebook, Google, Sign in with Apple). You can configure these options later.
data:image/s3,"s3://crabby-images/218a4/218a4cbccab807f82a947673ca6f15c496b986cb" alt=""
data:image/s3,"s3://crabby-images/3a741/3a7418741115be24c8c6c1531beae002d33dd445" alt=""
Step Two: Configure Security Requirements
- Leave Cognito Defaults for Password Policy
- Configure Multi-Factor Authentication (MFA) as per your security requirements.
- Disable Self-Service Account Recovery
data:image/s3,"s3://crabby-images/ca9e8/ca9e88eeb042ec11483393b2cfb27120a27333c2" alt=""
data:image/s3,"s3://crabby-images/e0f68/e0f688cb7ace58fdcba9fc356c46fcab73d7b31f" alt=""
Step Three: Configure Sign-Up Experience
- Disable Self-Registration
- Uncheck Allow Cognito to Automatically Send Messages
- Leave Required Attributes and Custom Attributes as Default
data:image/s3,"s3://crabby-images/cd6f6/cd6f6103db460aa403be676ffd0ee4335511e437" alt=""
data:image/s3,"s3://crabby-images/5e057/5e0578a29c8cd0d7758498aba73164611d44e4df" alt=""
data:image/s3,"s3://crabby-images/c5b71/c5b71fe5a7db213e8d2acd3b3c5c7eab2b0f8b2f" alt=""
Step Four: Configure Message Delivery
- Leave Email Provider as Send Email with Amazon SES
- Choose Your Region
- Choose an email address that you have verified with Amazon SES
- Configure SMS IAM Role. (Create a new role or choose an existing role)
data:image/s3,"s3://crabby-images/a4324/a432443e398df817a74dae285a1be1a7ce3398c6" alt=""
data:image/s3,"s3://crabby-images/ea54f/ea54f56477742769560ed240dc1e35fbbe2d5e76" alt=""
Step Five: Connect Federated Identity Providers
- When prompted to register your app with Google, Facebook, and Apple, you can skip this step for now.
data:image/s3,"s3://crabby-images/c4935/c4935a3365386804b59db35e600f8a3f693a781c" alt=""
Step Six: Integrate Your App
- Enter the User Pool name
- Select Use a Cognito domain, and provide a unique Cognito Domain name.
- For the initial app client, choose Public client, set the App client name, and choose to generate a client secret if needed.
- Specify allowed callback URLs .
data:image/s3,"s3://crabby-images/8b248/8b248597999d3bc06ad43c16f20afebf4007eafe" alt=""
![]() | Matthew Mendez, Junior DevOps Engineer Matt is a Junior DevOps Engineer at Keyva. He has experience working with AWS, Azure, and GCP. Most recently, he worked on a project supporting Azure subscriptions and operationalizing client facing workloads using Terraform. He works on projects involving cloud automation, container technologies, IT operational strategies and implementations, and more. |