truemark-cdk-lib 1.6.7-alpha.4 → 1.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -52,12 +52,6 @@ export interface StandardFargateServiceProps extends ExtendedConstructProps {
52
52
  * @default - false
53
53
  */
54
54
  readonly disableXray?: boolean;
55
- /**
56
- * Disables SSM access. Default is false.
57
- *
58
- * @default - false
59
- */
60
- readonly disableSsmAccess?: boolean;
61
55
  /**
62
56
  * Enables the ability to push custom metrics to CloudWatch from the service.
63
57
  *
@@ -31,17 +31,6 @@ class StandardFargateService extends aws_cdk_1.ExtendedConstruct {
31
31
  actions: ['cloudwatch:PutMetricData'],
32
32
  }));
33
33
  }
34
- if (!props.disableSsmAccess) {
35
- taskDefinition.addToExecutionRolePolicy(new aws_iam_1.PolicyStatement({
36
- resources: ["*"],
37
- actions: [
38
- "ssmmessages:CreateControlChannel",
39
- "ssmmessages:CreateDataChannel",
40
- "ssmmessages:OpenControlChannel",
41
- "ssmmessages:OpenDataChannel"
42
- ]
43
- }));
44
- }
45
34
  const logGroup = this.resolveLogGroup(this, props);
46
35
  const logging = this.resolveLogDriver(this, props, logGroup);
47
36
  const port = (_d = props.port) !== null && _d !== void 0 ? _d : 8080;
@@ -203,4 +192,4 @@ class StandardFargateService extends aws_cdk_1.ExtendedConstruct {
203
192
  }
204
193
  }
205
194
  exports.StandardFargateService = StandardFargateService;
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-fargate-service.js","sourceRoot":"","sources":["standard-fargate-service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Construct} from \"constructs\";\nimport {\n  CapacityProviderStrategy,\n  ContainerImage,\n  CpuArchitecture,\n  DeploymentControllerType,\n  FargatePlatformVersion,\n  FargateService,\n  FargateTaskDefinition,\n  ICluster,\n  LogDriver,\n  OperatingSystemFamily,\n  Protocol, ScalableTaskCount,\n  Secret\n} from \"aws-cdk-lib/aws-ecs\";\nimport {LogConfiguration} from \"./log-configuration\";\nimport {SecurityGroup, SubnetSelection, SubnetType} from \"aws-cdk-lib/aws-ec2\";\nimport {LogGroup, RetentionDays} from \"aws-cdk-lib/aws-logs\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {PolicyStatement} from \"aws-cdk-lib/aws-iam\";\nimport {BasicStepScalingPolicyProps} from \"aws-cdk-lib/aws-autoscaling\";\nimport {IMetric} from \"aws-cdk-lib/aws-cloudwatch\";\nimport {ScalingSchedule} from \"aws-cdk-lib/aws-applicationautoscaling\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for StandardFargateService.\n */\nexport interface StandardFargateServiceProps extends ExtendedConstructProps {\n\n  /**\n   * The CPU allocated to the task.\n   *\n   * @default - 2048\n   */\n  readonly cpu?: number;\n\n  /**\n   * The memory allocated to the task.\n   *\n   * @default - 4096\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * Optional ephemeral storage allocated to the task.\n   *\n   * @default - 20\n   */\n  readonly ephemeralStorageGiB?: number;\n\n  /**\n   * CPU architecture to use for the task\n   *\n   * @default - CpuArchitecture.ARM64\n   */\n  readonly cpuArchitecture?: CpuArchitecture;\n\n  /**\n   * The name of the service as it appears in the console or in the AWS CLI.\n   *\n   * @default - CloudFormation-generated name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * Log configuration for this service.\n   */\n  readonly logConfiguration?: LogConfiguration;\n\n  /**\n   * Disables X-Ray for this service. Default is false.\n   *\n   * @default - false\n   */\n  readonly disableXray?: boolean\n\n  /**\n   * Disables SSM access. Default is false.\n   *\n   * @default - false\n   */\n  readonly disableSsmAccess?: boolean\n\n  /**\n   * Enables the ability to push custom metrics to CloudWatch from the service.\n   *\n   * @default - true\n   */\n  readonly enablePublishMetrics?: boolean\n\n  /**\n   * The cluster to place services in.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The container port.\n   *\n   * @default 8080\n   */\n  readonly port?: number;\n\n  /**\n   * Whether the port is TCP or UDP.\n   *\n   * @default Protocol.TCP\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * Container image to deploy in this service.\n   */\n  readonly image: ContainerImage;\n\n  /**\n   * Subnets to put the service in. If this is left empty, subnet type PRIVATE_WITH_EGRESS is used.\n   */\n  readonly vpcSubnets?: SubnetSelection;\n\n  /**\n   * Environment variables to pass to this service.\n   */\n  readonly environment?: Record<string, string>;\n\n  /**\n   * A key/value map of labels to add to the container.\n   */\n  readonly dockerLabels?: Record<string, string>;\n\n  /**\n   * The secret environment variables to pass to the container.\n   */\n  readonly secrets?: Record<string, Secret>;\n\n  /**\n   * The maximum number of tasks, specified as a percentage of the Amazon ECS\n   * service's DesiredCount value, that can run in a service during a\n   * deployment.\n   *\n   * @default - 200\n   */\n  readonly maxHealthyPercent?: number;\n\n  /**\n   * The minimum number of tasks, specified as a percentage of\n   * the Amazon ECS service's DesiredCount value, that must\n   * continue to run and remain healthy during a deployment.\n   *\n   * @default - 100\n   */\n  readonly minHealthyPercent?: number;\n\n  /**\n   * Enable rollback on deployment failure\n   *\n   * @default - true\n   */\n  readonly enableRollback?: boolean;\n\n  /**\n   * Specifies which deployment controller to use for the service\n   *\n   * @default - DeploymentControllerType.ECS\n   */\n  readonly deploymentControllerType?: DeploymentControllerType;\n\n  /**\n   * Whether to enable the ability to execute into a container\n   *\n   * @default - true\n   */\n  readonly enableExecuteCommand?: boolean;\n\n  /**\n   * The platform version on which to run your service.\n   *\n   * @default - FargatePlatformVersion.LATEST\n   */\n  readonly platformVersion?: FargatePlatformVersion;\n\n  /**\n   * Whether to assign a public IP address to the containers.\n   *\n   * @default - false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Specifies whether to enable Amazon ECS managed tags for the tasks within the service\n   *\n   * @default - true\n   */\n  readonly enableECSManagedTags?: boolean;\n\n  /**\n   * The period of time, in seconds, that the Amazon ECS service scheduler ignores unhealthy Elastic Load Balancing target health checks after a task has first started.\n   *\n   * @default - Duration.seconds(30)\n   */\n  readonly healthCheckGracePeriod?: Duration;\n\n  /**\n   * Desired count for this service. If not set, defaults to minCapacity.\n   *\n   * @default - minCapacity\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * Minimum capacity to scale to.\n   *\n   * @default - 1\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity to scale to.\n   *\n   * @default - 2\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Period after a scale in activity completes before another scale in activity can start.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly scaleInCooldown?: Duration;\n\n  /**\n   * Period after a scale out activity completes before another scale out activity can start.\n   *\n   * @default - Duration.seconds(60)\n   */\n  readonly scaleOutCooldown?: Duration;\n\n  /**\n   * The target value for CPU utilization across all tasks in the service.\n   * Set this to 0 to disable CPU scaling.\n   *\n   * @default - 60\n   */\n  readonly scaleCpuTargetUtilizationPercent?: number;\n\n  /**\n   * The target value for memory utilization across all tasks in the service.\n   * Disabled by default.\n   */\n  readonly scaleMemoryTargetUtilizationPercent?: number;\n\n  /**\n   * Capacity weight for the FARGATE capacity provider. Default is to not use capacity providers.\n   */\n  readonly capacityWeight?: number;\n\n  /**\n   * The minimum number of tasks to run on the FARGATE capacity provider. Default is to not use capacity providers.\n   */\n  readonly capacityBase?: number;\n\n  /**\n   * Capacity weight for the FARGATE_SPOT capacity provider. Default is to not use capacity providers.\n   */\n  readonly spotCapacityWeight?: number;\n\n  /**\n   * The minimum number of tasks to run on the FARGATE_SPOT capacity provider. Default is to not use capacity providers.\n   */\n  readonly spotCapacityBase?: number;\n\n  /**\n   * Setting this to true will suppress the creation of default tags on resources\n   * created by this construct. Default is false.\n   *\n   * @default - false\n   */\n  readonly suppressTagging?: boolean;\n\n  /**\n   * Setting this to true will enable outbound IPv6 for the service. Default is false.\n   *\n   * @default - false\n   */\n  readonly allowAllIpv6Outbound?: boolean;\n}\n\n/**\n * Standard class for creating a FargateService. It's recommended to use the StandardApplicationFargateService or\n * StandardNetworkFargateService instead of this class.\n */\nexport class StandardFargateService extends ExtendedConstruct {\n\n  readonly taskDefinition: FargateTaskDefinition;\n  readonly logGroup?: LogGroup;\n  readonly service: FargateService;\n  readonly port: number;\n  readonly scaling: ScalableTaskCount;\n  readonly scaleInCooldown: Duration;\n  readonly scaleOutCooldown: Duration;\n  readonly securityGroup: SecurityGroup;\n\n  protected resolveLogGroup(scope: Construct, props: StandardFargateServiceProps): LogGroup | undefined {\n    if (props.logConfiguration?.enabled ?? true) {\n      return new LogGroup(scope, \"LogGroup\", {\n        retention: props.logConfiguration?.retention ?? RetentionDays.FIVE_DAYS,\n        logGroupName: props.logConfiguration?.logGroupName,\n        encryptionKey: props.logConfiguration?.encryptionKey,\n        removalPolicy: props.logConfiguration?.removalPolicy ?? RemovalPolicy.DESTROY\n      });\n    }\n    return undefined;\n  }\n\n  protected resolveLogDriver(scope: Construct, props: StandardFargateServiceProps, logGroup: LogGroup | undefined):\n    LogDriver | undefined {\n    if (props.logConfiguration?.enabled ?? true) {\n      return LogDriver.awsLogs({\n        streamPrefix: scope.node.id,\n        logGroup\n      });\n    }\n    return undefined;\n  }\n\n  protected resolveVpcSubnets(scope: Construct, props: StandardFargateServiceProps): SubnetSelection {\n    if (props.vpcSubnets === undefined) {\n      return {\n        subnetType: SubnetType.PRIVATE_WITH_EGRESS\n      }\n    }\n    return props.vpcSubnets\n  }\n\n  protected resolvedCapacityProviderStrategies(props: StandardFargateServiceProps):\n    CapacityProviderStrategy[] | undefined {\n    let strategies: CapacityProviderStrategy[] = [];\n    if (props.capacityWeight !== undefined || props.capacityBase !== undefined) {\n      strategies.push({\n        capacityProvider: \"FARGATE\",\n        base: props.capacityBase,\n        weight: props.capacityWeight\n      });\n    }\n    if (props.spotCapacityWeight !== undefined || props.spotCapacityBase !== undefined) {\n      strategies.push({\n        capacityProvider: \"FARGATE_SPOT\",\n        base: props.spotCapacityBase,\n        weight: props.spotCapacityWeight\n      });\n    }\n    return strategies.length > 0 ? strategies : undefined;\n  }\n\n  constructor(scope: Construct, id: string, props: StandardFargateServiceProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const taskDefinition = new FargateTaskDefinition(this, \"Resource\", {\n      cpu: props.cpu ?? 2048,\n      memoryLimitMiB: props.memoryLimitMiB ?? 4096,\n      ephemeralStorageGiB: props.ephemeralStorageGiB,\n      runtimePlatform: {\n        operatingSystemFamily: OperatingSystemFamily.LINUX,\n        cpuArchitecture: props.cpuArchitecture ?? CpuArchitecture.ARM64\n      }\n    });\n\n    if (!props.disableXray) {\n      taskDefinition.addToTaskRolePolicy(\n        new PolicyStatement({\n          resources: ['*'],\n          actions: ['cloudwatch:PutMetricData'],\n        })\n      );\n    }\n\n    if (!props.disableSsmAccess) {\n      taskDefinition.addToExecutionRolePolicy(\n        new PolicyStatement({\n          resources: [\"*\"],\n          actions: [\n            \"ssmmessages:CreateControlChannel\",\n            \"ssmmessages:CreateDataChannel\",\n            \"ssmmessages:OpenControlChannel\",\n            \"ssmmessages:OpenDataChannel\"\n          ]\n        })\n      )\n    }\n\n    const logGroup = this.resolveLogGroup(this, props);\n    const logging = this.resolveLogDriver(this, props, logGroup);\n    const port = props.port ?? 8080;\n    const protocol = props.protocol ?? Protocol.TCP;\n\n    taskDefinition.addContainer(\"Container\", {\n      image: props.image,\n      portMappings: [\n        {\n          containerPort: port,\n          hostPort: port,\n          protocol\n        }\n      ],\n      logging,\n      environment: props.environment,\n      dockerLabels: props.dockerLabels,\n      secrets: props.secrets\n    });\n\n    // TODO Otel Collector\n\n    const vpcSubnets = this.resolveVpcSubnets(this, props);\n    const desiredCount = props.desiredCount ?? props.minCapacity ?? 1;\n    const capacityProviderStrategies = this.resolvedCapacityProviderStrategies(props);\n\n    const securityGroup = new SecurityGroup(this, \"SecurityGroup\", {\n      vpc: props.cluster.vpc,\n      allowAllIpv6Outbound: props.allowAllIpv6Outbound ?? false,\n      allowAllOutbound: true\n    });\n\n    const service = new FargateService(this, \"Default\", {\n      cluster: props.cluster,\n      taskDefinition,\n      serviceName: props.serviceName,\n      maxHealthyPercent: props.maxHealthyPercent ?? 200,\n      minHealthyPercent: props.minHealthyPercent ?? 100,\n      desiredCount,\n      circuitBreaker: {\n        rollback: props.enableRollback ?? true\n      },\n      deploymentController: {\n        type: props.deploymentControllerType ?? DeploymentControllerType.ECS\n      },\n      vpcSubnets,\n      platformVersion: props.platformVersion ?? FargatePlatformVersion.LATEST,\n      enableExecuteCommand: props.enableExecuteCommand ?? true,\n      assignPublicIp: props.assignPublicIp ?? false,\n      enableECSManagedTags: props.enableECSManagedTags ?? true,\n      healthCheckGracePeriod: props.healthCheckGracePeriod ?? Duration.seconds(30),\n      capacityProviderStrategies,\n      securityGroups: [securityGroup]\n    });\n\n    const scaling = service.autoScaleTaskCount({\n      minCapacity: props.minCapacity ?? 1,\n      maxCapacity: props.maxCapacity ?? 2\n    });\n    const scaleInCooldown = props.scaleInCooldown ?? Duration.seconds(10);\n    const scaleOutCooldown = props.scaleOutCooldown ?? Duration.seconds(60);\n\n    if (props.scaleCpuTargetUtilizationPercent !== 0) {\n      scaling.scaleOnCpuUtilization(\"CpuScaling\", {\n        scaleInCooldown,\n        scaleOutCooldown,\n        targetUtilizationPercent: props.scaleCpuTargetUtilizationPercent ?? 60,\n      });\n    }\n\n    if (props.scaleMemoryTargetUtilizationPercent !== undefined) {\n      scaling.scaleOnMemoryUtilization(\"MemoryScaling\", {\n        scaleInCooldown,\n        scaleOutCooldown,\n        targetUtilizationPercent: props.scaleMemoryTargetUtilizationPercent\n      });\n    }\n\n    this.port = port;\n    this.taskDefinition = taskDefinition;\n    this.logGroup = logGroup;\n    this.service = service;\n    this.scaling = scaling;\n    this.scaleInCooldown = scaleInCooldown;\n    this.scaleOutCooldown = scaleOutCooldown;\n    this.securityGroup = securityGroup;\n  }\n\n  /**\n   * Helper method to conduct scaling based on tracking custom metrics.\n   *\n   * @param id the id to give the scaling\n   * @param metric the metric to track\n   * @param targetValue the target value\n   */\n  scaleToTrackCustomMetric(id: string, metric: IMetric,  targetValue: number) {\n    this.scaling.scaleToTrackCustomMetric(id, {\n      scaleInCooldown: this.scaleInCooldown,\n      scaleOutCooldown: this.scaleOutCooldown,\n      metric,\n      targetValue\n    });\n  }\n\n  /**\n   * Convenience method to scale based on a metric.\n   *\n   * @param id the id to give the scaling policy\n   * @param props scaling properties\n   */\n  scaleOnMetric(id: string, props: BasicStepScalingPolicyProps) {\n    this.scaling.scaleOnMetric(id, props);\n  }\n\n  /**\n   * Convenience method to scale based on a schedule.\n   *\n   * @param id the id to give the scaling policy\n   * @param props scaling properties\n   */\n  scaleOnSchedule(id: string, props: ScalingSchedule) {\n    this.scaling.scaleOnSchedule(id, props);\n  }\n}\n"]}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"standard-fargate-service.js","sourceRoot":"","sources":["standard-fargate-service.ts"],"names":[],"mappings":";;;AACA,iDAa6B;AAE7B,iDAA+E;AAC/E,mDAA6D;AAC7D,6CAAoD;AACpD,iDAAoD;AAIpD,2CAAsF;AACtF,6CAA+C;AAiQ/C;;;GAGG;AACH,MAAa,sBAAuB,SAAQ,2BAAiB;IA+D3D,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAkC;;QAC1E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,EAAC,YAAY,EAAE,sBAAY,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,0BAAe,CAAC,EAAC,CAAC,CAAC;QAE1F,MAAM,cAAc,GAAG,IAAI,+BAAqB,CAAC,IAAI,EAAE,UAAU,EAAE;YACjE,GAAG,QAAE,KAAK,CAAC,GAAG,mCAAI,IAAI;YACtB,cAAc,QAAE,KAAK,CAAC,cAAc,mCAAI,IAAI;YAC5C,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;YAC9C,eAAe,EAAE;gBACf,qBAAqB,EAAE,+BAAqB,CAAC,KAAK;gBAClD,eAAe,QAAE,KAAK,CAAC,eAAe,mCAAI,yBAAe,CAAC,KAAK;aAChE;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;YACtB,cAAc,CAAC,mBAAmB,CAChC,IAAI,yBAAe,CAAC;gBAClB,SAAS,EAAE,CAAC,GAAG,CAAC;gBAChB,OAAO,EAAE,CAAC,0BAA0B,CAAC;aACtC,CAAC,CACH,CAAC;SACH;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACnD,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC7D,MAAM,IAAI,SAAG,KAAK,CAAC,IAAI,mCAAI,IAAI,CAAC;QAChC,MAAM,QAAQ,SAAG,KAAK,CAAC,QAAQ,mCAAI,kBAAQ,CAAC,GAAG,CAAC;QAEhD,cAAc,CAAC,YAAY,CAAC,WAAW,EAAE;YACvC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,YAAY,EAAE;gBACZ;oBACE,aAAa,EAAE,IAAI;oBACnB,QAAQ,EAAE,IAAI;oBACd,QAAQ;iBACT;aACF;YACD,OAAO;YACP,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,YAAY,EAAE,KAAK,CAAC,YAAY;YAChC,OAAO,EAAE,KAAK,CAAC,OAAO;SACvB,CAAC,CAAC;QAEH,sBAAsB;QAEtB,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACvD,MAAM,YAAY,eAAG,KAAK,CAAC,YAAY,mCAAI,KAAK,CAAC,WAAW,mCAAI,CAAC,CAAC;QAClE,MAAM,0BAA0B,GAAG,IAAI,CAAC,kCAAkC,CAAC,KAAK,CAAC,CAAC;QAElF,MAAM,aAAa,GAAG,IAAI,uBAAa,CAAC,IAAI,EAAE,eAAe,EAAE;YAC7D,GAAG,EAAE,KAAK,CAAC,OAAO,CAAC,GAAG;YACtB,oBAAoB,QAAE,KAAK,CAAC,oBAAoB,mCAAI,KAAK;YACzD,gBAAgB,EAAE,IAAI;SACvB,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,IAAI,wBAAc,CAAC,IAAI,EAAE,SAAS,EAAE;YAClD,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,cAAc;YACd,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,iBAAiB,QAAE,KAAK,CAAC,iBAAiB,mCAAI,GAAG;YACjD,iBAAiB,QAAE,KAAK,CAAC,iBAAiB,mCAAI,GAAG;YACjD,YAAY;YACZ,cAAc,EAAE;gBACd,QAAQ,QAAE,KAAK,CAAC,cAAc,mCAAI,IAAI;aACvC;YACD,oBAAoB,EAAE;gBACpB,IAAI,QAAE,KAAK,CAAC,wBAAwB,mCAAI,kCAAwB,CAAC,GAAG;aACrE;YACD,UAAU;YACV,eAAe,QAAE,KAAK,CAAC,eAAe,mCAAI,gCAAsB,CAAC,MAAM;YACvE,oBAAoB,QAAE,KAAK,CAAC,oBAAoB,mCAAI,IAAI;YACxD,cAAc,QAAE,KAAK,CAAC,cAAc,mCAAI,KAAK;YAC7C,oBAAoB,QAAE,KAAK,CAAC,oBAAoB,mCAAI,IAAI;YACxD,sBAAsB,QAAE,KAAK,CAAC,sBAAsB,mCAAI,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC5E,0BAA0B;YAC1B,cAAc,EAAE,CAAC,aAAa,CAAC;SAChC,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,OAAO,CAAC,kBAAkB,CAAC;YACzC,WAAW,QAAE,KAAK,CAAC,WAAW,mCAAI,CAAC;YACnC,WAAW,QAAE,KAAK,CAAC,WAAW,mCAAI,CAAC;SACpC,CAAC,CAAC;QACH,MAAM,eAAe,SAAG,KAAK,CAAC,eAAe,mCAAI,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACtE,MAAM,gBAAgB,SAAG,KAAK,CAAC,gBAAgB,mCAAI,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAExE,IAAI,KAAK,CAAC,gCAAgC,KAAK,CAAC,EAAE;YAChD,OAAO,CAAC,qBAAqB,CAAC,YAAY,EAAE;gBAC1C,eAAe;gBACf,gBAAgB;gBAChB,wBAAwB,QAAE,KAAK,CAAC,gCAAgC,mCAAI,EAAE;aACvE,CAAC,CAAC;SACJ;QAED,IAAI,KAAK,CAAC,mCAAmC,KAAK,SAAS,EAAE;YAC3D,OAAO,CAAC,wBAAwB,CAAC,eAAe,EAAE;gBAChD,eAAe;gBACf,gBAAgB;gBAChB,wBAAwB,EAAE,KAAK,CAAC,mCAAmC;aACpE,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;QACrC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;IACrC,CAAC;IAhKS,eAAe,CAAC,KAAgB,EAAE,KAAkC;;QAC5E,gBAAI,KAAK,CAAC,gBAAgB,0CAAE,OAAO,mCAAI,IAAI,EAAE;YAC3C,OAAO,IAAI,mBAAQ,CAAC,KAAK,EAAE,UAAU,EAAE;gBACrC,SAAS,cAAE,KAAK,CAAC,gBAAgB,0CAAE,SAAS,mCAAI,wBAAa,CAAC,SAAS;gBACvE,YAAY,QAAE,KAAK,CAAC,gBAAgB,0CAAE,YAAY;gBAClD,aAAa,QAAE,KAAK,CAAC,gBAAgB,0CAAE,aAAa;gBACpD,aAAa,cAAE,KAAK,CAAC,gBAAgB,0CAAE,aAAa,mCAAI,2BAAa,CAAC,OAAO;aAC9E,CAAC,CAAC;SACJ;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAES,gBAAgB,CAAC,KAAgB,EAAE,KAAkC,EAAE,QAA8B;;QAE7G,gBAAI,KAAK,CAAC,gBAAgB,0CAAE,OAAO,mCAAI,IAAI,EAAE;YAC3C,OAAO,mBAAS,CAAC,OAAO,CAAC;gBACvB,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE;gBAC3B,QAAQ;aACT,CAAC,CAAC;SACJ;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAES,iBAAiB,CAAC,KAAgB,EAAE,KAAkC;QAC9E,IAAI,KAAK,CAAC,UAAU,KAAK,SAAS,EAAE;YAClC,OAAO;gBACL,UAAU,EAAE,oBAAU,CAAC,mBAAmB;aAC3C,CAAA;SACF;QACD,OAAO,KAAK,CAAC,UAAU,CAAA;IACzB,CAAC;IAES,kCAAkC,CAAC,KAAkC;QAE7E,IAAI,UAAU,GAA+B,EAAE,CAAC;QAChD,IAAI,KAAK,CAAC,cAAc,KAAK,SAAS,IAAI,KAAK,CAAC,YAAY,KAAK,SAAS,EAAE;YAC1E,UAAU,CAAC,IAAI,CAAC;gBACd,gBAAgB,EAAE,SAAS;gBAC3B,IAAI,EAAE,KAAK,CAAC,YAAY;gBACxB,MAAM,EAAE,KAAK,CAAC,cAAc;aAC7B,CAAC,CAAC;SACJ;QACD,IAAI,KAAK,CAAC,kBAAkB,KAAK,SAAS,IAAI,KAAK,CAAC,gBAAgB,KAAK,SAAS,EAAE;YAClF,UAAU,CAAC,IAAI,CAAC;gBACd,gBAAgB,EAAE,cAAc;gBAChC,IAAI,EAAE,KAAK,CAAC,gBAAgB;gBAC5B,MAAM,EAAE,KAAK,CAAC,kBAAkB;aACjC,CAAC,CAAC;SACJ;QACD,OAAO,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAgHD;;;;;;OAMG;IACH,wBAAwB,CAAC,EAAU,EAAE,MAAe,EAAG,WAAmB;QACxE,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,EAAE,EAAE;YACxC,eAAe,EAAE,IAAI,CAAC,eAAe;YACrC,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,MAAM;YACN,WAAW;SACZ,CAAC,CAAC;IACL,CAAC;IAED;;;;;OAKG;IACH,aAAa,CAAC,EAAU,EAAE,KAAkC;QAC1D,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IACxC,CAAC;IAED;;;;;OAKG;IACH,eAAe,CAAC,EAAU,EAAE,KAAsB;QAChD,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IAC1C,CAAC;CACF;AAhND,wDAgNC","sourcesContent":["import {Construct} from \"constructs\";\nimport {\n  CapacityProviderStrategy,\n  ContainerImage,\n  CpuArchitecture,\n  DeploymentControllerType,\n  FargatePlatformVersion,\n  FargateService,\n  FargateTaskDefinition,\n  ICluster,\n  LogDriver,\n  OperatingSystemFamily,\n  Protocol, ScalableTaskCount,\n  Secret\n} from \"aws-cdk-lib/aws-ecs\";\nimport {LogConfiguration} from \"./log-configuration\";\nimport {SecurityGroup, SubnetSelection, SubnetType} from \"aws-cdk-lib/aws-ec2\";\nimport {LogGroup, RetentionDays} from \"aws-cdk-lib/aws-logs\";\nimport {Duration, RemovalPolicy} from \"aws-cdk-lib\";\nimport {PolicyStatement} from \"aws-cdk-lib/aws-iam\";\nimport {BasicStepScalingPolicyProps} from \"aws-cdk-lib/aws-autoscaling\";\nimport {IMetric} from \"aws-cdk-lib/aws-cloudwatch\";\nimport {ScalingSchedule} from \"aws-cdk-lib/aws-applicationautoscaling\";\nimport {ExtendedConstruct, ExtendedConstructProps, StandardTags} from \"../../aws-cdk\";\nimport {LibStandardTags} from \"../../truemark\";\n\n/**\n * Properties for StandardFargateService.\n */\nexport interface StandardFargateServiceProps extends ExtendedConstructProps {\n\n  /**\n   * The CPU allocated to the task.\n   *\n   * @default - 2048\n   */\n  readonly cpu?: number;\n\n  /**\n   * The memory allocated to the task.\n   *\n   * @default - 4096\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * Optional ephemeral storage allocated to the task.\n   *\n   * @default - 20\n   */\n  readonly ephemeralStorageGiB?: number;\n\n  /**\n   * CPU architecture to use for the task\n   *\n   * @default - CpuArchitecture.ARM64\n   */\n  readonly cpuArchitecture?: CpuArchitecture;\n\n  /**\n   * The name of the service as it appears in the console or in the AWS CLI.\n   *\n   * @default - CloudFormation-generated name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * Log configuration for this service.\n   */\n  readonly logConfiguration?: LogConfiguration;\n\n  /**\n   * Disables X-Ray for this service. Default is false.\n   *\n   * @default - false\n   */\n  readonly disableXray?: boolean\n\n  /**\n   * Enables the ability to push custom metrics to CloudWatch from the service.\n   *\n   * @default - true\n   */\n  readonly enablePublishMetrics?: boolean\n\n  /**\n   * The cluster to place services in.\n   */\n  readonly cluster: ICluster;\n\n  /**\n   * The container port.\n   *\n   * @default 8080\n   */\n  readonly port?: number;\n\n  /**\n   * Whether the port is TCP or UDP.\n   *\n   * @default Protocol.TCP\n   */\n  readonly protocol?: Protocol;\n\n  /**\n   * Container image to deploy in this service.\n   */\n  readonly image: ContainerImage;\n\n  /**\n   * Subnets to put the service in. If this is left empty, subnet type PRIVATE_WITH_EGRESS is used.\n   */\n  readonly vpcSubnets?: SubnetSelection;\n\n  /**\n   * Environment variables to pass to this service.\n   */\n  readonly environment?: Record<string, string>;\n\n  /**\n   * A key/value map of labels to add to the container.\n   */\n  readonly dockerLabels?: Record<string, string>;\n\n  /**\n   * The secret environment variables to pass to the container.\n   */\n  readonly secrets?: Record<string, Secret>;\n\n  /**\n   * The maximum number of tasks, specified as a percentage of the Amazon ECS\n   * service's DesiredCount value, that can run in a service during a\n   * deployment.\n   *\n   * @default - 200\n   */\n  readonly maxHealthyPercent?: number;\n\n  /**\n   * The minimum number of tasks, specified as a percentage of\n   * the Amazon ECS service's DesiredCount value, that must\n   * continue to run and remain healthy during a deployment.\n   *\n   * @default - 100\n   */\n  readonly minHealthyPercent?: number;\n\n  /**\n   * Enable rollback on deployment failure\n   *\n   * @default - true\n   */\n  readonly enableRollback?: boolean;\n\n  /**\n   * Specifies which deployment controller to use for the service\n   *\n   * @default - DeploymentControllerType.ECS\n   */\n  readonly deploymentControllerType?: DeploymentControllerType;\n\n  /**\n   * Whether to enable the ability to execute into a container\n   *\n   * @default - true\n   */\n  readonly enableExecuteCommand?: boolean;\n\n  /**\n   * The platform version on which to run your service.\n   *\n   * @default - FargatePlatformVersion.LATEST\n   */\n  readonly platformVersion?: FargatePlatformVersion;\n\n  /**\n   * Whether to assign a public IP address to the containers.\n   *\n   * @default - false\n   */\n  readonly assignPublicIp?: boolean;\n\n  /**\n   * Specifies whether to enable Amazon ECS managed tags for the tasks within the service\n   *\n   * @default - true\n   */\n  readonly enableECSManagedTags?: boolean;\n\n  /**\n   * The period of time, in seconds, that the Amazon ECS service scheduler ignores unhealthy Elastic Load Balancing target health checks after a task has first started.\n   *\n   * @default - Duration.seconds(30)\n   */\n  readonly healthCheckGracePeriod?: Duration;\n\n  /**\n   * Desired count for this service. If not set, defaults to minCapacity.\n   *\n   * @default - minCapacity\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * Minimum capacity to scale to.\n   *\n   * @default - 1\n   */\n  readonly minCapacity?: number;\n\n  /**\n   * Maximum capacity to scale to.\n   *\n   * @default - 2\n   */\n  readonly maxCapacity?: number;\n\n  /**\n   * Period after a scale in activity completes before another scale in activity can start.\n   *\n   * @default - Duration.seconds(10)\n   */\n  readonly scaleInCooldown?: Duration;\n\n  /**\n   * Period after a scale out activity completes before another scale out activity can start.\n   *\n   * @default - Duration.seconds(60)\n   */\n  readonly scaleOutCooldown?: Duration;\n\n  /**\n   * The target value for CPU utilization across all tasks in the service.\n   * Set this to 0 to disable CPU scaling.\n   *\n   * @default - 60\n   */\n  readonly scaleCpuTargetUtilizationPercent?: number;\n\n  /**\n   * The target value for memory utilization across all tasks in the service.\n   * Disabled by default.\n   */\n  readonly scaleMemoryTargetUtilizationPercent?: number;\n\n  /**\n   * Capacity weight for the FARGATE capacity provider. Default is to not use capacity providers.\n   */\n  readonly capacityWeight?: number;\n\n  /**\n   * The minimum number of tasks to run on the FARGATE capacity provider. Default is to not use capacity providers.\n   */\n  readonly capacityBase?: number;\n\n  /**\n   * Capacity weight for the FARGATE_SPOT capacity provider. Default is to not use capacity providers.\n   */\n  readonly spotCapacityWeight?: number;\n\n  /**\n   * The minimum number of tasks to run on the FARGATE_SPOT capacity provider. Default is to not use capacity providers.\n   */\n  readonly spotCapacityBase?: number;\n\n  /**\n   * Setting this to true will suppress the creation of default tags on resources\n   * created by this construct. Default is false.\n   *\n   * @default - false\n   */\n  readonly suppressTagging?: boolean;\n\n  /**\n   * Setting this to true will enable outbound IPv6 for the service. Default is false.\n   *\n   * @default - false\n   */\n  readonly allowAllIpv6Outbound?: boolean;\n}\n\n/**\n * Standard class for creating a FargateService. It's recommended to use the StandardApplicationFargateService or\n * StandardNetworkFargateService instead of this class.\n */\nexport class StandardFargateService extends ExtendedConstruct {\n\n  readonly taskDefinition: FargateTaskDefinition;\n  readonly logGroup?: LogGroup;\n  readonly service: FargateService;\n  readonly port: number;\n  readonly scaling: ScalableTaskCount;\n  readonly scaleInCooldown: Duration;\n  readonly scaleOutCooldown: Duration;\n  readonly securityGroup: SecurityGroup;\n\n  protected resolveLogGroup(scope: Construct, props: StandardFargateServiceProps): LogGroup | undefined {\n    if (props.logConfiguration?.enabled ?? true) {\n      return new LogGroup(scope, \"LogGroup\", {\n        retention: props.logConfiguration?.retention ?? RetentionDays.FIVE_DAYS,\n        logGroupName: props.logConfiguration?.logGroupName,\n        encryptionKey: props.logConfiguration?.encryptionKey,\n        removalPolicy: props.logConfiguration?.removalPolicy ?? RemovalPolicy.DESTROY\n      });\n    }\n    return undefined;\n  }\n\n  protected resolveLogDriver(scope: Construct, props: StandardFargateServiceProps, logGroup: LogGroup | undefined):\n    LogDriver | undefined {\n    if (props.logConfiguration?.enabled ?? true) {\n      return LogDriver.awsLogs({\n        streamPrefix: scope.node.id,\n        logGroup\n      });\n    }\n    return undefined;\n  }\n\n  protected resolveVpcSubnets(scope: Construct, props: StandardFargateServiceProps): SubnetSelection {\n    if (props.vpcSubnets === undefined) {\n      return {\n        subnetType: SubnetType.PRIVATE_WITH_EGRESS\n      }\n    }\n    return props.vpcSubnets\n  }\n\n  protected resolvedCapacityProviderStrategies(props: StandardFargateServiceProps):\n    CapacityProviderStrategy[] | undefined {\n    let strategies: CapacityProviderStrategy[] = [];\n    if (props.capacityWeight !== undefined || props.capacityBase !== undefined) {\n      strategies.push({\n        capacityProvider: \"FARGATE\",\n        base: props.capacityBase,\n        weight: props.capacityWeight\n      });\n    }\n    if (props.spotCapacityWeight !== undefined || props.spotCapacityBase !== undefined) {\n      strategies.push({\n        capacityProvider: \"FARGATE_SPOT\",\n        base: props.spotCapacityBase,\n        weight: props.spotCapacityWeight\n      });\n    }\n    return strategies.length > 0 ? strategies : undefined;\n  }\n\n  constructor(scope: Construct, id: string, props: StandardFargateServiceProps) {\n    super(scope, id, {standardTags: StandardTags.merge(props.standardTags, LibStandardTags)});\n\n    const taskDefinition = new FargateTaskDefinition(this, \"Resource\", {\n      cpu: props.cpu ?? 2048,\n      memoryLimitMiB: props.memoryLimitMiB ?? 4096,\n      ephemeralStorageGiB: props.ephemeralStorageGiB,\n      runtimePlatform: {\n        operatingSystemFamily: OperatingSystemFamily.LINUX,\n        cpuArchitecture: props.cpuArchitecture ?? CpuArchitecture.ARM64\n      }\n    });\n\n    if (!props.disableXray) {\n      taskDefinition.addToTaskRolePolicy(\n        new PolicyStatement({\n          resources: ['*'],\n          actions: ['cloudwatch:PutMetricData'],\n        })\n      );\n    }\n\n    const logGroup = this.resolveLogGroup(this, props);\n    const logging = this.resolveLogDriver(this, props, logGroup);\n    const port = props.port ?? 8080;\n    const protocol = props.protocol ?? Protocol.TCP;\n\n    taskDefinition.addContainer(\"Container\", {\n      image: props.image,\n      portMappings: [\n        {\n          containerPort: port,\n          hostPort: port,\n          protocol\n        }\n      ],\n      logging,\n      environment: props.environment,\n      dockerLabels: props.dockerLabels,\n      secrets: props.secrets\n    });\n\n    // TODO Otel Collector\n\n    const vpcSubnets = this.resolveVpcSubnets(this, props);\n    const desiredCount = props.desiredCount ?? props.minCapacity ?? 1;\n    const capacityProviderStrategies = this.resolvedCapacityProviderStrategies(props);\n\n    const securityGroup = new SecurityGroup(this, \"SecurityGroup\", {\n      vpc: props.cluster.vpc,\n      allowAllIpv6Outbound: props.allowAllIpv6Outbound ?? false,\n      allowAllOutbound: true\n    });\n\n    const service = new FargateService(this, \"Default\", {\n      cluster: props.cluster,\n      taskDefinition,\n      serviceName: props.serviceName,\n      maxHealthyPercent: props.maxHealthyPercent ?? 200,\n      minHealthyPercent: props.minHealthyPercent ?? 100,\n      desiredCount,\n      circuitBreaker: {\n        rollback: props.enableRollback ?? true\n      },\n      deploymentController: {\n        type: props.deploymentControllerType ?? DeploymentControllerType.ECS\n      },\n      vpcSubnets,\n      platformVersion: props.platformVersion ?? FargatePlatformVersion.LATEST,\n      enableExecuteCommand: props.enableExecuteCommand ?? true,\n      assignPublicIp: props.assignPublicIp ?? false,\n      enableECSManagedTags: props.enableECSManagedTags ?? true,\n      healthCheckGracePeriod: props.healthCheckGracePeriod ?? Duration.seconds(30),\n      capacityProviderStrategies,\n      securityGroups: [securityGroup]\n    });\n\n    const scaling = service.autoScaleTaskCount({\n      minCapacity: props.minCapacity ?? 1,\n      maxCapacity: props.maxCapacity ?? 2\n    });\n    const scaleInCooldown = props.scaleInCooldown ?? Duration.seconds(10);\n    const scaleOutCooldown = props.scaleOutCooldown ?? Duration.seconds(60);\n\n    if (props.scaleCpuTargetUtilizationPercent !== 0) {\n      scaling.scaleOnCpuUtilization(\"CpuScaling\", {\n        scaleInCooldown,\n        scaleOutCooldown,\n        targetUtilizationPercent: props.scaleCpuTargetUtilizationPercent ?? 60,\n      });\n    }\n\n    if (props.scaleMemoryTargetUtilizationPercent !== undefined) {\n      scaling.scaleOnMemoryUtilization(\"MemoryScaling\", {\n        scaleInCooldown,\n        scaleOutCooldown,\n        targetUtilizationPercent: props.scaleMemoryTargetUtilizationPercent\n      });\n    }\n\n    this.port = port;\n    this.taskDefinition = taskDefinition;\n    this.logGroup = logGroup;\n    this.service = service;\n    this.scaling = scaling;\n    this.scaleInCooldown = scaleInCooldown;\n    this.scaleOutCooldown = scaleOutCooldown;\n    this.securityGroup = securityGroup;\n  }\n\n  /**\n   * Helper method to conduct scaling based on tracking custom metrics.\n   *\n   * @param id the id to give the scaling\n   * @param metric the metric to track\n   * @param targetValue the target value\n   */\n  scaleToTrackCustomMetric(id: string, metric: IMetric,  targetValue: number) {\n    this.scaling.scaleToTrackCustomMetric(id, {\n      scaleInCooldown: this.scaleInCooldown,\n      scaleOutCooldown: this.scaleOutCooldown,\n      metric,\n      targetValue\n    });\n  }\n\n  /**\n   * Convenience method to scale based on a metric.\n   *\n   * @param id the id to give the scaling policy\n   * @param props scaling properties\n   */\n  scaleOnMetric(id: string, props: BasicStepScalingPolicyProps) {\n    this.scaling.scaleOnMetric(id, props);\n  }\n\n  /**\n   * Convenience method to scale based on a schedule.\n   *\n   * @param id the id to give the scaling policy\n   * @param props scaling properties\n   */\n  scaleOnSchedule(id: string, props: ScalingSchedule) {\n    this.scaling.scaleOnSchedule(id, props);\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "truemark-cdk-lib",
3
- "version": "1.6.7-alpha.4+1d5b2ac",
3
+ "version": "1.7.0",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "scripts": {
@@ -72,5 +72,5 @@
72
72
  "publishConfig": {
73
73
  "access": "public"
74
74
  },
75
- "gitHead": "1d5b2ac1fa55173cd8fa4cca9a0fb644ba81a9af"
75
+ "gitHead": "bf2def829a25a44c9c6d5d0a42f35f56a781d466"
76
76
  }