1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.CfnCodeDeployBlueGreenHook = exports.CfnTrafficRoutingType = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const cfn_hook_1 = require("./cfn-hook");
|
8 | const util_1 = require("./util");
|
9 | /**
|
10 | * The possible types of traffic shifting for the blue-green deployment configuration.
|
11 | * The type of the {@link CfnTrafficRoutingConfig.type} property.
|
12 | */
|
13 | var CfnTrafficRoutingType;
|
14 | (function (CfnTrafficRoutingType) {
|
15 | /**
|
16 | * Switch from blue to green at once.
|
17 | */
|
18 | CfnTrafficRoutingType["ALL_AT_ONCE"] = "AllAtOnce";
|
19 | /**
|
20 | * Specifies a configuration that shifts traffic from blue to green in two increments.
|
21 | */
|
22 | CfnTrafficRoutingType["TIME_BASED_CANARY"] = "TimeBasedCanary";
|
23 | /**
|
24 | * Specifies a configuration that shifts traffic from blue to green in equal increments,
|
25 | * with an equal number of minutes between each increment.
|
26 | */
|
27 | CfnTrafficRoutingType["TIME_BASED_LINEAR"] = "TimeBasedLinear";
|
28 | })(CfnTrafficRoutingType = exports.CfnTrafficRoutingType || (exports.CfnTrafficRoutingType = {}));
|
29 | /**
|
30 | * A CloudFormation Hook for CodeDeploy blue-green ECS deployments.
|
31 | *
|
32 | * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/blue-green.html#blue-green-template-reference
|
33 | */
|
34 | class CfnCodeDeployBlueGreenHook extends cfn_hook_1.CfnHook {
|
35 | /**
|
36 | * Creates a new CodeDeploy blue-green ECS Hook.
|
37 | *
|
38 | * @param scope the scope to create the hook in (usually the containing Stack object)
|
39 | * @param id the identifier of the construct - will be used to generate the logical ID of the Hook
|
40 | * @param props the properties of the Hook
|
41 | */
|
42 | constructor(scope, id, props) {
|
43 | super(scope, id, {
|
44 | type: 'AWS::CodeDeploy::BlueGreen',
|
45 | });
|
46 | try {
|
47 | jsiiDeprecationWarnings._aws_cdk_core_CfnCodeDeployBlueGreenHookProps(props);
|
48 | }
|
49 | catch (error) {
|
50 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
51 | Error.captureStackTrace(error, CfnCodeDeployBlueGreenHook);
|
52 | }
|
53 | throw error;
|
54 | }
|
55 | this._serviceRole = props.serviceRole;
|
56 | this._applications = props.applications;
|
57 | this._trafficRoutingConfig = props.trafficRoutingConfig;
|
58 | this._additionalOptions = props.additionalOptions;
|
59 | this._lifecycleEventHooks = props.lifecycleEventHooks;
|
60 | }
|
61 | /**
|
62 | * A factory method that creates a new instance of this class from an object
|
63 | * containing the CloudFormation properties of this resource.
|
64 | * Used in the @aws-cdk/cloudformation-include module.
|
65 | *
|
66 | * @internal
|
67 | */
|
68 | static _fromCloudFormation(scope, id, hookAttributes, options) {
|
69 | hookAttributes = hookAttributes || {};
|
70 | const hookProperties = options.parser.parseValue(hookAttributes.Properties);
|
71 | return new CfnCodeDeployBlueGreenHook(scope, id, {
|
72 | serviceRole: hookProperties?.ServiceRole,
|
73 | applications: hookProperties?.Applications?.map(applicationFromCloudFormation),
|
74 | trafficRoutingConfig: {
|
75 | type: hookProperties?.TrafficRoutingConfig?.Type,
|
76 | timeBasedCanary: {
|
77 | stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.StepPercentage,
|
78 | bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.BakeTimeMins,
|
79 | },
|
80 | timeBasedLinear: {
|
81 | stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.StepPercentage,
|
82 | bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.BakeTimeMins,
|
83 | },
|
84 | },
|
85 | additionalOptions: {
|
86 | terminationWaitTimeInMinutes: hookProperties?.AdditionalOptions?.TerminationWaitTimeInMinutes,
|
87 | },
|
88 | lifecycleEventHooks: {
|
89 | beforeInstall: hookProperties?.LifecycleEventHooks?.BeforeInstall,
|
90 | afterInstall: hookProperties?.LifecycleEventHooks?.AfterInstall,
|
91 | afterAllowTestTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTestTraffic,
|
92 | beforeAllowTraffic: hookProperties?.LifecycleEventHooks?.BeforeAllowTraffic,
|
93 | afterAllowTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTraffic,
|
94 | },
|
95 | });
|
96 | function applicationFromCloudFormation(app) {
|
97 | const target = findResource(app?.Target?.LogicalID);
|
98 | const taskDefinitions = app?.ECSAttributes?.TaskDefinitions?.map((td) => findResource(td));
|
99 | const taskSets = app?.ECSAttributes?.TaskSets?.map((ts) => findResource(ts));
|
100 | const prodTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.LogicalID);
|
101 | const testTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.LogicalID);
|
102 | const targetGroups = app?.ECSAttributes?.TrafficRouting?.TargetGroups?.map((tg) => findResource(tg));
|
103 | return {
|
104 | target: {
|
105 | type: app?.Target?.Type,
|
106 | logicalId: target?.logicalId,
|
107 | },
|
108 | ecsAttributes: {
|
109 | taskDefinitions: taskDefinitions?.map(td => td?.logicalId),
|
110 | taskSets: taskSets?.map(ts => ts?.logicalId),
|
111 | trafficRouting: {
|
112 | prodTrafficRoute: {
|
113 | type: app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.Type,
|
114 | logicalId: prodTrafficRoute?.logicalId,
|
115 | },
|
116 | testTrafficRoute: {
|
117 | type: app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.Type,
|
118 | logicalId: testTrafficRoute?.logicalId,
|
119 | },
|
120 | targetGroups: targetGroups?.map((tg) => tg?.logicalId),
|
121 | },
|
122 | },
|
123 | };
|
124 | }
|
125 | function findResource(logicalId) {
|
126 | if (logicalId == null) {
|
127 | return undefined;
|
128 | }
|
129 | const ret = options.parser.finder.findResource(logicalId);
|
130 | if (!ret) {
|
131 | throw new Error(`Hook '${id}' references resource '${logicalId}' that was not found in the template`);
|
132 | }
|
133 | return ret;
|
134 | }
|
135 | }
|
136 | /**
|
137 | * The IAM Role for CloudFormation to use to perform blue-green deployments.
|
138 | */
|
139 | get serviceRole() {
|
140 | return this._serviceRole;
|
141 | }
|
142 | set serviceRole(serviceRole) {
|
143 | this._serviceRole = serviceRole;
|
144 | }
|
145 | /**
|
146 | * Properties of the Amazon ECS applications being deployed.
|
147 | */
|
148 | get applications() {
|
149 | return this._applications;
|
150 | }
|
151 | set applications(value) {
|
152 | this._applications = value;
|
153 | }
|
154 | /**
|
155 | * Traffic routing configuration settings.
|
156 | *
|
157 | * @default - time-based canary traffic shifting, with a 15% step percentage and a five minute bake time
|
158 | */
|
159 | get trafficRoutingConfig() {
|
160 | return this._trafficRoutingConfig;
|
161 | }
|
162 | set trafficRoutingConfig(value) {
|
163 | this._trafficRoutingConfig = value;
|
164 | }
|
165 | /**
|
166 | * Additional options for the blue/green deployment.
|
167 | *
|
168 | * @default - no additional options
|
169 | */
|
170 | get additionalOptions() {
|
171 | return this._additionalOptions;
|
172 | }
|
173 | set additionalOptions(value) {
|
174 | this._additionalOptions = value;
|
175 | }
|
176 | /**
|
177 | * Use lifecycle event hooks to specify a Lambda function that CodeDeploy can call to validate a deployment.
|
178 | * You can use the same function or a different one for deployment lifecycle events.
|
179 | * Following completion of the validation tests,
|
180 | * the Lambda {@link CfnCodeDeployBlueGreenLifecycleEventHooks.afterAllowTraffic}
|
181 | * function calls back CodeDeploy and delivers a result of 'Succeeded' or 'Failed'.
|
182 | *
|
183 | * @default - no lifecycle event hooks
|
184 | */
|
185 | get lifecycleEventHooks() {
|
186 | return this._lifecycleEventHooks;
|
187 | }
|
188 | set lifecycleEventHooks(value) {
|
189 | this._lifecycleEventHooks = value;
|
190 | }
|
191 | renderProperties(_props) {
|
192 | return {
|
193 | ServiceRole: this.serviceRole,
|
194 | Applications: this.applications.map((app) => ({
|
195 | Target: {
|
196 | Type: app.target.type,
|
197 | LogicalID: app.target.logicalId,
|
198 | },
|
199 | ECSAttributes: {
|
200 | TaskDefinitions: app.ecsAttributes.taskDefinitions,
|
201 | TaskSets: app.ecsAttributes.taskSets,
|
202 | TrafficRouting: {
|
203 | ProdTrafficRoute: {
|
204 | Type: app.ecsAttributes.trafficRouting.prodTrafficRoute.type,
|
205 | LogicalID: app.ecsAttributes.trafficRouting.prodTrafficRoute.logicalId,
|
206 | },
|
207 | TestTrafficRoute: {
|
208 | Type: app.ecsAttributes.trafficRouting.testTrafficRoute.type,
|
209 | LogicalID: app.ecsAttributes.trafficRouting.testTrafficRoute.logicalId,
|
210 | },
|
211 | TargetGroups: app.ecsAttributes.trafficRouting.targetGroups,
|
212 | },
|
213 | },
|
214 | })),
|
215 | TrafficRoutingConfig: util_1.undefinedIfAllValuesAreEmpty({
|
216 | Type: this.trafficRoutingConfig?.type,
|
217 | TimeBasedCanary: util_1.undefinedIfAllValuesAreEmpty({
|
218 | StepPercentage: this.trafficRoutingConfig?.timeBasedCanary?.stepPercentage,
|
219 | BakeTimeMins: this.trafficRoutingConfig?.timeBasedCanary?.bakeTimeMins,
|
220 | }),
|
221 | TimeBasedLinear: util_1.undefinedIfAllValuesAreEmpty({
|
222 | StepPercentage: this.trafficRoutingConfig?.timeBasedLinear?.stepPercentage,
|
223 | BakeTimeMins: this.trafficRoutingConfig?.timeBasedLinear?.bakeTimeMins,
|
224 | }),
|
225 | }),
|
226 | AdditionalOptions: util_1.undefinedIfAllValuesAreEmpty({
|
227 | TerminationWaitTimeInMinutes: this.additionalOptions?.terminationWaitTimeInMinutes,
|
228 | }),
|
229 | LifecycleEventHooks: util_1.undefinedIfAllValuesAreEmpty({
|
230 | BeforeInstall: this.lifecycleEventHooks?.beforeInstall,
|
231 | AfterInstall: this.lifecycleEventHooks?.afterInstall,
|
232 | AfterAllowTestTraffic: this.lifecycleEventHooks?.afterAllowTestTraffic,
|
233 | BeforeAllowTraffic: this.lifecycleEventHooks?.beforeAllowTraffic,
|
234 | AfterAllowTraffic: this.lifecycleEventHooks?.afterAllowTraffic,
|
235 | }),
|
236 | };
|
237 | }
|
238 | }
|
239 | exports.CfnCodeDeployBlueGreenHook = CfnCodeDeployBlueGreenHook;
|
240 | _a = JSII_RTTI_SYMBOL_1;
|
241 | CfnCodeDeployBlueGreenHook[_a] = { fqn: "@aws-cdk/core.CfnCodeDeployBlueGreenHook", version: "1.204.0" };
|
242 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cfn-codedeploy-blue-green-hook.js","sourceRoot":"","sources":["cfn-codedeploy-blue-green-hook.ts"],"names":[],"mappings":"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","sourcesContent":["import { Construct } from 'constructs';\nimport { CfnHook } from './cfn-hook';\nimport { CfnResource } from './cfn-resource';\nimport { FromCloudFormationOptions } from './helpers-internal';\nimport { undefinedIfAllValuesAreEmpty } from './util';\n\n/**\n * The possible types of traffic shifting for the blue-green deployment configuration.\n * The type of the {@link CfnTrafficRoutingConfig.type} property.\n */\nexport enum CfnTrafficRoutingType {\n  /**\n   * Switch from blue to green at once.\n   */\n  ALL_AT_ONCE = 'AllAtOnce',\n\n  /**\n   * Specifies a configuration that shifts traffic from blue to green in two increments.\n   */\n  TIME_BASED_CANARY = 'TimeBasedCanary',\n\n  /**\n   * Specifies a configuration that shifts traffic from blue to green in equal increments,\n   * with an equal number of minutes between each increment.\n   */\n  TIME_BASED_LINEAR = 'TimeBasedLinear',\n}\n\n/**\n * The traffic routing configuration if {@link CfnTrafficRoutingConfig.type}\n * is {@link CfnTrafficRoutingType.TIME_BASED_CANARY}.\n */\nexport interface CfnTrafficRoutingTimeBasedCanary {\n  /**\n   * The percentage of traffic to shift in the first increment of a time-based canary deployment.\n   * The step percentage must be 14% or greater.\n   *\n   * @default 15\n   */\n  readonly stepPercentage?: number;\n\n  /**\n   * The number of minutes between the first and second traffic shifts of a time-based canary deployment.\n   *\n   * @default 5\n   */\n  readonly bakeTimeMins?: number;\n}\n\n/**\n * The traffic routing configuration if {@link CfnTrafficRoutingConfig.type}\n * is {@link CfnTrafficRoutingType.TIME_BASED_LINEAR}.\n */\nexport interface CfnTrafficRoutingTimeBasedLinear {\n  /**\n   * The percentage of traffic that is shifted at the start of each increment of a time-based linear deployment.\n   * The step percentage must be 14% or greater.\n   *\n   * @default 15\n   */\n  readonly stepPercentage?: number;\n\n  /**\n   * The number of minutes between the first and second traffic shifts of a time-based linear deployment.\n   *\n   * @default 5\n   */\n  readonly bakeTimeMins?: number;\n}\n\n/**\n * Traffic routing configuration settings.\n * The type of the {@link CfnCodeDeployBlueGreenHookProps.trafficRoutingConfig} property.\n */\nexport interface CfnTrafficRoutingConfig {\n  /**\n   * The type of traffic shifting used by the blue-green deployment configuration.\n   */\n  readonly type: CfnTrafficRoutingType;\n\n  /**\n   * The configuration for traffic routing when {@link type} is\n   * {@link CfnTrafficRoutingType.TIME_BASED_CANARY}.\n   *\n   * @default - none\n   */\n  readonly timeBasedCanary?: CfnTrafficRoutingTimeBasedCanary;\n\n  /**\n   * The configuration for traffic routing when {@link type} is\n   * {@link CfnTrafficRoutingType.TIME_BASED_LINEAR}.\n   *\n   * @default - none\n   */\n  readonly timeBasedLinear?: CfnTrafficRoutingTimeBasedLinear;\n}\n\n/**\n * Additional options for the blue/green deployment.\n * The type of the {@link CfnCodeDeployBlueGreenHookProps.additionalOptions} property.\n */\nexport interface CfnCodeDeployBlueGreenAdditionalOptions {\n  /**\n   * Specifies time to wait, in minutes, before terminating the blue resources.\n   *\n   * @default - 5 minutes\n   */\n  readonly terminationWaitTimeInMinutes?: number;\n}\n\n/**\n * Lifecycle events for blue-green deployments.\n * The type of the {@link CfnCodeDeployBlueGreenHookProps.lifecycleEventHooks} property.\n */\nexport interface CfnCodeDeployBlueGreenLifecycleEventHooks {\n  /**\n   * Function to use to run tasks before the replacement task set is created.\n   *\n   * @default - none\n   */\n  readonly beforeInstall?: string;\n\n  /**\n   * Function to use to run tasks after the replacement task set is created and one of the target groups is associated with it.\n   *\n   * @default - none\n   */\n  readonly afterInstall?: string;\n\n  /**\n   * Function to use to run tasks after the test listener serves traffic to the replacement task set.\n   *\n   * @default - none\n   */\n  readonly afterAllowTestTraffic?: string;\n\n  /**\n   * Function to use to run tasks after the second target group is associated with the replacement task set,\n   * but before traffic is shifted to the replacement task set.\n   *\n   * @default - none\n   */\n  readonly beforeAllowTraffic?: string;\n\n  /**\n   * Function to use to run tasks after the second target group serves traffic to the replacement task set.\n   *\n   * @default - none\n   */\n  readonly afterAllowTraffic?: string;\n}\n\n/**\n * Type of the {@link CfnCodeDeployBlueGreenApplication.target} property.\n */\nexport interface CfnCodeDeployBlueGreenApplicationTarget {\n  /**\n   * The resource type of the target being deployed.\n   * Right now, the only allowed value is 'AWS::ECS::Service'.\n   */\n  readonly type: string;\n\n  /**\n   * The logical id of the target resource.\n   */\n  readonly logicalId: string;\n}\n\n/**\n * A traffic route,\n * representing where the traffic is being directed to.\n */\nexport interface CfnTrafficRoute {\n  /**\n   * The resource type of the route.\n   * Today, the only allowed value is 'AWS::ElasticLoadBalancingV2::Listener'.\n   */\n  readonly type: string;\n\n  /**\n   * The logical id of the target resource.\n   */\n  readonly logicalId: string;\n}\n\n/**\n * Type of the {@link CfnCodeDeployBlueGreenEcsAttributes.trafficRouting} property.\n */\nexport interface CfnTrafficRouting {\n  /**\n   * The listener to be used by your load balancer to direct traffic to your target groups.\n   */\n  readonly prodTrafficRoute: CfnTrafficRoute;\n\n  /**\n   * The listener to be used by your load balancer to direct traffic to your target groups.\n   */\n  readonly testTrafficRoute: CfnTrafficRoute;\n\n  /**\n   * The logical IDs of the blue and green, respectively,\n   * AWS::ElasticLoadBalancingV2::TargetGroup target groups.\n   */\n  readonly targetGroups: string[];\n}\n\n/**\n * The attributes of the ECS Service being deployed.\n * Type of the {@link CfnCodeDeployBlueGreenApplication.ecsAttributes} property.\n */\nexport interface CfnCodeDeployBlueGreenEcsAttributes {\n  /**\n   * The logical IDs of the blue and green, respectively,\n   * AWS::ECS::TaskDefinition task definitions.\n   */\n  readonly taskDefinitions: string[];\n\n  /**\n   * The logical IDs of the blue and green, respectively,\n   * AWS::ECS::TaskSet task sets.\n   */\n  readonly taskSets: string[];\n\n  /**\n   * The traffic routing configuration.\n   */\n  readonly trafficRouting: CfnTrafficRouting;\n}\n\n/**\n * The application actually being deployed.\n * Type of the {@link CfnCodeDeployBlueGreenHookProps.applications} property.\n */\nexport interface CfnCodeDeployBlueGreenApplication {\n  /**\n   * The target that is being deployed.\n   */\n  readonly target: CfnCodeDeployBlueGreenApplicationTarget;\n\n  /**\n   * The detailed attributes of the deployed target.\n   */\n  readonly ecsAttributes: CfnCodeDeployBlueGreenEcsAttributes;\n}\n\n/**\n * Construction properties of {@link CfnCodeDeployBlueGreenHook}.\n */\nexport interface CfnCodeDeployBlueGreenHookProps {\n  /**\n   * The IAM Role for CloudFormation to use to perform blue-green deployments.\n   */\n  readonly serviceRole: string;\n\n  /**\n   * Properties of the Amazon ECS applications being deployed.\n   */\n  readonly applications: CfnCodeDeployBlueGreenApplication[];\n\n  /**\n   * Traffic routing configuration settings.\n   *\n   * @default - time-based canary traffic shifting, with a 15% step percentage and a five minute bake time\n   */\n  readonly trafficRoutingConfig?: CfnTrafficRoutingConfig;\n\n  /**\n   * Additional options for the blue/green deployment.\n   *\n   * @default - no additional options\n   */\n  readonly additionalOptions?: CfnCodeDeployBlueGreenAdditionalOptions;\n\n  /**\n   * Use lifecycle event hooks to specify a Lambda function that CodeDeploy can call to validate a deployment.\n   * You can use the same function or a different one for deployment lifecycle events.\n   * Following completion of the validation tests,\n   * the Lambda {@link CfnCodeDeployBlueGreenLifecycleEventHooks.afterAllowTraffic}\n   * function calls back CodeDeploy and delivers a result of 'Succeeded' or 'Failed'.\n   *\n   * @default - no lifecycle event hooks\n   */\n  readonly lifecycleEventHooks?: CfnCodeDeployBlueGreenLifecycleEventHooks;\n}\n\n/**\n * A CloudFormation Hook for CodeDeploy blue-green ECS deployments.\n *\n * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/blue-green.html#blue-green-template-reference\n */\nexport class CfnCodeDeployBlueGreenHook extends CfnHook {\n  /**\n   * A factory method that creates a new instance of this class from an object\n   * containing the CloudFormation properties of this resource.\n   * Used in the @aws-cdk/cloudformation-include module.\n   *\n   * @internal\n   */\n  public static _fromCloudFormation(scope: Construct, id: string, hookAttributes: any,\n    options: FromCloudFormationOptions): CfnCodeDeployBlueGreenHook {\n\n    hookAttributes = hookAttributes || {};\n    const hookProperties = options.parser.parseValue(hookAttributes.Properties);\n    return new CfnCodeDeployBlueGreenHook(scope, id, {\n      serviceRole: hookProperties?.ServiceRole,\n      applications: hookProperties?.Applications?.map(applicationFromCloudFormation),\n      trafficRoutingConfig: {\n        type: hookProperties?.TrafficRoutingConfig?.Type,\n        timeBasedCanary: {\n          stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.StepPercentage,\n          bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.BakeTimeMins,\n        },\n        timeBasedLinear: {\n          stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.StepPercentage,\n          bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.BakeTimeMins,\n        },\n      },\n      additionalOptions: {\n        terminationWaitTimeInMinutes: hookProperties?.AdditionalOptions?.TerminationWaitTimeInMinutes,\n      },\n      lifecycleEventHooks: {\n        beforeInstall: hookProperties?.LifecycleEventHooks?.BeforeInstall,\n        afterInstall: hookProperties?.LifecycleEventHooks?.AfterInstall,\n        afterAllowTestTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTestTraffic,\n        beforeAllowTraffic: hookProperties?.LifecycleEventHooks?.BeforeAllowTraffic,\n        afterAllowTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTraffic,\n      },\n    });\n\n    function applicationFromCloudFormation(app: any) {\n      const target = findResource(app?.Target?.LogicalID);\n      const taskDefinitions: Array<CfnResource | undefined> | undefined = app?.ECSAttributes?.TaskDefinitions?.map(\n        (td: any) => findResource(td));\n      const taskSets: Array<CfnResource | undefined> | undefined = app?.ECSAttributes?.TaskSets?.map(\n        (ts: any) => findResource(ts));\n      const prodTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.LogicalID);\n      const testTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.LogicalID);\n      const targetGroups: Array<CfnResource | undefined> | undefined = app?.ECSAttributes?.TrafficRouting?.TargetGroups?.map(\n        (tg: any) => findResource(tg));\n\n      return {\n        target: {\n          type: app?.Target?.Type,\n          logicalId: target?.logicalId,\n        },\n        ecsAttributes: {\n          taskDefinitions: taskDefinitions?.map(td => td?.logicalId),\n          taskSets: taskSets?.map(ts => ts?.logicalId),\n          trafficRouting: {\n            prodTrafficRoute: {\n              type: app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.Type,\n              logicalId: prodTrafficRoute?.logicalId,\n            },\n            testTrafficRoute: {\n              type: app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.Type,\n              logicalId: testTrafficRoute?.logicalId,\n            },\n            targetGroups: targetGroups?.map((tg) => tg?.logicalId),\n          },\n        },\n      };\n    }\n\n    function findResource(logicalId: string | undefined): CfnResource | undefined {\n      if (logicalId == null) {\n        return undefined;\n      }\n      const ret = options.parser.finder.findResource(logicalId);\n      if (!ret) {\n        throw new Error(`Hook '${id}' references resource '${logicalId}' that was not found in the template`);\n      }\n      return ret;\n    }\n  }\n\n  private _serviceRole: string;\n  private _applications: CfnCodeDeployBlueGreenApplication[];\n  private _trafficRoutingConfig?: CfnTrafficRoutingConfig;\n  private _additionalOptions?: CfnCodeDeployBlueGreenAdditionalOptions;\n  private _lifecycleEventHooks?: CfnCodeDeployBlueGreenLifecycleEventHooks;\n\n  /**\n   * Creates a new CodeDeploy blue-green ECS Hook.\n   *\n   * @param scope the scope to create the hook in (usually the containing Stack object)\n   * @param id the identifier of the construct - will be used to generate the logical ID of the Hook\n   * @param props the properties of the Hook\n   */\n  constructor(scope: Construct, id: string, props: CfnCodeDeployBlueGreenHookProps) {\n    super(scope, id, {\n      type: 'AWS::CodeDeploy::BlueGreen',\n      // we render the properties ourselves\n    });\n\n    this._serviceRole = props.serviceRole;\n    this._applications = props.applications;\n    this._trafficRoutingConfig = props.trafficRoutingConfig;\n    this._additionalOptions = props.additionalOptions;\n    this._lifecycleEventHooks = props.lifecycleEventHooks;\n  }\n\n  /**\n   * The IAM Role for CloudFormation to use to perform blue-green deployments.\n   */\n  public get serviceRole(): string {\n    return this._serviceRole;\n  }\n\n  public set serviceRole(serviceRole: string) {\n    this._serviceRole = serviceRole;\n  }\n\n  /**\n   * Properties of the Amazon ECS applications being deployed.\n   */\n  public get applications(): CfnCodeDeployBlueGreenApplication[] {\n    return this._applications;\n  }\n\n  public set applications(value: CfnCodeDeployBlueGreenApplication[]) {\n    this._applications = value;\n  }\n\n  /**\n   * Traffic routing configuration settings.\n   *\n   * @default - time-based canary traffic shifting, with a 15% step percentage and a five minute bake time\n   */\n  public get trafficRoutingConfig(): CfnTrafficRoutingConfig | undefined {\n    return this._trafficRoutingConfig;\n  }\n\n  public set trafficRoutingConfig(value: CfnTrafficRoutingConfig | undefined) {\n    this._trafficRoutingConfig = value;\n  }\n\n  /**\n   * Additional options for the blue/green deployment.\n   *\n   * @default - no additional options\n   */\n  public get additionalOptions(): CfnCodeDeployBlueGreenAdditionalOptions | undefined {\n    return this._additionalOptions;\n  }\n\n  public set additionalOptions(value: CfnCodeDeployBlueGreenAdditionalOptions | undefined) {\n    this._additionalOptions = value;\n  }\n\n  /**\n   * Use lifecycle event hooks to specify a Lambda function that CodeDeploy can call to validate a deployment.\n   * You can use the same function or a different one for deployment lifecycle events.\n   * Following completion of the validation tests,\n   * the Lambda {@link CfnCodeDeployBlueGreenLifecycleEventHooks.afterAllowTraffic}\n   * function calls back CodeDeploy and delivers a result of 'Succeeded' or 'Failed'.\n   *\n   * @default - no lifecycle event hooks\n   */\n  public get lifecycleEventHooks(): CfnCodeDeployBlueGreenLifecycleEventHooks | undefined {\n    return this._lifecycleEventHooks;\n  }\n\n  public set lifecycleEventHooks(value: CfnCodeDeployBlueGreenLifecycleEventHooks | undefined) {\n    this._lifecycleEventHooks = value;\n  }\n\n  protected renderProperties(_props?: { [p: string]: any }): { [p: string]: any } | undefined {\n    return {\n      ServiceRole: this.serviceRole,\n      Applications: this.applications.map((app) => ({\n        Target: {\n          Type: app.target.type,\n          LogicalID: app.target.logicalId,\n        },\n        ECSAttributes: {\n          TaskDefinitions: app.ecsAttributes.taskDefinitions,\n          TaskSets: app.ecsAttributes.taskSets,\n          TrafficRouting: {\n            ProdTrafficRoute: {\n              Type: app.ecsAttributes.trafficRouting.prodTrafficRoute.type,\n              LogicalID: app.ecsAttributes.trafficRouting.prodTrafficRoute.logicalId,\n            },\n            TestTrafficRoute: {\n              Type: app.ecsAttributes.trafficRouting.testTrafficRoute.type,\n              LogicalID: app.ecsAttributes.trafficRouting.testTrafficRoute.logicalId,\n            },\n            TargetGroups: app.ecsAttributes.trafficRouting.targetGroups,\n          },\n        },\n      })),\n      TrafficRoutingConfig: undefinedIfAllValuesAreEmpty({\n        Type: this.trafficRoutingConfig?.type,\n        TimeBasedCanary: undefinedIfAllValuesAreEmpty({\n          StepPercentage: this.trafficRoutingConfig?.timeBasedCanary?.stepPercentage,\n          BakeTimeMins: this.trafficRoutingConfig?.timeBasedCanary?.bakeTimeMins,\n        }),\n        TimeBasedLinear: undefinedIfAllValuesAreEmpty({\n          StepPercentage: this.trafficRoutingConfig?.timeBasedLinear?.stepPercentage,\n          BakeTimeMins: this.trafficRoutingConfig?.timeBasedLinear?.bakeTimeMins,\n        }),\n      }),\n      AdditionalOptions: undefinedIfAllValuesAreEmpty({\n        TerminationWaitTimeInMinutes: this.additionalOptions?.terminationWaitTimeInMinutes,\n      }),\n      LifecycleEventHooks: undefinedIfAllValuesAreEmpty({\n        BeforeInstall: this.lifecycleEventHooks?.beforeInstall,\n        AfterInstall: this.lifecycleEventHooks?.afterInstall,\n        AfterAllowTestTraffic: this.lifecycleEventHooks?.afterAllowTestTraffic,\n        BeforeAllowTraffic: this.lifecycleEventHooks?.beforeAllowTraffic,\n        AfterAllowTraffic: this.lifecycleEventHooks?.afterAllowTraffic,\n      }),\n    };\n  }\n}\n"]} |
\ | No newline at end of file |