UNPKG

15.6 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CfnOutput = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const cfn_element_1 = require("./cfn-element");
8class CfnOutput extends cfn_element_1.CfnElement {
9 /**
10 * Creates an CfnOutput value for this stack.
11 * @param scope The parent construct.
12 * @param props CfnOutput properties.
13 */
14 constructor(scope, id, props) {
15 super(scope, id);
16 try {
17 jsiiDeprecationWarnings._aws_cdk_core_CfnOutputProps(props);
18 }
19 catch (error) {
20 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
21 Error.captureStackTrace(error, CfnOutput);
22 }
23 throw error;
24 }
25 if (props.value === undefined) {
26 throw new Error(`Missing value for CloudFormation output at path "${this.node.path}"`);
27 }
28 this._description = props.description;
29 this._value = props.value;
30 this._condition = props.condition;
31 this._exportName = props.exportName;
32 }
33 /**
34 * A String type that describes the output value.
35 * The description can be a maximum of 4 K in length.
36 *
37 * @default - No description.
38 */
39 get description() {
40 return this._description;
41 }
42 set description(description) {
43 this._description = description;
44 }
45 /**
46 * The value of the property returned by the aws cloudformation describe-stacks command.
47 * The value of an output can include literals, parameter references, pseudo-parameters,
48 * a mapping value, or intrinsic functions.
49 */
50 get value() {
51 return this._value;
52 }
53 set value(value) {
54 this._value = value;
55 }
56 /**
57 * A condition to associate with this output value. If the condition evaluates
58 * to `false`, this output value will not be included in the stack.
59 *
60 * @default - No condition is associated with the output.
61 */
62 get condition() {
63 return this._condition;
64 }
65 set condition(condition) {
66 this._condition = condition;
67 }
68 /**
69 * The name used to export the value of this output across stacks.
70 *
71 * To use the value in another stack, pass the value of
72 * `output.importValue` to it.
73 *
74 * @default - the output is not exported
75 */
76 get exportName() {
77 return this._exportName;
78 }
79 set exportName(exportName) {
80 this._exportName = exportName;
81 }
82 /**
83 * Return the `Fn.importValue` expression to import this value into another stack
84 *
85 * The returned value should not be used in the same stack, but in a
86 * different one. It must be deployed to the same environment, as
87 * CloudFormation exports can only be imported in the same Region and
88 * account.
89 *
90 * The is no automatic registration of dependencies between stacks when using
91 * this mechanism, so you should make sure to deploy them in the right order
92 * yourself.
93 *
94 * You can use this mechanism to share values across Stacks in different
95 * Stages. If you intend to share the value to another Stack inside the same
96 * Stage, the automatic cross-stack referencing mechanism is more convenient.
97 */
98 get importValue() {
99 // We made _exportName mutable so this will have to be lazy.
100 return cfn_fn_1.Fn.importValue(lazy_1.Lazy.uncachedString({
101 produce: (ctx) => {
102 if (stack_1.Stack.of(ctx.scope) === this.stack) {
103 throw new Error(`'importValue' property of '${this.node.path}' should only be used in a different Stack`);
104 }
105 if (!this._exportName) {
106 throw new Error(`Add an exportName to the CfnOutput at '${this.node.path}' in order to use 'output.importValue'`);
107 }
108 return this._exportName;
109 },
110 }));
111 }
112 /**
113 * @internal
114 */
115 _toCloudFormation() {
116 return {
117 Outputs: {
118 [this.logicalId]: {
119 Description: this._description,
120 Value: this._value,
121 Export: this._exportName != null ? { Name: this._exportName } : undefined,
122 Condition: this._condition ? this._condition.logicalId : undefined,
123 },
124 },
125 };
126 }
127 validate() {
128 if (this._exportName && !token_1.Token.isUnresolved(this._exportName) && this._exportName.length > 255) {
129 return [`Export name cannot exceed 255 characters (got ${this._exportName.length} characters)`];
130 }
131 return [];
132 }
133}
134exports.CfnOutput = CfnOutput;
135_a = JSII_RTTI_SYMBOL_1;
136CfnOutput[_a] = { fqn: "@aws-cdk/core.CfnOutput", version: "1.204.0" };
137const cfn_fn_1 = require("./cfn-fn");
138const lazy_1 = require("./lazy");
139const stack_1 = require("./stack");
140const token_1 = require("./token");
141//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-output.js","sourceRoot":"","sources":["cfn-output.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\nimport { CfnElement } from './cfn-element';\n\nexport interface CfnOutputProps {\n  /**\n   * A String type that describes the output value.\n   * The description can be a maximum of 4 K in length.\n   *\n   * @default - No description.\n   */\n  readonly description?: string;\n\n  /**\n   * The value of the property returned by the aws cloudformation describe-stacks command.\n   * The value of an output can include literals, parameter references, pseudo-parameters,\n   * a mapping value, or intrinsic functions.\n   */\n  readonly value: string;\n\n  /**\n   * The name used to export the value of this output across stacks.\n   *\n   * To import the value from another stack, use `Fn.importValue(exportName)`.\n   *\n   * @default - the output is not exported\n   */\n  readonly exportName?: string;\n\n  /**\n   * A condition to associate with this output value. If the condition evaluates\n   * to `false`, this output value will not be included in the stack.\n   *\n   * @default - No condition is associated with the output.\n   */\n  readonly condition?: CfnCondition;\n}\n\nexport class CfnOutput extends CfnElement {\n  private _description?: string;\n  private _condition?: CfnCondition;\n  private _value?: any;\n  private _exportName?: string;\n\n  /**\n   * Creates an CfnOutput value for this stack.\n   * @param scope The parent construct.\n   * @param props CfnOutput properties.\n   */\n  constructor(scope: Construct, id: string, props: CfnOutputProps) {\n    super(scope, id);\n\n    if (props.value === undefined) {\n      throw new Error(`Missing value for CloudFormation output at path \"${this.node.path}\"`);\n    }\n\n    this._description = props.description;\n    this._value = props.value;\n    this._condition = props.condition;\n    this._exportName = props.exportName;\n  }\n\n  /**\n   * A String type that describes the output value.\n   * The description can be a maximum of 4 K in length.\n   *\n   * @default - No description.\n   */\n  public get description() {\n    return this._description;\n  }\n\n  public set description(description: string | undefined) {\n    this._description = description;\n  }\n\n  /**\n   * The value of the property returned by the aws cloudformation describe-stacks command.\n   * The value of an output can include literals, parameter references, pseudo-parameters,\n   * a mapping value, or intrinsic functions.\n   */\n  public get value() {\n    return this._value;\n  }\n\n  public set value(value: any) {\n    this._value = value;\n  }\n\n  /**\n   * A condition to associate with this output value. If the condition evaluates\n   * to `false`, this output value will not be included in the stack.\n   *\n   * @default - No condition is associated with the output.\n   */\n  public get condition() {\n    return this._condition;\n  }\n\n  public set condition(condition: CfnCondition | undefined) {\n    this._condition = condition;\n  }\n\n  /**\n   * The name used to export the value of this output across stacks.\n   *\n   * To use the value in another stack, pass the value of\n   * `output.importValue` to it.\n   *\n   * @default - the output is not exported\n   */\n  public get exportName() {\n    return this._exportName;\n  }\n\n  public set exportName(exportName: string | undefined) {\n    this._exportName = exportName;\n  }\n\n  /**\n   * Return the `Fn.importValue` expression to import this value into another stack\n   *\n   * The returned value should not be used in the same stack, but in a\n   * different one. It must be deployed to the same environment, as\n   * CloudFormation exports can only be imported in the same Region and\n   * account.\n   *\n   * The is no automatic registration of dependencies between stacks when using\n   * this mechanism, so you should make sure to deploy them in the right order\n   * yourself.\n   *\n   * You can use this mechanism to share values across Stacks in different\n   * Stages. If you intend to share the value to another Stack inside the same\n   * Stage, the automatic cross-stack referencing mechanism is more convenient.\n   */\n  public get importValue() {\n    // We made _exportName mutable so this will have to be lazy.\n    return Fn.importValue(Lazy.uncachedString({\n      produce: (ctx) => {\n        if (Stack.of(ctx.scope) === this.stack) {\n          throw new Error(`'importValue' property of '${this.node.path}' should only be used in a different Stack`);\n        }\n        if (!this._exportName) {\n          throw new Error(`Add an exportName to the CfnOutput at '${this.node.path}' in order to use 'output.importValue'`);\n        }\n\n        return this._exportName;\n      },\n    }));\n  }\n\n  /**\n   * @internal\n   */\n  public _toCloudFormation(): object {\n    return {\n      Outputs: {\n        [this.logicalId]: {\n          Description: this._description,\n          Value: this._value,\n          Export: this._exportName != null ? { Name: this._exportName } : undefined,\n          Condition: this._condition ? this._condition.logicalId : undefined,\n        },\n      },\n    };\n  }\n\n  protected validate(): string[] {\n    if (this._exportName && !Token.isUnresolved(this._exportName) && this._exportName.length > 255) {\n      return [`Export name cannot exceed 255 characters (got ${this._exportName.length} characters)`];\n    }\n    return [];\n  }\n}\n\nimport { CfnCondition } from './cfn-condition';\nimport { Fn } from './cfn-fn';\nimport { Lazy } from './lazy';\nimport { Stack } from './stack';\nimport { Token } from './token';\n\n"]}
\No newline at end of file