@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
123 lines • 18.7 kB
JavaScript
/**
* 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":";AAAA;;;;;;;;;;;GAWG;;AAwBH,sCAyBC;AAKD,kDAMC;AAKD,8CAWC;AAKD,oEA+CC;AAKD,oEAaC;AAhJD;;;GAGG;AAEH,mDAAmD;AACnD,2CAA2C;AAC3C,mCAAmC;AACnC,mCAA0F;AAC1F,yDAAgH;AAUhH;;GAEG;AACH,SAAgB,aAAa,CAAC,KAAgB,EAAE,aAAqC;IACnF,MAAM,oBAAoB,GAAG,IAAA,wBAAgB,EAAC,uCAAoB,EAAE,aAAa,CAAC,CAAC;IAEnF,MAAM,QAAQ,GAAG,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,EAAE,iBAAiB,EAAE,oBAAoB,CAAC,CAAC;IAEtF,2CAA2C;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAwB,CAAC;IAE/E,WAAW,CAAC,cAAc,GAAG;QAC3B,oBAAoB,EAAE,UAAU;KACjC,CAAC;IAEF,uDAAuD;IACvD,MAAM,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAa,CAAC;IAE1E,IAAI,eAAe,EAAE,CAAC;QACpB,IAAA,2BAAmB,EAAC,QAAQ,EAAE;YAC5B;gBACE,EAAE,EAAE,KAAK;gBACT,MAAM,EAAE,0GAA0G;aACnH;SACF,CAAC,CAAC;IACL,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CAAC,KAAgB,EAAE,QAA0B,EAC9E,0BAAwD;IAExD,MAAM,mBAAmB,GAAG,IAAA,wBAAgB,EAAC,IAAA,6CAA0B,EAAC,QAAQ,CAAC,EAAE,0BAA0B,CAAC,CAAC;IAE/G,OAAO,IAAI,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,uBAAuB,EAAE,mBAAmB,CAAC,CAAC;AACzF,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,KAAgB,EAAE,QAA0B,EAAE,cAAsC,EACpH,iBAAgD;IAEhD,IAAI,wBAAwB,GAAiC,IAAA,2CAAwB,EAAC,cAAc,CAAC,gBAAgB,EACnH,QAAQ,CAAC,oBAAoB,CAAC,CAAC;IAEjC,wBAAwB,GAAG,IAAA,wBAAgB,EAAC,wBAAwB,EAAE,iBAAiB,CAAC,CAAC;IAEzF,MAAM,MAAM,GAAG,IAAI,OAAO,CAAC,eAAe,CAAC,KAAK,EAAE,qBAAqB,EAAE,wBAAwB,CAAC,CAAC;IAEnG,OAAO,MAAM,CAAC;AAChB,CAAC;AAED;;GAEG;AACH,SAAgB,4BAA4B,CAAC,KAAgB,EAAE,UAAkB,EAAE,OAAuB;IAExG,yCAAyC;IACzC,MAAM,cAAc,GAAG,IAAI,OAAO,CAAC,iBAAiB,CAAC,KAAK,EAAE,gBAAgB,EAAE;QAC5E,MAAM,EAAE,UAAU;QAClB,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,UAAU;KACxC,CAAC,CAAC;IACH,cAAc,CAAC,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAwB,CAAC,CAAC;IAEjG,kDAAkD;IAClD,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC,kBAAkB,CACjD,gCAAgC,EAChC;QACE,cAAc,EAAE,EAAE,oCAAoC,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,EAAE;QAClF,wBAAwB,EAAE,EAAE,oCAAoC,EAAE,eAAe,EAAE;KACpF,EACD,+BAA+B,CAAC,CAAC;IAEnC,MAAM,qBAAqB,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,uBAAuB,EAAE;QACzE,SAAS,EAAE,gBAAgB;QAC3B,cAAc,EAAE;YACd,mBAAmB,EAAE,IAAI,GAAG,CAAC,cAAc,CAAC;gBAC1C,UAAU,EAAE,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC;wBACnC,OAAO,EAAE;4BACP,YAAY;yBACb;wBACD,SAAS,EAAE,CAAC,OAAO,GAAG,CAAC,GAAG,CAAC,SAAS,OAAO,GAAG,CAAC,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,GAAG,CAAC,UAAU,WAAW,UAAU,IAAI,CAAC;qBAC1G,CAAC;iBACD;aACF,CAAC;SACH;KACF,CAAC,CAAC;IAEH,IAAA,gCAAwB,EAAC,qBAAqB,EAAE,CAAC,4BAA4B,CAAC,CAAC,CAAC;IAEhF,mDAAmD;IACnD,MAAM,KAAK,GAA+C;QACxD,cAAc,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG;QACxC,KAAK,EAAE;YACL,aAAa,EAAE,qBAAqB,CAAC,OAAO;SAC7C;KACF,CAAC;IAEF,iCAAiC;IACjC,IAAI,OAAO,CAAC,6BAA6B,CAAC,KAAK,EAAE,yBAAyB,EAAE,KAAK,CAAC,CAAC,CAAC,UAAU;IAE9F,OAAO,qBAAqB,CAAC;AAC/B,CAAC;AAED;;GAEG;AACH,SAAgB,4BAA4B,CAAC,KAAgB,EAAE,UAAkB;IAE/E,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;IACtC,MAAM,cAAc,GAAG,mBAAmB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;IAC5D,MAAM,YAAY,GAAG,iBAAiB,CAAC,KAAK,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;IAExE,MAAM,qBAAqB,GAAa,4BAA4B,CAAC,KAAK,EAAE,UAAU,EAAE;QACtF,QAAQ,EAAE,QAAQ;QAClB,YAAY,EAAE,YAAY;QAC1B,cAAc,EAAE,cAAc;KAC/B,CAAC,CAAC;IAEH,OAAO,CAAC,QAAQ,EAAE,cAAc,EAAE,YAAY,EAAE,qBAAqB,CAAC,CAAC;AACzE,CAAC","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}"]}
;