@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
171 lines • 18 kB
JavaScript
"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 });
const aws_cdk_lib_1 = require("aws-cdk-lib");
const defaults = require("../index");
const assertions_1 = require("aws-cdk-lib/assertions");
test('Test override for buildUserPool', () => {
const stack = new aws_cdk_lib_1.Stack();
const userpoolProps = {
userPoolName: 'test',
signInAliases: { username: false, email: true, phone: true }
};
defaults.buildUserPool(stack, userpoolProps);
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Cognito::UserPool', {
UsernameAttributes: [
"email",
"phone_number"
],
UserPoolAddOns: {
AdvancedSecurityMode: "ENFORCED"
},
UserPoolName: "test"
});
});
test('Test override for buildUserPoolClient', () => {
const stack = new aws_cdk_lib_1.Stack();
const userpool = defaults.buildUserPool(stack);
const userpoolclientProps = {
userPoolClientName: 'test',
userPool: userpool
};
defaults.buildUserPoolClient(stack, userpool, userpoolclientProps);
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Cognito::UserPoolClient', {
UserPoolId: {
Ref: "CognitoUserPool53E37E69"
},
ClientName: "test"
});
});
test('Test override for buildIdentityPool', () => {
const stack = new aws_cdk_lib_1.Stack();
const userpool = defaults.buildUserPool(stack);
const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {
userPoolClientName: 'test',
userPool: userpool
});
defaults.buildIdentityPool(stack, userpool, userpoolclient, {
allowUnauthenticatedIdentities: true
});
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Cognito::IdentityPool', {
AllowUnauthenticatedIdentities: true,
CognitoIdentityProviders: [
{
ClientId: {
Ref: "CognitoUserPoolClient5AB59AE4"
},
ProviderName: {
"Fn::GetAtt": [
"CognitoUserPool53E37E69",
"ProviderName"
]
},
ServerSideTokenCheck: true
}
]
});
});
test('Test setupCognitoForSearchService', () => {
const stack = new aws_cdk_lib_1.Stack();
const userpool = defaults.buildUserPool(stack);
const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {
userPoolClientName: 'test',
userPool: userpool
});
const identitypool = defaults.buildIdentityPool(stack, userpool, userpoolclient);
defaults.setupCognitoForSearchService(stack, 'test-domain', {
userpool,
userpoolclient,
identitypool
});
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties('AWS::Cognito::UserPoolDomain', {
Domain: "test-domain"
});
template.hasResourceProperties('AWS::Cognito::IdentityPoolRoleAttachment', {
IdentityPoolId: {
Ref: "CognitoIdentityPool"
},
Roles: {
authenticated: {
"Fn::GetAtt": [
"CognitoAuthorizedRole14E74FE0",
"Arn"
]
}
}
});
template.hasResourceProperties('AWS::IAM::Role', {
AssumeRolePolicyDocument: {
Statement: [
{
Action: "sts:AssumeRoleWithWebIdentity",
Condition: {
"StringEquals": {
"cognito-identity.amazonaws.com:aud": {
Ref: "CognitoIdentityPool"
}
},
"ForAnyValue:StringLike": {
"cognito-identity.amazonaws.com:amr": "authenticated"
}
},
Effect: "Allow",
Principal: {
Federated: "cognito-identity.amazonaws.com"
}
}
],
Version: "2012-10-17"
},
Policies: [
{
PolicyDocument: {
Statement: [
{
Action: "es:ESHttp*",
Effect: "Allow",
Resource: {
"Fn::Join": [
"",
[
"arn:",
{
Ref: "AWS::Partition"
},
":es:",
{
Ref: "AWS::Region"
},
":",
{
Ref: "AWS::AccountId"
},
":domain/test-domain/*"
]
]
}
}
],
Version: "2012-10-17"
},
PolicyName: "CognitoAccessPolicy"
}
]
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"congnito-helper.test.js","sourceRoot":"","sources":["congnito-helper.test.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\nimport { Stack } from 'aws-cdk-lib';\nimport * as cognito from 'aws-cdk-lib/aws-cognito';\nimport * as defaults from '../index';\nimport { Template } from 'aws-cdk-lib/assertions';\n\ntest('Test override for buildUserPool', () => {\n  const stack = new Stack();\n\n  const userpoolProps: cognito.UserPoolProps = {\n    userPoolName: 'test',\n    signInAliases: { username: false, email: true, phone: true }\n  };\n\n  defaults.buildUserPool(stack, userpoolProps);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Cognito::UserPool', {\n    UsernameAttributes: [\n      \"email\",\n      \"phone_number\"\n    ],\n    UserPoolAddOns: {\n      AdvancedSecurityMode: \"ENFORCED\"\n    },\n    UserPoolName: \"test\"\n  });\n});\n\ntest('Test override for buildUserPoolClient', () => {\n  const stack = new Stack();\n\n  const userpool = defaults.buildUserPool(stack);\n\n  const userpoolclientProps: cognito.UserPoolClientProps = {\n    userPoolClientName: 'test',\n    userPool: userpool\n  };\n\n  defaults.buildUserPoolClient(stack, userpool, userpoolclientProps);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Cognito::UserPoolClient', {\n    UserPoolId: {\n      Ref: \"CognitoUserPool53E37E69\"\n    },\n    ClientName: \"test\"\n  });\n});\n\ntest('Test override for buildIdentityPool', () => {\n  const stack = new Stack();\n\n  const userpool = defaults.buildUserPool(stack);\n  const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {\n    userPoolClientName: 'test',\n    userPool: userpool\n  });\n  defaults.buildIdentityPool(stack, userpool, userpoolclient, {\n    allowUnauthenticatedIdentities: true\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Cognito::IdentityPool', {\n    AllowUnauthenticatedIdentities: true,\n    CognitoIdentityProviders: [\n      {\n        ClientId: {\n          Ref: \"CognitoUserPoolClient5AB59AE4\"\n        },\n        ProviderName: {\n          \"Fn::GetAtt\": [\n            \"CognitoUserPool53E37E69\",\n            \"ProviderName\"\n          ]\n        },\n        ServerSideTokenCheck: true\n      }\n    ]\n  });\n});\n\ntest('Test setupCognitoForSearchService', () => {\n  const stack = new Stack();\n\n  const userpool = defaults.buildUserPool(stack);\n  const userpoolclient = defaults.buildUserPoolClient(stack, userpool, {\n    userPoolClientName: 'test',\n    userPool: userpool\n  });\n  const identitypool = defaults.buildIdentityPool(stack, userpool, userpoolclient);\n\n  defaults.setupCognitoForSearchService(stack, 'test-domain', {\n    userpool,\n    userpoolclient,\n    identitypool\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Cognito::UserPoolDomain', {\n    Domain: \"test-domain\"\n  });\n\n  template.hasResourceProperties('AWS::Cognito::IdentityPoolRoleAttachment', {\n    IdentityPoolId: {\n      Ref: \"CognitoIdentityPool\"\n    },\n    Roles: {\n      authenticated: {\n        \"Fn::GetAtt\": [\n          \"CognitoAuthorizedRole14E74FE0\",\n          \"Arn\"\n        ]\n      }\n    }\n  });\n\n  template.hasResourceProperties('AWS::IAM::Role', {\n    AssumeRolePolicyDocument: {\n      Statement: [\n        {\n          Action: \"sts:AssumeRoleWithWebIdentity\",\n          Condition: {\n            \"StringEquals\": {\n              \"cognito-identity.amazonaws.com:aud\": {\n                Ref: \"CognitoIdentityPool\"\n              }\n            },\n            \"ForAnyValue:StringLike\": {\n              \"cognito-identity.amazonaws.com:amr\": \"authenticated\"\n            }\n          },\n          Effect: \"Allow\",\n          Principal: {\n            Federated: \"cognito-identity.amazonaws.com\"\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    Policies: [\n      {\n        PolicyDocument: {\n          Statement: [\n            {\n              Action: \"es:ESHttp*\",\n              Effect: \"Allow\",\n              Resource: {\n                \"Fn::Join\": [\n                  \"\",\n                  [\n                    \"arn:\",\n                    {\n                      Ref: \"AWS::Partition\"\n                    },\n                    \":es:\",\n                    {\n                      Ref: \"AWS::Region\"\n                    },\n                    \":\",\n                    {\n                      Ref: \"AWS::AccountId\"\n                    },\n                    \":domain/test-domain/*\"\n                  ]\n                ]\n              }\n            }\n          ],\n          Version: \"2012-10-17\"\n        },\n        PolicyName: \"CognitoAccessPolicy\"\n      }\n    ]\n  });\n\n});\n"]}