1 | ;
|
2 | var _a, _b;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.CfnRefElement = exports.CfnElement = void 0;
|
5 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
6 | const cxschema = require("@aws-cdk/cloud-assembly-schema");
|
7 | const cxapi = require("@aws-cdk/cx-api");
|
8 | const constructs_1 = require("constructs");
|
9 | // v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.
|
10 | // eslint-disable-next-line
|
11 | const construct_compat_1 = require("./construct-compat");
|
12 | const lazy_1 = require("./lazy");
|
13 | const CFN_ELEMENT_SYMBOL = Symbol.for('@aws-cdk/core.CfnElement');
|
14 | /**
|
15 | * An element of a CloudFormation stack.
|
16 | */
|
17 | class CfnElement extends construct_compat_1.Construct {
|
18 | /**
|
19 | * Creates an entity and binds it to a tree.
|
20 | * Note that the root of the tree must be a Stack object (not just any Root).
|
21 | *
|
22 | * @param scope The parent construct
|
23 | * @param props Construct properties
|
24 | */
|
25 | constructor(scope, id) {
|
26 | super(scope, id);
|
27 | Object.defineProperty(this, CFN_ELEMENT_SYMBOL, { value: true });
|
28 | this.stack = stack_1.Stack.of(this);
|
29 | this.logicalId = lazy_1.Lazy.uncachedString({ produce: () => this.synthesizeLogicalId() }, {
|
30 | displayHint: `${notTooLong(constructs_1.Node.of(this).path)}.LogicalID`,
|
31 | });
|
32 | if (!this.node.tryGetContext(cxapi.DISABLE_LOGICAL_ID_METADATA)) {
|
33 | constructs_1.Node.of(this).addMetadata(cxschema.ArtifactMetadataEntryType.LOGICAL_ID, this.logicalId, this.constructor);
|
34 | }
|
35 | }
|
36 | /**
|
37 | * Returns `true` if a construct is a stack element (i.e. part of the
|
38 | * synthesized cloudformation template).
|
39 | *
|
40 | * Uses duck-typing instead of `instanceof` to allow stack elements from different
|
41 | * versions of this library to be included in the same stack.
|
42 | *
|
43 | * @returns The construct as a stack element or undefined if it is not a stack element.
|
44 | */
|
45 | static isCfnElement(x) {
|
46 | return CFN_ELEMENT_SYMBOL in x;
|
47 | }
|
48 | /**
|
49 | * Overrides the auto-generated logical ID with a specific ID.
|
50 | * @param newLogicalId The new logical ID to use for this stack element.
|
51 | */
|
52 | overrideLogicalId(newLogicalId) {
|
53 | if (this._logicalIdLocked) {
|
54 | throw new Error(`The logicalId for resource at path ${constructs_1.Node.of(this).path} has been locked and cannot be overridden\n` +
|
55 | 'Make sure you are calling "overrideLogicalId" before Stack.exportValue');
|
56 | }
|
57 | else {
|
58 | this._logicalIdOverride = newLogicalId;
|
59 | }
|
60 | }
|
61 | /**
|
62 | * Lock the logicalId of the element and do not allow
|
63 | * any updates (e.g. via overrideLogicalId)
|
64 | *
|
65 | * This is needed in cases where you are consuming the LogicalID
|
66 | * of an element prior to synthesis and you need to not allow future
|
67 | * changes to the id since doing so would cause the value you just
|
68 | * consumed to differ from the synth time value of the logicalId.
|
69 | *
|
70 | * For example:
|
71 | *
|
72 | * const bucket = new Bucket(stack, 'Bucket');
|
73 | * stack.exportValue(bucket.bucketArn) <--- consuming the logicalId
|
74 | * bucket.overrideLogicalId('NewLogicalId') <--- updating logicalId
|
75 | *
|
76 | * You should most likely never need to use this method, and if
|
77 | * you are implementing a feature that requires this, make sure
|
78 | * you actually require it.
|
79 | *
|
80 | * @internal
|
81 | */
|
82 | _lockLogicalId() {
|
83 | this._logicalIdLocked = true;
|
84 | }
|
85 | /**
|
86 | * @returns the stack trace of the point where this Resource was created from, sourced
|
87 | * from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most
|
88 | * node +internal+ entries filtered.
|
89 | */
|
90 | get creationStack() {
|
91 | const trace = constructs_1.Node.of(this).metadata.find(md => md.type === cxschema.ArtifactMetadataEntryType.LOGICAL_ID).trace;
|
92 | if (!trace) {
|
93 | return [];
|
94 | }
|
95 | return filterStackTrace(trace);
|
96 | function filterStackTrace(stack) {
|
97 | const result = Array.of(...stack);
|
98 | while (result.length > 0 && shouldFilter(result[result.length - 1])) {
|
99 | result.pop();
|
100 | }
|
101 | // It's weird if we filtered everything, so return the whole stack...
|
102 | return result.length === 0 ? stack : result;
|
103 | }
|
104 | function shouldFilter(str) {
|
105 | return str.match(/[^(]+\(internal\/.*/) !== null;
|
106 | }
|
107 | }
|
108 | /**
|
109 | * Called during synthesize to render the logical ID of this element. If
|
110 | * `overrideLogicalId` was it will be used, otherwise, we will allocate the
|
111 | * logical ID through the stack.
|
112 | */
|
113 | synthesizeLogicalId() {
|
114 | if (this._logicalIdOverride) {
|
115 | return this._logicalIdOverride;
|
116 | }
|
117 | else {
|
118 | return this.stack.getLogicalId(this);
|
119 | }
|
120 | }
|
121 | }
|
122 | exports.CfnElement = CfnElement;
|
123 | _a = JSII_RTTI_SYMBOL_1;
|
124 | CfnElement[_a] = { fqn: "@aws-cdk/core.CfnElement", version: "1.204.0" };
|
125 | /**
|
126 | * Base class for referenceable CloudFormation constructs which are not Resources
|
127 | *
|
128 | * These constructs are things like Conditions and Parameters, can be
|
129 | * referenced by taking the `.ref` attribute.
|
130 | *
|
131 | * Resource constructs do not inherit from CfnRefElement because they have their
|
132 | * own, more specific types returned from the .ref attribute. Also, some
|
133 | * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).
|
134 | */
|
135 | class CfnRefElement extends CfnElement {
|
136 | /**
|
137 | * Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.
|
138 | *
|
139 | * If, by any chance, the intrinsic reference of a resource is not a string, you could
|
140 | * coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.
|
141 | */
|
142 | get ref() {
|
143 | return token_1.Token.asString(cfn_reference_1.CfnReference.for(this, 'Ref'));
|
144 | }
|
145 | }
|
146 | exports.CfnRefElement = CfnRefElement;
|
147 | _b = JSII_RTTI_SYMBOL_1;
|
148 | CfnRefElement[_b] = { fqn: "@aws-cdk/core.CfnRefElement", version: "1.204.0" };
|
149 | function notTooLong(x) {
|
150 | if (x.length < 100) {
|
151 | return x;
|
152 | }
|
153 | return x.slice(0, 47) + '...' + x.slice(-47);
|
154 | }
|
155 | const cfn_reference_1 = require("./private/cfn-reference");
|
156 | const stack_1 = require("./stack");
|
157 | const token_1 = require("./token");
|
158 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-element.js","sourceRoot":"","sources":["cfn-element.ts"],"names":[],"mappings":";;;;;AAAA,2DAA2D;AAC3D,yCAAyC;AACzC,2CAA6C;AAE7C,gHAAgH;AAChH,2BAA2B;AAC3B,yDAAgE;AAChE,iCAA8B;AAE9B,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;AAElE;;GAEG;AACH,MAAsB,UAAW,SAAQ,4BAAa;IA2CpD;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU;QACtC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,kBAAkB,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QAEjE,IAAI,CAAC,KAAK,GAAG,aAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAE5B,IAAI,CAAC,SAAS,GAAG,WAAI,CAAC,cAAc,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,EAAE;YAClF,WAAW,EAAE,GAAG,UAAU,CAAC,iBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,YAAY;SAC3D,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,2BAA2B,CAAC,EAAE;YAC/D,iBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,yBAAyB,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;SAC5G;KACF;IA/DD;;;;;;;;OAQG;IACI,MAAM,CAAC,YAAY,CAAC,CAAM;QAC/B,OAAO,kBAAkB,IAAI,CAAC,CAAC;KAChC;IAsDD;;;OAGG;IACI,iBAAiB,CAAC,YAAoB;QAC3C,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,MAAM,IAAI,KAAK,CAAC,sCAAsC,iBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,6CAA6C;gBACnH,wEAAwE,CAAC,CAAC;SAC7E;aAAM;YACL,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC;SACxC;KACF;IAED;;;;;;;;;;;;;;;;;;;;OAoBG;IACI,cAAc;QACnB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;KAC9B;IAED;;;;OAIG;IACH,IAAW,aAAa;QACtB,MAAM,KAAK,GAAG,iBAAI,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,KAAK,QAAQ,CAAC,yBAAyB,CAAC,UAAU,CAAE,CAAC,KAAK,CAAC;QAClH,IAAI,CAAC,KAAK,EAAE;YACV,OAAO,EAAE,CAAC;SACX;QAED,OAAO,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAE/B,SAAS,gBAAgB,CAAC,KAAe;YACvC,MAAM,MAAM,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC;YAClC,OAAO,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,EAAE;gBACnE,MAAM,CAAC,GAAG,EAAE,CAAC;aACd;YACD,qEAAqE;YACrE,OAAO,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC;QAC9C,CAAC;QAED,SAAS,YAAY,CAAC,GAAW;YAC/B,OAAO,GAAG,CAAC,KAAK,CAAC,qBAAqB,CAAC,KAAK,IAAI,CAAC;QACnD,CAAC;KACF;IAqBD;;;;OAIG;IACK,mBAAmB;QACzB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,OAAO,IAAI,CAAC,kBAAkB,CAAC;SAChC;aAAM;YACL,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;SACtC;KACF;;AAjKH,gCAkKC;;;AAED;;;;;;;;;GASG;AACH,MAAsB,aAAc,SAAQ,UAAU;IACpD;;;;;OAKG;IACH,IAAW,GAAG;QACZ,OAAO,aAAK,CAAC,QAAQ,CAAC,4BAAY,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;KACtD;;AATH,sCAUC;;;AAED,SAAS,UAAU,CAAC,CAAS;IAC3B,IAAI,CAAC,CAAC,MAAM,GAAG,GAAG,EAAE;QAAE,OAAO,CAAC,CAAC;KAAE;IACjC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC;AAC/C,CAAC;AAED,2DAAuD;AACvD,mCAAgC;AAChC,mCAAgC","sourcesContent":["import * as cxschema from '@aws-cdk/cloud-assembly-schema';\nimport * as cxapi from '@aws-cdk/cx-api';\nimport { Construct, Node } from 'constructs';\n\n// v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.\n// eslint-disable-next-line\nimport { Construct as CoreConstruct } from './construct-compat';\nimport { Lazy } from './lazy';\n\nconst CFN_ELEMENT_SYMBOL = Symbol.for('@aws-cdk/core.CfnElement');\n\n/**\n * An element of a CloudFormation stack.\n */\nexport abstract class CfnElement extends CoreConstruct {\n  /**\n   * Returns `true` if a construct is a stack element (i.e. part of the\n   * synthesized cloudformation template).\n   *\n   * Uses duck-typing instead of `instanceof` to allow stack elements from different\n   * versions of this library to be included in the same stack.\n   *\n   * @returns The construct as a stack element or undefined if it is not a stack element.\n   */\n  public static isCfnElement(x: any): x is CfnElement {\n    return CFN_ELEMENT_SYMBOL in x;\n  }\n\n  /**\n   * The logical ID for this CloudFormation stack element. The logical ID of the element\n   * is calculated from the path of the resource node in the construct tree.\n   *\n   * To override this value, use `overrideLogicalId(newLogicalId)`.\n   *\n   * @returns the logical ID as a stringified token. This value will only get\n   * resolved during synthesis.\n   */\n  public readonly logicalId: string;\n\n  /**\n   * The stack in which this element is defined. CfnElements must be defined within a stack scope (directly or indirectly).\n   */\n  public readonly stack: Stack;\n\n  /**\n   * An explicit logical ID provided by `overrideLogicalId`.\n   */\n  private _logicalIdOverride?: string;\n\n  /**\n   * If the logicalId is locked then it can no longer be overridden.\n   * This is needed for cases where the logicalId is consumed prior to synthesis\n   * (i.e. Stack.exportValue).\n   */\n  private _logicalIdLocked?: boolean;\n\n\n  /**\n   * Creates an entity and binds it to a tree.\n   * Note that the root of the tree must be a Stack object (not just any Root).\n   *\n   * @param scope The parent construct\n   * @param props Construct properties\n   */\n  constructor(scope: Construct, id: string) {\n    super(scope, id);\n\n    Object.defineProperty(this, CFN_ELEMENT_SYMBOL, { value: true });\n\n    this.stack = Stack.of(this);\n\n    this.logicalId = Lazy.uncachedString({ produce: () => this.synthesizeLogicalId() }, {\n      displayHint: `${notTooLong(Node.of(this).path)}.LogicalID`,\n    });\n\n    if (!this.node.tryGetContext(cxapi.DISABLE_LOGICAL_ID_METADATA)) {\n      Node.of(this).addMetadata(cxschema.ArtifactMetadataEntryType.LOGICAL_ID, this.logicalId, this.constructor);\n    }\n  }\n\n  /**\n   * Overrides the auto-generated logical ID with a specific ID.\n   * @param newLogicalId The new logical ID to use for this stack element.\n   */\n  public overrideLogicalId(newLogicalId: string) {\n    if (this._logicalIdLocked) {\n      throw new Error(`The logicalId for resource at path ${Node.of(this).path} has been locked and cannot be overridden\\n` +\n        'Make sure you are calling \"overrideLogicalId\" before Stack.exportValue');\n    } else {\n      this._logicalIdOverride = newLogicalId;\n    }\n  }\n\n  /**\n   * Lock the logicalId of the element and do not allow\n   * any updates (e.g. via overrideLogicalId)\n   *\n   * This is needed in cases where you are consuming the LogicalID\n   * of an element prior to synthesis and you need to not allow future\n   * changes to the id since doing so would cause the value you just\n   * consumed to differ from the synth time value of the logicalId.\n   *\n   * For example:\n   *\n   * const bucket = new Bucket(stack, 'Bucket');\n   * stack.exportValue(bucket.bucketArn) <--- consuming the logicalId\n   * bucket.overrideLogicalId('NewLogicalId') <--- updating logicalId\n   *\n   * You should most likely never need to use this method, and if\n   * you are implementing a feature that requires this, make sure\n   * you actually require it.\n   *\n   * @internal\n   */\n  public _lockLogicalId(): void {\n    this._logicalIdLocked = true;\n  }\n\n  /**\n   * @returns the stack trace of the point where this Resource was created from, sourced\n   *      from the +metadata+ entry typed +aws:cdk:logicalId+, and with the bottom-most\n   *      node +internal+ entries filtered.\n   */\n  public get creationStack(): string[] {\n    const trace = Node.of(this).metadata.find(md => md.type === cxschema.ArtifactMetadataEntryType.LOGICAL_ID)!.trace;\n    if (!trace) {\n      return [];\n    }\n\n    return filterStackTrace(trace);\n\n    function filterStackTrace(stack: string[]): string[] {\n      const result = Array.of(...stack);\n      while (result.length > 0 && shouldFilter(result[result.length - 1])) {\n        result.pop();\n      }\n      // It's weird if we filtered everything, so return the whole stack...\n      return result.length === 0 ? stack : result;\n    }\n\n    function shouldFilter(str: string): boolean {\n      return str.match(/[^(]+\\(internal\\/.*/) !== null;\n    }\n  }\n\n  /**\n   * Returns the CloudFormation 'snippet' for this entity. The snippet will only be merged\n   * at the root level to ensure there are no identity conflicts.\n   *\n   * For example, a Resource class will return something like:\n   * {\n   *   Resources: {\n   *     [this.logicalId]: {\n   *       Type: this.resourceType,\n   *       Properties: this.props,\n   *       Condition: this.condition\n   *     }\n   *   }\n   * }\n   *\n   * @internal\n   */\n  public abstract _toCloudFormation(): object;\n\n  /**\n   * Called during synthesize to render the logical ID of this element. If\n   * `overrideLogicalId` was it will be used, otherwise, we will allocate the\n   * logical ID through the stack.\n   */\n  private synthesizeLogicalId() {\n    if (this._logicalIdOverride) {\n      return this._logicalIdOverride;\n    } else {\n      return this.stack.getLogicalId(this);\n    }\n  }\n}\n\n/**\n * Base class for referenceable CloudFormation constructs which are not Resources\n *\n * These constructs are things like Conditions and Parameters, can be\n * referenced by taking the `.ref` attribute.\n *\n * Resource constructs do not inherit from CfnRefElement because they have their\n * own, more specific types returned from the .ref attribute. Also, some\n * resources aren't referenceable at all (such as BucketPolicies or GatewayAttachments).\n */\nexport abstract class CfnRefElement extends CfnElement {\n  /**\n   * Return a string that will be resolved to a CloudFormation `{ Ref }` for this element.\n   *\n   * If, by any chance, the intrinsic reference of a resource is not a string, you could\n   * coerce it to an IResolvable through `Lazy.any({ produce: resource.ref })`.\n   */\n  public get ref(): string {\n    return Token.asString(CfnReference.for(this, 'Ref'));\n  }\n}\n\nfunction notTooLong(x: string) {\n  if (x.length < 100) { return x; }\n  return x.slice(0, 47) + '...' + x.slice(-47);\n}\n\nimport { CfnReference } from './private/cfn-reference';\nimport { Stack } from './stack';\nimport { Token } from './token';\n"]} |
\ | No newline at end of file |