User Pools
Userpools securely store your users and provide sign-up, sign-in, and access control for your applications.
Userpools support OAuth 2.0, SAML 2.0, and OpenID Connect standards.
Userpools can be integrated with HTTP API Gateways using authorizers to provide access only for authenticated users.
When to use
Userpools can be used almost anytime your application needs to authenticate and authorize users.
Advantages
- Pay-per-MAU - You pay for Monthly Active Users.
- Free-tier - There's a free tier of 50,000 MAUs for users who sign in directly to Cognito User Pools (not using SAML or OIDC federation).
- Serverless - You can seamlessly scale your userbase almost indefinitely.
- Secure by default - Your users are securely stored by AWS.
- Compliant - With userpools, you are HIPAA eligible and PCI DSS, SOC, ISO/IEC 27001, ISO/IEC 27017, ISO/IEC 27018, and ISO 9001 compliant by default.
Disadvantages
- Not cheap for large user bases - When you have more than 50,000 MAUs or many users with SAML or OIDC federation, can get expensive.
- Not easy to understand - Similarly to almost everything related to authentication or OAUTH, understanding user pool authentication flows can be complicated.
Basic usage
- Example: Lambda function connected to HTTP API Gateway with authorizer that allows only users authenticated using
myUserPool
to access the configured path.
resources:createPost:type: functionproperties:packageConfig:filePath: src/index.tsevents:- type: http-api-gatewayproperties:httpApiGatewayName: myGatewaypath: /post/createmethod: POSTauthorizer:type: cognitoproperties:userPoolName: myUserPoolmyUserPool:type: user-auth-poolproperties:userVerificationType: email-codepasswordPolicy:minimumLength: 8
API reference
No description
Type: string "user-auth-pool"
Type: boolean
Type: number
Type: boolean
Type: boolean
Type: string
Type: string
Type: UserPoolHooks
Type: EmailConfiguration
Type: InviteMessageConfig
Type: string ENUM
Possible values: email-codeemail-linknonesms
Type: string ENUM
Type: MfaConfiguration
Type: PasswordPolicy
No description
Type: Array of AttributeSchema
Type: boolean
Type: boolean
Type: number
Type: number
Type: number
Type: Array of string ENUM
Possible values: client_credentialscodeimplicit
Type: Array of string ENUM
Type: Array of string
Type: Array of string
Type: Array of string
Type: Array of IdentityProvider
Type: Object
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string
No description
Type: string ENUM
Possible values: OFFONOPTIONAL
No description
Type: Array of string ENUM
Possible values: SMSSOFTWARE_TOKEN
No description
Type: number
No description
Type: boolean
No description
Type: boolean
No description
Type: boolean
No description
Type: boolean
No description
Type: number
No description
Type: string
No description
Type: string
No description
Type: boolean
No description
Type: boolean
No description
Type: boolean
No description
Type: number
No description
Type: number
No description
Type: number
No description
Type: number
No description
Type: string ENUM
Possible values: FacebookGoogleLoginWithAmazonOIDCSAMLSignInWithApple
No description
Type: string
No description
Type: string
No description
Type: Object - { string : string }
No description
Type: Array of string
No description
Type: Object - { string : any }