Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-kms

Package Overview
Dependencies
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-kms - npm Package Compare versions

Comparing version 0.23.0 to 0.24.0

lib/kms-augmentations.generated.d.ts

10

lib/key.d.ts
import { PolicyDocument, PolicyStatement } from '@aws-cdk/aws-iam';
import { Construct, IConstruct, TagManager, Tags } from '@aws-cdk/cdk';
import { Construct, IConstruct } from '@aws-cdk/cdk';
import { EncryptionKeyAlias } from './alias';

@@ -85,6 +85,2 @@ export interface IEncryptionKey extends IConstruct {

policy?: PolicyDocument;
/**
* The AWS resource tags to associate with the KMS key.
*/
tags?: Tags;
}

@@ -114,6 +110,2 @@ /**

static import(scope: Construct, id: string, props: EncryptionKeyImportProps): IEncryptionKey;
/**
* Manage tags for this construct and children
*/
readonly tags: TagManager;
readonly keyArn: string;

@@ -120,0 +112,0 @@ protected readonly policy?: PolicyDocument;

@@ -66,3 +66,2 @@ "use strict";

}
this.tags = new cdk_1.TagManager(this, { initialTags: props.tags });
const resource = new kms_generated_1.CfnKey(this, 'Resource', {

@@ -73,3 +72,2 @@ description: props.description,

keyPolicy: this.policy,
tags: this.tags
});

