1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.Alias = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const iam = require("@aws-cdk/aws-iam");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const kms_generated_1 = require("./kms.generated");
|
10 | const REQUIRED_ALIAS_PREFIX = 'alias/';
|
11 | const DISALLOWED_PREFIX = REQUIRED_ALIAS_PREFIX + 'aws/';
|
12 | class 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 | */
|
53 | class 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, Alias);
|
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 | }
|
148 | exports.Alias = Alias;
|
149 | _a = JSII_RTTI_SYMBOL_1;
|
150 | Alias[_a] = { fqn: "@aws-cdk/aws-kms.Alias", version: "1.204.0" };
|
151 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alias.js","sourceRoot":"","sources":["alias.ts"],"names":[],"mappings":"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","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 |