UNPKG

42.6 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CfnCodeDeployBlueGreenHook = exports.CfnTrafficRoutingType = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const cfn_hook_1 = require("./cfn-hook");
8const 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 */
13var 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 */
34class 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}
239exports.CfnCodeDeployBlueGreenHook = CfnCodeDeployBlueGreenHook;
240_a = JSII_RTTI_SYMBOL_1;
241CfnCodeDeployBlueGreenHook[_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