@@ -125,2 +123,2 @@ this.keyArn = resource.keyArn;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["key.ts"],"names":[],"mappings":"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","sourcesContent":["import { PolicyDocument, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { Construct, DeletionPolicy, IConstruct, Output, TagManager, Tags } from '@aws-cdk/cdk';\nimport { EncryptionKeyAlias } from './alias';\nimport { CfnKey } from './kms.generated';\n\nexport interface IEncryptionKey extends IConstruct {\n  /**\n   * The ARN of the key.\n   */\n  readonly keyArn: string;\n\n  /**\n   * Defines a new alias for the key.\n   */\n  addAlias(alias: string): EncryptionKeyAlias;\n\n  /**\n   * Adds a statement to the KMS key resource policy.\n   * @param statement The policy statement to add\n   * @param allowNoOp If this is set to `false` and there is no policy\n   * defined (i.e. external key), the operation will fail. Otherwise, it will\n   * no-op.\n   */\n  addToResourcePolicy(statement: PolicyStatement, allowNoOp?: boolean): void;\n\n  /**\n   * Exports this key from the current stack.\n   * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n   */\n  export(): EncryptionKeyImportProps;\n}\n\nexport interface EncryptionKeyImportProps {\n  /**\n   * The ARN of the external KMS key.\n   */\n  keyArn: string;\n}\n\nexport abstract class EncryptionKeyBase extends Construct {\n  /**\n   * The ARN of the key.\n   */\n  public abstract readonly keyArn: string;\n\n  /**\n   * Optional policy document that represents the resource policy of this key.\n   *\n   * If specified, addToResourcePolicy can be used to edit this policy.\n   * Otherwise this method will no-op.\n   */\n  protected abstract readonly policy?: PolicyDocument;\n\n  /**\n   * Defines a new alias for the key.\n   */\n  public addAlias(alias: string): EncryptionKeyAlias {\n    return new EncryptionKeyAlias(this, 'Alias', { alias, key: this });\n  }\n\n  /**\n   * Adds a statement to the KMS key resource policy.\n   * @param statement The policy statement to add\n   * @param allowNoOp If this is set to `false` and there is no policy\n   * defined (i.e. external key), the operation will fail. Otherwise, it will\n   * no-op.\n   */\n  public addToResourcePolicy(statement: PolicyStatement, allowNoOp = true) {\n    if (!this.policy) {\n      if (allowNoOp) { return; }\n      throw new Error(`Unable to add statement to IAM resource policy for KMS key: ${JSON.stringify(this.node.resolve(this.keyArn))}`);\n    }\n\n    this.policy.addStatement(statement);\n  }\n\n  public abstract export(): EncryptionKeyImportProps;\n}\n\n/**\n * Construction properties for a KMS Key object\n */\nexport interface EncryptionKeyProps {\n  /**\n   * A description of the key. Use a description that helps your users decide\n   * whether the key is appropriate for a particular task.\n   */\n  description?: string;\n\n  /**\n   * Indicates whether AWS KMS rotates the key.\n   * @default false\n   */\n  enableKeyRotation?: boolean;\n\n  /**\n   * Indicates whether the key is available for use.\n   * @default Key is enabled\n   */\n  enabled?: boolean;\n\n  /**\n   * Custom policy document to attach to the KMS key.\n   *\n   * @default A policy document with permissions for the account root to\n   * administer the key will be created.\n   */\n  policy?: PolicyDocument;\n\n  /**\n   * The AWS resource tags to associate with the KMS key.\n   */\n  tags?: Tags;\n}\n\n/**\n * Defines a KMS key.\n */\nexport class EncryptionKey extends EncryptionKeyBase {\n  /**\n   * Defines an imported encryption key.\n   *\n   * `ref` can be obtained either via a call to `key.export()` or using\n   * literals.\n   *\n   * For example:\n   *\n   *   const keyAttr = key.export();\n   *   const keyRef1 = EncryptionKey.import(this, 'MyImportedKey1', keyAttr);\n   *   const keyRef2 = EncryptionKey.import(this, 'MyImportedKey2', {\n   *     keyArn: new KeyArn('arn:aws:kms:...')\n   *   });\n   *\n   * @param scope The parent construct.\n   * @param id The name of the construct.\n   * @param props The key reference.\n   */\n  public static import(scope: Construct, id: string, props: EncryptionKeyImportProps): IEncryptionKey {\n    return new ImportedEncryptionKey(scope, id, props);\n  }\n\n  /**\n   * Manage tags for this construct and children\n   */\n  public readonly tags: TagManager;\n\n  public readonly keyArn: string;\n  protected readonly policy?: PolicyDocument;\n\n  constructor(scope: Construct, id: string, props: EncryptionKeyProps = {}) {\n    super(scope, id);\n\n    if (props.policy) {\n      this.policy = props.policy;\n    } else {\n      this.policy = new PolicyDocument();\n      this.allowAccountToAdmin();\n    }\n\n    this.tags = new TagManager(this, { initialTags: props.tags });\n\n    const resource = new CfnKey(this, 'Resource', {\n      description: props.description,\n      enableKeyRotation: props.enableKeyRotation,\n      enabled: props.enabled,\n      keyPolicy: this.policy,\n      tags: this.tags\n    });\n\n    this.keyArn = resource.keyArn;\n    resource.options.deletionPolicy = DeletionPolicy.Retain;\n  }\n\n  /**\n   * Exports this key from the current stack.\n   * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n   */\n  public export(): EncryptionKeyImportProps {\n    return {\n      keyArn: new Output(this, 'KeyArn', { value: this.keyArn }).makeImportValue().toString()\n    };\n  }\n\n  /**\n   * Let users from this account admin this key.\n   * @link https://aws.amazon.com/premiumsupport/knowledge-center/update-key-policy-future/\n   */\n  private allowAccountToAdmin() {\n    const actions = [\n      \"kms:Create*\",\n      \"kms:Describe*\",\n      \"kms:Enable*\",\n      \"kms:List*\",\n      \"kms:Put*\",\n      \"kms:Update*\",\n      \"kms:Revoke*\",\n      \"kms:Disable*\",\n      \"kms:Get*\",\n      \"kms:Delete*\",\n      \"kms:ScheduleKeyDeletion\",\n      \"kms:CancelKeyDeletion\"\n    ];\n\n    this.addToResourcePolicy(new PolicyStatement()\n      .addAllResources()\n      .addActions(...actions)\n      .addAccountRootPrincipal());\n  }\n}\n\nclass ImportedEncryptionKey extends EncryptionKeyBase {\n  public readonly keyArn: string;\n  protected readonly policy = undefined; // no policy associated with an imported key\n\n  constructor(scope: Construct, id: string, private readonly props: EncryptionKeyImportProps) {\n    super(scope, id);\n\n    this.keyArn = props.keyArn;\n  }\n\n  public export() {\n    return this.props;\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"key.js","sourceRoot":"","sources":["key.ts"],"names":[],"mappings":"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","sourcesContent":["import { PolicyDocument, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { Construct, DeletionPolicy, IConstruct, Output } from '@aws-cdk/cdk';\nimport { EncryptionKeyAlias } from './alias';\nimport { CfnKey } from './kms.generated';\n\nexport interface IEncryptionKey extends IConstruct {\n  /**\n   * The ARN of the key.\n   */\n  readonly keyArn: string;\n\n  /**\n   * Defines a new alias for the key.\n   */\n  addAlias(alias: string): EncryptionKeyAlias;\n\n  /**\n   * Adds a statement to the KMS key resource policy.\n   * @param statement The policy statement to add\n   * @param allowNoOp If this is set to `false` and there is no policy\n   * defined (i.e. external key), the operation will fail. Otherwise, it will\n   * no-op.\n   */\n  addToResourcePolicy(statement: PolicyStatement, allowNoOp?: boolean): void;\n\n  /**\n   * Exports this key from the current stack.\n   * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n   */\n  export(): EncryptionKeyImportProps;\n}\n\nexport interface EncryptionKeyImportProps {\n  /**\n   * The ARN of the external KMS key.\n   */\n  keyArn: string;\n}\n\nexport abstract class EncryptionKeyBase extends Construct {\n  /**\n   * The ARN of the key.\n   */\n  public abstract readonly keyArn: string;\n\n  /**\n   * Optional policy document that represents the resource policy of this key.\n   *\n   * If specified, addToResourcePolicy can be used to edit this policy.\n   * Otherwise this method will no-op.\n   */\n  protected abstract readonly policy?: PolicyDocument;\n\n  /**\n   * Defines a new alias for the key.\n   */\n  public addAlias(alias: string): EncryptionKeyAlias {\n    return new EncryptionKeyAlias(this, 'Alias', { alias, key: this });\n  }\n\n  /**\n   * Adds a statement to the KMS key resource policy.\n   * @param statement The policy statement to add\n   * @param allowNoOp If this is set to `false` and there is no policy\n   * defined (i.e. external key), the operation will fail. Otherwise, it will\n   * no-op.\n   */\n  public addToResourcePolicy(statement: PolicyStatement, allowNoOp = true) {\n    if (!this.policy) {\n      if (allowNoOp) { return; }\n      throw new Error(`Unable to add statement to IAM resource policy for KMS key: ${JSON.stringify(this.node.resolve(this.keyArn))}`);\n    }\n\n    this.policy.addStatement(statement);\n  }\n\n  public abstract export(): EncryptionKeyImportProps;\n}\n\n/**\n * Construction properties for a KMS Key object\n */\nexport interface EncryptionKeyProps {\n  /**\n   * A description of the key. Use a description that helps your users decide\n   * whether the key is appropriate for a particular task.\n   */\n  description?: string;\n\n  /**\n   * Indicates whether AWS KMS rotates the key.\n   * @default false\n   */\n  enableKeyRotation?: boolean;\n\n  /**\n   * Indicates whether the key is available for use.\n   * @default Key is enabled\n   */\n  enabled?: boolean;\n\n  /**\n   * Custom policy document to attach to the KMS key.\n   *\n   * @default A policy document with permissions for the account root to\n   * administer the key will be created.\n   */\n  policy?: PolicyDocument;\n}\n\n/**\n * Defines a KMS key.\n */\nexport class EncryptionKey extends EncryptionKeyBase {\n  /**\n   * Defines an imported encryption key.\n   *\n   * `ref` can be obtained either via a call to `key.export()` or using\n   * literals.\n   *\n   * For example:\n   *\n   *   const keyAttr = key.export();\n   *   const keyRef1 = EncryptionKey.import(this, 'MyImportedKey1', keyAttr);\n   *   const keyRef2 = EncryptionKey.import(this, 'MyImportedKey2', {\n   *     keyArn: new KeyArn('arn:aws:kms:...')\n   *   });\n   *\n   * @param scope The parent construct.\n   * @param id The name of the construct.\n   * @param props The key reference.\n   */\n  public static import(scope: Construct, id: string, props: EncryptionKeyImportProps): IEncryptionKey {\n    return new ImportedEncryptionKey(scope, id, props);\n  }\n\n  public readonly keyArn: string;\n  protected readonly policy?: PolicyDocument;\n\n  constructor(scope: Construct, id: string, props: EncryptionKeyProps = {}) {\n    super(scope, id);\n\n    if (props.policy) {\n      this.policy = props.policy;\n    } else {\n      this.policy = new PolicyDocument();\n      this.allowAccountToAdmin();\n    }\n\n    const resource = new CfnKey(this, 'Resource', {\n      description: props.description,\n      enableKeyRotation: props.enableKeyRotation,\n      enabled: props.enabled,\n      keyPolicy: this.policy,\n    });\n\n    this.keyArn = resource.keyArn;\n    resource.options.deletionPolicy = DeletionPolicy.Retain;\n  }\n\n  /**\n   * Exports this key from the current stack.\n   * @returns a key ref which can be used in a call to `EncryptionKey.import(ref)`.\n   */\n  public export(): EncryptionKeyImportProps {\n    return {\n      keyArn: new Output(this, 'KeyArn', { value: this.keyArn }).makeImportValue().toString()\n    };\n  }\n\n  /**\n   * Let users from this account admin this key.\n   * @link https://aws.amazon.com/premiumsupport/knowledge-center/update-key-policy-future/\n   */\n  private allowAccountToAdmin() {\n    const actions = [\n      \"kms:Create*\",\n      \"kms:Describe*\",\n      \"kms:Enable*\",\n      \"kms:List*\",\n      \"kms:Put*\",\n      \"kms:Update*\",\n      \"kms:Revoke*\",\n      \"kms:Disable*\",\n      \"kms:Get*\",\n      \"kms:Delete*\",\n      \"kms:ScheduleKeyDeletion\",\n      \"kms:CancelKeyDeletion\"\n    ];\n\n    this.addToResourcePolicy(new PolicyStatement()\n      .addAllResources()\n      .addActions(...actions)\n      .addAccountRootPrincipal());\n  }\n}\n\nclass ImportedEncryptionKey extends EncryptionKeyBase {\n  public readonly keyArn: string;\n  protected readonly policy = undefined; // no policy associated with an imported key\n\n  constructor(scope: Construct, id: string, private readonly props: EncryptionKeyImportProps) {\n    super(scope, id);\n\n    this.keyArn = props.keyArn;\n  }\n\n  public export() {\n    return this.props;\n  }\n}\n"]}

@@ -77,3 +77,3 @@ import cdk = require('@aws-cdk/cdk');

*/
tags?: Array<cdk.Tag | cdk.Token> | cdk.Token;
tags?: Array<cdk.CfnTag | cdk.Token> | cdk.Token;
}

@@ -94,2 +94,11 @@ /**

/**
* The ``TagManager`` handles setting, removing and formatting tags
*
* Tags should be managed either passing them as properties during
* initiation or by calling methods on this object. If both techniques are
* used only the tags from the TagManager will be used. ``Tag`` (aspect)
* will use the manager.
*/
readonly tags: cdk.TagManager;
/**
* Creates a new ``AWS::KMS::Key``.

@@ -96,0 +105,0 @@ *

"use strict";
// Copyright 2012-2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.
// Copyright 2012-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
// Generated from the AWS CloudFormation Resource Specification
// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html
// @cfn2ts:meta@ {"generated":"2019-02-04T14:42:43.188Z","fingerprint":"S/OqpiCKwgfSaOuSpLPZzvSgUfkC/1P6L5/Db3ZM8Yg="}
// @cfn2ts:meta@ {"generated":"2019-02-07T11:03:06.831Z","fingerprint":"z/bwWLC7ty6UnCgTnOe2FySfKI/VFqQ7DvNrk2iqOSQ="}
Object.defineProperty(exports, "__esModule", { value: true });

@@ -92,3 +92,3 @@ // tslint:disable:max-line-length | This is generated code - line lengths are difficult to control

errors.collect(cdk.propertyValidator('pendingWindowInDays', cdk.validateNumber)(properties.pendingWindowInDays));
errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateTag))(properties.tags));
errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));
return errors.wrap('supplied properties not correct for "CfnKeyProps"');

@@ -115,3 +115,3 @@ }

PendingWindowInDays: cdk.numberToCloudFormation(properties.pendingWindowInDays),
Tags: cdk.listMapper(cdk.tagToCloudFormation)(properties.tags),
Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),
};

@@ -132,2 +132,11 @@ }

super(scope, id, { type: CfnKey.resourceTypeName, properties: props });
/**
* The ``TagManager`` handles setting, removing and formatting tags
*
* Tags should be managed either passing them as properties during
* initiation or by calling methods on this object. If both techniques are
* used only the tags from the TagManager will be used. ``Tag`` (aspect)
* will use the manager.
*/
this.tags = new cdk.TagManager(cdk.TagType.Standard, "AWS::KMS::Key");
cdk.requireProperty(props, 'keyPolicy', this);

@@ -149,2 +158,2 @@ this.keyArn = this.getAtt('Arn').toString();

exports.CfnKey = CfnKey;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":";AAAA,+EAA+E;AAC/E,+DAA+D;AAC/D,8FAA8F;AAC9F,sHAAsH;;AAEtH,kGAAkG;AAElG,oCAAqC;AAkBrC;;;;;;GAMG;AACH,SAAS,sBAAsB,CAAC,UAAe;IAC3C,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,GAAG,CAAC,kBAAkB,CAAC;KAAE;IACnE,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC;IAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAChG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAC7F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACpG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACjG,OAAO,MAAM,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;AAC9E,CAAC;AAED;;;;;;GAMG;AACH,SAAS,6BAA6B,CAAC,UAAe;IAClD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,UAAU,CAAC;KAAE;IACvD,sBAAsB,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,CAAC;IACnD,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,SAAS,CAAC;QAC3D,WAAW,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,WAAW,CAAC;KAChE,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAa,QAAS,SAAQ,GAAG,CAAC,QAAQ;IAOtC;;;;;;OAMG;IACH,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAoB;QAC9D,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,CAAC,gBAAgB,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC9C,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACzC,CAAC;IAED,IAAW,iBAAiB;QACxB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACzC,CAAC;IACS,gBAAgB,CAAC,UAAe;QACtC,OAAO,6BAA6B,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC;IACxE,CAAC;;AAzBD;;GAEG;AACoB,yBAAgB,GAAG,iBAAiB,CAAC;AAJhE,4BA2BC;AA2CD;;;;;;GAMG;AACH,SAAS,oBAAoB,CAAC,UAAe;IACzC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,GAAG,CAAC,kBAAkB,CAAC;KAAE;IACnE,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC;IAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACjG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9G,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IAC1F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAChG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAC7F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,UAAU,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC3F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC;IACjH,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;IACnG,OAAO,MAAM,CAAC,IAAI,CAAC,mDAAmD,CAAC,CAAC;AAC5E,CAAC;AAED;;;;;;GAMG;AACH,SAAS,2BAA2B,CAAC,UAAe;IAChD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,UAAU,CAAC;KAAE;IACvD,oBAAoB,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,CAAC;IACjD,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,SAAS,CAAC;QAC3D,WAAW,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,WAAW,CAAC;QAC/D,OAAO,EAAE,GAAG,CAAC,uBAAuB,CAAC,UAAU,CAAC,OAAO,CAAC;QACxD,iBAAiB,EAAE,GAAG,CAAC,uBAAuB,CAAC,UAAU,CAAC,iBAAiB,CAAC;QAC5E,QAAQ,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,QAAQ,CAAC;QACzD,mBAAmB,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,mBAAmB,CAAC;QAC/E,IAAI,EAAE,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC;KAC/D,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAa,MAAO,SAAQ,GAAG,CAAC,QAAQ;IAYpC;;;;;;OAMG;IACH,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAkB;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,gBAAgB,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QACvE,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAED,IAAW,iBAAiB;QACxB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACzC,CAAC;IACS,gBAAgB,CAAC,UAAe;QACtC,OAAO,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC;IACtE,CAAC;;AA9BD;;GAEG;AACoB,uBAAgB,GAAG,eAAe,CAAC;AAJ9D,wBAgCC","sourcesContent":["// Copyright 2012-2018 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// Generated from the AWS CloudFormation Resource Specification\n// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html\n// @cfn2ts:meta@ {\"generated\":\"2019-02-04T14:42:43.188Z\",\"fingerprint\":\"S/OqpiCKwgfSaOuSpLPZzvSgUfkC/1P6L5/Db3ZM8Yg=\"}\n\n// tslint:disable:max-line-length | This is generated code - line lengths are difficult to control\n\nimport cdk = require('@aws-cdk/cdk');\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n */\nexport interface CfnAliasProps {\n    /**\n     * ``AWS::KMS::Alias.AliasName``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-aliasname\n     */\n    aliasName: string;\n    /**\n     * ``AWS::KMS::Alias.TargetKeyId``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-targetkeyid\n     */\n    targetKeyId: string;\n}\n\n/**\n * Determine whether the given properties match those of a ``CfnAliasProps``\n *\n * @param properties the TypeScript properties of a ``CfnAliasProps``\n *\n * @returns the result of the validation.\n */\nfunction CfnAliasPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    errors.collect(cdk.propertyValidator('aliasName', cdk.requiredValidator)(properties.aliasName));\n    errors.collect(cdk.propertyValidator('aliasName', cdk.validateString)(properties.aliasName));\n    errors.collect(cdk.propertyValidator('targetKeyId', cdk.requiredValidator)(properties.targetKeyId));\n    errors.collect(cdk.propertyValidator('targetKeyId', cdk.validateString)(properties.targetKeyId));\n    return errors.wrap('supplied properties not correct for \"CfnAliasProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource\n *\n * @param properties the TypeScript properties of a ``CfnAliasProps``\n *\n * @returns the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource.\n */\nfunction cfnAliasPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnAliasPropsValidator(properties).assertSuccess();\n    return {\n      AliasName: cdk.stringToCloudFormation(properties.aliasName),\n      TargetKeyId: cdk.stringToCloudFormation(properties.targetKeyId),\n    };\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n */\nexport class CfnAlias extends cdk.Resource {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly resourceTypeName = \"AWS::KMS::Alias\";\n    public readonly aliasName: string;\n\n    /**\n     * Creates a new ``AWS::KMS::Alias``.\n     *\n     * @param scope scope in which this resource is defined\n     * @param id    scoped id of the resource\n     * @param props resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnAliasProps) {\n        super(scope, id, { type: CfnAlias.resourceTypeName, properties: props });\n        cdk.requireProperty(props, 'aliasName', this);\n        cdk.requireProperty(props, 'targetKeyId', this);\n        this.aliasName = this.ref.toString();\n    }\n\n    public get propertyOverrides(): CfnAliasProps {\n        return this.untypedPropertyOverrides;\n    }\n    protected renderProperties(properties: any): { [key: string]: any }  {\n        return cfnAliasPropsToCloudFormation(this.node.resolve(properties));\n    }\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n */\nexport interface CfnKeyProps {\n    /**\n     * ``AWS::KMS::Key.KeyPolicy``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keypolicy\n     */\n    keyPolicy: object | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.Description``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-description\n     */\n    description?: string;\n    /**\n     * ``AWS::KMS::Key.Enabled``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enabled\n     */\n    enabled?: boolean | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.EnableKeyRotation``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enablekeyrotation\n     */\n    enableKeyRotation?: boolean | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.KeyUsage``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keyusage\n     */\n    keyUsage?: string;\n    /**\n     * ``AWS::KMS::Key.PendingWindowInDays``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-pendingwindowindays\n     */\n    pendingWindowInDays?: number | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.Tags``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-tags\n     */\n    tags?: Array<cdk.Tag | cdk.Token> | cdk.Token;\n}\n\n/**\n * Determine whether the given properties match those of a ``CfnKeyProps``\n *\n * @param properties the TypeScript properties of a ``CfnKeyProps``\n *\n * @returns the result of the validation.\n */\nfunction CfnKeyPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n    errors.collect(cdk.propertyValidator('enableKeyRotation', cdk.validateBoolean)(properties.enableKeyRotation));\n    errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));\n    errors.collect(cdk.propertyValidator('keyPolicy', cdk.requiredValidator)(properties.keyPolicy));\n    errors.collect(cdk.propertyValidator('keyPolicy', cdk.validateObject)(properties.keyPolicy));\n    errors.collect(cdk.propertyValidator('keyUsage', cdk.validateString)(properties.keyUsage));\n    errors.collect(cdk.propertyValidator('pendingWindowInDays', cdk.validateNumber)(properties.pendingWindowInDays));\n    errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateTag))(properties.tags));\n    return errors.wrap('supplied properties not correct for \"CfnKeyProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource\n *\n * @param properties the TypeScript properties of a ``CfnKeyProps``\n *\n * @returns the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource.\n */\nfunction cfnKeyPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnKeyPropsValidator(properties).assertSuccess();\n    return {\n      KeyPolicy: cdk.objectToCloudFormation(properties.keyPolicy),\n      Description: cdk.stringToCloudFormation(properties.description),\n      Enabled: cdk.booleanToCloudFormation(properties.enabled),\n      EnableKeyRotation: cdk.booleanToCloudFormation(properties.enableKeyRotation),\n      KeyUsage: cdk.stringToCloudFormation(properties.keyUsage),\n      PendingWindowInDays: cdk.numberToCloudFormation(properties.pendingWindowInDays),\n      Tags: cdk.listMapper(cdk.tagToCloudFormation)(properties.tags),\n    };\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n */\nexport class CfnKey extends cdk.Resource {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly resourceTypeName = \"AWS::KMS::Key\";\n\n    /**\n     * @cloudformation_attribute Arn\n     */\n    public readonly keyArn: string;\n    public readonly keyId: string;\n\n    /**\n     * Creates a new ``AWS::KMS::Key``.\n     *\n     * @param scope scope in which this resource is defined\n     * @param id    scoped id of the resource\n     * @param props resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnKeyProps) {\n        super(scope, id, { type: CfnKey.resourceTypeName, properties: props });\n        cdk.requireProperty(props, 'keyPolicy', this);\n        this.keyArn = this.getAtt('Arn').toString();\n        this.keyId = this.ref.toString();\n    }\n\n    public get propertyOverrides(): CfnKeyProps {\n        return this.untypedPropertyOverrides;\n    }\n    protected renderProperties(properties: any): { [key: string]: any }  {\n        return cfnKeyPropsToCloudFormation(this.node.resolve(properties));\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kms.generated.js","sourceRoot":"","sources":["kms.generated.ts"],"names":[],"mappings":";AAAA,+EAA+E;AAC/E,+DAA+D;AAC/D,8FAA8F;AAC9F,sHAAsH;;AAEtH,kGAAkG;AAElG,oCAAqC;AAkBrC;;;;;;GAMG;AACH,SAAS,sBAAsB,CAAC,UAAe;IAC3C,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,GAAG,CAAC,kBAAkB,CAAC;KAAE;IACnE,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC;IAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAChG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAC7F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACpG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACjG,OAAO,MAAM,CAAC,IAAI,CAAC,qDAAqD,CAAC,CAAC;AAC9E,CAAC;AAED;;;;;;GAMG;AACH,SAAS,6BAA6B,CAAC,UAAe;IAClD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,UAAU,CAAC;KAAE;IACvD,sBAAsB,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,CAAC;IACnD,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,SAAS,CAAC;QAC3D,WAAW,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,WAAW,CAAC;KAChE,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAa,QAAS,SAAQ,GAAG,CAAC,QAAQ;IAOtC;;;;;;OAMG;IACH,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAoB;QAC9D,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,CAAC,gBAAgB,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC9C,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACzC,CAAC;IAED,IAAW,iBAAiB;QACxB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACzC,CAAC;IACS,gBAAgB,CAAC,UAAe;QACtC,OAAO,6BAA6B,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC;IACxE,CAAC;;AAzBD;;GAEG;AACoB,yBAAgB,GAAG,iBAAiB,CAAC;AAJhE,4BA2BC;AA2CD;;;;;;GAMG;AACH,SAAS,oBAAoB,CAAC,UAAe;IACzC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,GAAG,CAAC,kBAAkB,CAAC;KAAE;IACnE,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,iBAAiB,EAAE,CAAC;IAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,aAAa,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC;IACjG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,mBAAmB,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9G,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,SAAS,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IAC1F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,iBAAiB,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAChG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,WAAW,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC;IAC7F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,UAAU,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC3F,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC,CAAC;IACjH,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,MAAM,EAAE,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC;IACtG,OAAO,MAAM,CAAC,IAAI,CAAC,mDAAmD,CAAC,CAAC;AAC5E,CAAC;AAED;;;;;;GAMG;AACH,SAAS,2BAA2B,CAAC,UAAe;IAChD,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;QAAE,OAAO,UAAU,CAAC;KAAE;IACvD,oBAAoB,CAAC,UAAU,CAAC,CAAC,aAAa,EAAE,CAAC;IACjD,OAAO;QACL,SAAS,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,SAAS,CAAC;QAC3D,WAAW,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,WAAW,CAAC;QAC/D,OAAO,EAAE,GAAG,CAAC,uBAAuB,CAAC,UAAU,CAAC,OAAO,CAAC;QACxD,iBAAiB,EAAE,GAAG,CAAC,uBAAuB,CAAC,UAAU,CAAC,iBAAiB,CAAC;QAC5E,QAAQ,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,QAAQ,CAAC;QACzD,mBAAmB,EAAE,GAAG,CAAC,sBAAsB,CAAC,UAAU,CAAC,mBAAmB,CAAC;QAC/E,IAAI,EAAE,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC;KAClE,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAa,MAAO,SAAQ,GAAG,CAAC,QAAQ;IAsBpC;;;;;;OAMG;IACH,YAAY,KAAoB,EAAE,EAAU,EAAE,KAAkB;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,gBAAgB,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAC;QAlB3E;;;;;;;WAOG;QACa,SAAI,GAAG,IAAI,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QAW7E,GAAG,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC;QAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAED,IAAW,iBAAiB;QACxB,OAAO,IAAI,CAAC,wBAAwB,CAAC;IACzC,CAAC;IACS,gBAAgB,CAAC,UAAe;QACtC,OAAO,2BAA2B,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC;IACtE,CAAC;;AAxCD;;GAEG;AACoB,uBAAgB,GAAG,eAAe,CAAC;AAJ9D,wBA0CC","sourcesContent":["// Copyright 2012-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// Generated from the AWS CloudFormation Resource Specification\n// See: docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/cfn-resource-specification.html\n// @cfn2ts:meta@ {\"generated\":\"2019-02-07T11:03:06.831Z\",\"fingerprint\":\"z/bwWLC7ty6UnCgTnOe2FySfKI/VFqQ7DvNrk2iqOSQ=\"}\n\n// tslint:disable:max-line-length | This is generated code - line lengths are difficult to control\n\nimport cdk = require('@aws-cdk/cdk');\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n */\nexport interface CfnAliasProps {\n    /**\n     * ``AWS::KMS::Alias.AliasName``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-aliasname\n     */\n    aliasName: string;\n    /**\n     * ``AWS::KMS::Alias.TargetKeyId``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html#cfn-kms-alias-targetkeyid\n     */\n    targetKeyId: string;\n}\n\n/**\n * Determine whether the given properties match those of a ``CfnAliasProps``\n *\n * @param properties the TypeScript properties of a ``CfnAliasProps``\n *\n * @returns the result of the validation.\n */\nfunction CfnAliasPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    errors.collect(cdk.propertyValidator('aliasName', cdk.requiredValidator)(properties.aliasName));\n    errors.collect(cdk.propertyValidator('aliasName', cdk.validateString)(properties.aliasName));\n    errors.collect(cdk.propertyValidator('targetKeyId', cdk.requiredValidator)(properties.targetKeyId));\n    errors.collect(cdk.propertyValidator('targetKeyId', cdk.validateString)(properties.targetKeyId));\n    return errors.wrap('supplied properties not correct for \"CfnAliasProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource\n *\n * @param properties the TypeScript properties of a ``CfnAliasProps``\n *\n * @returns the AWS CloudFormation properties of an ``AWS::KMS::Alias`` resource.\n */\nfunction cfnAliasPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnAliasPropsValidator(properties).assertSuccess();\n    return {\n      AliasName: cdk.stringToCloudFormation(properties.aliasName),\n      TargetKeyId: cdk.stringToCloudFormation(properties.targetKeyId),\n    };\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-alias.html\n */\nexport class CfnAlias extends cdk.Resource {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly resourceTypeName = \"AWS::KMS::Alias\";\n    public readonly aliasName: string;\n\n    /**\n     * Creates a new ``AWS::KMS::Alias``.\n     *\n     * @param scope scope in which this resource is defined\n     * @param id    scoped id of the resource\n     * @param props resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnAliasProps) {\n        super(scope, id, { type: CfnAlias.resourceTypeName, properties: props });\n        cdk.requireProperty(props, 'aliasName', this);\n        cdk.requireProperty(props, 'targetKeyId', this);\n        this.aliasName = this.ref.toString();\n    }\n\n    public get propertyOverrides(): CfnAliasProps {\n        return this.untypedPropertyOverrides;\n    }\n    protected renderProperties(properties: any): { [key: string]: any }  {\n        return cfnAliasPropsToCloudFormation(this.node.resolve(properties));\n    }\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n */\nexport interface CfnKeyProps {\n    /**\n     * ``AWS::KMS::Key.KeyPolicy``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keypolicy\n     */\n    keyPolicy: object | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.Description``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-description\n     */\n    description?: string;\n    /**\n     * ``AWS::KMS::Key.Enabled``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enabled\n     */\n    enabled?: boolean | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.EnableKeyRotation``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-enablekeyrotation\n     */\n    enableKeyRotation?: boolean | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.KeyUsage``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-keyusage\n     */\n    keyUsage?: string;\n    /**\n     * ``AWS::KMS::Key.PendingWindowInDays``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-pendingwindowindays\n     */\n    pendingWindowInDays?: number | cdk.Token;\n    /**\n     * ``AWS::KMS::Key.Tags``\n     * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html#cfn-kms-key-tags\n     */\n    tags?: Array<cdk.CfnTag | cdk.Token> | cdk.Token;\n}\n\n/**\n * Determine whether the given properties match those of a ``CfnKeyProps``\n *\n * @param properties the TypeScript properties of a ``CfnKeyProps``\n *\n * @returns the result of the validation.\n */\nfunction CfnKeyPropsValidator(properties: any): cdk.ValidationResult {\n    if (!cdk.canInspect(properties)) { return cdk.VALIDATION_SUCCESS; }\n    const errors = new cdk.ValidationResults();\n    errors.collect(cdk.propertyValidator('description', cdk.validateString)(properties.description));\n    errors.collect(cdk.propertyValidator('enableKeyRotation', cdk.validateBoolean)(properties.enableKeyRotation));\n    errors.collect(cdk.propertyValidator('enabled', cdk.validateBoolean)(properties.enabled));\n    errors.collect(cdk.propertyValidator('keyPolicy', cdk.requiredValidator)(properties.keyPolicy));\n    errors.collect(cdk.propertyValidator('keyPolicy', cdk.validateObject)(properties.keyPolicy));\n    errors.collect(cdk.propertyValidator('keyUsage', cdk.validateString)(properties.keyUsage));\n    errors.collect(cdk.propertyValidator('pendingWindowInDays', cdk.validateNumber)(properties.pendingWindowInDays));\n    errors.collect(cdk.propertyValidator('tags', cdk.listValidator(cdk.validateCfnTag))(properties.tags));\n    return errors.wrap('supplied properties not correct for \"CfnKeyProps\"');\n}\n\n/**\n * Renders the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource\n *\n * @param properties the TypeScript properties of a ``CfnKeyProps``\n *\n * @returns the AWS CloudFormation properties of an ``AWS::KMS::Key`` resource.\n */\nfunction cfnKeyPropsToCloudFormation(properties: any): any {\n    if (!cdk.canInspect(properties)) { return properties; }\n    CfnKeyPropsValidator(properties).assertSuccess();\n    return {\n      KeyPolicy: cdk.objectToCloudFormation(properties.keyPolicy),\n      Description: cdk.stringToCloudFormation(properties.description),\n      Enabled: cdk.booleanToCloudFormation(properties.enabled),\n      EnableKeyRotation: cdk.booleanToCloudFormation(properties.enableKeyRotation),\n      KeyUsage: cdk.stringToCloudFormation(properties.keyUsage),\n      PendingWindowInDays: cdk.numberToCloudFormation(properties.pendingWindowInDays),\n      Tags: cdk.listMapper(cdk.cfnTagToCloudFormation)(properties.tags),\n    };\n}\n\n/**\n * @link http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-kms-key.html\n */\nexport class CfnKey extends cdk.Resource {\n    /**\n     * The CloudFormation resource type name for this resource class.\n     */\n    public static readonly resourceTypeName = \"AWS::KMS::Key\";\n\n    /**\n     * @cloudformation_attribute Arn\n     */\n    public readonly keyArn: string;\n    public readonly keyId: string;\n\n    /**\n     * The ``TagManager`` handles setting, removing and formatting tags\n     *\n     * Tags should be managed either passing them as properties during\n     * initiation or by calling methods on this object. If both techniques are\n     * used only the tags from the TagManager will be used. ``Tag`` (aspect)\n     * will use the manager.\n     */\n    public readonly tags = new cdk.TagManager(cdk.TagType.Standard, \"AWS::KMS::Key\");\n\n    /**\n     * Creates a new ``AWS::KMS::Key``.\n     *\n     * @param scope scope in which this resource is defined\n     * @param id    scoped id of the resource\n     * @param props resource properties\n     */\n    constructor(scope: cdk.Construct, id: string, props: CfnKeyProps) {\n        super(scope, id, { type: CfnKey.resourceTypeName, properties: props });\n        cdk.requireProperty(props, 'keyPolicy', this);\n        this.keyArn = this.getAtt('Arn').toString();\n        this.keyId = this.ref.toString();\n    }\n\n    public get propertyOverrides(): CfnKeyProps {\n        return this.untypedPropertyOverrides;\n    }\n    protected renderProperties(properties: any): { [key: string]: any }  {\n        return cfnKeyPropsToCloudFormation(this.node.resolve(properties));\n    }\n}\n"]}
{
"name": "@aws-cdk/aws-kms",
"version": "0.23.0",
"version": "0.24.0",
"description": "CDK Constructs for AWS KMS",

@@ -57,16 +57,16 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.23.0",
"cdk-build-tools": "^0.23.0",
"cdk-integ-tools": "^0.23.0",
"cfn2ts": "^0.23.0",
"pkglint": "^0.23.0"
"@aws-cdk/assert": "^0.24.0",
"cdk-build-tools": "^0.24.0",
"cdk-integ-tools": "^0.24.0",
"cfn2ts": "^0.24.0",
"pkglint": "^0.24.0"
},
"dependencies": {
"@aws-cdk/aws-iam": "^0.23.0",
"@aws-cdk/cdk": "^0.23.0"
"@aws-cdk/aws-iam": "^0.24.0",
"@aws-cdk/cdk": "^0.24.0"
},
"homepage": "https://github.com/awslabs/aws-cdk",
"peerDependencies": {
"@aws-cdk/aws-iam": "^0.23.0",
"@aws-cdk/cdk": "^0.23.0"
"@aws-cdk/aws-iam": "^0.24.0",
"@aws-cdk/cdk": "^0.24.0"
},

@@ -76,2 +76,2 @@ "engines": {

}
}
}

