UNPKG

@aws-cdk/core

Version:

AWS Cloud Development Kit Core Library

242 lines 42.6 kB
"use strict"; var _a; Object.defineProperty(exports, "__esModule", { value: true }); exports.CfnCodeDeployBlueGreenHook = exports.CfnTrafficRoutingType = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const cfn_hook_1 = require("./cfn-hook"); const util_1 = require("./util"); /** * The possible types of traffic shifting for the blue-green deployment configuration. * The type of the {@link CfnTrafficRoutingConfig.type} property. */ var CfnTrafficRoutingType; (function (CfnTrafficRoutingType) { /** * Switch from blue to green at once. */ CfnTrafficRoutingType["ALL_AT_ONCE"] = "AllAtOnce"; /** * Specifies a configuration that shifts traffic from blue to green in two increments. */ CfnTrafficRoutingType["TIME_BASED_CANARY"] = "TimeBasedCanary"; /** * Specifies a configuration that shifts traffic from blue to green in equal increments, * with an equal number of minutes between each increment. */ CfnTrafficRoutingType["TIME_BASED_LINEAR"] = "TimeBasedLinear"; })(CfnTrafficRoutingType = exports.CfnTrafficRoutingType || (exports.CfnTrafficRoutingType = {})); /** * A CloudFormation Hook for CodeDeploy blue-green ECS deployments. * * @see https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/blue-green.html#blue-green-template-reference */ class CfnCodeDeployBlueGreenHook extends cfn_hook_1.CfnHook { /** * Creates a new CodeDeploy blue-green ECS Hook. * * @param scope the scope to create the hook in (usually the containing Stack object) * @param id the identifier of the construct - will be used to generate the logical ID of the Hook * @param props the properties of the Hook */ constructor(scope, id, props) { super(scope, id, { type: 'AWS::CodeDeploy::BlueGreen', }); try { jsiiDeprecationWarnings._aws_cdk_core_CfnCodeDeployBlueGreenHookProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, CfnCodeDeployBlueGreenHook); } throw error; } this._serviceRole = props.serviceRole; this._applications = props.applications; this._trafficRoutingConfig = props.trafficRoutingConfig; this._additionalOptions = props.additionalOptions; this._lifecycleEventHooks = props.lifecycleEventHooks; } /** * A factory method that creates a new instance of this class from an object * containing the CloudFormation properties of this resource. * Used in the @aws-cdk/cloudformation-include module. * * @internal */ static _fromCloudFormation(scope, id, hookAttributes, options) { hookAttributes = hookAttributes || {}; const hookProperties = options.parser.parseValue(hookAttributes.Properties); return new CfnCodeDeployBlueGreenHook(scope, id, { serviceRole: hookProperties?.ServiceRole, applications: hookProperties?.Applications?.map(applicationFromCloudFormation), trafficRoutingConfig: { type: hookProperties?.TrafficRoutingConfig?.Type, timeBasedCanary: { stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.StepPercentage, bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedCanary?.BakeTimeMins, }, timeBasedLinear: { stepPercentage: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.StepPercentage, bakeTimeMins: hookProperties?.TrafficRoutingConfig?.TimeBasedLinear?.BakeTimeMins, }, }, additionalOptions: { terminationWaitTimeInMinutes: hookProperties?.AdditionalOptions?.TerminationWaitTimeInMinutes, }, lifecycleEventHooks: { beforeInstall: hookProperties?.LifecycleEventHooks?.BeforeInstall, afterInstall: hookProperties?.LifecycleEventHooks?.AfterInstall, afterAllowTestTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTestTraffic, beforeAllowTraffic: hookProperties?.LifecycleEventHooks?.BeforeAllowTraffic, afterAllowTraffic: hookProperties?.LifecycleEventHooks?.AfterAllowTraffic, }, }); function applicationFromCloudFormation(app) { const target = findResource(app?.Target?.LogicalID); const taskDefinitions = app?.ECSAttributes?.TaskDefinitions?.map((td) => findResource(td)); const taskSets = app?.ECSAttributes?.TaskSets?.map((ts) => findResource(ts)); const prodTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.LogicalID); const testTrafficRoute = findResource(app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.LogicalID); const targetGroups = app?.ECSAttributes?.TrafficRouting?.TargetGroups?.map((tg) => findResource(tg)); return { target: { type: app?.Target?.Type, logicalId: target?.logicalId, }, ecsAttributes: { taskDefinitions: taskDefinitions?.map(td => td?.logicalId), taskSets: taskSets?.map(ts => ts?.logicalId), trafficRouting: { prodTrafficRoute: { type: app?.ECSAttributes?.TrafficRouting?.ProdTrafficRoute?.Type, logicalId: prodTrafficRoute?.logicalId, }, testTrafficRoute: { type: app?.ECSAttributes?.TrafficRouting?.TestTrafficRoute?.Type, logicalId: testTrafficRoute?.logicalId, }, targetGroups: targetGroups?.map((tg) => tg?.logicalId), }, }, }; } function findResource(logicalId) { if (logicalId == null) { return undefined; } const ret = options.parser.finder.findResource(logicalId); if (!ret) { throw new Error(`Hook '${id}' references resource '${logicalId}' that was not found in the template`); } return ret; } } /** * The IAM Role for CloudFormation to use to perform blue-green deployments. */ get serviceRole() { return this._serviceRole; } set serviceRole(serviceRole) { this._serviceRole = serviceRole; } /** * Properties of the Amazon ECS applications being deployed. */ get applications() { return this._applications; } set applications(value) { this._applications = value; } /** * Traffic routing configuration settings. * * @default - time-based canary traffic shifting, with a 15% step percentage and a five minute bake time */ get trafficRoutingConfig() { return this._trafficRoutingConfig; } set trafficRoutingConfig(value) { this._trafficRoutingConfig = value; } /** * Additional options for the blue/green deployment. * * @default - no additional options */ get additionalOptions() { return this._additionalOptions; } set additionalOptions(value) { this._additionalOptions = value; } /** * Use lifecycle event hooks to specify a Lambda function that CodeDeploy can call to validate a deployment. * You can use the same function or a different one for deployment lifecycle events. * Following completion of the validation tests, * the Lambda {@link CfnCodeDeployBlueGreenLifecycleEventHooks.afterAllowTraffic} * function calls back CodeDeploy and delivers a result of 'Succeeded' or 'Failed'. * * @default - no lifecycle event hooks */ get lifecycleEventHooks() { return this._lifecycleEventHooks; } set lifecycleEventHooks(value) { this._lifecycleEventHooks = value; } renderProperties(_props) { return { ServiceRole: this.serviceRole, Applications: this.applications.map((app) => ({ Target: { Type: app.target.type, LogicalID: app.target.logicalId, }, ECSAttributes: { TaskDefinitions: app.ecsAttributes.taskDefinitions, TaskSets: app.ecsAttributes.taskSets, TrafficRouting: { ProdTrafficRoute: { Type: app.ecsAttributes.trafficRouting.prodTrafficRoute.type, LogicalID: app.ecsAttributes.trafficRouting.prodTrafficRoute.logicalId, }, TestTrafficRoute: { Type: app.ecsAttributes.trafficRouting.testTrafficRoute.type, LogicalID: app.ecsAttributes.trafficRouting.testTrafficRoute.logicalId, }, TargetGroups: app.ecsAttributes.trafficRouting.targetGroups, }, }, })), TrafficRoutingConfig: util_1.undefinedIfAllValuesAreEmpty({ Type: this.trafficRoutingConfig?.type, TimeBasedCanary: util_1.undefinedIfAllValuesAreEmpty({ StepPercentage: this.trafficRoutingConfig?.timeBasedCanary?.stepPercentage, BakeTimeMins: this.trafficRoutingConfig?.timeBasedCanary?.bakeTimeMins, }), TimeBasedLinear: util_1.undefinedIfAllValuesAreEmpty({ StepPercentage: this.trafficRoutingConfig?.timeBasedLinear?.stepPercentage, BakeTimeMins: this.trafficRoutingConfig?.timeBasedLinear?.bakeTimeMins, }), }), AdditionalOptions: util_1.undefinedIfAllValuesAreEmpty({ TerminationWaitTimeInMinutes: this.additionalOptions?.terminationWaitTimeInMinutes, }), LifecycleEventHooks: util_1.undefinedIfAllValuesAreEmpty({ BeforeInstall: this.lifecycleEventHooks?.beforeInstall, AfterInstall: this.lifecycleEventHooks?.afterInstall, AfterAllowTestTraffic: this.lifecycleEventHooks?.afterAllowTestTraffic, BeforeAllowTraffic: this.lifecycleEventHooks?.beforeAllowTraffic, AfterAllowTraffic: this.lifecycleEventHooks?.afterAllowTraffic, }), }; } } exports.CfnCodeDeployBlueGreenHook = CfnCodeDeployBlueGreenHook; _a = JSII_RTTI_SYMBOL_1; CfnCodeDeployBlueGreenHook[_a] = { fqn: "@aws-cdk/core.CfnCodeDeployBlueGreenHook", version: "1.204.0" }; //# 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"]}