UNPKG

@aws-solutions-constructs/core

Version:
123 lines 18.7 kB
"use strict"; /** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance * with the License. A copy of the License is located at * * http://www.apache.org/licenses/LICENSE-2.0 * * or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES * OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions * and limitations under the License. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.buildUserPool = buildUserPool; exports.buildUserPoolClient = buildUserPoolClient; exports.buildIdentityPool = buildIdentityPool; exports.setupCognitoForSearchService = setupCognitoForSearchService; exports.buildCognitoForSearchService = buildCognitoForSearchService; /* * The functions found here in the core library are for internal use and can be changed * or removed outside of a major release. We recommend against calling them directly from client code. */ const cognito = require("aws-cdk-lib/aws-cognito"); const iam = require("aws-cdk-lib/aws-iam"); const cdk = require("aws-cdk-lib"); const utils_1 = require("./utils"); const cognito_defaults_1 = require("./cognito-defaults"); /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function buildUserPool(scope, userPoolProps) { const cognitoUserPoolProps = (0, utils_1.consolidateProps)(cognito_defaults_1.defaultUserPoolProps, userPoolProps); const userPool = new cognito.UserPool(scope, 'CognitoUserPool', cognitoUserPoolProps); // Set the advancedSecurityMode to ENFORCED const cfnUserPool = userPool.node.findChild('Resource'); cfnUserPool.userPoolAddOns = { advancedSecurityMode: 'ENFORCED' }; // Add Cfn Nag suppress for the cognito SMS role policy const userPoolSmsRole = userPool.node.tryFindChild('smsRole'); if (userPoolSmsRole) { (0, utils_1.addCfnSuppressRules)(userPool, [ { id: 'W11', reason: `Allowing * resource on permissions policy since its used by Cognito to send SMS messages via sns:Publish` } ]); } return userPool; } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function buildUserPoolClient(scope, userPool, cognitoUserPoolClientProps) { const userPoolClientProps = (0, utils_1.consolidateProps)((0, cognito_defaults_1.DefaultUserPoolClientProps)(userPool), cognitoUserPoolClientProps); return new cognito.UserPoolClient(scope, 'CognitoUserPoolClient', userPoolClientProps); } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function buildIdentityPool(scope, userpool, userpoolclient, identityPoolProps) { let cognitoIdentityPoolProps = (0, cognito_defaults_1.DefaultIdentityPoolProps)(userpoolclient.userPoolClientId, userpool.userPoolProviderName); cognitoIdentityPoolProps = (0, utils_1.consolidateProps)(cognitoIdentityPoolProps, identityPoolProps); const idPool = new cognito.CfnIdentityPool(scope, 'CognitoIdentityPool', cognitoIdentityPoolProps); return idPool; } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function setupCognitoForSearchService(scope, domainName, options) { // Create the domain for Cognito UserPool const userpooldomain = new cognito.CfnUserPoolDomain(scope, 'UserPoolDomain', { domain: domainName, userPoolId: options.userpool.userPoolId }); userpooldomain.addDependency(options.userpool.node.findChild('Resource')); // Setup the IAM Role for Cognito Authorized Users const cognitoPrincipal = new iam.FederatedPrincipal('cognito-identity.amazonaws.com', { 'StringEquals': { 'cognito-identity.amazonaws.com:aud': options.identitypool.ref }, 'ForAnyValue:StringLike': { 'cognito-identity.amazonaws.com:amr': 'authenticated' } }, 'sts:AssumeRoleWithWebIdentity'); const cognitoAuthorizedRole = new iam.Role(scope, 'CognitoAuthorizedRole', { assumedBy: cognitoPrincipal, inlinePolicies: { CognitoAccessPolicy: new iam.PolicyDocument({ statements: [new iam.PolicyStatement({ actions: [ 'es:ESHttp*' ], resources: [`arn:${cdk.Aws.PARTITION}:es:${cdk.Aws.REGION}:${cdk.Aws.ACCOUNT_ID}:domain/${domainName}/*`] }) ] }) } }); (0, utils_1.addCfnGuardSuppressRules)(cognitoAuthorizedRole, ["IAM_NO_INLINE_POLICY_CHECK"]); // Attach the IAM Role for Cognito Authorized Users const props = { identityPoolId: options.identitypool.ref, roles: { authenticated: cognitoAuthorizedRole.roleArn } }; // Minimize code in a NOSONA line new cognito.CfnIdentityPoolRoleAttachment(scope, 'IdentityPoolRoleMapping', props); // NOSONAR return cognitoAuthorizedRole; } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function buildCognitoForSearchService(scope, domainName) { const userPool = buildUserPool(scope); const userPoolClient = buildUserPoolClient(scope, userPool); const identityPool = buildIdentityPool(scope, userPool, userPoolClient); const cognitoAuthorizedRole = setupCognitoForSearchService(scope, domainName, { userpool: userPool, identitypool: identityPool, userpoolclient: userPoolClient }); return [userPool, userPoolClient, identityPool, cognitoAuthorizedRole]; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cognito-helper.js","sourceRoot":"","sources":["cognito-helper.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n/*\n *  The functions found here in the core library are for internal use and can be changed\n *  or removed outside of a major release. We recommend against calling them directly from client code.\n */\n\nimport * as cognito from 'aws-cdk-lib/aws-cognito';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as cdk from 'aws-cdk-lib';\nimport { addCfnGuardSuppressRules, addCfnSuppressRules, consolidateProps } from './utils';\nimport { defaultUserPoolProps, DefaultUserPoolClientProps, DefaultIdentityPoolProps } from './cognito-defaults';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\n\nexport interface CognitoOptions {\n  readonly identitypool: cognito.CfnIdentityPool,\n  readonly userpool: cognito.UserPool,\n  readonly userpoolclient: cognito.UserPoolClient\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildUserPool(scope: Construct, userPoolProps?: cognito.UserPoolProps): cognito.UserPool {\n  const cognitoUserPoolProps = consolidateProps(defaultUserPoolProps, userPoolProps);\n\n  const userPool = new cognito.UserPool(scope, 'CognitoUserPool', cognitoUserPoolProps);\n\n  // Set the advancedSecurityMode to ENFORCED\n  const cfnUserPool = userPool.node.findChild('Resource') as cognito.CfnUserPool;\n\n  cfnUserPool.userPoolAddOns = {\n    advancedSecurityMode: 'ENFORCED'\n  };\n\n  // Add Cfn Nag suppress for the cognito SMS role policy\n  const userPoolSmsRole = userPool.node.tryFindChild('smsRole') as iam.Role;\n\n  if (userPoolSmsRole) {\n    addCfnSuppressRules(userPool, [\n      {\n        id: 'W11',\n        reason: `Allowing * resource on permissions policy since its used by Cognito to send SMS messages via sns:Publish`\n      }\n    ]);\n  }\n\n  return userPool;\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildUserPoolClient(scope: Construct, userPool: cognito.UserPool,\n  cognitoUserPoolClientProps?: cognito.UserPoolClientProps): cognito.UserPoolClient {\n\n  const userPoolClientProps = consolidateProps(DefaultUserPoolClientProps(userPool), cognitoUserPoolClientProps);\n\n  return new cognito.UserPoolClient(scope, 'CognitoUserPoolClient', userPoolClientProps);\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildIdentityPool(scope: Construct, userpool: cognito.UserPool, userpoolclient: cognito.UserPoolClient,\n  identityPoolProps?: cognito.CfnIdentityPoolProps): cognito.CfnIdentityPool {\n\n  let cognitoIdentityPoolProps: cognito.CfnIdentityPoolProps = DefaultIdentityPoolProps(userpoolclient.userPoolClientId,\n    userpool.userPoolProviderName);\n\n  cognitoIdentityPoolProps = consolidateProps(cognitoIdentityPoolProps, identityPoolProps);\n\n  const idPool = new cognito.CfnIdentityPool(scope, 'CognitoIdentityPool', cognitoIdentityPoolProps);\n\n  return idPool;\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function setupCognitoForSearchService(scope: Construct, domainName: string, options: CognitoOptions): iam.Role {\n\n  // Create the domain for Cognito UserPool\n  const userpooldomain = new cognito.CfnUserPoolDomain(scope, 'UserPoolDomain', {\n    domain: domainName,\n    userPoolId: options.userpool.userPoolId\n  });\n  userpooldomain.addDependency(options.userpool.node.findChild('Resource') as cognito.CfnUserPool);\n\n  // Setup the IAM Role for Cognito Authorized Users\n  const cognitoPrincipal = new iam.FederatedPrincipal(\n    'cognito-identity.amazonaws.com',\n    {\n      'StringEquals': { 'cognito-identity.amazonaws.com:aud': options.identitypool.ref },\n      'ForAnyValue:StringLike': { 'cognito-identity.amazonaws.com:amr': 'authenticated' }\n    },\n    'sts:AssumeRoleWithWebIdentity');\n\n  const cognitoAuthorizedRole = new iam.Role(scope, 'CognitoAuthorizedRole', {\n    assumedBy: cognitoPrincipal,\n    inlinePolicies: {\n      CognitoAccessPolicy: new iam.PolicyDocument({\n        statements: [new iam.PolicyStatement({\n          actions: [\n            'es:ESHttp*'\n          ],\n          resources: [`arn:${cdk.Aws.PARTITION}:es:${cdk.Aws.REGION}:${cdk.Aws.ACCOUNT_ID}:domain/${domainName}/*`]\n        })\n        ]\n      })\n    }\n  });\n\n  addCfnGuardSuppressRules(cognitoAuthorizedRole, [\"IAM_NO_INLINE_POLICY_CHECK\"]);\n\n  // Attach the IAM Role for Cognito Authorized Users\n  const props: cognito.CfnIdentityPoolRoleAttachmentProps = {\n    identityPoolId: options.identitypool.ref,\n    roles: {\n      authenticated: cognitoAuthorizedRole.roleArn\n    }\n  };\n\n  // Minimize code in a NOSONA line\n  new cognito.CfnIdentityPoolRoleAttachment(scope, 'IdentityPoolRoleMapping', props); // NOSONAR\n\n  return cognitoAuthorizedRole;\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function buildCognitoForSearchService(scope: Construct, domainName: string):\n  [cognito.UserPool, cognito.UserPoolClient, cognito.CfnIdentityPool, iam.Role] {\n  const userPool = buildUserPool(scope);\n  const userPoolClient = buildUserPoolClient(scope, userPool);\n  const identityPool = buildIdentityPool(scope, userPool, userPoolClient);\n\n  const cognitoAuthorizedRole: iam.Role = setupCognitoForSearchService(scope, domainName, {\n    userpool: userPool,\n    identitypool: identityPool,\n    userpoolclient: userPoolClient\n  });\n\n  return [userPool, userPoolClient, identityPool, cognitoAuthorizedRole];\n}"]}