UNPKG

@scloud/cdk-patterns

Version:

Serverless CDK patterns for common infrastructure needs

245 lines 31.4 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.googleIdp = googleIdp; exports.facebookIdp = facebookIdp; exports.samlIdp = samlIdp; exports.userPoolClient = userPoolClient; exports.cognitoPool = cognitoPool; const aws_cdk_lib_1 = require("aws-cdk-lib"); const aws_certificatemanager_1 = require("aws-cdk-lib/aws-certificatemanager"); const cognito = __importStar(require("aws-cdk-lib/aws-cognito")); const aws_cognito_1 = require("aws-cdk-lib/aws-cognito"); const aws_route53_1 = require("aws-cdk-lib/aws-route53"); const aws_route53_targets_1 = require("aws-cdk-lib/aws-route53-targets"); // @deprecated function googleIdp(construct, name, userPool, idpConfig) { // Google identity provider return new aws_cognito_1.UserPoolIdentityProviderGoogle(construct, `${name}GoogleIDP`, { userPool, clientId: idpConfig.googleClientId || '', clientSecret: idpConfig.googleClientSecret || '', scopes: ['profile', 'email', 'openid'], attributeMapping: { email: cognito.ProviderAttribute.GOOGLE_EMAIL, givenName: cognito.ProviderAttribute.GOOGLE_GIVEN_NAME, familyName: cognito.ProviderAttribute.GOOGLE_FAMILY_NAME, fullname: cognito.ProviderAttribute.GOOGLE_NAME, profilePicture: cognito.ProviderAttribute.GOOGLE_PICTURE, }, // scopes: [ // 'https://www.googleapis.com/auth/userinfo.email', // 'https://www.googleapis.com/auth/userinfo.profile'], }); } // @deprecated function facebookIdp(construct, name, userPool, idpConfig) { return new aws_cognito_1.UserPoolIdentityProviderFacebook(construct, `${name}FacebookIDP`, { userPool, clientId: idpConfig.facebookAppId || '', clientSecret: idpConfig.facebookAppSecret || '', scopes: ['public_profile', 'email'], attributeMapping: { email: cognito.ProviderAttribute.FACEBOOK_EMAIL, givenName: cognito.ProviderAttribute.FACEBOOK_FIRST_NAME, familyName: cognito.ProviderAttribute.FACEBOOK_LAST_NAME, fullname: cognito.ProviderAttribute.FACEBOOK_NAME, }, }); } // @deprecated function samlIdp(construct, name, userPool, samlProvider) { // https://docs.aws.amazon.com/cdk/api/latest/docs/aws-cdk-lib_aws-cognito.CfnUserPoolIdentityProvider.html // https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cognito-userpoolidentityprovider.html const providerDetails = {}; if (samlProvider.FederationMetadataUrl) { providerDetails.MetadataURL = samlProvider.FederationMetadataUrl; } if (samlProvider.FederationMetadataXml) { providerDetails.MetadataFile = samlProvider.FederationMetadataXml; } return new aws_cognito_1.CfnUserPoolIdentityProvider(construct, `${name}SamlIDP${samlProvider.SamlProviderName}`, { userPoolId: userPool.userPoolId, providerName: samlProvider.SamlProviderName || name, providerType: 'SAML', attributeMapping: { // https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-settings-attributes.html given_name: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/givenname', family_name: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/surname', email: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress', }, providerDetails, }); } /** * @deprecated * * Create a Cognito User Pool Client. * @param callbackUrl Authentication callback URL. * @returns cognito.UserPoolClient */ function userPoolClient(construct, name, userPool, callbackUrl, enableEmail, google, facebook, samls, alternativeCallbackUrl) { const identityProviders = []; if (enableEmail) identityProviders.push(aws_cognito_1.UserPoolClientIdentityProvider.COGNITO); if (google) identityProviders.push(aws_cognito_1.UserPoolClientIdentityProvider.GOOGLE); if (facebook) identityProviders.push(aws_cognito_1.UserPoolClientIdentityProvider.FACEBOOK); if (samls) { samls.forEach((saml) => { identityProviders.push(aws_cognito_1.UserPoolClientIdentityProvider.custom(saml.providerName)); }); } const callbackUrls = [callbackUrl]; if (alternativeCallbackUrl) callbackUrls.push(alternativeCallbackUrl); const client = new aws_cognito_1.UserPoolClient(construct, `${name}UserPoolClient`, { userPool, userPoolClientName: name, generateSecret: false, preventUserExistenceErrors: true, supportedIdentityProviders: identityProviders, oAuth: { callbackUrls, flows: { authorizationCodeGrant: true, }, scopes: [ cognito.OAuthScope.EMAIL, cognito.OAuthScope.OPENID, cognito.OAuthScope.PROFILE, ], }, }); if (google) client.node.addDependency(google); if (facebook) client.node.addDependency(facebook); if (samls) { samls.forEach((saml) => client.node.addDependency(saml)); } return client; } /** * @deprecated * * Authentication setup with Cognito. * * NB: IF you want to use a custom domain, the CDK deployment * will fail unless there's an A record at the zone apex. * * @param construct CDK construct ("this") * @param name The name for the user pool and related resources * @param callbackUrl Allowed callback URL * @param idpConfig Identity provider configuration * @param zone If you want a custom domain, pass the zone to create it in * @param domainName If you're passing a zone, you can pass a domain name, * or leave out for a recommended `auth.${zone.zoneName}`. * If not passing a zone, this will be used as a Cognito domain prefix. * @returns Information about the created UserPool */ function cognitoPool(construct, name, callbackUrl, idpConfig, zone, domainName, alternativeCallbackUrl) { // Cognito user pool const userPool = new aws_cognito_1.UserPool(construct, `${name}UserPool`, { userPoolName: name, selfSignUpEnabled: true, accountRecovery: aws_cognito_1.AccountRecovery.EMAIL_ONLY, signInAliases: { username: false, email: true }, removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY, }); // Identity providers const google = idpConfig.googleClientId ? googleIdp(construct, name, userPool, idpConfig) : undefined; const facebook = idpConfig.facebookAppId ? facebookIdp(construct, name, userPool, idpConfig) : undefined; const saml = []; if (idpConfig.FederationMetadataUrl || idpConfig.FederationMetadataXml) { saml.push(samlIdp(construct, name, userPool, idpConfig)); } if (idpConfig.SamlProviders) { idpConfig.SamlProviders.forEach((samlProvider) => { saml.push(samlIdp(construct, name, userPool, samlProvider)); }); } // Production client const client = userPoolClient(construct, name, userPool, callbackUrl, idpConfig.enableEmail, google, facebook, saml, alternativeCallbackUrl); // Custom domain let domain; let signInUrl; if (zone) { // Auth domain name: // AWS recommends auth.<domain> for custom domains // NB at the time of writing there's a hard limit of 4 custom Cognito domains. const authDomainName = domainName || `auth.${zone.zoneName}`; // Custom domain can only be set up after the initial pass has created an A record at the apex domain = new cognito.UserPoolDomain(construct, `${name}UserPoolDomain`, { userPool, customDomain: { domainName: authDomainName, certificate: new aws_certificatemanager_1.DnsValidatedCertificate(construct, `${name}UserPoolCertificate`, { domainName: authDomainName, hostedZone: zone, region: 'us-east-1', // Cloudfront requires this }), }, }); // https://stackoverflow.com/a/62075314/723506 new aws_route53_1.ARecord(construct, `${name}CognitoCustomDomainARecord`, { zone, recordName: authDomainName, target: aws_route53_1.RecordTarget.fromAlias(new aws_route53_targets_1.UserPoolDomainTarget(domain)), }); } else if (domainName) { // Customise the domain prefix domain = new cognito.UserPoolDomain(construct, `${name}UserPoolDomain`, { userPool, cognitoDomain: { domainPrefix: domainName, }, }); } if (domain) signInUrl = domain === null || domain === void 0 ? void 0 : domain.signInUrl(client, { redirectUri: callbackUrl }); return { userPool, domain, client, callbackUrl, signInUrl, }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cognitoDeprecated.js","sourceRoot":"","sources":["../../src/deprecated/cognitoDeprecated.ts"],"names":[],"mappings":"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","sourcesContent":["import { RemovalPolicy } from 'aws-cdk-lib';\nimport { DnsValidatedCertificate } from 'aws-cdk-lib/aws-certificatemanager';\nimport * as cognito from 'aws-cdk-lib/aws-cognito';\nimport {\n  AccountRecovery, CfnUserPoolIdentityProvider, UserPool, UserPoolClient,\n  UserPoolClientIdentityProvider,\n  UserPoolDomain,\n  UserPoolIdentityProviderFacebook,\n  UserPoolIdentityProviderGoogle,\n} from 'aws-cdk-lib/aws-cognito';\nimport {\n  ARecord, IHostedZone, RecordTarget,\n} from 'aws-cdk-lib/aws-route53';\nimport { UserPoolDomainTarget } from 'aws-cdk-lib/aws-route53-targets';\nimport { Construct } from 'constructs';\n\n// @deprecated\nexport interface SamlProvider {\n  FederationMetadataUrl?: string, // SAML XML URL (e.g. Azure)\n  FederationMetadataXml?: string, // SAML metadata XML (e.g. Google Workspace)\n  SamlProviderName?: string, // Name in the Cognito hosted UI under \"Sign in with your corporate ID\"\n}\n\n// @deprecated\nexport interface IdpConfig {\n  enableEmail?: boolean, // Allow email sign-up/in\n  googleClientId?: string,\n  googleClientSecret?: string,\n  facebookAppId?: string,\n  facebookAppSecret?: string,\n  SamlProviders?: SamlProvider[],\n  FederationMetadataUrl?: string, // SAML XML URL (e.g. Azure)\n  FederationMetadataXml?: string, // SAML metadata XML (e.g. Google Workspace)\n  SamlProviderName?: string, // Name in the Cognito hosted UI under \"Sign in with your corporate ID\"\n}\n\n// @deprecated\nexport interface CognitoConstructs {\n  userPool: UserPool,\n  domain?: UserPoolDomain,\n  client: UserPoolClient,\n  callbackUrl: string,\n  signInUrl?: string,\n}\n\n// @deprecated\nexport function googleIdp(\n  construct: Construct,\n  name: string,\n  userPool: UserPool,\n  idpConfig: IdpConfig,\n)\n  : UserPoolIdentityProviderGoogle {\n  // Google identity provider\n  return new UserPoolIdentityProviderGoogle(construct, `${name}GoogleIDP`, {\n    userPool,\n    clientId: idpConfig.googleClientId || '',\n    clientSecret: idpConfig.googleClientSecret || '',\n    scopes: ['profile', 'email', 'openid'],\n    attributeMapping: {\n      email: cognito.ProviderAttribute.GOOGLE_EMAIL,\n      givenName: cognito.ProviderAttribute.GOOGLE_GIVEN_NAME,\n      familyName: cognito.ProviderAttribute.GOOGLE_FAMILY_NAME,\n      fullname: cognito.ProviderAttribute.GOOGLE_NAME,\n      profilePicture: cognito.ProviderAttribute.GOOGLE_PICTURE,\n    },\n    // scopes: [\n    //   'https://www.googleapis.com/auth/userinfo.email',\n    //   'https://www.googleapis.com/auth/userinfo.profile'],\n  });\n}\n\n// @deprecated\nexport function facebookIdp(\n  construct: Construct,\n  name: string,\n  userPool: UserPool,\n  idpConfig: IdpConfig,\n)\n  : UserPoolIdentityProviderFacebook {\n  return new UserPoolIdentityProviderFacebook(construct, `${name}FacebookIDP`, {\n    userPool,\n    clientId: idpConfig.facebookAppId || '',\n    clientSecret: idpConfig.facebookAppSecret || '',\n    scopes: ['public_profile', 'email'],\n    attributeMapping: {\n      email: cognito.ProviderAttribute.FACEBOOK_EMAIL,\n      givenName: cognito.ProviderAttribute.FACEBOOK_FIRST_NAME,\n      familyName: cognito.ProviderAttribute.FACEBOOK_LAST_NAME,\n      fullname: cognito.ProviderAttribute.FACEBOOK_NAME,\n    },\n  });\n}\n\n// @deprecated\nexport function samlIdp(\n  construct: Construct,\n  name: string,\n  userPool: UserPool,\n  samlProvider: SamlProvider,\n): CfnUserPoolIdentityProvider {\n  // https://docs.aws.amazon.com/cdk/api/latest/docs/aws-cdk-lib_aws-cognito.CfnUserPoolIdentityProvider.html\n  // https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-cognito-userpoolidentityprovider.html\n\n  const providerDetails: { [key: string]: string; } = {};\n  if (samlProvider.FederationMetadataUrl) {\n    providerDetails.MetadataURL = samlProvider.FederationMetadataUrl;\n  }\n  if (samlProvider.FederationMetadataXml) {\n    providerDetails.MetadataFile = samlProvider.FederationMetadataXml;\n  }\n\n  return new CfnUserPoolIdentityProvider(construct, `${name}SamlIDP${samlProvider.SamlProviderName}`, {\n    userPoolId: userPool.userPoolId,\n    providerName: samlProvider.SamlProviderName || name,\n    providerType: 'SAML',\n    attributeMapping: {\n      // https://docs.aws.amazon.com/cognito/latest/developerguide/user-pool-settings-attributes.html\n      given_name: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/givenname',\n      family_name: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/surname',\n      email: 'http://schemas.xmlsoap.org/ws/2005/05/identity/claims/emailaddress',\n    },\n    providerDetails,\n  });\n}\n\n/**\n * @deprecated\n *\n * Create a Cognito User Pool Client.\n * @param callbackUrl Authentication callback URL.\n * @returns cognito.UserPoolClient\n */\nexport function userPoolClient(\n  construct: Construct,\n  name: string,\n  userPool: UserPool,\n  callbackUrl: string,\n  enableEmail?: boolean,\n  google?: UserPoolIdentityProviderGoogle,\n  facebook?: UserPoolIdentityProviderFacebook,\n  samls?: CfnUserPoolIdentityProvider[],\n  alternativeCallbackUrl?: string,\n): UserPoolClient {\n  const identityProviders: cognito.UserPoolClientIdentityProvider[] = [];\n  if (enableEmail) identityProviders.push(UserPoolClientIdentityProvider.COGNITO);\n  if (google) identityProviders.push(UserPoolClientIdentityProvider.GOOGLE);\n  if (facebook) identityProviders.push(UserPoolClientIdentityProvider.FACEBOOK);\n  if (samls) {\n    samls.forEach((saml) => {\n      identityProviders.push(UserPoolClientIdentityProvider.custom(saml.providerName));\n    });\n  }\n\n  const callbackUrls = [callbackUrl];\n  if (alternativeCallbackUrl) callbackUrls.push(alternativeCallbackUrl);\n  const client = new UserPoolClient(construct, `${name}UserPoolClient`, {\n    userPool,\n    userPoolClientName: name,\n    generateSecret: false,\n    preventUserExistenceErrors: true,\n    supportedIdentityProviders: identityProviders,\n    oAuth: {\n      callbackUrls,\n      flows: {\n        authorizationCodeGrant: true,\n      },\n      scopes: [\n        cognito.OAuthScope.EMAIL,\n        cognito.OAuthScope.OPENID,\n        cognito.OAuthScope.PROFILE,\n      ],\n    },\n  });\n  if (google) client.node.addDependency(google);\n  if (facebook) client.node.addDependency(facebook);\n  if (samls) {\n    samls.forEach((saml) => client.node.addDependency(saml));\n  }\n\n  return client;\n}\n\n/**\n * @deprecated\n *\n * Authentication setup with Cognito.\n *\n * NB: IF you want to use a custom domain, the CDK deployment\n * will fail unless there's an A record at the zone apex.\n *\n * @param construct CDK construct (\"this\")\n * @param name The name for the user pool and related resources\n * @param callbackUrl Allowed callback URL\n * @param idpConfig Identity provider configuration\n * @param zone If you want a custom domain, pass the zone to create it in\n * @param domainName If you're passing a zone, you can pass a domain name,\n * or leave out for a recommended `auth.${zone.zoneName}`.\n * If not passing a zone, this will be used as a Cognito domain prefix.\n * @returns Information about the created UserPool\n */\nexport function cognitoPool(\n  construct: Construct,\n  name: string,\n  callbackUrl: string,\n  idpConfig: IdpConfig,\n  zone?: IHostedZone,\n  domainName?: string,\n  alternativeCallbackUrl? : string,\n): CognitoConstructs {\n  // Cognito user pool\n  const userPool = new UserPool(construct, `${name}UserPool`, {\n    userPoolName: name,\n    selfSignUpEnabled: true,\n    accountRecovery: AccountRecovery.EMAIL_ONLY,\n    signInAliases: { username: false, email: true },\n    removalPolicy: RemovalPolicy.DESTROY,\n  });\n\n  // Identity providers\n  const google = idpConfig.googleClientId\n    ? googleIdp(construct, name, userPool, idpConfig) : undefined;\n  const facebook = idpConfig.facebookAppId\n    ? facebookIdp(construct, name, userPool, idpConfig) : undefined;\n  const saml = [];\n\n  if (idpConfig.FederationMetadataUrl || idpConfig.FederationMetadataXml) {\n    saml.push(samlIdp(construct, name, userPool, idpConfig));\n  }\n  if (idpConfig.SamlProviders) {\n    idpConfig.SamlProviders.forEach((samlProvider) => {\n      saml.push(samlIdp(\n        construct,\n        name,\n        userPool,\n        samlProvider,\n      ));\n    });\n  }\n  // Production client\n  const client = userPoolClient(\n    construct,\n    name,\n    userPool,\n    callbackUrl,\n    idpConfig.enableEmail,\n    google,\n    facebook,\n    saml,\n    alternativeCallbackUrl,\n  );\n\n  // Custom domain\n  let domain: UserPoolDomain | undefined;\n  let signInUrl: string | undefined;\n  if (zone) {\n    // Auth domain name:\n    // AWS recommends auth.<domain> for custom domains\n    // NB at the time of writing there's a hard limit of 4 custom Cognito domains.\n    const authDomainName = domainName || `auth.${zone.zoneName}`;\n\n    // Custom domain can only be set up after the initial pass has created an A record at the apex\n    domain = new cognito.UserPoolDomain(construct, `${name}UserPoolDomain`, {\n      userPool,\n      customDomain: {\n        domainName: authDomainName,\n        certificate: new DnsValidatedCertificate(construct, `${name}UserPoolCertificate`, {\n          domainName: authDomainName,\n          hostedZone: zone,\n          region: 'us-east-1', // Cloudfront requires this\n        }),\n      },\n    });\n\n    // https://stackoverflow.com/a/62075314/723506\n    new ARecord(construct, `${name}CognitoCustomDomainARecord`, {\n      zone,\n      recordName: authDomainName,\n      target: RecordTarget.fromAlias(\n        new UserPoolDomainTarget(domain),\n      ),\n    });\n  } else if (domainName) {\n    // Customise the domain prefix\n    domain = new cognito.UserPoolDomain(construct, `${name}UserPoolDomain`, {\n      userPool,\n      cognitoDomain: {\n        domainPrefix: domainName,\n      },\n    });\n  }\n\n  if (domain) signInUrl = domain?.signInUrl(client, { redirectUri: callbackUrl });\n\n  return {\n    userPool,\n    domain,\n    client,\n    callbackUrl,\n    signInUrl,\n  };\n}\n"]}