UNPKG

20.8 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.Alias = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const iam = require("@aws-cdk/aws-iam");
8const core_1 = require("@aws-cdk/core");
9const kms_generated_1 = require("./kms.generated");
10const REQUIRED_ALIAS_PREFIX = 'alias/';
11const DISALLOWED_PREFIX = REQUIRED_ALIAS_PREFIX + 'aws/';
12class AliasBase extends core_1.Resource {
13 get keyArn() {
14 return core_1.Stack.of(this).formatArn({
15 service: 'kms',
16 // aliasName already contains the '/'
17 resource: this.aliasName,
18 });
19 }
20 get keyId() {
21 return this.aliasName;
22 }
23 addAlias(alias) {
24 return this.aliasTargetKey.addAlias(alias);
25 }
26 addToResourcePolicy(statement, allowNoOp) {
27 return this.aliasTargetKey.addToResourcePolicy(statement, allowNoOp);
28 }
29 grant(grantee, ...actions) {
30 return this.aliasTargetKey.grant(grantee, ...actions);
31 }
32 grantDecrypt(grantee) {
33 return this.aliasTargetKey.grantDecrypt(grantee);
34 }
35 grantEncrypt(grantee) {
36 return this.aliasTargetKey.grantEncrypt(grantee);
37 }
38 grantEncryptDecrypt(grantee) {
39 return this.aliasTargetKey.grantEncryptDecrypt(grantee);
40 }
41}
42/**
43 * Defines a display name for a customer master key (CMK) in AWS Key Management
44 * Service (AWS KMS). Using an alias to refer to a key can help you simplify key
45 * management. For example, when rotating keys, you can just update the alias
46 * mapping instead of tracking and changing key IDs. For more information, see
47 * Working with Aliases in the AWS Key Management Service Developer Guide.
48 *
49 * You can also add an alias for a key by calling `key.addAlias(alias)`.
50 *
51 * @resource AWS::KMS::Alias
52 */
53class Alias extends AliasBase {
54 constructor(scope, id, props) {
55 try {
56 jsiiDeprecationWarnings._aws_cdk_aws_kms_AliasProps(props);
57 }
58 catch (error) {
59 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
60 Error.captureStackTrace(error, this.constructor);
61 }
62 throw error;
63 }
64 let aliasName = props.aliasName;
65 if (!core_1.Token.isUnresolved(aliasName)) {
66 if (!aliasName.startsWith(REQUIRED_ALIAS_PREFIX)) {
67 aliasName = REQUIRED_ALIAS_PREFIX + aliasName;
68 }
69 if (aliasName === REQUIRED_ALIAS_PREFIX) {
70 throw new Error(`Alias must include a value after "${REQUIRED_ALIAS_PREFIX}": ${aliasName}`);
71 }
72 if (aliasName.toLocaleLowerCase().startsWith(DISALLOWED_PREFIX)) {
73 throw new Error(`Alias cannot start with ${DISALLOWED_PREFIX}: ${aliasName}`);
74 }
75 if (!aliasName.match(/^[a-zA-Z0-9:/_-]{1,256}$/)) {
76 throw new Error('Alias name must be between 1 and 256 characters in a-zA-Z0-9:/_-');
77 }
78 }
79 super(scope, id, {
80 physicalName: aliasName,
81 });
82 this.aliasTargetKey = props.targetKey;
83 const resource = new kms_generated_1.CfnAlias(this, 'Resource', {
84 aliasName: this.physicalName,
85 targetKeyId: this.aliasTargetKey.keyArn,
86 });
87 this.aliasName = this.getResourceNameAttribute(resource.aliasName);
88 if (props.removalPolicy) {
89 resource.applyRemovalPolicy(props.removalPolicy);
90 }
91 }
92 /**
93 * Import an existing KMS Alias defined outside the CDK app.
94 *
95 * @param scope The parent creating construct (usually `this`).
96 * @param id The construct's name.
97 * @param attrs the properties of the referenced KMS Alias
98 */
99 static fromAliasAttributes(scope, id, attrs) {
100 try {
101 jsiiDeprecationWarnings._aws_cdk_aws_kms_AliasAttributes(attrs);
102 }
103 catch (error) {
104 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
105 Error.captureStackTrace(error, this.fromAliasAttributes);
106 }
107 throw error;
108 }
109 class _Alias extends AliasBase {
110 get aliasName() { return attrs.aliasName; }
111 get aliasTargetKey() { return attrs.aliasTargetKey; }
112 }
113 return new _Alias(scope, id);
114 }
115 /**
116 * Import an existing KMS Alias defined outside the CDK app, by the alias name. This method should be used
117 * instead of 'fromAliasAttributes' when the underlying KMS Key ARN is not available.
118 * This Alias will not have a direct reference to the KMS Key, so addAlias and grant* methods are not supported.
119 *
120 * @param scope The parent creating construct (usually `this`).
121 * @param id The construct's name.
122 * @param aliasName The full name of the KMS Alias (e.g., 'alias/aws/s3', 'alias/myKeyAlias').
123 */
124 static fromAliasName(scope, id, aliasName) {
125 class Import extends core_1.Resource {
126 constructor() {
127 super(...arguments);
128 this.keyArn = core_1.Stack.of(this).formatArn({ service: 'kms', resource: aliasName });
129 this.keyId = aliasName;
130 this.aliasName = aliasName;
131 }
132 get aliasTargetKey() { throw new Error('Cannot access aliasTargetKey on an Alias imported by Alias.fromAliasName().'); }
133 addAlias(_alias) { throw new Error('Cannot call addAlias on an Alias imported by Alias.fromAliasName().'); }
134 addToResourcePolicy(_statement, _allowNoOp) {
135 return { statementAdded: false };
136 }
137 grant(grantee, ..._actions) { return iam.Grant.drop(grantee, ''); }
138 grantDecrypt(grantee) { return iam.Grant.drop(grantee, ''); }
139 grantEncrypt(grantee) { return iam.Grant.drop(grantee, ''); }
140 grantEncryptDecrypt(grantee) { return iam.Grant.drop(grantee, ''); }
141 }
142 return new Import(scope, id);
143 }
144 generatePhysicalName() {
145 return REQUIRED_ALIAS_PREFIX + super.generatePhysicalName();
146 }
147}
148exports.Alias = Alias;
149_a = JSII_RTTI_SYMBOL_1;
150Alias[_a] = { fqn: "@aws-cdk/aws-kms.Alias", version: "1.159.0" };
151//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAwC;AACxC,wCAAsE;AAGtE,mDAA2C;AAE3C,MAAM,qBAAqB,GAAG,QAAQ,CAAC;AACvC,MAAM,iBAAiB,GAAG,qBAAqB,GAAG,MAAM,CAAC;AAgDzD,MAAe,SAAU,SAAQ,eAAQ;IAKvC,IAAW,MAAM;QACf,OAAO,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;YAC9B,OAAO,EAAE,KAAK;YACd,qCAAqC;YACrC,QAAQ,EAAE,IAAI,CAAC,SAAS;SACzB,CAAC,CAAC;KACJ;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,SAAS,CAAC;KACvB;IAEM,QAAQ,CAAC,KAAa;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;KAC5C;IAEM,mBAAmB,CAAC,SAA8B,EAAE,SAAmB;QAC5E,OAAO,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;KACtE;IAEM,KAAK,CAAC,OAAuB,EAAE,GAAG,OAAiB;QACxD,OAAO,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,CAAC;KACvD;IAEM,YAAY,CAAC,OAAuB;QACzC,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;KAClD;IAEM,YAAY,CAAC,OAAuB;QACzC,OAAO,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;KAClD;IAEM,mBAAmB,CAAC,OAAuB;QAChD,OAAO,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;KACzD;CACF;AAiBD;;;;;;;;;;GAUG;AACH,MAAa,KAAM,SAAQ,SAAS;IA+ClC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAiB;;;;;;;;;;QACzD,IAAI,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;QAEhC,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE;YAClC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,qBAAqB,CAAC,EAAE;gBAChD,SAAS,GAAG,qBAAqB,GAAG,SAAS,CAAC;aAC/C;YAED,IAAI,SAAS,KAAK,qBAAqB,EAAE;gBACvC,MAAM,IAAI,KAAK,CAAC,qCAAqC,qBAAqB,MAAM,SAAS,EAAE,CAAC,CAAC;aAC9F;YAED,IAAI,SAAS,CAAC,iBAAiB,EAAE,CAAC,UAAU,CAAC,iBAAiB,CAAC,EAAE;gBAC/D,MAAM,IAAI,KAAK,CAAC,2BAA2B,iBAAiB,KAAK,SAAS,EAAE,CAAC,CAAC;aAC/E;YAED,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,0BAA0B,CAAC,EAAE;gBAChD,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;aACrF;SACF;QAED,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,SAAS;SACxB,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,SAAS,CAAC;QAEtC,MAAM,QAAQ,GAAG,IAAI,wBAAQ,CAAC,IAAI,EAAE,UAAU,EAAE;YAC9C,SAAS,EAAE,IAAI,CAAC,YAAY;YAC5B,WAAW,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM;SACxC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAEnE,IAAI,KAAK,CAAC,aAAa,EAAE;YACvB,QAAQ,CAAC,kBAAkB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;SAClD;KACF;IAnFD;;;;;;OAMG;IACI,MAAM,CAAC,mBAAmB,CAAC,KAAgB,EAAE,EAAU,EAAE,KAAsB;;;;;;;;;;QACpF,MAAM,MAAO,SAAQ,SAAS;YAC5B,IAAW,SAAS,KAAK,OAAO,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;YAClD,IAAW,cAAc,KAAK,OAAO,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC;SAC7D;QACD,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IAED;;;;;;;;OAQG;IACI,MAAM,CAAC,aAAa,CAAC,KAAgB,EAAE,EAAU,EAAE,SAAiB;QACzE,MAAM,MAAO,SAAQ,eAAQ;YAA7B;;gBACkB,WAAM,GAAG,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC;gBAC3E,UAAK,GAAG,SAAS,CAAC;gBAClB,cAAS,GAAG,SAAS,CAAC;YAUxC,CAAC;YATC,IAAW,cAAc,KAAW,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC,CAAC,CAAC;YAC9H,QAAQ,CAAC,MAAc,IAAW,MAAM,IAAI,KAAK,CAAC,qEAAqE,CAAC,CAAC,CAAC,CAAC;YAC3H,mBAAmB,CAAC,UAA+B,EAAE,UAAoB;gBAC9E,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC;YACnC,CAAC;YACM,KAAK,CAAC,OAAuB,EAAE,GAAG,QAAkB,IAAe,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACxG,YAAY,CAAC,OAAuB,IAAe,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACxF,YAAY,CAAC,OAAuB,IAAe,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;YACxF,mBAAmB,CAAC,OAAuB,IAAe,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;SACvG;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;IA4CS,oBAAoB;QAC5B,OAAO,qBAAqB,GAAG,KAAK,CAAC,oBAAoB,EAAE,CAAC;KAC7D;;AAxFH,sBAyFC","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport { RemovalPolicy, Resource, Stack, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { IKey } from './key';\nimport { CfnAlias } from './kms.generated';\n\nconst REQUIRED_ALIAS_PREFIX = 'alias/';\nconst DISALLOWED_PREFIX = REQUIRED_ALIAS_PREFIX + 'aws/';\n\n/**\n * A KMS Key alias.\n * An alias can be used in all places that expect a key.\n */\nexport interface IAlias extends IKey {\n  /**\n   * The name of the alias.\n   *\n   * @attribute\n   */\n  readonly aliasName: string;\n\n  /**\n   * The Key to which the Alias refers.\n   *\n   * @attribute\n   */\n  readonly aliasTargetKey: IKey;\n}\n\n/**\n * Construction properties for a KMS Key Alias object.\n */\nexport interface AliasProps {\n  /**\n   * The name of the alias. The name must start with alias followed by a\n   * forward slash, such as alias/. You can't specify aliases that begin with\n   * alias/AWS. These aliases are reserved.\n   */\n  readonly aliasName: string;\n\n  /**\n   * The ID of the key for which you are creating the alias. Specify the key's\n   * globally unique identifier or Amazon Resource Name (ARN). You can't\n   * specify another alias.\n   */\n  readonly targetKey: IKey;\n\n  /**\n   * Policy to apply when the alias is removed from this stack.\n   *\n   * @default - The alias will be deleted\n   */\n  readonly removalPolicy?: RemovalPolicy;\n}\n\nabstract class AliasBase extends Resource implements IAlias {\n  public abstract readonly aliasName: string;\n\n  public abstract readonly aliasTargetKey: IKey;\n\n  public get keyArn(): string {\n    return Stack.of(this).formatArn({\n      service: 'kms',\n      // aliasName already contains the '/'\n      resource: this.aliasName,\n    });\n  }\n\n  public get keyId(): string {\n    return this.aliasName;\n  }\n\n  public addAlias(alias: string): Alias {\n    return this.aliasTargetKey.addAlias(alias);\n  }\n\n  public addToResourcePolicy(statement: iam.PolicyStatement, allowNoOp?: boolean): iam.AddToResourcePolicyResult {\n    return this.aliasTargetKey.addToResourcePolicy(statement, allowNoOp);\n  }\n\n  public grant(grantee: iam.IGrantable, ...actions: string[]): iam.Grant {\n    return this.aliasTargetKey.grant(grantee, ...actions);\n  }\n\n  public grantDecrypt(grantee: iam.IGrantable): iam.Grant {\n    return this.aliasTargetKey.grantDecrypt(grantee);\n  }\n\n  public grantEncrypt(grantee: iam.IGrantable): iam.Grant {\n    return this.aliasTargetKey.grantEncrypt(grantee);\n  }\n\n  public grantEncryptDecrypt(grantee: iam.IGrantable): iam.Grant {\n    return this.aliasTargetKey.grantEncryptDecrypt(grantee);\n  }\n}\n\n/**\n * Properties of a reference to an existing KMS Alias\n */\nexport interface AliasAttributes {\n  /**\n   * Specifies the alias name. This value must begin with alias/ followed by a name (i.e. alias/ExampleAlias)\n   */\n  readonly aliasName: string;\n\n  /**\n   * The customer master key (CMK) to which the Alias refers.\n   */\n  readonly aliasTargetKey: IKey;\n}\n\n/**\n * Defines a display name for a customer master key (CMK) in AWS Key Management\n * Service (AWS KMS). Using an alias to refer to a key can help you simplify key\n * management. For example, when rotating keys, you can just update the alias\n * mapping instead of tracking and changing key IDs. For more information, see\n * Working with Aliases in the AWS Key Management Service Developer Guide.\n *\n * You can also add an alias for a key by calling `key.addAlias(alias)`.\n *\n * @resource AWS::KMS::Alias\n */\nexport class Alias extends AliasBase {\n  /**\n   * Import an existing KMS Alias defined outside the CDK app.\n   *\n   * @param scope The parent creating construct (usually `this`).\n   * @param id The construct's name.\n   * @param attrs the properties of the referenced KMS Alias\n   */\n  public static fromAliasAttributes(scope: Construct, id: string, attrs: AliasAttributes): IAlias {\n    class _Alias extends AliasBase {\n      public get aliasName() { return attrs.aliasName; }\n      public get aliasTargetKey() { return attrs.aliasTargetKey; }\n    }\n    return new _Alias(scope, id);\n  }\n\n  /**\n   * Import an existing KMS Alias defined outside the CDK app, by the alias name. This method should be used\n   * instead of 'fromAliasAttributes' when the underlying KMS Key ARN is not available.\n   * This Alias will not have a direct reference to the KMS Key, so addAlias and grant* methods are not supported.\n   *\n   * @param scope The parent creating construct (usually `this`).\n   * @param id The construct's name.\n   * @param aliasName The full name of the KMS Alias (e.g., 'alias/aws/s3', 'alias/myKeyAlias').\n   */\n  public static fromAliasName(scope: Construct, id: string, aliasName: string): IAlias {\n    class Import extends Resource implements IAlias {\n      public readonly keyArn = Stack.of(this).formatArn({ service: 'kms', resource: aliasName });\n      public readonly keyId = aliasName;\n      public readonly aliasName = aliasName;\n      public get aliasTargetKey(): IKey { throw new Error('Cannot access aliasTargetKey on an Alias imported by Alias.fromAliasName().'); }\n      public addAlias(_alias: string): Alias { throw new Error('Cannot call addAlias on an Alias imported by Alias.fromAliasName().'); }\n      public addToResourcePolicy(_statement: iam.PolicyStatement, _allowNoOp?: boolean): iam.AddToResourcePolicyResult {\n        return { statementAdded: false };\n      }\n      public grant(grantee: iam.IGrantable, ..._actions: string[]): iam.Grant { return iam.Grant.drop(grantee, ''); }\n      public grantDecrypt(grantee: iam.IGrantable): iam.Grant { return iam.Grant.drop(grantee, ''); }\n      public grantEncrypt(grantee: iam.IGrantable): iam.Grant { return iam.Grant.drop(grantee, ''); }\n      public grantEncryptDecrypt(grantee: iam.IGrantable): iam.Grant { return iam.Grant.drop(grantee, ''); }\n    }\n\n    return new Import(scope, id);\n  }\n\n  public readonly aliasName: string;\n  public readonly aliasTargetKey: IKey;\n\n  constructor(scope: Construct, id: string, props: AliasProps) {\n    let aliasName = props.aliasName;\n\n    if (!Token.isUnresolved(aliasName)) {\n      if (!aliasName.startsWith(REQUIRED_ALIAS_PREFIX)) {\n        aliasName = REQUIRED_ALIAS_PREFIX + aliasName;\n      }\n\n      if (aliasName === REQUIRED_ALIAS_PREFIX) {\n        throw new Error(`Alias must include a value after \"${REQUIRED_ALIAS_PREFIX}\": ${aliasName}`);\n      }\n\n      if (aliasName.toLocaleLowerCase().startsWith(DISALLOWED_PREFIX)) {\n        throw new Error(`Alias cannot start with ${DISALLOWED_PREFIX}: ${aliasName}`);\n      }\n\n      if (!aliasName.match(/^[a-zA-Z0-9:/_-]{1,256}$/)) {\n        throw new Error('Alias name must be between 1 and 256 characters in a-zA-Z0-9:/_-');\n      }\n    }\n\n    super(scope, id, {\n      physicalName: aliasName,\n    });\n\n    this.aliasTargetKey = props.targetKey;\n\n    const resource = new CfnAlias(this, 'Resource', {\n      aliasName: this.physicalName,\n      targetKeyId: this.aliasTargetKey.keyArn,\n    });\n\n    this.aliasName = this.getResourceNameAttribute(resource.aliasName);\n\n    if (props.removalPolicy) {\n      resource.applyRemovalPolicy(props.removalPolicy);\n    }\n  }\n\n  protected generatePhysicalName(): string {\n    return REQUIRED_ALIAS_PREFIX + super.generatePhysicalName();\n  }\n}\n"]}
\No newline at end of file