@@ -8,6 +8,5 @@ "use strict";

'default key'(test) {
const app = new cdk_1.App();
const stack = new cdk_1.Stack(app, 'TestStack');
const stack = new cdk_1.Stack();
new lib_1.EncryptionKey(stack, 'MyKey');
assert_1.expect(app.synthesizeStack(stack.name)).to(assert_1.exactlyMatchTemplate({
assert_1.expect(stack).to(assert_1.exactlyMatchTemplate({
Resources: {

@@ -134,12 +133,6 @@ MyKey6AB29FA6: {

'key with some options'(test) {
const app = new cdk_1.App();
const stack = new cdk_1.Stack(app, 'Test');
const stack = new cdk_1.Stack();
const key = new lib_1.EncryptionKey(stack, 'MyKey', {
enableKeyRotation: true,
enabled: false,
tags: {
tag1: 'value1',
tag2: 'value2',
tag3: ''
}
});

@@ -149,3 +142,6 @@ const p = new aws_iam_1.PolicyStatement().addAllResources().addAction('kms:encrypt');

key.addToResourcePolicy(p);
assert_1.expect(app.synthesizeStack(stack.name)).to(assert_1.exactlyMatchTemplate({
key.apply(new cdk_1.Tag('tag1', 'value1'));
key.apply(new cdk_1.Tag('tag2', 'value2'));
key.apply(new cdk_1.Tag('tag3', ''));
assert_1.expect(stack).to(assert_1.exactlyMatchTemplate({
Resources: {

@@ -155,4 +151,2 @@ MyKey6AB29FA6: {

Properties: {
Enabled: false,
EnableKeyRotation: true,
KeyPolicy: {

@@ -207,2 +201,4 @@ Statement: [

},
Enabled: false,
EnableKeyRotation: true,
Tags: [

@@ -377,2 +373,2 @@ {

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.key.js","sourceRoot":"","sources":["test.key.ts"],"names":[],"mappings":"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","sourcesContent":["import { exactlyMatchTemplate, expect } from '@aws-cdk/assert';\nimport { PolicyDocument, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { App, Stack } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { EncryptionKey } from '../lib';\n\nexport = {\n  'default key'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'TestStack');\n\n    new EncryptionKey(stack, 'MyKey');\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        KeyPolicy: {\n          Statement: [\n          {\n            Action: [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\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          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      }\n      }\n    }));\n    test.done();\n  },\n\n  'default with some permission'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey');\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n          KeyPolicy: {\n          Statement: [\n            {\n            Action: [\n              \"kms:Create*\",\n              \"kms:Describe*\",\n              \"kms:Enable*\",\n              \"kms:List*\",\n              \"kms:Put*\",\n              \"kms:Update*\",\n              \"kms:Revoke*\",\n              \"kms:Disable*\",\n              \"kms:Get*\",\n              \"kms:Delete*\",\n              \"kms:ScheduleKeyDeletion\",\n              \"kms:CancelKeyDeletion\"\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            },\n            {\n            Action: \"kms:encrypt\",\n            Effect: \"Allow\",\n            Principal: {\n              AWS: \"arn\"\n            },\n            Resource: \"*\"\n            }\n          ],\n          Version: \"2012-10-17\"\n          }\n        },\n        DeletionPolicy: \"Retain\"\n        }\n      }\n      }));\n\n    test.done();\n  },\n\n  'key with some options'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false,\n      tags: {\n        tag1: 'value1',\n        tag2: 'value2',\n        tag3: ''\n      }\n    });\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n          Enabled: false,\n          EnableKeyRotation: true,\n          KeyPolicy: {\n          Statement: [\n            {\n            Action: [\n              \"kms:Create*\",\n              \"kms:Describe*\",\n              \"kms:Enable*\",\n              \"kms:List*\",\n              \"kms:Put*\",\n              \"kms:Update*\",\n              \"kms:Revoke*\",\n              \"kms:Disable*\",\n              \"kms:Get*\",\n              \"kms:Delete*\",\n              \"kms:ScheduleKeyDeletion\",\n              \"kms:CancelKeyDeletion\"\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            },\n            {\n            Action: \"kms:encrypt\",\n            Effect: \"Allow\",\n            Principal: {\n              AWS: \"arn\"\n            },\n            Resource: \"*\"\n            }\n          ],\n          Version: \"2012-10-17\"\n          },\n          Tags: [\n            {\n              Key: \"tag1\",\n              Value: \"value1\"\n            },\n            {\n              Key: \"tag2\",\n              Value: \"value2\"\n            },\n            {\n              Key: \"tag3\",\n              Value: \"\"\n            }\n          ]\n        },\n        DeletionPolicy: \"Retain\"\n        }\n      }\n      }));\n\n    test.done();\n  },\n\n  'addAlias creates an alias'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false\n    });\n\n    const alias = key.addAlias('alias/xoo');\n    test.ok(alias.aliasName);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, {\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        EnableKeyRotation: true,\n        Enabled: false,\n        KeyPolicy: {\n          Statement: [\n          {\n            Action: [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\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          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      },\n      MyKeyAlias1B45D9DA: {\n        Type: \"AWS::KMS::Alias\",\n        Properties: {\n        AliasName: \"alias/xoo\",\n        TargetKeyId: {\n          \"Fn::GetAtt\": [\n          \"MyKey6AB29FA6\",\n          \"Arn\"\n          ]\n        }\n        }\n      }\n      }\n    });\n\n    test.done();\n  },\n\n  'import/export can be used to bring in an existing key'(test: Test) {\n    const stack1 = new Stack();\n    const policy = new PolicyDocument();\n    policy.addStatement(new PolicyStatement().addAllResources());\n    const myKey = new EncryptionKey(stack1, 'MyKey', { policy });\n    const exportedKeyRef = myKey.export();\n\n    expect(stack1).toMatch({\n      Resources: {\n        MyKey6AB29FA6: {\n          Type: \"AWS::KMS::Key\",\n          Properties: {\n            KeyPolicy: {\n              Statement: [\n                {\n                  Effect: \"Allow\",\n                  Resource: \"*\"\n                }\n              ],\n              Version: \"2012-10-17\"\n            }\n          },\n          DeletionPolicy: \"Retain\"\n        }\n      },\n      Outputs: {\n        MyKeyKeyArn317F1332: {\n          Value: {\n            \"Fn::GetAtt\": [\n              \"MyKey6AB29FA6\",\n              \"Arn\"\n            ]\n          },\n          Export: {\n            Name: \"MyKeyKeyArn317F1332\"\n          }\n        }\n      }\n    });\n\n    const stack2 = new Stack();\n    const myKeyImported = EncryptionKey.import(stack2, 'MyKeyImported', exportedKeyRef);\n\n    // addAlias can be called on imported keys.\n    myKeyImported.addAlias('alias/hello');\n\n    expect(stack2).toMatch({\n      Resources: {\n      MyKeyImportedAliasB1C5269F: {\n        Type: \"AWS::KMS::Alias\",\n        Properties: {\n        AliasName: \"alias/hello\",\n        TargetKeyId: {\n          \"Fn::ImportValue\": \"MyKeyKeyArn317F1332\"\n        }\n        }\n      }\n      }\n    });\n\n    test.done();\n  },\n\n  'addToResourcePolicy allowNoOp and there is no policy': {\n    'succeed if set to true (default)'(test: Test) {\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'));\n\n      test.done();\n    },\n\n    'fails if set to false'(test: Test) {\n\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      test.throws(() =>\n        key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'), /* allowNoOp */ false),\n        'Unable to add statement to IAM resource policy for KMS key: \"foo/bar\"');\n\n      test.done();\n\n    }\n  }\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.key.js","sourceRoot":"","sources":["test.key.ts"],"names":[],"mappings":"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","sourcesContent":["import { exactlyMatchTemplate, expect } from '@aws-cdk/assert';\nimport { PolicyDocument, PolicyStatement } from '@aws-cdk/aws-iam';\nimport { App, Stack, Tag } from '@aws-cdk/cdk';\nimport { Test } from 'nodeunit';\nimport { EncryptionKey } from '../lib';\n\nexport = {\n  'default key'(test: Test) {\n    const stack = new Stack();\n\n    new EncryptionKey(stack, 'MyKey');\n\n    expect(stack).to(exactlyMatchTemplate({\n      Resources: {\n      MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n        KeyPolicy: {\n          Statement: [\n          {\n            Action: [\n            \"kms:Create*\",\n            \"kms:Describe*\",\n            \"kms:Enable*\",\n            \"kms:List*\",\n            \"kms:Put*\",\n            \"kms:Update*\",\n            \"kms:Revoke*\",\n            \"kms:Disable*\",\n            \"kms:Get*\",\n            \"kms:Delete*\",\n            \"kms:ScheduleKeyDeletion\",\n            \"kms:CancelKeyDeletion\"\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          }\n          ],\n          Version: \"2012-10-17\"\n        }\n        },\n        DeletionPolicy: \"Retain\"\n      }\n      }\n    }));\n    test.done();\n  },\n\n  'default with some permission'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey');\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    expect(app.synthesizeStack(stack.name)).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n        Type: \"AWS::KMS::Key\",\n        Properties: {\n          KeyPolicy: {\n          Statement: [\n            {\n            Action: [\n              \"kms:Create*\",\n              \"kms:Describe*\",\n              \"kms:Enable*\",\n              \"kms:List*\",\n              \"kms:Put*\",\n              \"kms:Update*\",\n              \"kms:Revoke*\",\n              \"kms:Disable*\",\n              \"kms:Get*\",\n              \"kms:Delete*\",\n              \"kms:ScheduleKeyDeletion\",\n              \"kms:CancelKeyDeletion\"\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            },\n            {\n            Action: \"kms:encrypt\",\n            Effect: \"Allow\",\n            Principal: {\n              AWS: \"arn\"\n            },\n            Resource: \"*\"\n            }\n          ],\n          Version: \"2012-10-17\"\n          }\n        },\n        DeletionPolicy: \"Retain\"\n        }\n      }\n      }));\n\n    test.done();\n  },\n\n  'key with some options'(test: Test) {\n    const stack = new Stack();\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false,\n    });\n    const p = new PolicyStatement().addAllResources().addAction('kms:encrypt');\n    p.addAwsPrincipal('arn');\n    key.addToResourcePolicy(p);\n\n    key.apply(new Tag('tag1', 'value1'));\n    key.apply(new Tag('tag2', 'value2'));\n    key.apply(new Tag('tag3', ''));\n\n    expect(stack).to(exactlyMatchTemplate({\n      Resources: {\n        MyKey6AB29FA6: {\n          Type: \"AWS::KMS::Key\",\n          Properties: {\n            KeyPolicy: {\n              Statement: [\n                {\n                  Action: [\n                    \"kms:Create*\",\n                    \"kms:Describe*\",\n                    \"kms:Enable*\",\n                    \"kms:List*\",\n                    \"kms:Put*\",\n                    \"kms:Update*\",\n                    \"kms:Revoke*\",\n                    \"kms:Disable*\",\n                    \"kms:Get*\",\n                    \"kms:Delete*\",\n                    \"kms:ScheduleKeyDeletion\",\n                    \"kms:CancelKeyDeletion\"\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                },\n                {\n                  Action: \"kms:encrypt\",\n                  Effect: \"Allow\",\n                  Principal: {\n                    AWS: \"arn\"\n                  },\n                  Resource: \"*\"\n                }\n              ],\n              Version: \"2012-10-17\"\n            },\n            Enabled: false,\n            EnableKeyRotation: true,\n            Tags: [\n              {\n                Key: \"tag1\",\n                Value: \"value1\"\n              },\n              {\n                Key: \"tag2\",\n                Value: \"value2\"\n              },\n              {\n                Key: \"tag3\",\n                Value: \"\"\n              }\n            ]\n          },\n          DeletionPolicy: \"Retain\"\n        }\n      }\n    }));\n\n    test.done();\n  },\n\n  'addAlias creates an alias'(test: Test) {\n    const app = new App();\n    const stack = new Stack(app, 'Test');\n\n    const key = new EncryptionKey(stack, 'MyKey', {\n      enableKeyRotation: true,\n      enabled: false\n    });\n\n    const alias = key.addAlias('alias/xoo');\n    test.ok(alias.aliasName);\n\n    test.deepEqual(app.synthesizeStack(stack.name).template, {\n      Resources: {\n        MyKey6AB29FA6: {\n          Type: \"AWS::KMS::Key\",\n          Properties: {\n            EnableKeyRotation: true,\n            Enabled: false,\n            KeyPolicy: {\n              Statement: [\n                {\n                  Action: [\n                    \"kms:Create*\",\n                    \"kms:Describe*\",\n                    \"kms:Enable*\",\n                    \"kms:List*\",\n                    \"kms:Put*\",\n                    \"kms:Update*\",\n                    \"kms:Revoke*\",\n                    \"kms:Disable*\",\n                    \"kms:Get*\",\n                    \"kms:Delete*\",\n                    \"kms:ScheduleKeyDeletion\",\n                    \"kms:CancelKeyDeletion\"\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                }\n              ],\n              Version: \"2012-10-17\"\n            }\n          },\n          DeletionPolicy: \"Retain\"\n        },\n        MyKeyAlias1B45D9DA: {\n          Type: \"AWS::KMS::Alias\",\n          Properties: {\n            AliasName: \"alias/xoo\",\n            TargetKeyId: {\n              \"Fn::GetAtt\": [\n                \"MyKey6AB29FA6\",\n                \"Arn\"\n              ]\n            }\n          }\n        }\n      }\n    });\n\n    test.done();\n  },\n\n  'import/export can be used to bring in an existing key'(test: Test) {\n    const stack1 = new Stack();\n    const policy = new PolicyDocument();\n    policy.addStatement(new PolicyStatement().addAllResources());\n    const myKey = new EncryptionKey(stack1, 'MyKey', { policy });\n    const exportedKeyRef = myKey.export();\n\n    expect(stack1).toMatch({\n      Resources: {\n        MyKey6AB29FA6: {\n          Type: \"AWS::KMS::Key\",\n          Properties: {\n            KeyPolicy: {\n              Statement: [\n                {\n                  Effect: \"Allow\",\n                  Resource: \"*\"\n                }\n              ],\n              Version: \"2012-10-17\"\n            }\n          },\n          DeletionPolicy: \"Retain\"\n        }\n      },\n      Outputs: {\n        MyKeyKeyArn317F1332: {\n          Value: {\n            \"Fn::GetAtt\": [\n              \"MyKey6AB29FA6\",\n              \"Arn\"\n            ]\n          },\n          Export: {\n            Name: \"MyKeyKeyArn317F1332\"\n          }\n        }\n      }\n    });\n\n    const stack2 = new Stack();\n    const myKeyImported = EncryptionKey.import(stack2, 'MyKeyImported', exportedKeyRef);\n\n    // addAlias can be called on imported keys.\n    myKeyImported.addAlias('alias/hello');\n\n    expect(stack2).toMatch({\n      Resources: {\n        MyKeyImportedAliasB1C5269F: {\n          Type: \"AWS::KMS::Alias\",\n          Properties: {\n            AliasName: \"alias/hello\",\n            TargetKeyId: {\n              \"Fn::ImportValue\": \"MyKeyKeyArn317F1332\"\n            }\n          }\n        }\n      }\n    });\n\n    test.done();\n  },\n\n  'addToResourcePolicy allowNoOp and there is no policy': {\n    'succeed if set to true (default)'(test: Test) {\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'));\n\n      test.done();\n    },\n\n    'fails if set to false'(test: Test) {\n\n      const stack = new Stack();\n\n      const key = EncryptionKey.import(stack, 'Imported', { keyArn: 'foo/bar' });\n\n      test.throws(() =>\n        key.addToResourcePolicy(new PolicyStatement().addAllResources().addAction('*'), /* allowNoOp */ false),\n        'Unable to add statement to IAM resource policy for KMS key: \"foo/bar\"');\n\n      test.done();\n\n    }\n  }\n};\n"]}

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc