Skip to content

trussworks/terraform-aws-saml-cognito

terraform-aws-saml-cognito

Provisions AWS Cognito resources for connecting SAML authentication.

This gives you a user pool, user pool client, and user pool domain (using a custom domain with a certificate and both A and AAAA records), which can be used with ALB's authentication support.

Usage Example

In order to use this module, you will need to define a us-east-1 provider using the following code:

provider "aws" {
  alias  = "us-east-1"
  region = "us-east-1"
}

Process wise, you'll need to setup and download the SAML Metadata XML file from your chosen IDP, then create the Terraform resources.

Using GSuite for example, you'll use the following configuration values in the GSuite admin:

  • ACS URL: https://{dns_name}/saml2/idpresponse
  • Entity ID: urn:amazon:cognito:sp:{id} where id is the final component of the Cognito User Pool ARN.
  • Name ID Format: EMAIL
  • Attribute Mapping:
    • Add a value named email which maps to Primary Email
module "saml_cognito" {
  source = "trussworks/saml-cognito/aws"

  name                                   = "GSuiteSAML"
  dns_name                               = "cognito-sso.my-corp.com"
  zone_id                                = aws_route53_zone.my_corp.zone_id
  saml_metadata_file_content             = file("cognito-gsuite-saml-metadata.xml")
  saml_metadata_sso_redirect_binding_uri = "https://accounts.google.com/o/saml2/idp?idpid=<id>"
  relying_party_dns_names                = ["my-app.int.my-corp.com", "my-other-app.int.my-corp.com"]

  providers = {
    aws           = aws
    aws.us-east-1 = aws.us-east-1
  }
}

This will leave you with Cognito resources, that use https://cognito-sso.my-corp.com as the domain that is a RP for the GSuite SAML IDP. It can be used to provide authentication for apps running on the domains my-app.int.my-corp.com and my-other-app.int.my-corp.com.

Requirements

Name Version
terraform >= 1.0
aws >= 3.0

Providers

Name Version
aws >= 3.0

Modules

Name Source Version
auth_domain_certificate trussworks/acm-cert/aws n/a

Resources

Name Type
aws_cognito_identity_provider.saml resource
aws_cognito_user_pool.saml resource
aws_cognito_user_pool_client.saml resource
aws_cognito_user_pool_domain.saml resource
aws_route53_record.cognito_auth resource
aws_route53_record.cognito_auth_ipv6 resource
aws_route53_zone.selected data source

Inputs

Name Description Type Default Required
dns_name DNS name for the authenticate page (e.g. auth.my-company.com) string n/a yes
environment Environment tag. e.g. prod string n/a yes
name Name for the various cognito resources string n/a yes
relying_party_dns_names List of DNS names for the relying parties (i.e. the applications you are authenticating with this) list(string) n/a yes
saml_metadata_file_content Contents of the SAML metadata file string n/a yes
saml_metadata_sso_redirect_binding_uri The HTTP-Redirect SSO binding from the SAML metadata file. Must be kept in sync with saml_metadata_file_content! string n/a yes
zone_id Route53 zone id to put DNS records in string n/a yes

Outputs

Name Description
cognito_user_pool_arn ARN for the Cognito User Pool
cognito_user_pool_client_id ID for the Cognito User Pool Client
cognito_user_pool_domain Name for the Cognito User Pool Domain

Attribution

This module has been based on alloy-commons/alloy-open-source