Follow the procedures for the target OIDC provider, and note the values for the OIDC client ID and secret. Also issuer URL is required on the following steps. If redirect URI is needed for the setup process, enter dummy value, which will be replaced after deployment completed.
-
Go to the AWS Management Console.
-
Navigate to Secrets Manager and choose "Store a new secret".
-
Select "Other type of secrets".
-
Input the client ID and client secret as key-value pairs.
- Key:
clientId
, Value: <YOUR_GOOGLE_CLIENT_ID> - Key:
clientSecret
, Value: <YOUR_GOOGLE_CLIENT_SECRET> - Key:
issuerUrl
, Value: <ISSUER_URL_OF_THE_PROVIDER>
- Key:
-
Follow the prompts to name and describe the secret. Note the secret name as you will need it in your CDK code (Used in Step 3 variable name <YOUR_SECRET_NAME>).
-
Review and store the secret.
The key names must exactly match the strings clientId
, clientSecret
and issuerUrl
.
In your cdk.json file, add the ID Provider and SecretName to the cdk.json file.
like so:
{
"context": {
// ...
"identityProviders": [
{
"service": "oidc", // Do not change
"serviceName": "<YOUR_SERVICE_NAME>", // Set any value you like
"secretName": "<YOUR_SECRET_NAME>"
}
],
"userPoolDomainPrefix": "<UNIQUE_DOMAIN_PREFIX_FOR_YOUR_USER_POOL>"
}
}
The userPoolDomainPrefix
must be globally unique across all Amazon Cognito users. If you choose a prefix that's already in use by another AWS account, the creation of the user pool domain will fail. It's a good practice to include identifiers, project names, or environment names in the prefix to ensure uniqueness.
Deploy your CDK stack to AWS:
npx cdk deploy --require-approval never --all
After deploying the stack, AuthApprovedRedirectURI
is showing on the CloudFormation outputs. Go back to your OIDC configuration and update with the correct redirect URIs.