@rio-cloud/cdk-v2-constructs 4.5.1 → 4.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.
@@ -36,7 +36,6 @@ var DataDogLoggingMode;
36
36
  })(DataDogLoggingMode = exports.DataDogLoggingMode || (exports.DataDogLoggingMode = {}));
37
37
  class RioFargateService extends constructs.Construct {
38
38
  constructor(scope, id, props) {
39
- var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t;
40
39
  super(scope, id);
41
40
  this.DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE = [];
42
41
  this.DEFAULT_DATADOG_SIDECAR_CPU = 64;
@@ -51,17 +50,17 @@ class RioFargateService extends constructs.Construct {
51
50
  this.LOG_ROUTER_MEMORY_LIMIT_MIB = 64;
52
51
  const { loadBalancerOptions, vpc, cluster, fargateOptions, datadogOptions, serviceName, containerDefinitionOption, stage, version, frameworks, } = props;
53
52
  this.node.addValidation(new DenyListedKeyValidator(RioFargateService.DD_ENV_DENY_LIST, props.containerDefinitionOption.environment, it => `Environment ${it} is not allowed to be set. This value will be inferred from the account or other properties.`));
54
- this.node.addValidation(new DenyListedKeyValidator(RioFargateService.DD_TAG_DENY_LIST, (_b = props.datadogOptions) === null || _b === void 0 ? void 0 : _b.additionalTags, it => `Tag ${it} is not allowed to be set. This value will be inferred from the account or other properties.`));
53
+ this.node.addValidation(new DenyListedKeyValidator(RioFargateService.DD_TAG_DENY_LIST, props.datadogOptions?.additionalTags, it => `Tag ${it} is not allowed to be set. This value will be inferred from the account or other properties.`));
55
54
  this.node.addValidation(new ClusterVpcValidator(props.vpc, props.cluster));
56
- const fargateCluster = cluster !== null && cluster !== void 0 ? cluster : new ecs.Cluster(this, 'Cluster', {
55
+ const fargateCluster = cluster ?? new ecs.Cluster(this, 'Cluster', {
57
56
  vpc: vpc,
58
57
  });
59
58
  this.taskDefinition = new ecs.FargateTaskDefinition(this, 'TaskDefinition', {
60
59
  cpu: fargateOptions.cpu,
61
60
  memoryLimitMiB: fargateOptions.memoryLimitMiB,
62
61
  runtimePlatform: {
63
- cpuArchitecture: (_d = (_c = fargateOptions.runtimePlatform) === null || _c === void 0 ? void 0 : _c.cpuArchitecture) !== null && _d !== void 0 ? _d : ecs.CpuArchitecture.X86_64,
64
- operatingSystemFamily: (_f = (_e = fargateOptions.runtimePlatform) === null || _e === void 0 ? void 0 : _e.operatingSystemFamily) !== null && _f !== void 0 ? _f : ecs.OperatingSystemFamily.LINUX,
62
+ cpuArchitecture: fargateOptions.runtimePlatform?.cpuArchitecture ?? ecs.CpuArchitecture.X86_64,
63
+ operatingSystemFamily: fargateOptions.runtimePlatform?.operatingSystemFamily ?? ecs.OperatingSystemFamily.LINUX,
65
64
  },
66
65
  });
67
66
  const accountName = ssm.StringParameter.fromStringParameterName(this, 'AccountName', '/config/account/name').stringValue;
@@ -69,11 +68,11 @@ class RioFargateService extends constructs.Construct {
69
68
  const teamIdentifier = ssm.StringParameter.fromStringParameterName(this, 'TeamIdentifier', '/config/team/identifier').stringValue;
70
69
  const datadogSite = ssm.StringParameter.fromStringParameterName(this, 'DatadogSite', '/rio/config/datadog-integration/site').stringValue;
71
70
  const datadogApiKeyParameter = ssm.StringParameter.fromStringParameterName(this, 'DatadogApiKey', '/rio/config/datadog-integration/api-key');
72
- const datadogSidecarCpu = (_g = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.cpu) !== null && _g !== void 0 ? _g : this.DEFAULT_DATADOG_SIDECAR_CPU;
73
- const datadogSidecarMemoryMiB = (_h = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.memoryLimitMiB) !== null && _h !== void 0 ? _h : this.DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB;
74
- const datadogSidecarEssential = (_j = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.datadogSidecarEssential) !== null && _j !== void 0 ? _j : this.DEFAULT_DATADOG_SIDECAR_ESSENTIAL;
75
- const loggingModeForService = (_k = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.loggingModeForService) !== null && _k !== void 0 ? _k : this.DEFAULT_LOGGING_MODE_FOR_SERVICE;
76
- const loggingModeForDatadogAgent = (_l = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.loggingModeForDatadogAgent) !== null && _l !== void 0 ? _l : this.DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR;
71
+ const datadogSidecarCpu = datadogOptions?.cpu ?? this.DEFAULT_DATADOG_SIDECAR_CPU;
72
+ const datadogSidecarMemoryMiB = datadogOptions?.memoryLimitMiB ?? this.DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB;
73
+ const datadogSidecarEssential = datadogOptions?.datadogSidecarEssential ?? this.DEFAULT_DATADOG_SIDECAR_ESSENTIAL;
74
+ const loggingModeForService = datadogOptions?.loggingModeForService ?? this.DEFAULT_LOGGING_MODE_FOR_SERVICE;
75
+ const loggingModeForDatadogAgent = datadogOptions?.loggingModeForDatadogAgent ?? this.DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR;
77
76
  const fireLensLogRouterRequired = loggingModeForService === DataDogLoggingMode.AWS_FIRE_LENS ||
78
77
  loggingModeForDatadogAgent === DataDogLoggingMode.AWS_FIRE_LENS;
79
78
  let serviceContainerCpuUnits;
@@ -99,7 +98,7 @@ class RioFargateService extends constructs.Construct {
99
98
  accountName,
100
99
  teamName,
101
100
  teamIdentifier,
102
- additionalTags: datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.additionalTags,
101
+ additionalTags: datadogOptions?.additionalTags,
103
102
  }),
104
103
  ...containerDefinitionOption.environment,
105
104
  },
@@ -119,11 +118,11 @@ class RioFargateService extends constructs.Construct {
119
118
  datadogLoggingMode: loggingModeForService,
120
119
  datadogSite,
121
120
  containerType: 'service',
122
- additionalTags: datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.additionalTags,
121
+ additionalTags: datadogOptions?.additionalTags,
123
122
  }),
124
123
  secrets: containerDefinitionOption.secrets,
125
124
  });
126
- if (frameworks === null || frameworks === void 0 ? void 0 : frameworks.includes(Framework.SPRING)) {
125
+ if (frameworks?.includes(Framework.SPRING)) {
127
126
  spring_1.Spring.allowParameterStoreAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);
128
127
  spring_1.Spring.allowSecretsManagerAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);
129
128
  }
@@ -146,12 +145,12 @@ class RioFargateService extends constructs.Construct {
146
145
  datadogApiKeyParameter,
147
146
  datadogSite,
148
147
  datadogLoggingMode: loggingModeForDatadogAgent,
149
- apmGetResourcesToIgnore: (_m = datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.apmGetEndpointsToIgnore) !== null && _m !== void 0 ? _m : this.DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE,
148
+ apmGetResourcesToIgnore: datadogOptions?.apmGetEndpointsToIgnore ?? this.DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE,
150
149
  cpu: datadogSidecarCpu,
151
150
  memoryLimitMiB: datadogSidecarMemoryMiB,
152
151
  essential: datadogSidecarEssential,
153
- containerTag: (_p = (_o = props.datadogOptions) === null || _o === void 0 ? void 0 : _o.datadogSidecarTag) !== null && _p !== void 0 ? _p : this.DEFAULT_DATADOG_SIDECAR_TAG,
154
- additionalTags: datadogOptions === null || datadogOptions === void 0 ? void 0 : datadogOptions.additionalTags,
152
+ containerTag: props.datadogOptions?.datadogSidecarTag ?? this.DEFAULT_DATADOG_SIDECAR_TAG,
153
+ additionalTags: datadogOptions?.additionalTags,
155
154
  });
156
155
  datadog.ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(this);
157
156
  const loadBalancerOptionsForFargateService = loadBalancerOptions
@@ -163,7 +162,7 @@ class RioFargateService extends constructs.Construct {
163
162
  circuitBreaker: { rollback: true },
164
163
  maxHealthyPercent: 200,
165
164
  minHealthyPercent: 100,
166
- desiredCount: fargateOptions === null || fargateOptions === void 0 ? void 0 : fargateOptions.desiredCount,
165
+ desiredCount: fargateOptions?.desiredCount,
167
166
  ...loadBalancerOptionsForFargateService,
168
167
  propagateTags: ecs.PropagatedTagSource.SERVICE,
169
168
  });
@@ -181,8 +180,8 @@ class RioFargateService extends constructs.Construct {
181
180
  targetType: elbv2.TargetType.IP,
182
181
  targets: [this.service],
183
182
  healthCheck: loadBalancerOptions.healthCheck,
184
- slowStart: (_r = (_q = props.loadBalancerOptions) === null || _q === void 0 ? void 0 : _q.slowStart) !== null && _r !== void 0 ? _r : this.DEFAULT_SLOW_START,
185
- deregistrationDelay: (_t = (_s = props.loadBalancerOptions) === null || _s === void 0 ? void 0 : _s.deregistrationDelay) !== null && _t !== void 0 ? _t : this.DEFAULT_DEREGISTRATION_DELAY,
183
+ slowStart: props.loadBalancerOptions?.slowStart ?? this.DEFAULT_SLOW_START,
184
+ deregistrationDelay: props.loadBalancerOptions?.deregistrationDelay ?? this.DEFAULT_DEREGISTRATION_DELAY,
186
185
  });
