UNPKG

@aws-solutions-constructs/core

Version:
367 lines 41 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 }); // Imports const aws_cdk_lib_1 = require("aws-cdk-lib"); const defaults = require("../"); const assertions_1 = require("aws-cdk-lib/assertions"); const kms = require("aws-cdk-lib/aws-kms"); const sns = require("aws-cdk-lib/aws-sns"); const __1 = require("../"); // -------------------------------------------------------------- // Test deployment with no properties using AWS Managed KMS Key // -------------------------------------------------------------- test('Test deployment with no properties using AWS Managed KMS Key', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Helper declaration const buildTopicResponse = defaults.buildTopic(stack, 'test', {}); expect(buildTopicResponse.topic).toBeDefined(); expect(buildTopicResponse.key).toBeDefined(); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::SNS::Topic", { KmsMasterKeyId: { "Fn::Join": [ "", [ "arn:", { Ref: "AWS::Partition" }, ":kms:", { Ref: "AWS::Region" }, ":", { Ref: "AWS::AccountId" }, ":alias/aws/sns" ] ] } }); }); // -------------------------------------------------------------- // Test deployment without imported encryption key // -------------------------------------------------------------- test('Test deployment without imported encryption key', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Helper declaration defaults.buildTopic(stack, 'test', { topicProps: { topicName: "custom-topic" }, enableEncryptionWithCustomerManagedKey: true }); const template = assertions_1.Template.fromStack(stack); template.hasResourceProperties("AWS::SNS::Topic", { TopicName: "custom-topic" }); // Assertion 3 template.hasResourceProperties("AWS::KMS::Key", { EnableKeyRotation: true }); }); // -------------------------------------------------------------- // Test deployment w/ imported encryption key // -------------------------------------------------------------- test('Test deployment w/ imported encryption key', () => { // Stack const stack = new aws_cdk_lib_1.Stack(); // Generate KMS Key const key = defaults.buildEncryptionKey(stack, 'key-test'); // Helper declaration const buildTopicResponse = defaults.buildTopic(stack, 'test', { topicProps: { topicName: "custom-topic" }, enableEncryptionWithCustomerManagedKey: true, encryptionKey: key }); expect(buildTopicResponse.topic).toBeDefined(); expect(buildTopicResponse.key).toBeDefined(); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::SNS::Topic", { KmsMasterKeyId: { "Fn::GetAtt": [ "keytestKey8AE2FF0A", "Arn" ] }, TopicName: "custom-topic" }); }); test('enableEncryptionWithCustomerManagedKey flag is ignored when encryptionKey is set', () => { const stack = new aws_cdk_lib_1.Stack(); defaults.buildTopic(stack, 'test', { enableEncryptionWithCustomerManagedKey: false, encryptionKey: defaults.buildEncryptionKey(stack, 'key-test') }); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::SNS::Topic", { KmsMasterKeyId: { "Fn::GetAtt": [ "keytestKey8AE2FF0A", "Arn" ] } }); }); test('enableEncryptionWithCustomerManagedKey flag is ignored when topicProps.masterKey is set', () => { const stack = new aws_cdk_lib_1.Stack(); defaults.buildTopic(stack, 'test', { enableEncryptionWithCustomerManagedKey: false, topicProps: { masterKey: defaults.buildEncryptionKey(stack, 'key-test') } }); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::SNS::Topic", { KmsMasterKeyId: { "Fn::GetAtt": [ "keytestKey8AE2FF0A", "Arn" ] } }); }); test('enableEncryptionWithCustomerManagedKey flag is ignored when encryptionKeyProps is set', () => { const stack = new aws_cdk_lib_1.Stack(); const description = "custom description"; defaults.buildTopic(stack, 'test', { enableEncryptionWithCustomerManagedKey: false, encryptionKeyProps: { description }, }); const template = assertions_1.Template.fromStack(stack); template.hasResourceProperties("AWS::SNS::Topic", { KmsMasterKeyId: { "Fn::GetAtt": [ "testKey2C00E5E5", "Arn" ] } }); template.hasResourceProperties("AWS::KMS::Key", { Description: description }); }); test('encryptionProps are set correctly on the SNS Topic', () => { const stack = new aws_cdk_lib_1.Stack(); const description = "custom description"; defaults.buildTopic(stack, 'test', { encryptionKeyProps: { description } }); assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::KMS::Key", { Description: description }); }); test('Check SNS Topic policy', () => { const stack = new aws_cdk_lib_1.Stack(); defaults.buildTopic(stack, 'test', {}); const template = assertions_1.Template.fromStack(stack); template.hasResourceProperties("AWS::SNS::TopicPolicy", { PolicyDocument: { Statement: [ { Action: [ "SNS:Publish", "SNS:RemovePermission", "SNS:SetTopicAttributes", "SNS:DeleteTopic", "SNS:ListSubscriptionsByTopic", "SNS:GetTopicAttributes", "SNS:Receive", "SNS:AddPermission", "SNS:Subscribe" ], Condition: { StringEquals: { "AWS:SourceOwner": { Ref: "AWS::AccountId" } } }, Effect: "Allow", Principal: { AWS: { "Fn::Join": [ "", [ "arn:", { Ref: "AWS::Partition" }, ":iam::", { Ref: "AWS::AccountId" }, ":root" ] ] } }, Resource: { Ref: "SnsTopic2C1570A4" }, Sid: "TopicOwnerOnlyAccess" }, { Action: [ "SNS:Publish", "SNS:RemovePermission", "SNS:SetTopicAttributes", "SNS:DeleteTopic", "SNS:ListSubscriptionsByTopic", "SNS:GetTopicAttributes", "SNS:Receive", "SNS:AddPermission", "SNS:Subscribe" ], Condition: { Bool: { "aws:SecureTransport": "false" } }, Effect: "Deny", Principal: { AWS: "*" }, Resource: { Ref: "SnsTopic2C1570A4" }, Sid: "HttpsOnly" } ], Version: "2012-10-17" }, }); }); test('existing topic encrypted with CMK is not overridden by defaults', () => { const stack = new aws_cdk_lib_1.Stack(); const cmk = new kms.Key(stack, 'Key', { description: 'new-key-description' }); const topic = new sns.Topic(stack, 'Topic', { masterKey: cmk }); defaults.buildTopic(stack, 'test', { existingTopicObj: topic, existingTopicEncryptionKey: cmk }); (0, __1.expectKmsKeyAttachedToCorrectResource)(stack, 'AWS::SNS::Topic', 'new-key-description'); // Make sure the construct did not create any other topics or keys created const template = assertions_1.Template.fromStack(stack); template.resourceCountIs('AWS::KMS::Key', 1); template.resourceCountIs('AWS::SNS::Topic', 1); }); test('existing unencrypted topic is not overridden with defaults', () => { const stack = new aws_cdk_lib_1.Stack(); const topic = new sns.Topic(stack, 'Topic'); const buildBuildTopicResponse = defaults.buildTopic(stack, 'test', { existingTopicObj: topic, }); expect(buildBuildTopicResponse.topic).toBeDefined(); expect(buildBuildTopicResponse.key).not.toBeDefined(); // Make sure the construct did not create any other topics and that no keys exist const template = assertions_1.Template.fromStack(stack); template.resourceCountIs('AWS::KMS::Key', 0); template.resourceCountIs('AWS::SNS::Topic', 1); }); // --------------------------- // Prop Tests // --------------------------- test('Test fail SNS topic check', () => { const stack = new aws_cdk_lib_1.Stack(); const props = { topicProps: {}, existingTopicObj: new sns.Topic(stack, 'placeholder', {}) }; const app = () => { defaults.CheckSnsProps(props); }; // Assertion expect(app).toThrowError('Error - Either provide topicProps or existingTopicObj, but not both.\n'); }); test('Test fail SNS topic check with bad topic attribute name', () => { const stack = new aws_cdk_lib_1.Stack(); const props = { topicProps: {}, existingTopicObj: new sns.Topic(stack, 'placeholder', {}) }; const app = () => { defaults.CheckSnsProps(props); }; // Assertion expect(app).toThrowError('Error - Either provide topicProps or existingTopicObj, but not both.\n'); }); test('Test fail SNS topic check when both encryptionKey and encryptionKeyProps are specified', () => { const stack = new aws_cdk_lib_1.Stack(); const props = { encryptionKey: new kms.Key(stack, 'key'), encryptionKeyProps: { description: 'a description' } }; const app = () => { defaults.CheckSnsProps(props); }; expect(app).toThrowError('Error - Either provide encryptionKey or encryptionKeyProps, but not both.\n'); }); test('Test fail SNS topic check when both topicProps.masterKey and encryptionKeyProps are specified', () => { const stack = new aws_cdk_lib_1.Stack(); const props = { topicProps: { masterKey: new kms.Key(stack, 'key') }, encryptionKeyProps: { description: 'a description' } }; const app = () => { defaults.CheckSnsProps(props); }; expect(app).toThrowError('Error - Either provide topicProps.masterKey or encryptionKeyProps, but not both.\n'); }); test('Test fail SNS topic check when both encryptionKey and topicProps.masterKey are specified', () => { const stack = new aws_cdk_lib_1.Stack(); const props = { encryptionKey: new kms.Key(stack, 'key'), topicProps: { masterKey: new kms.Key(stack, 'otherkey') } }; const app = () => { defaults.CheckSnsProps(props); }; // Assertion expect(app).toThrowError('Error - Either provide topicProps.masterKey or encryptionKey, but not both.\n'); }); test('Test fail encryption key check', () => { const stack = new aws_cdk_lib_1.Stack(); const key = defaults.buildEncryptionKey(stack, 'key-test', { enableKeyRotation: false }); const props = { encryptionKey: key, encryptionKeyProps: {}, }; const app = () => { defaults.CheckSnsProps(props); }; // Assertion expect(app).toThrowError('Error - Either provide encryptionKey or encryptionKeyProps, but not both.\n'); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sns-helper.test.js","sourceRoot":"","sources":["sns-helper.test.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;GAWG;;AAEH,UAAU;AACV,6CAAoC;AACpC,gCAAgC;AAChC,uDAAkD;AAClD,2CAA2C;AAC3C,2CAA2C;AAC3C,2BAA4D;AAE5D,iEAAiE;AACjE,+DAA+D;AAC/D,iEAAiE;AACjE,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;IACxE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IAElE,MAAM,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IAC/C,MAAM,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IAC7C,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QACjE,cAAc,EAAE;YACd,UAAU,EAAE;gBACV,EAAE;gBACF;oBACE,MAAM;oBACN;wBACE,GAAG,EAAE,gBAAgB;qBACtB;oBACD,OAAO;oBACP;wBACE,GAAG,EAAE,aAAa;qBACnB;oBACD,GAAG;oBACH;wBACE,GAAG,EAAE,gBAAgB;qBACtB;oBACD,gBAAgB;iBACjB;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,kDAAkD;AAClD,iEAAiE;AACjE,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;IAC3D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,UAAU,EAAE;YACV,SAAS,EAAE,cAAc;SAC1B;QACD,sCAAsC,EAAE,IAAI;KAC7C,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QAChD,SAAS,EAAE,cAAc;KAC1B,CAAC,CAAC;IACH,cAAc;IACd,QAAQ,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC9C,iBAAiB,EAAE,IAAI;KACxB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,6CAA6C;AAC7C,iEAAiE;AACjE,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;IACtD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,mBAAmB;IACnB,MAAM,GAAG,GAAG,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IAC3D,qBAAqB;IACrB,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QAC5D,UAAU,EAAE;YACV,SAAS,EAAE,cAAc;SAC1B;QACD,sCAAsC,EAAE,IAAI;QAC5C,aAAa,EAAE,GAAG;KACnB,CAAC,CAAC;IAEH,MAAM,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IAC/C,MAAM,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;IAE7C,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QACjE,cAAc,EAAE;YACd,YAAY,EAAE;gBACZ,oBAAoB;gBACpB,KAAK;aACN;SACF;QACD,SAAS,EAAE,cAAc;KAC1B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kFAAkF,EAAE,GAAG,EAAE;IAC5F,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,sCAAsC,EAAE,KAAK;QAC7C,aAAa,EAAE,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU,CAAC;KAC9D,CAAC,CAAC;IAEH,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QACjE,cAAc,EAAE;YACd,YAAY,EAAE;gBACZ,oBAAoB;gBACpB,KAAK;aACN;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yFAAyF,EAAE,GAAG,EAAE;IACnG,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,sCAAsC,EAAE,KAAK;QAC7C,UAAU,EAAE;YACV,SAAS,EAAE,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU,CAAC;SAC1D;KACF,CAAC,CAAC;IAEH,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QACjE,cAAc,EAAE;YACd,YAAY,EAAE;gBACZ,oBAAoB;gBACpB,KAAK;aACN;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,uFAAuF,EAAE,GAAG,EAAE;IACjG,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,MAAM,WAAW,GAAG,oBAAoB,CAAC;IACzC,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,sCAAsC,EAAE,KAAK;QAC7C,kBAAkB,EAAE;YAClB,WAAW;SACZ;KACF,CAAC,CAAC;IAEH,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,iBAAiB,EAAE;QAChD,cAAc,EAAE;YACd,YAAY,EAAE;gBACZ,iBAAiB;gBACjB,KAAK;aACN;SACF;KACF,CAAC,CAAC;IAEH,QAAQ,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC9C,WAAW,EAAE,WAAW;KACzB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;IAC9D,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,MAAM,WAAW,GAAG,oBAAoB,CAAC;IACzC,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,kBAAkB,EAAE;YAClB,WAAW;SACZ;KACF,CAAC,CAAC;IAEH,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,eAAe,EAAE;QAC/D,WAAW,EAAE,WAAW;KACzB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,wBAAwB,EAAE,GAAG,EAAE;IAClC,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IAEvC,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;QACtD,cAAc,EAAE;YACd,SAAS,EAAE;gBACT;oBACE,MAAM,EAAE;wBACN,aAAa;wBACb,sBAAsB;wBACtB,wBAAwB;wBACxB,iBAAiB;wBACjB,8BAA8B;wBAC9B,wBAAwB;wBACxB,aAAa;wBACb,mBAAmB;wBACnB,eAAe;qBAChB;oBACD,SAAS,EAAE;wBACT,YAAY,EAAE;4BACZ,iBAAiB,EAAE;gCACjB,GAAG,EAAE,gBAAgB;6BACtB;yBACF;qBACF;oBACD,MAAM,EAAE,OAAO;oBACf,SAAS,EAAE;wBACT,GAAG,EAAE;4BACH,UAAU,EAAE;gCACV,EAAE;gCACF;oCACE,MAAM;oCACN;wCACE,GAAG,EAAE,gBAAgB;qCACtB;oCACD,QAAQ;oCACR;wCACE,GAAG,EAAE,gBAAgB;qCACtB;oCACD,OAAO;iCACR;6BACF;yBACF;qBACF;oBACD,QAAQ,EAAE;wBACR,GAAG,EAAE,kBAAkB;qBACxB;oBACD,GAAG,EAAE,sBAAsB;iBAC5B;gBACD;oBACE,MAAM,EAAE;wBACN,aAAa;wBACb,sBAAsB;wBACtB,wBAAwB;wBACxB,iBAAiB;wBACjB,8BAA8B;wBAC9B,wBAAwB;wBACxB,aAAa;wBACb,mBAAmB;wBACnB,eAAe;qBAChB;oBACD,SAAS,EAAE;wBACT,IAAI,EAAE;4BACJ,qBAAqB,EAAE,OAAO;yBAC/B;qBACF;oBACD,MAAM,EAAE,MAAM;oBACd,SAAS,EAAE;wBACT,GAAG,EAAE,GAAG;qBACT;oBACD,QAAQ,EAAE;wBACR,GAAG,EAAE,kBAAkB;qBACxB;oBACD,GAAG,EAAE,WAAW;iBACjB;aACF;YACD,OAAO,EAAE,YAAY;SACtB;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,iEAAiE,EAAE,GAAG,EAAE;IAC3E,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE;QACpC,WAAW,EAAE,qBAAqB;KACnC,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,EAAE;QAC1C,SAAS,EAAE,GAAG;KACf,CAAC,CAAC;IAEH,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjC,gBAAgB,EAAE,KAAK;QACvB,0BAA0B,EAAE,GAAG;KAChC,CAAC,CAAC;IAEH,IAAA,yCAAqC,EAAC,KAAK,EAAE,iBAAiB,EAAE,qBAAqB,CAAC,CAAC;IAEvF,0EAA0E;IAC1E,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC;IAC7C,QAAQ,CAAC,eAAe,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC;AACjD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,4DAA4D,EAAE,GAAG,EAAE;IACtE,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IAE5C,MAAM,uBAAuB,GAAG,QAAQ,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE;QACjE,gBAAgB,EAAE,KAAK;KACxB,CAAC,CAAC;IAEH,MAAM,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;IACpD,MAAM,CAAC,uBAAuB,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;IACtD,iFAAiF;IACjF,MAAM,QAAQ,GAAG,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC3C,QAAQ,CAAC,eAAe,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC;IAC7C,QAAQ,CAAC,eAAe,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC;AACjD,CAAC,CAAC,CAAC;AAEH,8BAA8B;AAC9B,aAAa;AACb,8BAA8B;AAC9B,IAAI,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACrC,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAsB;QAC/B,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,aAAa,EAAE,EAAE,CAAC;KAC1D,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,wEAAwE,CAAC,CAAC;AACrG,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yDAAyD,EAAE,GAAG,EAAE;IACnE,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAsB;QAC/B,UAAU,EAAE,EAAE;QACd,gBAAgB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,aAAa,EAAE,EAAE,CAAC;KAC1D,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,wEAAwE,CAAC,CAAC;AACrG,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,wFAAwF,EAAE,GAAG,EAAE;IAClG,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAsB;QAC/B,aAAa,EAAE,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC;QACxC,kBAAkB,EAAE;YAClB,WAAW,EAAE,eAAe;SAC7B;KACF,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,6EAA6E,CAAC,CAAC;AAC1G,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,+FAA+F,EAAE,GAAG,EAAE;IACzG,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAsB;QAC/B,UAAU,EAAE;YACV,SAAS,EAAE,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC;SACrC;QACD,kBAAkB,EAAE;YAClB,WAAW,EAAE,eAAe;SAC7B;KACF,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,oFAAoF,CAAC,CAAC;AACjH,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,0FAA0F,EAAE,GAAG,EAAE;IACpG,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,KAAK,GAAsB;QAC/B,aAAa,EAAE,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC;QACxC,UAAU,EAAE;YACV,SAAS,EAAE,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC;SAC1C;KACF,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,+EAA+E,CAAC,CAAC;AAC5G,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,gCAAgC,EAAE,GAAG,EAAE;IAC1C,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU,EAAE;QACzD,iBAAiB,EAAE,KAAK;KACzB,CAAC,CAAC;IAEH,MAAM,KAAK,GAAsB;QAC/B,aAAa,EAAE,GAAG;QAClB,kBAAkB,EAAE,EAAE;KACvB,CAAC;IAEF,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,6EAA6E,CAAC,CAAC;AAC1G,CAAC,CAAC,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// Imports\nimport { Stack } from \"aws-cdk-lib\";\nimport * as defaults from '../';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport { expectKmsKeyAttachedToCorrectResource } from \"../\";\n\n// --------------------------------------------------------------\n// Test deployment with no properties using AWS Managed KMS Key\n// --------------------------------------------------------------\ntest('Test deployment with no properties using AWS Managed KMS Key', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const buildTopicResponse = defaults.buildTopic(stack, 'test', {});\n\n  expect(buildTopicResponse.topic).toBeDefined();\n  expect(buildTopicResponse.key).toBeDefined();\n  Template.fromStack(stack).hasResourceProperties(\"AWS::SNS::Topic\", {\n    KmsMasterKeyId: {\n      \"Fn::Join\": [\n        \"\",\n        [\n          \"arn:\",\n          {\n            Ref: \"AWS::Partition\"\n          },\n          \":kms:\",\n          {\n            Ref: \"AWS::Region\"\n          },\n          \":\",\n          {\n            Ref: \"AWS::AccountId\"\n          },\n          \":alias/aws/sns\"\n        ]\n      ]\n    }\n  });\n});\n\n// --------------------------------------------------------------\n// Test deployment without imported encryption key\n// --------------------------------------------------------------\ntest('Test deployment without imported encryption key', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  defaults.buildTopic(stack, 'test', {\n    topicProps: {\n      topicName: \"custom-topic\"\n    },\n    enableEncryptionWithCustomerManagedKey: true\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SNS::Topic\", {\n    TopicName: \"custom-topic\"\n  });\n  // Assertion 3\n  template.hasResourceProperties(\"AWS::KMS::Key\", {\n    EnableKeyRotation: true\n  });\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ imported encryption key\n// --------------------------------------------------------------\ntest('Test deployment w/ imported encryption key', () => {\n  // Stack\n  const stack = new Stack();\n  // Generate KMS Key\n  const key = defaults.buildEncryptionKey(stack, 'key-test');\n  // Helper declaration\n  const buildTopicResponse = defaults.buildTopic(stack, 'test', {\n    topicProps: {\n      topicName: \"custom-topic\"\n    },\n    enableEncryptionWithCustomerManagedKey: true,\n    encryptionKey: key\n  });\n\n  expect(buildTopicResponse.topic).toBeDefined();\n  expect(buildTopicResponse.key).toBeDefined();\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::SNS::Topic\", {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"keytestKey8AE2FF0A\",\n        \"Arn\"\n      ]\n    },\n    TopicName: \"custom-topic\"\n  });\n});\n\ntest('enableEncryptionWithCustomerManagedKey flag is ignored when encryptionKey is set', () => {\n  const stack = new Stack();\n  defaults.buildTopic(stack, 'test', {\n    enableEncryptionWithCustomerManagedKey: false,\n    encryptionKey: defaults.buildEncryptionKey(stack, 'key-test')\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::SNS::Topic\", {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"keytestKey8AE2FF0A\",\n        \"Arn\"\n      ]\n    }\n  });\n});\n\ntest('enableEncryptionWithCustomerManagedKey flag is ignored when topicProps.masterKey is set', () => {\n  const stack = new Stack();\n  defaults.buildTopic(stack, 'test', {\n    enableEncryptionWithCustomerManagedKey: false,\n    topicProps: {\n      masterKey: defaults.buildEncryptionKey(stack, 'key-test')\n    }\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::SNS::Topic\", {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"keytestKey8AE2FF0A\",\n        \"Arn\"\n      ]\n    }\n  });\n});\n\ntest('enableEncryptionWithCustomerManagedKey flag is ignored when encryptionKeyProps is set', () => {\n  const stack = new Stack();\n  const description = \"custom description\";\n  defaults.buildTopic(stack, 'test', {\n    enableEncryptionWithCustomerManagedKey: false,\n    encryptionKeyProps: {\n      description\n    },\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SNS::Topic\", {\n    KmsMasterKeyId: {\n      \"Fn::GetAtt\": [\n        \"testKey2C00E5E5\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  template.hasResourceProperties(\"AWS::KMS::Key\", {\n    Description: description\n  });\n});\n\ntest('encryptionProps are set correctly on the SNS Topic', () => {\n  const stack = new Stack();\n  const description = \"custom description\";\n  defaults.buildTopic(stack, 'test', {\n    encryptionKeyProps: {\n      description\n    }\n  });\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::KMS::Key\", {\n    Description: description\n  });\n});\n\ntest('Check SNS Topic policy', () => {\n  const stack = new Stack();\n  defaults.buildTopic(stack, 'test', {});\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SNS::TopicPolicy\", {\n    PolicyDocument: {\n      Statement: [\n        {\n          Action: [\n            \"SNS:Publish\",\n            \"SNS:RemovePermission\",\n            \"SNS:SetTopicAttributes\",\n            \"SNS:DeleteTopic\",\n            \"SNS:ListSubscriptionsByTopic\",\n            \"SNS:GetTopicAttributes\",\n            \"SNS:Receive\",\n            \"SNS:AddPermission\",\n            \"SNS:Subscribe\"\n          ],\n          Condition: {\n            StringEquals: {\n              \"AWS:SourceOwner\": {\n                Ref: \"AWS::AccountId\"\n              }\n            }\n          },\n          Effect: \"Allow\",\n          Principal: {\n            AWS: {\n              \"Fn::Join\": [\n                \"\",\n                [\n                  \"arn:\",\n                  {\n                    Ref: \"AWS::Partition\"\n                  },\n                  \":iam::\",\n                  {\n                    Ref: \"AWS::AccountId\"\n                  },\n                  \":root\"\n                ]\n              ]\n            }\n          },\n          Resource: {\n            Ref: \"SnsTopic2C1570A4\"\n          },\n          Sid: \"TopicOwnerOnlyAccess\"\n        },\n        {\n          Action: [\n            \"SNS:Publish\",\n            \"SNS:RemovePermission\",\n            \"SNS:SetTopicAttributes\",\n            \"SNS:DeleteTopic\",\n            \"SNS:ListSubscriptionsByTopic\",\n            \"SNS:GetTopicAttributes\",\n            \"SNS:Receive\",\n            \"SNS:AddPermission\",\n            \"SNS:Subscribe\"\n          ],\n          Condition: {\n            Bool: {\n              \"aws:SecureTransport\": \"false\"\n            }\n          },\n          Effect: \"Deny\",\n          Principal: {\n            AWS: \"*\"\n          },\n          Resource: {\n            Ref: \"SnsTopic2C1570A4\"\n          },\n          Sid: \"HttpsOnly\"\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n  });\n});\n\ntest('existing topic encrypted with CMK is not overridden by defaults', () => {\n  const stack = new Stack();\n\n  const cmk = new kms.Key(stack, 'Key', {\n    description: 'new-key-description'\n  });\n\n  const topic = new sns.Topic(stack, 'Topic', {\n    masterKey: cmk\n  });\n\n  defaults.buildTopic(stack, 'test', {\n    existingTopicObj: topic,\n    existingTopicEncryptionKey: cmk\n  });\n\n  expectKmsKeyAttachedToCorrectResource(stack, 'AWS::SNS::Topic', 'new-key-description');\n\n  // Make sure the construct did not create any other topics or keys created\n  const template = Template.fromStack(stack);\n  template.resourceCountIs('AWS::KMS::Key', 1);\n  template.resourceCountIs('AWS::SNS::Topic', 1);\n});\n\ntest('existing unencrypted topic is not overridden with defaults', () => {\n  const stack = new Stack();\n\n  const topic = new sns.Topic(stack, 'Topic');\n\n  const buildBuildTopicResponse = defaults.buildTopic(stack, 'test', {\n    existingTopicObj: topic,\n  });\n\n  expect(buildBuildTopicResponse.topic).toBeDefined();\n  expect(buildBuildTopicResponse.key).not.toBeDefined();\n  // Make sure the construct did not create any other topics and that no keys exist\n  const template = Template.fromStack(stack);\n  template.resourceCountIs('AWS::KMS::Key', 0);\n  template.resourceCountIs('AWS::SNS::Topic', 1);\n});\n\n// ---------------------------\n// Prop Tests\n// ---------------------------\ntest('Test fail SNS topic check', () => {\n  const stack = new Stack();\n\n  const props: defaults.SnsProps = {\n    topicProps: {},\n    existingTopicObj: new sns.Topic(stack, 'placeholder', {})\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide topicProps or existingTopicObj, but not both.\\n');\n});\n\ntest('Test fail SNS topic check with bad topic attribute name', () => {\n  const stack = new Stack();\n\n  const props: defaults.SnsProps = {\n    topicProps: {},\n    existingTopicObj: new sns.Topic(stack, 'placeholder', {})\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide topicProps or existingTopicObj, but not both.\\n');\n});\n\ntest('Test fail SNS topic check when both encryptionKey and encryptionKeyProps are specified', () => {\n  const stack = new Stack();\n\n  const props: defaults.SnsProps = {\n    encryptionKey: new kms.Key(stack, 'key'),\n    encryptionKeyProps: {\n      description: 'a description'\n    }\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  expect(app).toThrowError('Error - Either provide encryptionKey or encryptionKeyProps, but not both.\\n');\n});\n\ntest('Test fail SNS topic check when both topicProps.masterKey and encryptionKeyProps are specified', () => {\n  const stack = new Stack();\n\n  const props: defaults.SnsProps = {\n    topicProps: {\n      masterKey: new kms.Key(stack, 'key')\n    },\n    encryptionKeyProps: {\n      description: 'a description'\n    }\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  expect(app).toThrowError('Error - Either provide topicProps.masterKey or encryptionKeyProps, but not both.\\n');\n});\n\ntest('Test fail SNS topic check when both encryptionKey and topicProps.masterKey are specified', () => {\n  const stack = new Stack();\n\n  const props: defaults.SnsProps = {\n    encryptionKey: new kms.Key(stack, 'key'),\n    topicProps: {\n      masterKey: new kms.Key(stack, 'otherkey')\n    }\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide topicProps.masterKey or encryptionKey, but not both.\\n');\n});\n\ntest('Test fail encryption key check', () => {\n  const stack = new Stack();\n\n  const key = defaults.buildEncryptionKey(stack, 'key-test', {\n    enableKeyRotation: false\n  });\n\n  const props: defaults.SnsProps = {\n    encryptionKey: key,\n    encryptionKeyProps: {},\n  };\n\n  const app = () => {\n    defaults.CheckSnsProps(props);\n  };\n\n  // Assertion\n  expect(app).toThrowError('Error - Either provide encryptionKey or encryptionKeyProps, but not both.\\n');\n});\n"]}