187
186
  loadBalancerOptions.listenerRules.forEach(({ priority, conditions }) => {
188
187
  loadBalancerOptions.listener.addTargetGroups(`Priority${priority}ListenerRule`, {
@@ -246,4 +245,4 @@ class ClusterVpcValidator {
246
245
  return result;
247
246
  }
248
247
  }
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rio-fargate-service.js","sourceRoot":"","sources":["../../src/fargate/rio-fargate-service.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as constructs from 'constructs';\nimport * as datadog from './datadog';\nimport { Spring } from './spring';\n\n/**\n * Fargate Task Definition Properties.\n */\nexport interface RioFargateServiceProps {\n  /**\n   * The stage of the service, e.g. 'prod'.\n   */\n  readonly stage: string;\n\n  /**\n   * The Name of the service.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The version of the service, e.g. the git hash of the corresponding commit.\n   */\n  readonly version: string;\n\n  /**\n   * The frameworks in uses.\n   *\n   * @default - No frameworks.\n   */\n  readonly frameworks?: Framework[];\n\n  /**\n   * The VPC of the service's ecs.Cluster if no cluster is explicitly passed as prop.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * The Fargate cluster to run the service in.\n   * If not null, the cluster.vpc MUST match the vpc provided as direct argument.\n   *\n   * @default - Create a new Fargate cluster with default properties\n   */\n  readonly cluster?: ecs.ICluster;\n\n  /**\n   * Container definition options like image, cpu, memory.\n   */\n  readonly containerDefinitionOption: ContainerDefinitionOptions;\n\n  /**\n   * Fargate Task Definition Properties.\n   */\n  readonly fargateOptions: FargateTaskDefinitionProps;\n\n  /**\n   * Loadbalancer options.\n   */\n  readonly loadBalancerOptions?: LoadBalancerOptions;\n\n  /**\n   * Datadog integration properties\n   */\n  readonly datadogOptions?: DatadogIntegrationProps;\n}\n\nexport enum Framework {\n  /**\n   * Spring Framework, Spring Boot, and Spring Cloud AWS.\n   */\n  SPRING,\n}\n\nexport interface ContainerDefinitionOptions {\n  /**\n   * The image used to start a container.\n   *\n   * This string is passed directly to the Docker daemon.\n   * Images in the Docker Hub registry are available by default.\n   * Other repositories are specified with either repository-url/image:tag or repository-url/image@digest.\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The environment variables to pass to the container.\n   *\n   * Some Datadog specific environment variables are not allowed to be set,\n   * because they are set automatically or computed from other attributes.\n   * These are:\n   * * DD_ENV: Set same as prop stage\n   * * DD_SERVICE: Set same as prop serviceName\n   * * DD_VERSION: Set same as prop version\n   * * DD_TAGS: Set same as DatadogIntegrationProps#additionalTags\n   * * DD_LOGS_INJECTION: true\n   * Other DD_-prefixed vaiable may be added to this list.\n   *\n   * Other Environment variables set by default are overwritten if passed.\n   * These are:\n   * * DD_SERVICE_MAPPING: database:fargate-web-app-aurora,java-aws-sdk:fargate-web-app-aws-sdk,kafka:fargate-web-app-kafka,mysql:fargate-web-app-aurora\n   * * DD_TRACE_SAMPLE_RATE: 1.0\n   *\n   * @default - No environment variables.\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * The secret environment variables to pass to the container.\n   *\n   * @default - No secret environment variables.\n   */\n  readonly secrets?: { [key: string]: ecs.Secret };\n\n  /**\n   * The health check command and associated configuration parameters for the container.\n   *\n   * @default - Health check configuration from container.\n   */\n  readonly healthCheck?: ecs.HealthCheck;\n}\n\nexport interface FargateTaskDefinitionProps {\n  /**\n   * The number of cpu units used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   *\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   *\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   *\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   *\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default 512\n   */\n  readonly cpu: number;\n\n  /**\n   * The amount (in MiB) of memory used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values, which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   *\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   *\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   *\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   *\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default 1024\n   */\n  readonly memoryLimitMiB: number;\n\n  /**\n   * Desired count of running tasks\n   *\n   * @default - When creating the service, default is 1; when updating the service, default uses\n   * the current task number.\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * The operating system that your task definitions are running on.\n   *\n   * @default - Using ecs.OperatingSystemFamily.LINUX and ecs.CpuArchitecture.X86_64\n   */\n  readonly runtimePlatform?: ecs.RuntimePlatform;\n}\n\nexport interface ListenerRule {\n  readonly priority: number;\n\n  readonly conditions: elbv2.ListenerCondition[];\n}\n\nexport interface LoadBalancerOptions {\n  /**\n   * Listener for an Application Load Balancer\n   */\n  readonly listener: elbv2.IApplicationListener;\n\n  /**\n   * One or more path patterns to compare against the request URL.\n   * The maximum size of each string is 128 characters.\n   * The comparison is case sensitive.\n   * The following wildcard characters are supported: * (matches 0 or more characters) and ? (matches exactly 1 character).\n   *\n   * Update requires: No interruption\n   */\n  readonly listenerRules: ListenerRule[];\n\n  /**\n   *  Health check options.\n   */\n  readonly healthCheck: elbv2.HealthCheck;\n\n  /**\n   *  Health check grace period.\n   */\n  readonly healthCheckGracePeriod: cdk.Duration;\n\n  /**\n   * The time period during which the load balancer sends a newly registered target a linearly increasing share of the traffic to the target group.\n\n   *The range is 30-900 seconds (15 minutes).\n\n   * @default undefined\n  */\n  readonly slowStart?: cdk.Duration;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n\n   * The range is 0-3600 seconds.\n\n   * @default 5\n  */\n  readonly deregistrationDelay?: cdk.Duration;\n}\n\nexport interface DatadogIntegrationProps {\n  /**\n   * The minimum number of CPU units to reserve for the container.\n   *\n   * @default - 64\n   */\n  readonly cpu?: number;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   *\n   * If your container attempts to exceed the allocated memory, the container\n   * is terminated.\n   *\n   * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.\n   *\n   * @default - 128\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * The logging mode for the service.\n   *\n   * @default - Using the Datadog log forwarder lambda provided by the datadog-integration.\n   */\n  readonly loggingModeForService?: DataDogLoggingMode;\n\n  /**\n   * The logging mode for the Datadog agent sidecar.\n   *\n   * @default - No logs in Datadog, Cloudwatch only.\n   */\n  readonly loggingModeForDatadogAgent?: DataDogLoggingMode;\n\n  /**\n   * GET endpoints to ignore in Datadog's APM overview. This is useful to filter out all health check calls.\n\n    * @default - No endpoints are ignored.\n    */\n  readonly apmGetEndpointsToIgnore?: string[];\n\n  /**\n   * Configure if the Datadog agent sidecar is marked as essential.\n   *\n   * @default - true.\n   */\n  readonly datadogSidecarEssential?: boolean;\n\n  /**\n   * Configures the docker image tag for datadog sidecar\n   * @default - 'latest'\n   */\n  readonly datadogSidecarTag?: string;\n\n  /**\n   * Configure additional tags, which are appended to the defaults,\n   * When you define custom tags we would be glad if you contact us.\n   * We would like to learn about your use cases.\n   *\n   * Default tags are not allowed to be overridden!\n   *\n   * Defaults are:\n   * * env: Set to RioFargateServiceProps#stage prop\n   * * service: Set to RioFargateServiceProps#serviceName prop\n   * * version: Set to RioFargateServiceProps#version prop\n   * * account_id:${accountID}\n   * * account_name:${accountName}\n   * * region:${AWSRegion}\n   * * team:${teamName from ssm param /config/team/name}\n   * * team_identifier:${teamIdentifier from ssm param /config/team/identifier}\n   */\n  readonly additionalTags?: { [key: string]: string };\n}\n\nexport enum DataDogLoggingMode {\n  /**\n   * Forward logs directly to Datadog using AWS FireLens as log router,\n   * see https://docs.datadoghq.com/integrations/ecs_fargate/?tab=fluentbitandfirelens#log-collection.\n   */\n  AWS_FIRE_LENS,\n\n  /**\n   * Store logs in AWS Cloudwatch and use the Datadog log forwarder lambda to forward the logs to Datadog,\n   * see https://docs.datadoghq.com/integrations/ecs_fargate/?tab=logdriver#log-collection.\n   */\n  FORWARDER_LAMBDA,\n\n  /**\n   * Only log to AWS Cloudwatch without forwarding the logs to Datadog.\n   */\n  NONE,\n}\n\nexport class RioFargateService extends constructs.Construct implements ec2.IConnectable {\n\n  private static readonly DD_ENV_DENY_LIST = [\n    'DD_ENV',\n    'DD_TAGS',\n    'DD_SERVICE',\n    'DD_VERSION',\n    'DD_LOGS_INJECTION',\n  ];\n\n  private static readonly DD_TAG_DENY_LIST = [\n    'env',\n    'service',\n    'version',\n    'account_id',\n    'account_name',\n    'region',\n    'team',\n    'team_identifier',\n  ];\n\n  private readonly DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE: string[] = [];\n  private readonly DEFAULT_DATADOG_SIDECAR_CPU = 64;\n  private readonly DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB = 128;\n  private readonly DEFAULT_DATADOG_SIDECAR_ESSENTIAL = true;\n  private readonly DEFAULT_LOGGING_MODE_FOR_SERVICE = DataDogLoggingMode.FORWARDER_LAMBDA;\n  private readonly DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR = DataDogLoggingMode.NONE;\n  private readonly DEFAULT_DEREGISTRATION_DELAY = cdk.Duration.seconds(5);\n  private readonly DEFAULT_SLOW_START = undefined;\n  private readonly DEFAULT_DATADOG_SIDECAR_TAG = 'latest';\n\n  private readonly LOG_ROUTER_CPU = 64;\n  private readonly LOG_ROUTER_MEMORY_LIMIT_MIB = 64;\n\n  readonly serviceContainerDefinition: ecs.ContainerDefinition;\n  readonly datadogSideCarContainerDefinition: ecs.ContainerDefinition;\n  readonly logRouterContainerDefinition?: ecs.ContainerDefinition;\n  readonly taskDefinition: ecs.FargateTaskDefinition;\n\n  readonly connections: ec2.Connections;\n  readonly service: ecs.FargateService;\n  readonly targetGroup: elbv2.ApplicationTargetGroup|undefined;\n\n  constructor(scope: constructs.Construct, id: string, props: RioFargateServiceProps) {\n    super(scope, id);\n\n    const {\n      loadBalancerOptions,\n      vpc,\n      cluster,\n      fargateOptions,\n      datadogOptions,\n      serviceName,\n      containerDefinitionOption,\n      stage,\n      version,\n      frameworks,\n    } = props;\n\n    this.node.addValidation(new DenyListedKeyValidator(\n      RioFargateService.DD_ENV_DENY_LIST,\n      props.containerDefinitionOption.environment,\n      it => `Environment ${it} is not allowed to be set. This value will be inferred from the account or other properties.`,\n    ));\n    this.node.addValidation(new DenyListedKeyValidator(\n      RioFargateService.DD_TAG_DENY_LIST,\n      props.datadogOptions?.additionalTags,\n      it => `Tag ${it} is not allowed to be set. This value will be inferred from the account or other properties.`,\n    ));\n\n    this.node.addValidation(new ClusterVpcValidator(\n      props.vpc,\n      props.cluster,\n    ));\n\n    const fargateCluster = cluster ?? new ecs.Cluster(this, 'Cluster', {\n      vpc: vpc,\n    });\n    this.taskDefinition = new ecs.FargateTaskDefinition(this, 'TaskDefinition', {\n      cpu: fargateOptions.cpu,\n      memoryLimitMiB: fargateOptions.memoryLimitMiB,\n      runtimePlatform: {\n        cpuArchitecture: fargateOptions.runtimePlatform?.cpuArchitecture ?? ecs.CpuArchitecture.X86_64,\n        operatingSystemFamily: fargateOptions.runtimePlatform?.operatingSystemFamily ?? ecs.OperatingSystemFamily.LINUX,\n      },\n    });\n    const accountName = ssm.StringParameter.fromStringParameterName(this, 'AccountName', '/config/account/name').stringValue;\n    const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;\n    const teamIdentifier = ssm.StringParameter.fromStringParameterName(this, 'TeamIdentifier', '/config/team/identifier').stringValue;\n\n    const datadogSite = ssm.StringParameter.fromStringParameterName(this, 'DatadogSite', '/rio/config/datadog-integration/site').stringValue;\n    const datadogApiKeyParameter = ssm.StringParameter.fromStringParameterName(this, 'DatadogApiKey', '/rio/config/datadog-integration/api-key');\n\n    const datadogSidecarCpu = datadogOptions?.cpu ?? this.DEFAULT_DATADOG_SIDECAR_CPU;\n    const datadogSidecarMemoryMiB = datadogOptions?.memoryLimitMiB ?? this.DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB;\n    const datadogSidecarEssential = datadogOptions?.datadogSidecarEssential ?? this.DEFAULT_DATADOG_SIDECAR_ESSENTIAL;\n\n    const loggingModeForService = datadogOptions?.loggingModeForService ?? this.DEFAULT_LOGGING_MODE_FOR_SERVICE;\n    const loggingModeForDatadogAgent = datadogOptions?.loggingModeForDatadogAgent ?? this.DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR;\n    const fireLensLogRouterRequired =\n      loggingModeForService === DataDogLoggingMode.AWS_FIRE_LENS ||\n      loggingModeForDatadogAgent === DataDogLoggingMode.AWS_FIRE_LENS;\n\n    let serviceContainerCpuUnits;\n    let serviceContainerMemoryLimitMiB;\n\n    if (fireLensLogRouterRequired) {\n      serviceContainerCpuUnits = fargateOptions.cpu - datadogSidecarCpu - this.LOG_ROUTER_CPU;\n      serviceContainerMemoryLimitMiB = fargateOptions.memoryLimitMiB - datadogSidecarMemoryMiB - this.LOG_ROUTER_MEMORY_LIMIT_MIB;\n    } else {\n      serviceContainerCpuUnits = fargateOptions.cpu - datadogSidecarCpu;\n      serviceContainerMemoryLimitMiB = fargateOptions.memoryLimitMiB - datadogSidecarMemoryMiB;\n    }\n    this.serviceContainerDefinition = this.taskDefinition.addContainer(serviceName, {\n      image: containerDefinitionOption.image,\n      cpu: serviceContainerCpuUnits,\n      memoryLimitMiB: serviceContainerMemoryLimitMiB,\n      environment: {\n        ...datadog.getFargateContainerEnvironmentVariables({\n          scope: this,\n          stage,\n          serviceName,\n          version,\n          accountName,\n          teamName,\n          teamIdentifier,\n          additionalTags: datadogOptions?.additionalTags,\n        }),\n        ...containerDefinitionOption.environment,\n      },\n      dockerLabels: {\n        ...datadog.getFargateDockerLabels({ stage, serviceName, version }),\n      },\n      healthCheck: containerDefinitionOption.healthCheck,\n      logging: datadog.setupLogging({\n        scope,\n        accountName,\n        teamName,\n        teamIdentifier,\n        stage,\n        serviceName,\n        version,\n        datadogApiKeyParameter,\n        datadogLoggingMode: loggingModeForService,\n        datadogSite,\n        containerType: 'service',\n        additionalTags: datadogOptions?.additionalTags,\n      }),\n      secrets: containerDefinitionOption.secrets,\n    });\n\n    if (frameworks?.includes(Framework.SPRING)) {\n      Spring.allowParameterStoreAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);\n      Spring.allowSecretsManagerAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);\n    }\n\n    if (fireLensLogRouterRequired) {\n      this.logRouterContainerDefinition = datadog.addFireLensLogRouter({\n        taskDefinition: this.taskDefinition,\n        cpu: this.LOG_ROUTER_CPU,\n        memoryLimitMiB: this.LOG_ROUTER_MEMORY_LIMIT_MIB,\n      });\n    }\n    this.datadogSideCarContainerDefinition = datadog.addDatadogSidecar({\n      scope,\n      taskDefinition: this.taskDefinition,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKeyParameter,\n      datadogSite,\n      datadogLoggingMode: loggingModeForDatadogAgent,\n      apmGetResourcesToIgnore: datadogOptions?.apmGetEndpointsToIgnore ?? this.DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE,\n      cpu: datadogSidecarCpu,\n      memoryLimitMiB: datadogSidecarMemoryMiB,\n      essential: datadogSidecarEssential,\n      containerTag: props.datadogOptions?.datadogSidecarTag ?? this.DEFAULT_DATADOG_SIDECAR_TAG, // These are positional parameters,\n      additionalTags: datadogOptions?.additionalTags,\n    });\n\n    datadog.ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(this);\n\n    const loadBalancerOptionsForFargateService = loadBalancerOptions\n      ? { healthCheckGracePeriod: loadBalancerOptions.healthCheckGracePeriod }\n      : {};\n\n    this.service = new ecs.FargateService(this, 'Service', {\n      cluster: fargateCluster,\n      taskDefinition: this.taskDefinition,\n      circuitBreaker: { rollback: true },\n      maxHealthyPercent: 200,\n      minHealthyPercent: 100,\n      desiredCount: fargateOptions?.desiredCount,\n      ...loadBalancerOptionsForFargateService,\n      propagateTags: ecs.PropagatedTagSource.SERVICE,\n    });\n\n    this.connections = this.service.connections;\n\n    if (loadBalancerOptions != null) {\n      const containerPort = 443;\n      this.serviceContainerDefinition.addPortMappings({\n        containerPort: containerPort,\n        protocol: ecs.Protocol.TCP,\n      });\n      this.targetGroup = new elbv2.ApplicationTargetGroup(this, 'TargetGroup', {\n        vpc: vpc,\n        port: containerPort,\n        protocol: elbv2.ApplicationProtocol.HTTPS,\n        targetType: elbv2.TargetType.IP,\n        targets: [this.service],\n        healthCheck: loadBalancerOptions.healthCheck,\n        slowStart: props.loadBalancerOptions?.slowStart ?? this.DEFAULT_SLOW_START,\n        deregistrationDelay: props.loadBalancerOptions?.deregistrationDelay ?? this.DEFAULT_DEREGISTRATION_DELAY,\n      });\n\n      loadBalancerOptions.listenerRules.forEach(({ priority, conditions }) => {\n        loadBalancerOptions.listener.addTargetGroups(`Priority${priority}ListenerRule`, {\n          targetGroups: [this.targetGroup as elbv2.ApplicationTargetGroup],\n          priority: priority,\n          conditions: conditions,\n        });\n      });\n    }\n  }\n}\n\nclass DenyListedKeyValidator implements constructs.IValidation {\n  constructor(\n    private readonly denyList: string[],\n    private readonly dict: { [key: string]: any } | undefined,\n    private readonly messageGenerator: (keyName: string) => string,\n  ) {}\n\n  validate(): string[] {\n    if (!this.dict) {\n      return [];\n    }\n\n    const result: string[] = [];\n    this.denyList.forEach(keyName => {\n      if (this.dict && keyName in this.dict) {\n        result.push(this.messageGenerator(keyName));\n      }\n    });\n\n    return result;\n  }\n}\n\nclass ClusterVpcValidator implements constructs.IValidation {\n  constructor(\n    private readonly vpc: ec2.IVpc,\n    private readonly cluster?: ecs.ICluster,\n  ) {}\n\n  validate(): string[] {\n    const result = [];\n    if (this.cluster && this.cluster.vpc.vpcId !== this.vpc.vpcId) {\n      result.push(`The VPC provided in the cluster (${this.cluster.vpc.node.id}) MUST match the VPC provided as argument (${this.vpc.node.id}).`);\n    }\n    return result;\n  }\n}\n"]}
248
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rio-fargate-service.js","sourceRoot":"","sources":["../../src/fargate/rio-fargate-service.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport * as ec2 from 'aws-cdk-lib/aws-ec2';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as constructs from 'constructs';\nimport * as datadog from './datadog';\nimport { Spring } from './spring';\n\n/**\n * Fargate Task Definition Properties.\n */\nexport interface RioFargateServiceProps {\n  /**\n   * The stage of the service, e.g. 'prod'.\n   */\n  readonly stage: string;\n\n  /**\n   * The Name of the service.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The version of the service, e.g. the git hash of the corresponding commit.\n   */\n  readonly version: string;\n\n  /**\n   * The frameworks in uses.\n   *\n   * @default - No frameworks.\n   */\n  readonly frameworks?: Framework[];\n\n  /**\n   * The VPC of the service's ecs.Cluster if no cluster is explicitly passed as prop.\n   */\n  readonly vpc: ec2.IVpc;\n\n  /**\n   * The Fargate cluster to run the service in.\n   * If not null, the cluster.vpc MUST match the vpc provided as direct argument.\n   *\n   * @default - Create a new Fargate cluster with default properties\n   */\n  readonly cluster?: ecs.ICluster;\n\n  /**\n   * Container definition options like image, cpu, memory.\n   */\n  readonly containerDefinitionOption: ContainerDefinitionOptions;\n\n  /**\n   * Fargate Task Definition Properties.\n   */\n  readonly fargateOptions: FargateTaskDefinitionProps;\n\n  /**\n   * Loadbalancer options.\n   */\n  readonly loadBalancerOptions?: LoadBalancerOptions;\n\n  /**\n   * Datadog integration properties\n   */\n  readonly datadogOptions?: DatadogIntegrationProps;\n}\n\nexport enum Framework {\n  /**\n   * Spring Framework, Spring Boot, and Spring Cloud AWS.\n   */\n  SPRING,\n}\n\nexport interface ContainerDefinitionOptions {\n  /**\n   * The image used to start a container.\n   *\n   * This string is passed directly to the Docker daemon.\n   * Images in the Docker Hub registry are available by default.\n   * Other repositories are specified with either repository-url/image:tag or repository-url/image@digest.\n   */\n  readonly image: ecs.ContainerImage;\n\n  /**\n   * The environment variables to pass to the container.\n   *\n   * Some Datadog specific environment variables are not allowed to be set,\n   * because they are set automatically or computed from other attributes.\n   * These are:\n   * * DD_ENV: Set same as prop stage\n   * * DD_SERVICE: Set same as prop serviceName\n   * * DD_VERSION: Set same as prop version\n   * * DD_TAGS: Set same as DatadogIntegrationProps#additionalTags\n   * * DD_LOGS_INJECTION: true\n   * Other DD_-prefixed vaiable may be added to this list.\n   *\n   * Other Environment variables set by default are overwritten if passed.\n   * These are:\n   * * DD_SERVICE_MAPPING: database:fargate-web-app-aurora,java-aws-sdk:fargate-web-app-aws-sdk,kafka:fargate-web-app-kafka,mysql:fargate-web-app-aurora\n   * * DD_TRACE_SAMPLE_RATE: 1.0\n   *\n   * @default - No environment variables.\n   */\n  readonly environment?: { [key: string]: string };\n\n  /**\n   * The secret environment variables to pass to the container.\n   *\n   * @default - No secret environment variables.\n   */\n  readonly secrets?: { [key: string]: ecs.Secret };\n\n  /**\n   * The health check command and associated configuration parameters for the container.\n   *\n   * @default - Health check configuration from container.\n   */\n  readonly healthCheck?: ecs.HealthCheck;\n}\n\nexport interface FargateTaskDefinitionProps {\n  /**\n   * The number of cpu units used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values,\n   * which determines your range of valid values for the memory parameter:\n   *\n   * 256 (.25 vCPU) - Available memory values: 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB)\n   *\n   * 512 (.5 vCPU) - Available memory values: 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB)\n   *\n   * 1024 (1 vCPU) - Available memory values: 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB)\n   *\n   * 2048 (2 vCPU) - Available memory values: Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB)\n   *\n   * 4096 (4 vCPU) - Available memory values: Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB)\n   *\n   * @default 512\n   */\n  readonly cpu: number;\n\n  /**\n   * The amount (in MiB) of memory used by the task. For tasks using the Fargate launch type,\n   * this field is required and you must use one of the following values, which determines your range of valid values for the cpu parameter:\n   *\n   * 512 (0.5 GB), 1024 (1 GB), 2048 (2 GB) - Available cpu values: 256 (.25 vCPU)\n   *\n   * 1024 (1 GB), 2048 (2 GB), 3072 (3 GB), 4096 (4 GB) - Available cpu values: 512 (.5 vCPU)\n   *\n   * 2048 (2 GB), 3072 (3 GB), 4096 (4 GB), 5120 (5 GB), 6144 (6 GB), 7168 (7 GB), 8192 (8 GB) - Available cpu values: 1024 (1 vCPU)\n   *\n   * Between 4096 (4 GB) and 16384 (16 GB) in increments of 1024 (1 GB) - Available cpu values: 2048 (2 vCPU)\n   *\n   * Between 8192 (8 GB) and 30720 (30 GB) in increments of 1024 (1 GB) - Available cpu values: 4096 (4 vCPU)\n   *\n   * @default 1024\n   */\n  readonly memoryLimitMiB: number;\n\n  /**\n   * Desired count of running tasks\n   *\n   * @default - When creating the service, default is 1; when updating the service, default uses\n   * the current task number.\n   */\n  readonly desiredCount?: number;\n\n  /**\n   * The operating system that your task definitions are running on.\n   *\n   * @default - Using ecs.OperatingSystemFamily.LINUX and ecs.CpuArchitecture.X86_64\n   */\n  readonly runtimePlatform?: ecs.RuntimePlatform;\n}\n\nexport interface ListenerRule {\n  readonly priority: number;\n\n  readonly conditions: elbv2.ListenerCondition[];\n}\n\nexport interface LoadBalancerOptions {\n  /**\n   * Listener for an Application Load Balancer\n   */\n  readonly listener: elbv2.IApplicationListener;\n\n  /**\n   * One or more path patterns to compare against the request URL.\n   * The maximum size of each string is 128 characters.\n   * The comparison is case sensitive.\n   * The following wildcard characters are supported: * (matches 0 or more characters) and ? (matches exactly 1 character).\n   *\n   * Update requires: No interruption\n   */\n  readonly listenerRules: ListenerRule[];\n\n  /**\n   *  Health check options.\n   */\n  readonly healthCheck: elbv2.HealthCheck;\n\n  /**\n   *  Health check grace period.\n   */\n  readonly healthCheckGracePeriod: cdk.Duration;\n\n  /**\n   * The time period during which the load balancer sends a newly registered target a linearly increasing share of the traffic to the target group.\n\n   *The range is 30-900 seconds (15 minutes).\n\n   * @default undefined\n  */\n  readonly slowStart?: cdk.Duration;\n\n  /**\n   * The amount of time for Elastic Load Balancing to wait before deregistering a target.\n\n   * The range is 0-3600 seconds.\n\n   * @default 5\n  */\n  readonly deregistrationDelay?: cdk.Duration;\n}\n\nexport interface DatadogIntegrationProps {\n  /**\n   * The minimum number of CPU units to reserve for the container.\n   *\n   * @default - 64\n   */\n  readonly cpu?: number;\n\n  /**\n   * The amount (in MiB) of memory to present to the container.\n   *\n   * If your container attempts to exceed the allocated memory, the container\n   * is terminated.\n   *\n   * At least one of memoryLimitMiB and memoryReservationMiB is required for non-Fargate services.\n   *\n   * @default - 128\n   */\n  readonly memoryLimitMiB?: number;\n\n  /**\n   * The logging mode for the service.\n   *\n   * @default - Using the Datadog log forwarder lambda provided by the datadog-integration.\n   */\n  readonly loggingModeForService?: DataDogLoggingMode;\n\n  /**\n   * The logging mode for the Datadog agent sidecar.\n   *\n   * @default - No logs in Datadog, Cloudwatch only.\n   */\n  readonly loggingModeForDatadogAgent?: DataDogLoggingMode;\n\n  /**\n   * GET endpoints to ignore in Datadog's APM overview. This is useful to filter out all health check calls.\n\n    * @default - No endpoints are ignored.\n    */\n  readonly apmGetEndpointsToIgnore?: string[];\n\n  /**\n   * Configure if the Datadog agent sidecar is marked as essential.\n   *\n   * @default - true.\n   */\n  readonly datadogSidecarEssential?: boolean;\n\n  /**\n   * Configures the docker image tag for datadog sidecar\n   * @default - 'latest'\n   */\n  readonly datadogSidecarTag?: string;\n\n  /**\n   * Configure additional tags, which are appended to the defaults,\n   * When you define custom tags we would be glad if you contact us.\n   * We would like to learn about your use cases.\n   *\n   * Default tags are not allowed to be overridden!\n   *\n   * Defaults are:\n   * * env: Set to RioFargateServiceProps#stage prop\n   * * service: Set to RioFargateServiceProps#serviceName prop\n   * * version: Set to RioFargateServiceProps#version prop\n   * * account_id:${accountID}\n   * * account_name:${accountName}\n   * * region:${AWSRegion}\n   * * team:${teamName from ssm param /config/team/name}\n   * * team_identifier:${teamIdentifier from ssm param /config/team/identifier}\n   */\n  readonly additionalTags?: { [key: string]: string };\n}\n\nexport enum DataDogLoggingMode {\n  /**\n   * Forward logs directly to Datadog using AWS FireLens as log router,\n   * see https://docs.datadoghq.com/integrations/ecs_fargate/?tab=fluentbitandfirelens#log-collection.\n   */\n  AWS_FIRE_LENS,\n\n  /**\n   * Store logs in AWS Cloudwatch and use the Datadog log forwarder lambda to forward the logs to Datadog,\n   * see https://docs.datadoghq.com/integrations/ecs_fargate/?tab=logdriver#log-collection.\n   */\n  FORWARDER_LAMBDA,\n\n  /**\n   * Only log to AWS Cloudwatch without forwarding the logs to Datadog.\n   */\n  NONE,\n}\n\nexport class RioFargateService extends constructs.Construct implements ec2.IConnectable {\n\n  private static readonly DD_ENV_DENY_LIST = [\n    'DD_ENV',\n    'DD_TAGS',\n    'DD_SERVICE',\n    'DD_VERSION',\n    'DD_LOGS_INJECTION',\n  ];\n\n  private static readonly DD_TAG_DENY_LIST = [\n    'env',\n    'service',\n    'version',\n    'account_id',\n    'account_name',\n    'region',\n    'team',\n    'team_identifier',\n  ];\n\n  private readonly DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE: string[] = [];\n  private readonly DEFAULT_DATADOG_SIDECAR_CPU = 64;\n  private readonly DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB = 128;\n  private readonly DEFAULT_DATADOG_SIDECAR_ESSENTIAL = true;\n  private readonly DEFAULT_LOGGING_MODE_FOR_SERVICE = DataDogLoggingMode.FORWARDER_LAMBDA;\n  private readonly DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR = DataDogLoggingMode.NONE;\n  private readonly DEFAULT_DEREGISTRATION_DELAY = cdk.Duration.seconds(5);\n  private readonly DEFAULT_SLOW_START = undefined;\n  private readonly DEFAULT_DATADOG_SIDECAR_TAG = 'latest';\n\n  private readonly LOG_ROUTER_CPU = 64;\n  private readonly LOG_ROUTER_MEMORY_LIMIT_MIB = 64;\n\n  readonly serviceContainerDefinition: ecs.ContainerDefinition;\n  readonly datadogSideCarContainerDefinition: ecs.ContainerDefinition;\n  readonly logRouterContainerDefinition?: ecs.ContainerDefinition;\n  readonly taskDefinition: ecs.FargateTaskDefinition;\n\n  readonly connections: ec2.Connections;\n  readonly service: ecs.FargateService;\n  readonly targetGroup: elbv2.ApplicationTargetGroup|undefined;\n\n  constructor(scope: constructs.Construct, id: string, props: RioFargateServiceProps) {\n    super(scope, id);\n\n    const {\n      loadBalancerOptions,\n      vpc,\n      cluster,\n      fargateOptions,\n      datadogOptions,\n      serviceName,\n      containerDefinitionOption,\n      stage,\n      version,\n      frameworks,\n    } = props;\n\n    this.node.addValidation(new DenyListedKeyValidator(\n      RioFargateService.DD_ENV_DENY_LIST,\n      props.containerDefinitionOption.environment,\n      it => `Environment ${it} is not allowed to be set. This value will be inferred from the account or other properties.`,\n    ));\n    this.node.addValidation(new DenyListedKeyValidator(\n      RioFargateService.DD_TAG_DENY_LIST,\n      props.datadogOptions?.additionalTags,\n      it => `Tag ${it} is not allowed to be set. This value will be inferred from the account or other properties.`,\n    ));\n\n    this.node.addValidation(new ClusterVpcValidator(\n      props.vpc,\n      props.cluster,\n    ));\n\n    const fargateCluster = cluster ?? new ecs.Cluster(this, 'Cluster', {\n      vpc: vpc,\n    });\n    this.taskDefinition = new ecs.FargateTaskDefinition(this, 'TaskDefinition', {\n      cpu: fargateOptions.cpu,\n      memoryLimitMiB: fargateOptions.memoryLimitMiB,\n      runtimePlatform: {\n        cpuArchitecture: fargateOptions.runtimePlatform?.cpuArchitecture ?? ecs.CpuArchitecture.X86_64,\n        operatingSystemFamily: fargateOptions.runtimePlatform?.operatingSystemFamily ?? ecs.OperatingSystemFamily.LINUX,\n      },\n    });\n    const accountName = ssm.StringParameter.fromStringParameterName(this, 'AccountName', '/config/account/name').stringValue;\n    const teamName = ssm.StringParameter.fromStringParameterName(this, 'TeamName', '/config/team/name').stringValue;\n    const teamIdentifier = ssm.StringParameter.fromStringParameterName(this, 'TeamIdentifier', '/config/team/identifier').stringValue;\n\n    const datadogSite = ssm.StringParameter.fromStringParameterName(this, 'DatadogSite', '/rio/config/datadog-integration/site').stringValue;\n    const datadogApiKeyParameter = ssm.StringParameter.fromStringParameterName(this, 'DatadogApiKey', '/rio/config/datadog-integration/api-key');\n\n    const datadogSidecarCpu = datadogOptions?.cpu ?? this.DEFAULT_DATADOG_SIDECAR_CPU;\n    const datadogSidecarMemoryMiB = datadogOptions?.memoryLimitMiB ?? this.DEFAULT_DATADOG_SIDECAR_MEMORY_LIMIT_MIB;\n    const datadogSidecarEssential = datadogOptions?.datadogSidecarEssential ?? this.DEFAULT_DATADOG_SIDECAR_ESSENTIAL;\n\n    const loggingModeForService = datadogOptions?.loggingModeForService ?? this.DEFAULT_LOGGING_MODE_FOR_SERVICE;\n    const loggingModeForDatadogAgent = datadogOptions?.loggingModeForDatadogAgent ?? this.DEFAULT_LOGGING_MODE_FOR_DATADOG_SIDECAR;\n    const fireLensLogRouterRequired =\n      loggingModeForService === DataDogLoggingMode.AWS_FIRE_LENS ||\n      loggingModeForDatadogAgent === DataDogLoggingMode.AWS_FIRE_LENS;\n\n    let serviceContainerCpuUnits;\n    let serviceContainerMemoryLimitMiB;\n\n    if (fireLensLogRouterRequired) {\n      serviceContainerCpuUnits = fargateOptions.cpu - datadogSidecarCpu - this.LOG_ROUTER_CPU;\n      serviceContainerMemoryLimitMiB = fargateOptions.memoryLimitMiB - datadogSidecarMemoryMiB - this.LOG_ROUTER_MEMORY_LIMIT_MIB;\n    } else {\n      serviceContainerCpuUnits = fargateOptions.cpu - datadogSidecarCpu;\n      serviceContainerMemoryLimitMiB = fargateOptions.memoryLimitMiB - datadogSidecarMemoryMiB;\n    }\n    this.serviceContainerDefinition = this.taskDefinition.addContainer(serviceName, {\n      image: containerDefinitionOption.image,\n      cpu: serviceContainerCpuUnits,\n      memoryLimitMiB: serviceContainerMemoryLimitMiB,\n      environment: {\n        ...datadog.getFargateContainerEnvironmentVariables({\n          scope: this,\n          stage,\n          serviceName,\n          version,\n          accountName,\n          teamName,\n          teamIdentifier,\n          additionalTags: datadogOptions?.additionalTags,\n        }),\n        ...containerDefinitionOption.environment,\n      },\n      dockerLabels: {\n        ...datadog.getFargateDockerLabels({ stage, serviceName, version }),\n      },\n      healthCheck: containerDefinitionOption.healthCheck,\n      logging: datadog.setupLogging({\n        scope,\n        accountName,\n        teamName,\n        teamIdentifier,\n        stage,\n        serviceName,\n        version,\n        datadogApiKeyParameter,\n        datadogLoggingMode: loggingModeForService,\n        datadogSite,\n        containerType: 'service',\n        additionalTags: datadogOptions?.additionalTags,\n      }),\n      secrets: containerDefinitionOption.secrets,\n    });\n\n    if (frameworks?.includes(Framework.SPRING)) {\n      Spring.allowParameterStoreAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);\n      Spring.allowSecretsManagerAccessForSpringCloudAws(this, serviceName, this.taskDefinition.taskRole);\n    }\n\n    if (fireLensLogRouterRequired) {\n      this.logRouterContainerDefinition = datadog.addFireLensLogRouter({\n        taskDefinition: this.taskDefinition,\n        cpu: this.LOG_ROUTER_CPU,\n        memoryLimitMiB: this.LOG_ROUTER_MEMORY_LIMIT_MIB,\n      });\n    }\n    this.datadogSideCarContainerDefinition = datadog.addDatadogSidecar({\n      scope,\n      taskDefinition: this.taskDefinition,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKeyParameter,\n      datadogSite,\n      datadogLoggingMode: loggingModeForDatadogAgent,\n      apmGetResourcesToIgnore: datadogOptions?.apmGetEndpointsToIgnore ?? this.DEFAULT_APM_GET_ENDPOINTS_TO_IGNORE,\n      cpu: datadogSidecarCpu,\n      memoryLimitMiB: datadogSidecarMemoryMiB,\n      essential: datadogSidecarEssential,\n      containerTag: props.datadogOptions?.datadogSidecarTag ?? this.DEFAULT_DATADOG_SIDECAR_TAG, // These are positional parameters,\n      additionalTags: datadogOptions?.additionalTags,\n    });\n\n    datadog.ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(this);\n\n    const loadBalancerOptionsForFargateService = loadBalancerOptions\n      ? { healthCheckGracePeriod: loadBalancerOptions.healthCheckGracePeriod }\n      : {};\n\n    this.service = new ecs.FargateService(this, 'Service', {\n      cluster: fargateCluster,\n      taskDefinition: this.taskDefinition,\n      circuitBreaker: { rollback: true },\n      maxHealthyPercent: 200,\n      minHealthyPercent: 100,\n      desiredCount: fargateOptions?.desiredCount,\n      ...loadBalancerOptionsForFargateService,\n      propagateTags: ecs.PropagatedTagSource.SERVICE,\n    });\n\n    this.connections = this.service.connections;\n\n    if (loadBalancerOptions != null) {\n      const containerPort = 443;\n      this.serviceContainerDefinition.addPortMappings({\n        containerPort: containerPort,\n        protocol: ecs.Protocol.TCP,\n      });\n      this.targetGroup = new elbv2.ApplicationTargetGroup(this, 'TargetGroup', {\n        vpc: vpc,\n        port: containerPort,\n        protocol: elbv2.ApplicationProtocol.HTTPS,\n        targetType: elbv2.TargetType.IP,\n        targets: [this.service],\n        healthCheck: loadBalancerOptions.healthCheck,\n        slowStart: props.loadBalancerOptions?.slowStart ?? this.DEFAULT_SLOW_START,\n        deregistrationDelay: props.loadBalancerOptions?.deregistrationDelay ?? this.DEFAULT_DEREGISTRATION_DELAY,\n      });\n\n      loadBalancerOptions.listenerRules.forEach(({ priority, conditions }) => {\n        loadBalancerOptions.listener.addTargetGroups(`Priority${priority}ListenerRule`, {\n          targetGroups: [this.targetGroup as elbv2.ApplicationTargetGroup],\n          priority: priority,\n          conditions: conditions,\n        });\n      });\n    }\n  }\n}\n\nclass DenyListedKeyValidator implements constructs.IValidation {\n  constructor(\n    private readonly denyList: string[],\n    private readonly dict: { [key: string]: any } | undefined,\n    private readonly messageGenerator: (keyName: string) => string,\n  ) {}\n\n  validate(): string[] {\n    if (!this.dict) {\n      return [];\n    }\n\n    const result: string[] = [];\n    this.denyList.forEach(keyName => {\n      if (this.dict && keyName in this.dict) {\n        result.push(this.messageGenerator(keyName));\n      }\n    });\n\n    return result;\n  }\n}\n\nclass ClusterVpcValidator implements constructs.IValidation {\n  constructor(\n    private readonly vpc: ec2.IVpc,\n    private readonly cluster?: ecs.ICluster,\n  ) {}\n\n  validate(): string[] {\n    const result = [];\n    if (this.cluster && this.cluster.vpc.vpcId !== this.vpc.vpcId) {\n      result.push(`The VPC provided in the cluster (${this.cluster.vpc.node.id}) MUST match the VPC provided as argument (${this.vpc.node.id}).`);\n    }\n    return result;\n  }\n}\n"]}
@@ -80,8 +80,7 @@ class KafkaEventSpecSource {
80
80
  return parsedYamlSpec;
81
81
  }
82
82
  static isKafkaEventSpecification(parsedYamlSpec) {
83
- var _c;
84
- return typeof parsedYamlSpec === 'object' && ((_c = parsedYamlSpec === null || parsedYamlSpec === void 0 ? void 0 : parsedYamlSpec.info) === null || _c === void 0 ? void 0 : _c['x-event']);
83
+ return typeof parsedYamlSpec === 'object' && parsedYamlSpec?.info?.['x-event'];
85
84
  }
86
85
  static determineEventNameFromSpecification(spec) {
87
86
  const eventNames = Object.keys(spec.info['x-event']);
@@ -103,4 +102,4 @@ class KafkaEventSpecSource {
103
102
  exports.KafkaEventSpecSource = KafkaEventSpecSource;
104
103
  _b = JSII_RTTI_SYMBOL_1;
105
104
  KafkaEventSpecSource[_b] = { fqn: "@rio-cloud/cdk-v2-constructs.KafkaEventSpecSource", version: "0.0.0" };
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-event-spec.js","sourceRoot":"","sources":["../../src/kafka/kafka-event-spec.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport { Stack } from 'aws-cdk-lib';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\n\nexport interface KafkaEventSpecProps {\n  readonly source: KafkaEventSpecSource;\n}\n\n/**\n * Construct to provide an event specification for a Kafka topic and upload it to the central event store.\n */\nexport class KafkaEventSpec extends Construct {\n  constructor(scope: Construct, id: string, props: KafkaEventSpecProps) {\n    super(scope, id);\n\n    const action: cr.AwsSdkCall = {\n      service: 'SNS',\n      action: 'publish',\n      parameters: {\n        TopicArn: 'arn:aws:sns:eu-west-1:186993757734:event-specification-upload',\n        Message: props.source.toSnsMessage(),\n        MessageAttributes: {\n          accountId: {\n            DataType: 'String',\n            StringValue: Stack.of(this).account,\n          },\n        },\n      },\n      physicalResourceId: cr.PhysicalResourceId.of(`arn:aws:s3:::event-specification-store-186993757734/${props.source.eventName}.yaml`),\n    };\n\n    const eventSpecCustomResource = new cr.AwsCustomResource(this, 'KafkaEventSpec', {\n      onCreate: action,\n      onUpdate: action,\n      policy: cr.AwsCustomResourcePolicy.fromSdkCalls({ resources: cr.AwsCustomResourcePolicy.ANY_RESOURCE }),\n    });\n\n    const kmsKey = kms.Key.fromKeyArn(this, 'eventSpecSnsTopicKey', 'arn:aws:kms:eu-west-1:186993757734:key/1f72dd59-f32d-4d52-9b2b-447df88b3fa3');\n    kmsKey.grantEncryptDecrypt(eventSpecCustomResource);\n  }\n}\n\n/**\n * Wrapper class for the event spec itself to support providing it via file or inline string.\n *\n * @see https://collaboration.msi.audi.com/stash/projects/RSEVTBU/repos/topic-creation-example for\n * further information about the yaml spec.\n */\nexport class KafkaEventSpecSource {\n  /**\n   * Helper method to create a KafkaEventSpecSource by loading spec from a (UTF-8 encoded) yaml file.\n   *\n   * @param filename the filename of the event specification file. Must either be an absolute path or a path relative to CDK's working directory.\n   * @returns a KafkaEventSpecSource\n   */\n  static fromYamlFile(filename: string): KafkaEventSpecSource {\n    return this.fromYamlString(fs.readFileSync(filename, 'utf8'));\n  }\n\n  /**\n   * Helper method to create a KafkaEventSpecSource from an inline yaml string.\n   *\n   * @param spec as yaml formatted string\n   * @returns a KafkaEventSpecSource\n   */\n  static fromYamlString(spec: string): KafkaEventSpecSource {\n    const parsedSpec = this.parseYamlSpec(spec);\n    return new KafkaEventSpecSource(parsedSpec);\n  }\n\n  private static parseYamlSpec(spec: string): KafkaEventSpecification {\n    const parsedYamlSpec = yaml.load(spec) as any;\n    if (!this.isKafkaEventSpecification(parsedYamlSpec)) {\n      throw Error('Expecting event spec to be describe an object with the property [info.x-event].');\n    }\n    return parsedYamlSpec;\n  }\n\n  private static isKafkaEventSpecification(parsedYamlSpec: any): parsedYamlSpec is KafkaEventSpecification {\n    return typeof parsedYamlSpec === 'object' && parsedYamlSpec?.info?.['x-event'];\n  }\n\n  private static determineEventNameFromSpecification(spec: KafkaEventSpecification): string {\n    const eventNames = Object.keys(spec.info['x-event']);\n    if (eventNames.length === 0) {\n      throw Error('Expecting at least one event at [info.x-event].');\n    }\n    return this.removeYamlFileEnding(eventNames[0]);\n  }\n\n  private static removeYamlFileEnding(filename: string): string {\n    return filename.replace(/\\.ya?ml$/, '');\n  }\n\n  readonly eventName: string;\n\n  private constructor(private spec: KafkaEventSpecification) {\n    this.eventName = KafkaEventSpecSource.determineEventNameFromSpecification(spec);\n  }\n\n  /**\n   * @returns the message base64 encoded spec as expected by the event store\n   */\n  toSnsMessage(): string {\n    return Buffer.from(yaml.dump(this.spec)).toString('base64');\n  }\n}\n\n// This type is not exhaustive but only reflects the minimum properties required to validate the event specification\ninterface KafkaEventSpecification {\n  info: {\n    'x-event': { [eventName: string]: any }[];\n  };\n}\n"]}
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-event-spec.js","sourceRoot":"","sources":["../../src/kafka/kafka-event-spec.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport { Stack } from 'aws-cdk-lib';\nimport * as kms from 'aws-cdk-lib/aws-kms';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\n\nexport interface KafkaEventSpecProps {\n  readonly source: KafkaEventSpecSource;\n}\n\n/**\n * Construct to provide an event specification for a Kafka topic and upload it to the central event store.\n */\nexport class KafkaEventSpec extends Construct {\n  constructor(scope: Construct, id: string, props: KafkaEventSpecProps) {\n    super(scope, id);\n\n    const action: cr.AwsSdkCall = {\n      service: 'SNS',\n      action: 'publish',\n      parameters: {\n        TopicArn: 'arn:aws:sns:eu-west-1:186993757734:event-specification-upload',\n        Message: props.source.toSnsMessage(),\n        MessageAttributes: {\n          accountId: {\n            DataType: 'String',\n            StringValue: Stack.of(this).account,\n          },\n        },\n      },\n      physicalResourceId: cr.PhysicalResourceId.of(`arn:aws:s3:::event-specification-store-186993757734/${props.source.eventName}.yaml`),\n    };\n\n    const eventSpecCustomResource = new cr.AwsCustomResource(this, 'KafkaEventSpec', {\n      onCreate: action,\n      onUpdate: action,\n      policy: cr.AwsCustomResourcePolicy.fromSdkCalls({ resources: cr.AwsCustomResourcePolicy.ANY_RESOURCE }),\n    });\n\n    const kmsKey = kms.Key.fromKeyArn(this, 'eventSpecSnsTopicKey', 'arn:aws:kms:eu-west-1:186993757734:key/1f72dd59-f32d-4d52-9b2b-447df88b3fa3');\n    kmsKey.grantEncryptDecrypt(eventSpecCustomResource);\n  }\n}\n\n/**\n * Wrapper class for the event spec itself to support providing it via file or inline string.\n *\n * @see https://collaboration.msi.audi.com/stash/projects/RSEVTBU/repos/topic-creation-example for\n * further information about the yaml spec.\n */\nexport class KafkaEventSpecSource {\n  /**\n   * Helper method to create a KafkaEventSpecSource by loading spec from a (UTF-8 encoded) yaml file.\n   *\n   * @param filename the filename of the event specification file. Must either be an absolute path or a path relative to CDK's working directory.\n   * @returns a KafkaEventSpecSource\n   */\n  static fromYamlFile(filename: string): KafkaEventSpecSource {\n    return this.fromYamlString(fs.readFileSync(filename, 'utf8'));\n  }\n\n  /**\n   * Helper method to create a KafkaEventSpecSource from an inline yaml string.\n   *\n   * @param spec as yaml formatted string\n   * @returns a KafkaEventSpecSource\n   */\n  static fromYamlString(spec: string): KafkaEventSpecSource {\n    const parsedSpec = this.parseYamlSpec(spec);\n    return new KafkaEventSpecSource(parsedSpec);\n  }\n\n  private static parseYamlSpec(spec: string): KafkaEventSpecification {\n    const parsedYamlSpec = yaml.load(spec) as any;\n    if (!this.isKafkaEventSpecification(parsedYamlSpec)) {\n      throw Error('Expecting event spec to be describe an object with the property [info.x-event].');\n    }\n    return parsedYamlSpec;\n  }\n\n  private static isKafkaEventSpecification(parsedYamlSpec: any): parsedYamlSpec is KafkaEventSpecification {\n    return typeof parsedYamlSpec === 'object' && parsedYamlSpec?.info?.['x-event'];\n  }\n\n  private static determineEventNameFromSpecification(spec: KafkaEventSpecification): string {\n    const eventNames = Object.keys(spec.info['x-event']);\n    if (eventNames.length === 0) {\n      throw Error('Expecting at least one event at [info.x-event].');\n    }\n    return this.removeYamlFileEnding(eventNames[0]);\n  }\n\n  private static removeYamlFileEnding(filename: string): string {\n    return filename.replace(/\\.ya?ml$/, '');\n  }\n\n  readonly eventName: string;\n\n  private constructor(private spec: KafkaEventSpecification) {\n    this.eventName = KafkaEventSpecSource.determineEventNameFromSpecification(spec);\n  }\n\n  /**\n   * @returns the message base64 encoded spec as expected by the event store\n   */\n  toSnsMessage(): string {\n    return Buffer.from(yaml.dump(this.spec)).toString('base64');\n  }\n}\n\n// This type is not exhaustive but only reflects the minimum properties required to validate the event specification\ninterface KafkaEventSpecification {\n  info: {\n    'x-event': { [eventName: string]: any }[];\n  };\n}\n"]}
@@ -12,7 +12,6 @@ const kafka_event_spec_1 = require("./kafka-event-spec");
12
12
  */
13
13
  class KafkaTopic extends constructs_1.Construct {
14
14
  constructor(scope, id, props) {
15
- var _b, _c, _d, _e, _f;
16
15
  super(scope, id);
17
16
  /**
18
17
  SSM Parameter references dont generate logical names by appending IDs of the caller constructs. Instead simply use ID passed during function call 'fromStringParameterName'.
@@ -38,10 +37,10 @@ class KafkaTopic extends constructs_1.Construct {
38
37
  Description: props.metadata.description,
39
38
  Events: events,
40
39
  NumberOfPartitions: props.numberOfPartitions,
41
- ReplicationFactor: (_b = props.replicationFactor) !== null && _b !== void 0 ? _b : 3,
42
- RetentionMs: ((_c = props.retention) !== null && _c !== void 0 ? _c : aws_cdk_lib_1.Duration.days(7)).toMilliseconds(),
43
- DeleteRetentionMs: props.isLogCompacted ? (_e = (_d = props.logCompactionProperties) === null || _d === void 0 ? void 0 : _d.deleteRetention) !== null && _e !== void 0 ? _e : aws_cdk_lib_1.Duration.days(7).toMilliseconds() : undefined,
44
- InstantDeletionEnabled: (_f = props.instantDeletionEnabled) !== null && _f !== void 0 ? _f : false,
40
+ ReplicationFactor: props.replicationFactor ?? 3,
41
+ RetentionMs: (props.retention ?? aws_cdk_lib_1.Duration.days(7)).toMilliseconds(),
42
+ DeleteRetentionMs: props.isLogCompacted ? props.logCompactionProperties?.deleteRetention ?? aws_cdk_lib_1.Duration.days(7).toMilliseconds() : undefined,
43
+ InstantDeletionEnabled: props.instantDeletionEnabled ?? false,
45
44
  CleanupPolicy: props.isLogCompacted ? 'compact' : 'delete',
46
45
  TeamEmail: teamEmail,
47
46
  ACL: {
@@ -77,4 +76,4 @@ class KafkaTopic extends constructs_1.Construct {
77
76
  exports.KafkaTopic = KafkaTopic;
78
77
  _a = JSII_RTTI_SYMBOL_1;
79
78
  KafkaTopic[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.KafkaTopic", version: "0.0.0" };
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-topic.js","sourceRoot":"","sources":["../../src/kafka/kafka-topic.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, CfnResource, Stack } from 'aws-cdk-lib';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\n\nimport { KafkaEventSpec, KafkaEventSpecSource } from './kafka-event-spec';\n\n/**\n * Wrapper for all meta data of a topic.\n */\nexport interface KafkaTopicMetaData {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n}\n\n/**\n * Read and write permissions for the topic.\n *\n * strings are matched against the CNAME of the certificate of the Kafka clients.\n */\nexport interface KafkaAclStatement {\n  /**\n  * List of clients that should get write permissions\n  */\n  readonly write: string[];\n\n  /**\n   * List of clients that should get read permissions\n   */\n  readonly read: string[];\n}\n\n/**\n * Wrapper for all log compaction related properties.\n */\nexport interface LogCompactionProperties {\n  /**\n   * The amount of time to retain delete tombstone markers for log compacted topics;\n   * The soft limit is 10 days but can be increased upon requests.\n   * @default 1 day\n   */\n  readonly deleteRetention?: Duration;\n}\n\n/**\n * The current service limits can be found in the topic limits configuration of the topic manager.\n *\n * @see https://collaboration.msi.audi.com/stash/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml\n */\nexport interface KafkaTopicProps{\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @default 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @default 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @default false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaData;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @default undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n}\n\n/**\n * Construct to create a kafka topic.\n */\nexport class KafkaTopic extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicProps) {\n    super(scope, id);\n\n    /**\n    SSM Parameter references dont generate logical names by appending IDs of the caller constructs. Instead simply use ID passed during function call 'fromStringParameterName'.\n    This means that if this construct is called more than once in the same stack, it would fail with error 'Construct name already used'.\n    Checking for existing SSM Parameter used to avoid this error\n    */\n    const teamEmailSSMCDKIdentifier = 'TeamEmail';\n    const teamEmail = Stack.of(this).node.tryFindChild(teamEmailSSMCDKIdentifier)\n      ?\n      (Stack.of(this).node.findChild(teamEmailSSMCDKIdentifier) as ssm.StringParameter).stringValue\n      :\n      ssm.StringParameter.fromStringParameterName(\n        scope,\n        teamEmailSSMCDKIdentifier,\n        '/config/team/mail',\n      ).stringValue;\n\n    const events = props.metadata.events.map(source => {\n      new KafkaEventSpec(this, `${source.eventName.replace(/\\./g, '_')}-EventSpec`, { source });\n      return source.eventName;\n    });\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ServiceToken: 'arn:aws:sns:eu-west-1:186993757734:dp-topic-manager-sns-topic',\n        Version: '3',\n        TopicName: props.name,\n        Description: props.metadata.description,\n        Events: events,\n        NumberOfPartitions: props.numberOfPartitions,\n        ReplicationFactor: props.replicationFactor ?? 3,\n        RetentionMs: (props.retention ?? Duration.days(7)).toMilliseconds(),\n        DeleteRetentionMs: props.isLogCompacted ? props.logCompactionProperties?.deleteRetention ?? Duration.days(7).toMilliseconds() : undefined,\n        InstantDeletionEnabled: props.instantDeletionEnabled ?? false,\n        CleanupPolicy: props.isLogCompacted ? 'compact' : 'delete',\n        TeamEmail: teamEmail,\n        ACL: {\n          Read: props.acl.read,\n          Write: props.acl.write,\n        },\n      },\n    });\n\n    this.node.addValidation({\n      validate: (): string[] => {\n        const result = [];\n\n        if (!props.name.match(/^[A-Za-z0-9.-]+$/)) {\n          result.push('Invalid [name]: expecting topic name to match the reg exp `[A-Za-z0-9.-]+`.');\n        }\n\n        if (!Number.isInteger(props.numberOfPartitions) || props.numberOfPartitions < 1) {\n          result.push(`Invalid [numberOfPartitions]: expecting number of partitions to be a positive integer but got ${props.numberOfPartitions}.`);\n        }\n\n        if (props.replicationFactor !== undefined &&\n            (!Number.isInteger(props.replicationFactor) || props.replicationFactor < 1 || props.replicationFactor > 3)) {\n          result.push('Invalid [replicationFactor]: expecting an integer between 1 and 3.');\n        }\n\n        if (props.metadata.events.length === 0) {\n          result.push('Invalid [metadata]: expecting [events] to have at least on element.');\n        }\n\n        if (!props.isLogCompacted && props.logCompactionProperties) {\n          result.push('Invalid [logCompactionProperties]: log compaction is disabled so properties must be undefined.');\n        }\n\n        return result;\n      },\n    });\n  }\n}\n"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kafka-topic.js","sourceRoot":"","sources":["../../src/kafka/kafka-topic.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, CfnResource, Stack } from 'aws-cdk-lib';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\n\nimport { KafkaEventSpec, KafkaEventSpecSource } from './kafka-event-spec';\n\n/**\n * Wrapper for all meta data of a topic.\n */\nexport interface KafkaTopicMetaData {\n  /**\n   * The event specs of the events on that topic\n   */\n  readonly events: KafkaEventSpecSource[];\n\n  /**\n   * Describes the intent of the topic. This might be information about the events on that topic\n   * or additional information about the producer and the context of the events.\n   */\n  readonly description: string;\n}\n\n/**\n * Read and write permissions for the topic.\n *\n * strings are matched against the CNAME of the certificate of the Kafka clients.\n */\nexport interface KafkaAclStatement {\n  /**\n  * List of clients that should get write permissions\n  */\n  readonly write: string[];\n\n  /**\n   * List of clients that should get read permissions\n   */\n  readonly read: string[];\n}\n\n/**\n * Wrapper for all log compaction related properties.\n */\nexport interface LogCompactionProperties {\n  /**\n   * The amount of time to retain delete tombstone markers for log compacted topics;\n   * The soft limit is 10 days but can be increased upon requests.\n   * @default 1 day\n   */\n  readonly deleteRetention?: Duration;\n}\n\n/**\n * The current service limits can be found in the topic limits configuration of the topic manager.\n *\n * @see https://collaboration.msi.audi.com/stash/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml\n */\nexport interface KafkaTopicProps{\n  /**\n   * The unique name of the topic; has to match pattern [A-Za-z0-9.-]+\n   */\n  readonly name: string;\n\n  /**\n   * Defines degree of parallelism of the topic; should be increased for\n   * large expected loads (e.g., 25 for rio.asset-iot-events).\n   * The soft limit is 10 partitions but can be increased upon requests.\n   */\n  readonly numberOfPartitions: number;\n\n  /**\n   * Defines degree of replication of messages; has to be between 1 and the number of brokers (currently 3).\n   * @default 3\n   */\n  readonly replicationFactor?: number;\n\n  /**\n   * Time how long messages are retained on Kafka cluster;\n   *\n   * We recommend 30 days for general events and 7 days for sensor events and other high-load cases.\n   * The soft limit is 3 to 30 days but can be increased upon requests.\n   * @default 7 days\n   */\n  readonly retention?: Duration;\n\n  /**\n   * If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion.\n   * If set to 'true', it will be deleted immediately after stack deletion.\n   * @default false\n   */\n  readonly instantDeletionEnabled?: boolean;\n\n  /**\n   * The metadata of the topic.\n   */\n  readonly metadata: KafkaTopicMetaData;\n\n  /**\n   * The permissions to access to the topic's data.\n   */\n  readonly acl: KafkaAclStatement;\n\n  /**\n   * Specify whether the topic is log compacted or not.\n   */\n  readonly isLogCompacted: boolean;\n\n  /**\n   * Must only be provided if 'isLogCompacted' is 'true'.\n   * @default undefined\n   */\n  readonly logCompactionProperties?: LogCompactionProperties;\n}\n\n/**\n * Construct to create a kafka topic.\n */\nexport class KafkaTopic extends Construct {\n\n  constructor(scope: Construct, id: string, props: KafkaTopicProps) {\n    super(scope, id);\n\n    /**\n    SSM Parameter references dont generate logical names by appending IDs of the caller constructs. Instead simply use ID passed during function call 'fromStringParameterName'.\n    This means that if this construct is called more than once in the same stack, it would fail with error 'Construct name already used'.\n    Checking for existing SSM Parameter used to avoid this error\n    */\n    const teamEmailSSMCDKIdentifier = 'TeamEmail';\n    const teamEmail = Stack.of(this).node.tryFindChild(teamEmailSSMCDKIdentifier)\n      ?\n      (Stack.of(this).node.findChild(teamEmailSSMCDKIdentifier) as ssm.StringParameter).stringValue\n      :\n      ssm.StringParameter.fromStringParameterName(\n        scope,\n        teamEmailSSMCDKIdentifier,\n        '/config/team/mail',\n      ).stringValue;\n\n    const events = props.metadata.events.map(source => {\n      new KafkaEventSpec(this, `${source.eventName.replace(/\\./g, '_')}-EventSpec`, { source });\n      return source.eventName;\n    });\n\n    new CfnResource(this, 'KafkaTopic', {\n      type: 'Custom::KafkaTopic',\n      properties: {\n        ServiceToken: 'arn:aws:sns:eu-west-1:186993757734:dp-topic-manager-sns-topic',\n        Version: '3',\n        TopicName: props.name,\n        Description: props.metadata.description,\n        Events: events,\n        NumberOfPartitions: props.numberOfPartitions,\n        ReplicationFactor: props.replicationFactor ?? 3,\n        RetentionMs: (props.retention ?? Duration.days(7)).toMilliseconds(),\n        DeleteRetentionMs: props.isLogCompacted ? props.logCompactionProperties?.deleteRetention ?? Duration.days(7).toMilliseconds() : undefined,\n        InstantDeletionEnabled: props.instantDeletionEnabled ?? false,\n        CleanupPolicy: props.isLogCompacted ? 'compact' : 'delete',\n        TeamEmail: teamEmail,\n        ACL: {\n          Read: props.acl.read,\n          Write: props.acl.write,\n        },\n      },\n    });\n\n    this.node.addValidation({\n      validate: (): string[] => {\n        const result = [];\n\n        if (!props.name.match(/^[A-Za-z0-9.-]+$/)) {\n          result.push('Invalid [name]: expecting topic name to match the reg exp `[A-Za-z0-9.-]+`.');\n        }\n\n        if (!Number.isInteger(props.numberOfPartitions) || props.numberOfPartitions < 1) {\n          result.push(`Invalid [numberOfPartitions]: expecting number of partitions to be a positive integer but got ${props.numberOfPartitions}.`);\n        }\n\n        if (props.replicationFactor !== undefined &&\n            (!Number.isInteger(props.replicationFactor) || props.replicationFactor < 1 || props.replicationFactor > 3)) {\n          result.push('Invalid [replicationFactor]: expecting an integer between 1 and 3.');\n        }\n\n        if (props.metadata.events.length === 0) {\n          result.push('Invalid [metadata]: expecting [events] to have at least on element.');\n        }\n\n        if (!props.isLogCompacted && props.logCompactionProperties) {\n          result.push('Invalid [logCompactionProperties]: log compaction is disabled so properties must be undefined.');\n        }\n\n        return result;\n      },\n    });\n  }\n}\n"]}
@@ -20,6 +20,13 @@ export interface RioKafkaEventSourceProps extends lambdaEventSource.BaseStreamEv
20
20
  * (Otherwise, i.e., if you do not use the `--fqdn` parameter, your certificates CNAME contains the AWS account ID and you need to change all ACLs in case of a corrupted AWS account.)
21
21
  */
22
22
  readonly secret: secretsmanager.ISecret;
23
+ /**
24
+ * The identifier for the Kafka consumer group to join. The consumer group ID must be unique among all your Kafka event sources. After creating a Kafka event source mapping with the consumer group ID specified, you cannot update this value. The value must have a lenght between 1 and 200 and full the pattern '[a-zA-Z0-9-\/*:_+=.@-]*'.
25
+ * @see https://docs.aws.amazon.com/lambda/latest/dg/with-msk.html#services-msk-consumer-group-id
26
+ *
27
+ * @default - none
28
+ */
29
+ readonly consumerGroupId?: string;
23
30
  }
24
31
  /**
25
32
  * Use the Rio Kafka as a streaming source for AWS Lambda.
@@ -55,4 +55,4 @@ class RioKafkaEventSource {
55
55
  exports.RioKafkaEventSource = RioKafkaEventSource;
56
56
  _a = JSII_RTTI_SYMBOL_1;
57
57
  RioKafkaEventSource[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.RioKafkaEventSource", version: "0.0.0" };
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmlvLWthZmthLWV2ZW50LXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9rYWZrYS9yaW8ta2Fma2EtZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQW1DO0FBQ25DLDJDQUEyQztBQUMzQywyQ0FBMkM7QUFFM0MsMEVBQTBFO0FBRTFFLDJDQUEyQztBQUUzQywyQ0FBMkM7QUF1QjNDOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsbUJBQW1CO0lBRTlCLFlBQW9CLEtBQStCO1FBQS9CLFVBQUssR0FBTCxLQUFLLENBQTBCO0lBQ25ELENBQUM7SUFFRCxJQUFJLENBQUMsTUFBd0I7UUFDM0IsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sRUFBRSwyQkFBMkIsRUFBRSw0Q0FBNEMsQ0FBQyxDQUFDO1FBRWpLLE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3JELE1BQU0sYUFBYSxHQUFHLElBQUksR0FBRyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUscUJBQXFCLEVBQUUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBRXBGLE1BQU0sUUFBUSxHQUFHLElBQUksaUJBQWlCLENBQUMsMkJBQTJCLENBQUM7WUFDakUsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLHlCQUF5QixDQUFDLFdBQVcsQ0FBQztZQUMxRSxHQUFHLElBQUksQ0FBQyxLQUFLO1lBQ2IsR0FBRztZQUNILFVBQVUsRUFBRTtnQkFDVixPQUFPLEVBQUUsR0FBRyxDQUFDLGNBQWM7YUFDNUI7WUFDRCxhQUFhO1lBQ2Isb0JBQW9CLEVBQUUsaUJBQWlCLENBQUMsb0JBQW9CLENBQUMsMkJBQTJCO1NBQ3pGLENBQUMsQ0FBQztRQUVILFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFdEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BDLHlCQUF5QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUU1QyxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sRUFBRSxrQ0FBa0MsRUFBRSxnRUFBZ0UsQ0FBQyxDQUFDO1FBQ3BLLE1BQU0sQ0FBQyxJQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7QUE3Qkgsa0RBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCAqIGFzIGxhbWJkYUV2ZW50U291cmNlIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEtZXZlbnQtc291cmNlcyc7XG5pbXBvcnQgKiBhcyBzZWNyZXRzbWFuYWdlciBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc2VjcmV0c21hbmFnZXInO1xuaW1wb3J0ICogYXMgc3NtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1zc20nO1xuXG5pbXBvcnQgKiBhcyByaW8gZnJvbSAnLi4vcmlvLWxhbmRpbmctem9uZSc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgUmlvS2Fma2FFdmVudFNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcyBleHRlbmRzIGxhbWJkYUV2ZW50U291cmNlLkJhc2VTdHJlYW1FdmVudFNvdXJjZVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBLYWZrYSB0b3BpYyB0byBzdWJzY3JpYmUgdG9cbiAgICovXG4gIHJlYWRvbmx5IHRvcGljOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgc2VjcmV0IHdpdGggdGhlIEthZmthIGNyZWRlbnRpYWxzLCBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL21zay9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvbXNrLWF1dGhlbnRpY2F0aW9uLmh0bWwgZm9yIGRldGFpbHMuXG4gICAqXG4gICAqIFlvdSBjYW4gdXNlIHRoZSBgY3JlYXRlLWFuZC1zaWduLWNlcnRpZmljYXRlYCBzY3JpcHQgZnJvbSB0aGUgYGthZmthLWludGVncmF0aW9uYCB0byBjcmVhdGUgYSBzdWl0YWJsZSBBV1MgU2VjcmV0cyBNYW5hZ2VyIHNlY3JldC5cbiAgICogU2ltcGx5IGFkZCB0aGUgYC0tZnFkbiA8ZnFkbj4gLS1sYW1iZGFgIHBhcmFtZXRlcnMgdG8gdGhlIGBjcmVhdGUtYW5kLXNpZ24tY2VydGlmaWNhdGVgIHNjcmlwdCBhbmQgdGhlIHNjcmlwdCBnZW5lcmF0ZXMgYSBzZWNyZXQgbmFtZWQgYGthZmthLWludGVncmF0aW9uL21zay1jZXJ0aWZpY2F0ZS88ZnFkbj5gIHdpdGggYWxsIHJlbGV2YW50IGRhdGEuXG4gICAqXG4gICAqIFBsZWFzZSBub3RlIHRoYXQgd2UgZG8gb25seSBzdXBwb3J0IHRoZSBgLS1sYW1iZGFgIHBhcmFtZXRlciBpZiB0aGUgYC0tZnFkbmAgcGFyYW1ldGVyIGlzIHByZXNlbnQuXG4gICAqIFdlIGVuY291cmFnZSB5b3UgdG8gdXNlIHRoZSBgLS1mcWRuYCBwYXJhbWV0ZXIgZm9yIGFsbCB5b3VyIEthZmthIGNvbnN1bWVycyBhbmQgcHJvZHVjZXJzIGFzIHRoaXMgZWFzZXMgdGhlIHJlY292ZXJ5IHByb2Nlc3MgaW4gdGhlIGNhc2Ugb2YgYSBkaXNhc3Rlci5cbiAgICogKE90aGVyd2lzZSwgaS5lLiwgaWYgeW91IGRvIG5vdCB1c2UgdGhlIGAtLWZxZG5gIHBhcmFtZXRlciwgeW91ciBjZXJ0aWZpY2F0ZXMgQ05BTUUgY29udGFpbnMgdGhlIEFXUyBhY2NvdW50IElEIGFuZCB5b3UgbmVlZCB0byBjaGFuZ2UgYWxsIEFDTHMgaW4gY2FzZSBvZiBhIGNvcnJ1cHRlZCBBV1MgYWNjb3VudC4pXG4gICAqL1xuICByZWFkb25seSBzZWNyZXQ6IHNlY3JldHNtYW5hZ2VyLklTZWNyZXQ7XG59XG5cbi8qKlxuICogVXNlIHRoZSBSaW8gS2Fma2EgYXMgYSBzdHJlYW1pbmcgc291cmNlIGZvciBBV1MgTGFtYmRhLlxuICpcbiAqIGBgYFxuICogIGNvbnN0IGxhbWJkYSA9IG5ldyBub2RlanMuTm9kZWpzRnVuY3Rpb24odGhpcywgJ0thZmthQ29uc3VtZXJGdW5jdGlvbicsIHtcbiAqICAgICBlbnRyeTogJ3BhdGgudG8uaGFuZGxlci50cycsXG4gKiAgICAgaGFuZGxlcjogJ2hhbmRsZXJOYW1lJyxcbiAqICAgfSk7XG4gKlxuICogICBjb25zdCBzZWNyZXQgPSBTZWNyZXQuZnJvbVNlY3JldE5hbWVWMih0aGlzLCAnQ29uc3VtZXJTZWNyZXQnLCAna2Fma2EtaW50ZWdyYXRpb24vbXNrLWNlcnRpZmljYXRlLzxGUUROPicpXG4gKlxuICogICBsYW1iZGEuYWRkRXZlbnRTb3VyY2UobmV3IFJpb0thZmthRXZlbnRTb3VyY2Uoe1xuICogICAgIHNlY3JldCxcbiAqICAgICB0b3BpYzogJzxUT1BJQy9OQU1FPicsXG4gKiAgICAgc3RhcnRpbmdQb3NpdGlvbjogU3RhcnRpbmdQb3NpdGlvbi5UUklNX0hPUklaT04sXG4gKiAgIH0pKTtcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgUmlvS2Fma2FFdmVudFNvdXJjZSBpbXBsZW1lbnRzIGxhbWJkYS5JRXZlbnRTb3VyY2Uge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcHJvcHM6IFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcykge1xuICB9XG5cbiAgYmluZCh0YXJnZXQ6IGxhbWJkYS5JRnVuY3Rpb24pOiB2b2lkIHtcbiAgICBjb25zdCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyID0gc3NtLlN0cmluZ1BhcmFtZXRlci5mcm9tU3RyaW5nUGFyYW1ldGVyTmFtZSh0YXJnZXQsICdCb290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyJywgJy9jb25maWcva2Fma2EtaW50ZWdyYXRpb24vYm9vdHN0cmFwLXNlcnZlcicpO1xuXG4gICAgY29uc3QgdnBjID0gcmlvLlJpb0xhbmRpbmdab25lLmdldERlZmF1bHRWcGModGFyZ2V0KTtcbiAgICBjb25zdCBzZWN1cml0eUdyb3VwID0gbmV3IGVjMi5TZWN1cml0eUdyb3VwKHRhcmdldCwgJ0xhbWJkYVNlY3VyaXR5R3JvdXAnLCB7IHZwYyB9KTtcblxuICAgIGNvbnN0IGRlbGVnYXRlID0gbmV3IGxhbWJkYUV2ZW50U291cmNlLlNlbGZNYW5hZ2VkS2Fma2FFdmVudFNvdXJjZSh7XG4gICAgICBib290c3RyYXBTZXJ2ZXJzOiBjZGsuRm4uc3BsaXQoJywnLCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyLnN0cmluZ1ZhbHVlKSxcbiAgICAgIC4uLnRoaXMucHJvcHMsXG4gICAgICB2cGMsXG4gICAgICB2cGNTdWJuZXRzOiB7XG4gICAgICAgIHN1Ym5ldHM6IHZwYy5wcml2YXRlU3VibmV0cyxcbiAgICAgIH0sXG4gICAgICBzZWN1cml0eUdyb3VwLFxuICAgICAgYXV0aGVudGljYXRpb25NZXRob2Q6IGxhbWJkYUV2ZW50U291cmNlLkF1dGhlbnRpY2F0aW9uTWV0aG9kLkNMSUVOVF9DRVJUSUZJQ0FURV9UTFNfQVVUSCxcbiAgICB9KTtcblxuICAgIGRlbGVnYXRlLmJpbmQodGFyZ2V0KTtcblxuICAgIHRoaXMucHJvcHMuc2VjcmV0LmdyYW50UmVhZCh0YXJnZXQpO1xuICAgIGJvb3RzdHJhcFNlcnZlcnNQYXJhbWV0ZXIuZ3JhbnRSZWFkKHRhcmdldCk7XG5cbiAgICBjb25zdCBwb2xpY3kgPSBpYW0uTWFuYWdlZFBvbGljeS5mcm9tTWFuYWdlZFBvbGljeUFybih0YXJnZXQsICdNYW5hZ2VkQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScsICdhcm46YXdzOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScpO1xuICAgIHRhcmdldC5yb2xlIS5hZGRNYW5hZ2VkUG9saWN5KHBvbGljeSk7XG4gIH1cbn1cbiJdfQ==
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmlvLWthZmthLWV2ZW50LXNvdXJjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9rYWZrYS9yaW8ta2Fma2EtZXZlbnQtc291cmNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsbUNBQW1DO0FBQ25DLDJDQUEyQztBQUMzQywyQ0FBMkM7QUFFM0MsMEVBQTBFO0FBRTFFLDJDQUEyQztBQUUzQywyQ0FBMkM7QUE4QjNDOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsbUJBQW1CO0lBRTlCLFlBQW9CLEtBQStCO1FBQS9CLFVBQUssR0FBTCxLQUFLLENBQTBCO0lBQ25ELENBQUM7SUFFRCxJQUFJLENBQUMsTUFBd0I7UUFDM0IsTUFBTSx5QkFBeUIsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDLHVCQUF1QixDQUFDLE1BQU0sRUFBRSwyQkFBMkIsRUFBRSw0Q0FBNEMsQ0FBQyxDQUFDO1FBRWpLLE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3JELE1BQU0sYUFBYSxHQUFHLElBQUksR0FBRyxDQUFDLGFBQWEsQ0FBQyxNQUFNLEVBQUUscUJBQXFCLEVBQUUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBRXBGLE1BQU0sUUFBUSxHQUFHLElBQUksaUJBQWlCLENBQUMsMkJBQTJCLENBQUM7WUFDakUsZ0JBQWdCLEVBQUUsR0FBRyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLHlCQUF5QixDQUFDLFdBQVcsQ0FBQztZQUMxRSxHQUFHLElBQUksQ0FBQyxLQUFLO1lBQ2IsR0FBRztZQUNILFVBQVUsRUFBRTtnQkFDVixPQUFPLEVBQUUsR0FBRyxDQUFDLGNBQWM7YUFDNUI7WUFDRCxhQUFhO1lBQ2Isb0JBQW9CLEVBQUUsaUJBQWlCLENBQUMsb0JBQW9CLENBQUMsMkJBQTJCO1NBQ3pGLENBQUMsQ0FBQztRQUVILFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFdEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3BDLHlCQUF5QixDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUU1QyxNQUFNLE1BQU0sR0FBRyxHQUFHLENBQUMsYUFBYSxDQUFDLG9CQUFvQixDQUFDLE1BQU0sRUFBRSxrQ0FBa0MsRUFBRSxnRUFBZ0UsQ0FBQyxDQUFDO1FBQ3BLLE1BQU0sQ0FBQyxJQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEMsQ0FBQzs7QUE3Qkgsa0RBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY2RrIGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGVjMiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWMyJztcbmltcG9ydCAqIGFzIGlhbSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtaWFtJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCAqIGFzIGxhbWJkYUV2ZW50U291cmNlIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEtZXZlbnQtc291cmNlcyc7XG5pbXBvcnQgKiBhcyBzZWNyZXRzbWFuYWdlciBmcm9tICdhd3MtY2RrLWxpYi9hd3Mtc2VjcmV0c21hbmFnZXInO1xuaW1wb3J0ICogYXMgc3NtIGZyb20gJ2F3cy1jZGstbGliL2F3cy1zc20nO1xuXG5pbXBvcnQgKiBhcyByaW8gZnJvbSAnLi4vcmlvLWxhbmRpbmctem9uZSc7XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgUmlvS2Fma2FFdmVudFNvdXJjZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcyBleHRlbmRzIGxhbWJkYUV2ZW50U291cmNlLkJhc2VTdHJlYW1FdmVudFNvdXJjZVByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBLYWZrYSB0b3BpYyB0byBzdWJzY3JpYmUgdG9cbiAgICovXG4gIHJlYWRvbmx5IHRvcGljOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgc2VjcmV0IHdpdGggdGhlIEthZmthIGNyZWRlbnRpYWxzLCBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL21zay9sYXRlc3QvZGV2ZWxvcGVyZ3VpZGUvbXNrLWF1dGhlbnRpY2F0aW9uLmh0bWwgZm9yIGRldGFpbHMuXG4gICAqXG4gICAqIFlvdSBjYW4gdXNlIHRoZSBgY3JlYXRlLWFuZC1zaWduLWNlcnRpZmljYXRlYCBzY3JpcHQgZnJvbSB0aGUgYGthZmthLWludGVncmF0aW9uYCB0byBjcmVhdGUgYSBzdWl0YWJsZSBBV1MgU2VjcmV0cyBNYW5hZ2VyIHNlY3JldC5cbiAgICogU2ltcGx5IGFkZCB0aGUgYC0tZnFkbiA8ZnFkbj4gLS1sYW1iZGFgIHBhcmFtZXRlcnMgdG8gdGhlIGBjcmVhdGUtYW5kLXNpZ24tY2VydGlmaWNhdGVgIHNjcmlwdCBhbmQgdGhlIHNjcmlwdCBnZW5lcmF0ZXMgYSBzZWNyZXQgbmFtZWQgYGthZmthLWludGVncmF0aW9uL21zay1jZXJ0aWZpY2F0ZS88ZnFkbj5gIHdpdGggYWxsIHJlbGV2YW50IGRhdGEuXG4gICAqXG4gICAqIFBsZWFzZSBub3RlIHRoYXQgd2UgZG8gb25seSBzdXBwb3J0IHRoZSBgLS1sYW1iZGFgIHBhcmFtZXRlciBpZiB0aGUgYC0tZnFkbmAgcGFyYW1ldGVyIGlzIHByZXNlbnQuXG4gICAqIFdlIGVuY291cmFnZSB5b3UgdG8gdXNlIHRoZSBgLS1mcWRuYCBwYXJhbWV0ZXIgZm9yIGFsbCB5b3VyIEthZmthIGNvbnN1bWVycyBhbmQgcHJvZHVjZXJzIGFzIHRoaXMgZWFzZXMgdGhlIHJlY292ZXJ5IHByb2Nlc3MgaW4gdGhlIGNhc2Ugb2YgYSBkaXNhc3Rlci5cbiAgICogKE90aGVyd2lzZSwgaS5lLiwgaWYgeW91IGRvIG5vdCB1c2UgdGhlIGAtLWZxZG5gIHBhcmFtZXRlciwgeW91ciBjZXJ0aWZpY2F0ZXMgQ05BTUUgY29udGFpbnMgdGhlIEFXUyBhY2NvdW50IElEIGFuZCB5b3UgbmVlZCB0byBjaGFuZ2UgYWxsIEFDTHMgaW4gY2FzZSBvZiBhIGNvcnJ1cHRlZCBBV1MgYWNjb3VudC4pXG4gICAqL1xuICByZWFkb25seSBzZWNyZXQ6IHNlY3JldHNtYW5hZ2VyLklTZWNyZXQ7XG4gIC8qKlxuICAgKiBUaGUgaWRlbnRpZmllciBmb3IgdGhlIEthZmthIGNvbnN1bWVyIGdyb3VwIHRvIGpvaW4uIFRoZSBjb25zdW1lciBncm91cCBJRCBtdXN0IGJlIHVuaXF1ZSBhbW9uZyBhbGwgeW91ciBLYWZrYSBldmVudCBzb3VyY2VzLiBBZnRlciBjcmVhdGluZyBhIEthZmthIGV2ZW50IHNvdXJjZSBtYXBwaW5nIHdpdGggdGhlIGNvbnN1bWVyIGdyb3VwIElEIHNwZWNpZmllZCwgeW91IGNhbm5vdCB1cGRhdGUgdGhpcyB2YWx1ZS4gIFRoZSB2YWx1ZSBtdXN0IGhhdmUgYSBsZW5naHQgYmV0d2VlbiAxIGFuZCAyMDAgYW5kIGZ1bGwgdGhlIHBhdHRlcm4gJ1thLXpBLVowLTktXFwvKjpfKz0uQC1dKicuXG4gICAqIEBzZWUgaHR0cHM6Ly9kb2NzLmF3cy5hbWF6b24uY29tL2xhbWJkYS9sYXRlc3QvZGcvd2l0aC1tc2suaHRtbCNzZXJ2aWNlcy1tc2stY29uc3VtZXItZ3JvdXAtaWRcbiAgICpcbiAgICogQGRlZmF1bHQgLSBub25lXG4gICAqL1xuICByZWFkb25seSBjb25zdW1lckdyb3VwSWQ/OiBzdHJpbmc7XG59XG5cbi8qKlxuICogVXNlIHRoZSBSaW8gS2Fma2EgYXMgYSBzdHJlYW1pbmcgc291cmNlIGZvciBBV1MgTGFtYmRhLlxuICpcbiAqIGBgYFxuICogIGNvbnN0IGxhbWJkYSA9IG5ldyBub2RlanMuTm9kZWpzRnVuY3Rpb24odGhpcywgJ0thZmthQ29uc3VtZXJGdW5jdGlvbicsIHtcbiAqICAgICBlbnRyeTogJ3BhdGgudG8uaGFuZGxlci50cycsXG4gKiAgICAgaGFuZGxlcjogJ2hhbmRsZXJOYW1lJyxcbiAqICAgfSk7XG4gKlxuICogICBjb25zdCBzZWNyZXQgPSBTZWNyZXQuZnJvbVNlY3JldE5hbWVWMih0aGlzLCAnQ29uc3VtZXJTZWNyZXQnLCAna2Fma2EtaW50ZWdyYXRpb24vbXNrLWNlcnRpZmljYXRlLzxGUUROPicpXG4gKlxuICogICBsYW1iZGEuYWRkRXZlbnRTb3VyY2UobmV3IFJpb0thZmthRXZlbnRTb3VyY2Uoe1xuICogICAgIHNlY3JldCxcbiAqICAgICB0b3BpYzogJzxUT1BJQy9OQU1FPicsXG4gKiAgICAgc3RhcnRpbmdQb3NpdGlvbjogU3RhcnRpbmdQb3NpdGlvbi5UUklNX0hPUklaT04sXG4gKiAgIH0pKTtcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgUmlvS2Fma2FFdmVudFNvdXJjZSBpbXBsZW1lbnRzIGxhbWJkYS5JRXZlbnRTb3VyY2Uge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcHJvcHM6IFJpb0thZmthRXZlbnRTb3VyY2VQcm9wcykge1xuICB9XG5cbiAgYmluZCh0YXJnZXQ6IGxhbWJkYS5JRnVuY3Rpb24pOiB2b2lkIHtcbiAgICBjb25zdCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyID0gc3NtLlN0cmluZ1BhcmFtZXRlci5mcm9tU3RyaW5nUGFyYW1ldGVyTmFtZSh0YXJnZXQsICdCb290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyJywgJy9jb25maWcva2Fma2EtaW50ZWdyYXRpb24vYm9vdHN0cmFwLXNlcnZlcicpO1xuXG4gICAgY29uc3QgdnBjID0gcmlvLlJpb0xhbmRpbmdab25lLmdldERlZmF1bHRWcGModGFyZ2V0KTtcbiAgICBjb25zdCBzZWN1cml0eUdyb3VwID0gbmV3IGVjMi5TZWN1cml0eUdyb3VwKHRhcmdldCwgJ0xhbWJkYVNlY3VyaXR5R3JvdXAnLCB7IHZwYyB9KTtcblxuICAgIGNvbnN0IGRlbGVnYXRlID0gbmV3IGxhbWJkYUV2ZW50U291cmNlLlNlbGZNYW5hZ2VkS2Fma2FFdmVudFNvdXJjZSh7XG4gICAgICBib290c3RyYXBTZXJ2ZXJzOiBjZGsuRm4uc3BsaXQoJywnLCBib290c3RyYXBTZXJ2ZXJzUGFyYW1ldGVyLnN0cmluZ1ZhbHVlKSxcbiAgICAgIC4uLnRoaXMucHJvcHMsXG4gICAgICB2cGMsXG4gICAgICB2cGNTdWJuZXRzOiB7XG4gICAgICAgIHN1Ym5ldHM6IHZwYy5wcml2YXRlU3VibmV0cyxcbiAgICAgIH0sXG4gICAgICBzZWN1cml0eUdyb3VwLFxuICAgICAgYXV0aGVudGljYXRpb25NZXRob2Q6IGxhbWJkYUV2ZW50U291cmNlLkF1dGhlbnRpY2F0aW9uTWV0aG9kLkNMSUVOVF9DRVJUSUZJQ0FURV9UTFNfQVVUSCxcbiAgICB9KTtcblxuICAgIGRlbGVnYXRlLmJpbmQodGFyZ2V0KTtcblxuICAgIHRoaXMucHJvcHMuc2VjcmV0LmdyYW50UmVhZCh0YXJnZXQpO1xuICAgIGJvb3RzdHJhcFNlcnZlcnNQYXJhbWV0ZXIuZ3JhbnRSZWFkKHRhcmdldCk7XG5cbiAgICBjb25zdCBwb2xpY3kgPSBpYW0uTWFuYWdlZFBvbGljeS5mcm9tTWFuYWdlZFBvbGljeUFybih0YXJnZXQsICdNYW5hZ2VkQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScsICdhcm46YXdzOmlhbTo6YXdzOnBvbGljeS9zZXJ2aWNlLXJvbGUvQVdTTGFtYmRhTVNLRXhlY3V0aW9uUm9sZScpO1xuICAgIHRhcmdldC5yb2xlIS5hZGRNYW5hZ2VkUG9saWN5KHBvbGljeSk7XG4gIH1cbn1cbiJdfQ==
@@ -19,13 +19,12 @@ var TriggerKey;
19
19
  })(TriggerKey = exports.TriggerKey || (exports.TriggerKey = {}));
20
20
  class RioBitBucketSourceAction extends codepipeline_actions.S3SourceAction {
21
21
  constructor(scope, props) {
22
- var _b;
23
22
  const DEFAULT_TRIGGER_KEY = TriggerKey.MASTER_REPO;
24
23
  super({
25
24
  trigger: codepipeline_actions.S3Trigger.EVENTS,
26
25
  actionName: 'S3Trigger',
27
26
  bucket: s3.Bucket.fromBucketName(scope, 'TriggerBucket', aws_cdk_lib_1.Fn.importValue('bitbucket-integration-s3-bucket')),
28
- bucketKey: `${props.repositoryName}/trigger/${(_b = props.triggerKey) !== null && _b !== void 0 ? _b : DEFAULT_TRIGGER_KEY}`,
27
+ bucketKey: `${props.repositoryName}/trigger/${props.triggerKey ?? DEFAULT_TRIGGER_KEY}`,
29
28
  output: props.sourceArtifact,
30
29
  });
31
30
  }
@@ -33,4 +32,4 @@ class RioBitBucketSourceAction extends codepipeline_actions.S3SourceAction {
33
32
  exports.RioBitBucketSourceAction = RioBitBucketSourceAction;
34
33
  _a = JSII_RTTI_SYMBOL_1;
35
34
  RioBitBucketSourceAction[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.RioBitBucketSourceAction", version: "0.0.0" };
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmlvLWJpdGJ1Y2tldC1zb3VyY2UtYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BpcGVsaW5lL3Jpby1iaXRidWNrZXQtc291cmNlLWFjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUFpQztBQUVqQyw2RUFBNkU7QUFDN0UseUNBQXlDO0FBR3pDLElBQVksVUFTWDtBQVRELFdBQVksVUFBVTtJQUNwQjs7T0FFRztJQUNILDZDQUErQixDQUFBO0lBQy9COztPQUVHO0lBQ0gsNkNBQStCLENBQUE7QUFDakMsQ0FBQyxFQVRXLFVBQVUsR0FBVixrQkFBVSxLQUFWLGtCQUFVLFFBU3JCO0FBV0QsTUFBYSx3QkFBeUIsU0FBUSxvQkFBb0IsQ0FBQyxjQUFjO0lBRS9FLFlBQVksS0FBZ0IsRUFBRSxLQUFvQzs7UUFDaEUsTUFBTSxtQkFBbUIsR0FBRyxVQUFVLENBQUMsV0FBVyxDQUFDO1FBQ25ELEtBQUssQ0FBQztZQUNKLE9BQU8sRUFBRSxvQkFBb0IsQ0FBQyxTQUFTLENBQUMsTUFBTTtZQUM5QyxVQUFVLEVBQUUsV0FBVztZQUN2QixNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBSyxFQUFFLGVBQWUsRUFBRSxnQkFBRSxDQUFDLFdBQVcsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO1lBQzNHLFNBQVMsRUFBRSxHQUFHLEtBQUssQ0FBQyxjQUFjLFlBQVksTUFBQSxLQUFLLENBQUMsVUFBVSxtQ0FBSSxtQkFBbUIsRUFBRTtZQUN2RixNQUFNLEVBQUUsS0FBSyxDQUFDLGNBQWM7U0FDN0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7QUFYSCw0REFZQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZuIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgY29kZXBpcGVsaW5lIGZyb20gJ2F3cy1jZGstbGliL2F3cy1jb2RlcGlwZWxpbmUnO1xuaW1wb3J0ICogYXMgY29kZXBpcGVsaW5lX2FjdGlvbnMgZnJvbSAnYXdzLWNkay1saWIvYXdzLWNvZGVwaXBlbGluZS1hY3Rpb25zJztcbmltcG9ydCAqIGFzIHMzIGZyb20gJ2F3cy1jZGstbGliL2F3cy1zMyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcblxuZXhwb3J0IGVudW0gVHJpZ2dlcktleSB7XG4gIC8qKlxuICAgKiBwb2ludHMgdG8gbWFzdGVyX3JlcG8uemlwXG4gICAqL1xuICBNQVNURVJfUkVQTyA9ICdtYXN0ZXJfcmVwby56aXAnLFxuICAvKipcbiAgICogcG9pbnRzIHRvIGJyYW5jaF9yZXBvLnppcFxuICAgKi9cbiAgQlJBTkNIX1JFUE8gPSAnYnJhbmNoX3JlcG8uemlwJyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSaW9CaXRCdWNrZXRTb3VyY2VBY3Rpb25Qcm9wcyB7XG4gIHJlYWRvbmx5IHJlcG9zaXRvcnlOYW1lOiBzdHJpbmc7XG4gIHJlYWRvbmx5IHNvdXJjZUFydGlmYWN0OiBjb2RlcGlwZWxpbmUuQXJ0aWZhY3Q7XG4gIC8qKlxuICAgKiBUaGUgcGF0aCB0byBlaXRoZXIgbWFzdGVyX3JlcG8uemlwIG9yIGJyYW5jaF9yZXBvLnppcFxuICAgKiBAZGVmYXVsdCAtIFBvaW50cyB0byBtYXN0ZXJfcmVwby56aXAuXG4gICAqL1xuICByZWFkb25seSB0cmlnZ2VyS2V5PzogVHJpZ2dlcktleTtcbn1cbmV4cG9ydCBjbGFzcyBSaW9CaXRCdWNrZXRTb3VyY2VBY3Rpb24gZXh0ZW5kcyBjb2RlcGlwZWxpbmVfYWN0aW9ucy5TM1NvdXJjZUFjdGlvbiB7XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgcHJvcHM6IFJpb0JpdEJ1Y2tldFNvdXJjZUFjdGlvblByb3BzKSB7XG4gICAgY29uc3QgREVGQVVMVF9UUklHR0VSX0tFWSA9IFRyaWdnZXJLZXkuTUFTVEVSX1JFUE87XG4gICAgc3VwZXIoe1xuICAgICAgdHJpZ2dlcjogY29kZXBpcGVsaW5lX2FjdGlvbnMuUzNUcmlnZ2VyLkVWRU5UUyxcbiAgICAgIGFjdGlvbk5hbWU6ICdTM1RyaWdnZXInLFxuICAgICAgYnVja2V0OiBzMy5CdWNrZXQuZnJvbUJ1Y2tldE5hbWUoc2NvcGUsICdUcmlnZ2VyQnVja2V0JywgRm4uaW1wb3J0VmFsdWUoJ2JpdGJ1Y2tldC1pbnRlZ3JhdGlvbi1zMy1idWNrZXQnKSksXG4gICAgICBidWNrZXRLZXk6IGAke3Byb3BzLnJlcG9zaXRvcnlOYW1lfS90cmlnZ2VyLyR7cHJvcHMudHJpZ2dlcktleSA/PyBERUZBVUxUX1RSSUdHRVJfS0VZfWAsXG4gICAgICBvdXRwdXQ6IHByb3BzLnNvdXJjZUFydGlmYWN0LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmlvLWJpdGJ1Y2tldC1zb3VyY2UtYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3BpcGVsaW5lL3Jpby1iaXRidWNrZXQtc291cmNlLWFjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUFpQztBQUVqQyw2RUFBNkU7QUFDN0UseUNBQXlDO0FBR3pDLElBQVksVUFTWDtBQVRELFdBQVksVUFBVTtJQUNwQjs7T0FFRztJQUNILDZDQUErQixDQUFBO0lBQy9COztPQUVHO0lBQ0gsNkNBQStCLENBQUE7QUFDakMsQ0FBQyxFQVRXLFVBQVUsR0FBVixrQkFBVSxLQUFWLGtCQUFVLFFBU3JCO0FBV0QsTUFBYSx3QkFBeUIsU0FBUSxvQkFBb0IsQ0FBQyxjQUFjO0lBRS9FLFlBQVksS0FBZ0IsRUFBRSxLQUFvQztRQUNoRSxNQUFNLG1CQUFtQixHQUFHLFVBQVUsQ0FBQyxXQUFXLENBQUM7UUFDbkQsS0FBSyxDQUFDO1lBQ0osT0FBTyxFQUFFLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxNQUFNO1lBQzlDLFVBQVUsRUFBRSxXQUFXO1lBQ3ZCLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxLQUFLLEVBQUUsZUFBZSxFQUFFLGdCQUFFLENBQUMsV0FBVyxDQUFDLGlDQUFpQyxDQUFDLENBQUM7WUFDM0csU0FBUyxFQUFFLEdBQUcsS0FBSyxDQUFDLGNBQWMsWUFBWSxLQUFLLENBQUMsVUFBVSxJQUFJLG1CQUFtQixFQUFFO1lBQ3ZGLE1BQU0sRUFBRSxLQUFLLENBQUMsY0FBYztTQUM3QixDQUFDLENBQUM7SUFDTCxDQUFDOztBQVhILDREQVlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm4gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBjb2RlcGlwZWxpbmUgZnJvbSAnYXdzLWNkay1saWIvYXdzLWNvZGVwaXBlbGluZSc7XG5pbXBvcnQgKiBhcyBjb2RlcGlwZWxpbmVfYWN0aW9ucyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY29kZXBpcGVsaW5lLWFjdGlvbnMnO1xuaW1wb3J0ICogYXMgczMgZnJvbSAnYXdzLWNkay1saWIvYXdzLXMzJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG5leHBvcnQgZW51bSBUcmlnZ2VyS2V5IHtcbiAgLyoqXG4gICAqIHBvaW50cyB0byBtYXN0ZXJfcmVwby56aXBcbiAgICovXG4gIE1BU1RFUl9SRVBPID0gJ21hc3Rlcl9yZXBvLnppcCcsXG4gIC8qKlxuICAgKiBwb2ludHMgdG8gYnJhbmNoX3JlcG8uemlwXG4gICAqL1xuICBCUkFOQ0hfUkVQTyA9ICdicmFuY2hfcmVwby56aXAnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJpb0JpdEJ1Y2tldFNvdXJjZUFjdGlvblByb3BzIHtcbiAgcmVhZG9ubHkgcmVwb3NpdG9yeU5hbWU6IHN0cmluZztcbiAgcmVhZG9ubHkgc291cmNlQXJ0aWZhY3Q6IGNvZGVwaXBlbGluZS5BcnRpZmFjdDtcbiAgLyoqXG4gICAqIFRoZSBwYXRoIHRvIGVpdGhlciBtYXN0ZXJfcmVwby56aXAgb3IgYnJhbmNoX3JlcG8uemlwXG4gICAqIEBkZWZhdWx0IC0gUG9pbnRzIHRvIG1hc3Rlcl9yZXBvLnppcC5cbiAgICovXG4gIHJlYWRvbmx5IHRyaWdnZXJLZXk/OiBUcmlnZ2VyS2V5O1xufVxuZXhwb3J0IGNsYXNzIFJpb0JpdEJ1Y2tldFNvdXJjZUFjdGlvbiBleHRlbmRzIGNvZGVwaXBlbGluZV9hY3Rpb25zLlMzU291cmNlQWN0aW9uIHtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBwcm9wczogUmlvQml0QnVja2V0U291cmNlQWN0aW9uUHJvcHMpIHtcbiAgICBjb25zdCBERUZBVUxUX1RSSUdHRVJfS0VZID0gVHJpZ2dlcktleS5NQVNURVJfUkVQTztcbiAgICBzdXBlcih7XG4gICAgICB0cmlnZ2VyOiBjb2RlcGlwZWxpbmVfYWN0aW9ucy5TM1RyaWdnZXIuRVZFTlRTLFxuICAgICAgYWN0aW9uTmFtZTogJ1MzVHJpZ2dlcicsXG4gICAgICBidWNrZXQ6IHMzLkJ1Y2tldC5mcm9tQnVja2V0TmFtZShzY29wZSwgJ1RyaWdnZXJCdWNrZXQnLCBGbi5pbXBvcnRWYWx1ZSgnYml0YnVja2V0LWludGVncmF0aW9uLXMzLWJ1Y2tldCcpKSxcbiAgICAgIGJ1Y2tldEtleTogYCR7cHJvcHMucmVwb3NpdG9yeU5hbWV9L3RyaWdnZXIvJHtwcm9wcy50cmlnZ2VyS2V5ID8/IERFRkFVTFRfVFJJR0dFUl9LRVl9YCxcbiAgICAgIG91dHB1dDogcHJvcHMuc291cmNlQXJ0aWZhY3QsXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
@@ -22,7 +22,6 @@ var ComparisonOperator;
22
22
  })(ComparisonOperator = exports.ComparisonOperator || (exports.ComparisonOperator = {}));
23
23
  class DataDogLogAlarm extends constructs_1.Construct {
24
24
  constructor(scope, id, props) {
25
- var _b;
26
25
  super(scope, id);
27
26
  new aws_cdk_lib_1.CustomResource(this, 'DDMonitor', {
28
27
  serviceToken: props.serviceToken,
@@ -37,7 +36,7 @@ class DataDogLogAlarm extends constructs_1.Construct {
37
36
  type: 'log alert',
38
37
  priority: props.priority,
39
38
  query: this.alarmToDataDogQuery(props),
40
- name: `${(_b = this.node.scope) === null || _b === void 0 ? void 0 : _b.node.id} ${id}`,
39
+ name: `${this.node.scope?.node.id} ${id}`,
41
40
  message: `${props.alarmDescription}: {{log.link}}`,
42
41
  options: {
43
42
  notify_audit: false,
@@ -69,7 +68,7 @@ class DataDogLogAlarm extends constructs_1.Construct {
69
68
  return `logs("${concatenatedFilters}").index("${alarm.index}").rollup("${alarm.statistic}").last("${periodValue}${periodUnit}") ${comparisonOperator} ${alarm.threshold}`;
70
69
  }
71
70
  convertToDatadogPeriod(period, unitOfPeriod) {
72
- const unit = unitOfPeriod !== null && unitOfPeriod !== void 0 ? unitOfPeriod : DEFAULT_UNIT_OF_PERIOD;
71
+ const unit = unitOfPeriod ?? DEFAULT_UNIT_OF_PERIOD;
73
72
  const mapPeriodToDatadogTime = {
74
73
  [UnitOfPeriod.SECONDS]: () => period.toSeconds(),
75
74
  [UnitOfPeriod.MINUTES]: () => period.toMinutes(),
@@ -85,4 +84,4 @@ class DataDogLogAlarm extends constructs_1.Construct {
85
84
  exports.DataDogLogAlarm = DataDogLogAlarm;
86
85
  _a = JSII_RTTI_SYMBOL_1;
87
86
  DataDogLogAlarm[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.DataDogLogAlarm", version: "0.0.0" };
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-log-alarm.js","sourceRoot":"","sources":["../../src/watchful/datadog-log-alarm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Stack, CustomResource } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\n\nexport interface DataDogLogQueryAlarmProps extends DataDogProps, LogAlarmProps {\n}\n\nexport enum UnitOfPeriod {\n  SECONDS = 's',\n  MINUTES = 'm',\n  HOURS = 'h',\n  DAYS = 'd',\n}\n\nconst DEFAULT_UNIT_OF_PERIOD = UnitOfPeriod.SECONDS;\n\nexport enum ComparisonOperator {\n  GREATER_THAN_OR_EQUAL_TO_THRESHOLD = '>=',\n  GREATER_THAN_THRESHOLD = '>',\n  LESS_THAN_OR_EQUAL_TO_THRESHOLD = '<=',\n  LESS_THAN_THRESHOLD = '<',\n}\n\nexport interface DataDogProps {\n  readonly serviceToken: string; // points to DD monitor custom resource lambda or sns topic\n  readonly serviceName: string; // needs to match the service name used in datadog-integration\n}\n\nexport interface LogAlarmProps {\n  readonly autoCloseOpsGenieAlerts: boolean;\n  readonly period: Duration;\n  readonly unitOfPeriod?: UnitOfPeriod; // unit which will be used to create the alert. if none is provided the periods unit will default to seconds\n  readonly periodOperator: ComparisonOperator;\n  readonly statistic: 'count'; // aggregation function\n  readonly queryFilters: 'error'|'warn'; // it should either say error or warn\n  readonly alarmDescription: string;\n  readonly threshold: number;\n  readonly priority: number;\n  readonly index: string;\n}\n\nexport class DataDogLogAlarm extends Construct {\n  constructor(scope: Construct, id: string, props: DataDogLogQueryAlarmProps) {\n    super(scope, id);\n\n    new CustomResource(this, 'DDMonitor', {\n      serviceToken: props.serviceToken,\n      pascalCaseProperties: true,\n      resourceType: 'Custom::DataDogMonitor',\n      properties: {\n        alertTypes: ['opsgenie'], // alert Type is needed to integrate with OpsGenie and to set the autoCloseOpsGenieAlerts option\n        autoCloseOpsGenieAlerts: props.autoCloseOpsGenieAlerts,\n        ServiceName: props.serviceName,\n        version: '1.0.0',\n        monitor: {\n          type: 'log alert',\n          priority: props.priority,\n          query: this.alarmToDataDogQuery(props),\n          name: `${this.node.scope?.node.id} ${id}`, // datadog-integration custom resource prepend it with Team and ServiceName\n          message: `${props.alarmDescription}: {{log.link}}`,\n          options: {\n            notify_audit: false,\n            locked: false,\n            silenced: {},\n            include_tags: true,\n            require_full_window: false,\n            notify_no_data: false,\n            escalation_message: '',\n            enable_logs_sample: true,\n            renotify_interval: 10,\n            renotify_statuses: ['alert'],\n          },\n        },\n      },\n    });\n  }\n\n  private alarmToDataDogQuery(alarm: DataDogLogQueryAlarmProps): string {\n\n    const [periodValue, periodUnit] = this.convertToDatadogPeriod(alarm.period, alarm.unitOfPeriod);\n\n    let comparisonOperator = alarm.periodOperator;\n\n    const filters = new Map([\n      ['service', alarm.serviceName],\n      ['account_id', Stack.of(this).account],\n      ['status', alarm.queryFilters],\n    ]);\n\n    const concatenatedFilters = Array.from(filters.entries())\n      .map(([filterKey, filterValue]) => `${filterKey}:${filterValue}`)\n      .join(' ');\n\n    return `logs(\"${concatenatedFilters}\").index(\"${alarm.index}\").rollup(\"${alarm.statistic}\").last(\"${periodValue}${periodUnit}\") ${comparisonOperator} ${alarm.threshold}`;\n  }\n\n  private convertToDatadogPeriod(period: Duration, unitOfPeriod?: UnitOfPeriod): [number, string] {\n    const unit = unitOfPeriod ?? DEFAULT_UNIT_OF_PERIOD;\n    const mapPeriodToDatadogTime = {\n      [UnitOfPeriod.SECONDS]: () => period.toSeconds(),\n      [UnitOfPeriod.MINUTES]: () => period.toMinutes(),\n      [UnitOfPeriod.HOURS]: () => period.toHours(),\n      [UnitOfPeriod.DAYS]: () => period.toDays(),\n    };\n    return [\n      mapPeriodToDatadogTime[unit](),\n      unit.toString(),\n    ];\n  }\n}"]}
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-log-alarm.js","sourceRoot":"","sources":["../../src/watchful/datadog-log-alarm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Stack, CustomResource } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\n\nexport interface DataDogLogQueryAlarmProps extends DataDogProps, LogAlarmProps {\n}\n\nexport enum UnitOfPeriod {\n  SECONDS = 's',\n  MINUTES = 'm',\n  HOURS = 'h',\n  DAYS = 'd',\n}\n\nconst DEFAULT_UNIT_OF_PERIOD = UnitOfPeriod.SECONDS;\n\nexport enum ComparisonOperator {\n  GREATER_THAN_OR_EQUAL_TO_THRESHOLD = '>=',\n  GREATER_THAN_THRESHOLD = '>',\n  LESS_THAN_OR_EQUAL_TO_THRESHOLD = '<=',\n  LESS_THAN_THRESHOLD = '<',\n}\n\nexport interface DataDogProps {\n  readonly serviceToken: string; // points to DD monitor custom resource lambda or sns topic\n  readonly serviceName: string; // needs to match the service name used in datadog-integration\n}\n\nexport interface LogAlarmProps {\n  readonly autoCloseOpsGenieAlerts: boolean;\n  readonly period: Duration;\n  readonly unitOfPeriod?: UnitOfPeriod; // unit which will be used to create the alert. if none is provided the periods unit will default to seconds\n  readonly periodOperator: ComparisonOperator;\n  readonly statistic: 'count'; // aggregation function\n  readonly queryFilters: 'error'|'warn'; // it should either say error or warn\n  readonly alarmDescription: string;\n  readonly threshold: number;\n  readonly priority: number;\n  readonly index: string;\n}\n\nexport class DataDogLogAlarm extends Construct {\n  constructor(scope: Construct, id: string, props: DataDogLogQueryAlarmProps) {\n    super(scope, id);\n\n    new CustomResource(this, 'DDMonitor', {\n      serviceToken: props.serviceToken,\n      pascalCaseProperties: true,\n      resourceType: 'Custom::DataDogMonitor',\n      properties: {\n        alertTypes: ['opsgenie'], // alert Type is needed to integrate with OpsGenie and to set the autoCloseOpsGenieAlerts option\n        autoCloseOpsGenieAlerts: props.autoCloseOpsGenieAlerts,\n        ServiceName: props.serviceName,\n        version: '1.0.0',\n        monitor: {\n          type: 'log alert',\n          priority: props.priority,\n          query: this.alarmToDataDogQuery(props),\n          name: `${this.node.scope?.node.id} ${id}`, // datadog-integration custom resource prepend it with Team and ServiceName\n          message: `${props.alarmDescription}: {{log.link}}`,\n          options: {\n            notify_audit: false,\n            locked: false,\n            silenced: {},\n            include_tags: true,\n            require_full_window: false,\n            notify_no_data: false,\n            escalation_message: '',\n            enable_logs_sample: true,\n            renotify_interval: 10,\n            renotify_statuses: ['alert'],\n          },\n        },\n      },\n    });\n  }\n\n  private alarmToDataDogQuery(alarm: DataDogLogQueryAlarmProps): string {\n\n    const [periodValue, periodUnit] = this.convertToDatadogPeriod(alarm.period, alarm.unitOfPeriod);\n\n    let comparisonOperator = alarm.periodOperator;\n\n    const filters = new Map([\n      ['service', alarm.serviceName],\n      ['account_id', Stack.of(this).account],\n      ['status', alarm.queryFilters],\n    ]);\n\n    const concatenatedFilters = Array.from(filters.entries())\n      .map(([filterKey, filterValue]) => `${filterKey}:${filterValue}`)\n      .join(' ');\n\n    return `logs(\"${concatenatedFilters}\").index(\"${alarm.index}\").rollup(\"${alarm.statistic}\").last(\"${periodValue}${periodUnit}\") ${comparisonOperator} ${alarm.threshold}`;\n  }\n\n  private convertToDatadogPeriod(period: Duration, unitOfPeriod?: UnitOfPeriod): [number, string] {\n    const unit = unitOfPeriod ?? DEFAULT_UNIT_OF_PERIOD;\n    const mapPeriodToDatadogTime = {\n      [UnitOfPeriod.SECONDS]: () => period.toSeconds(),\n      [UnitOfPeriod.MINUTES]: () => period.toMinutes(),\n      [UnitOfPeriod.HOURS]: () => period.toHours(),\n      [UnitOfPeriod.DAYS]: () => period.toDays(),\n    };\n    return [\n      mapPeriodToDatadogTime[unit](),\n      unit.toString(),\n    ];\n  }\n}"]}