@rio-cloud/cdk-v2-constructs 7.6.0 → 7.8.1-alpha.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.
@@ -1,10 +1,11 @@
1
1
  "use strict";
2
- var _a;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.DatadogSharedSecret = void 0;
4
+ exports.DatadogSharedCredentials = exports.DatadogSharedSecret = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const path = require("path");
7
7
  const cdk = require("aws-cdk-lib");
8
+ const ecs = require("aws-cdk-lib/aws-ecs");
8
9
  const iam = require("aws-cdk-lib/aws-iam");
9
10
  const lambda = require("aws-cdk-lib/aws-lambda");
10
11
  const logs = require("aws-cdk-lib/aws-logs");
@@ -20,32 +21,7 @@ const sharedEuSecretArnPrefix = (region) => `arn:aws:secretsmanager:${region}:${
20
21
  const RESOURCE_ID = '__OrgCredentialsSecret__';
21
22
  const API_KEY_RESOURCE_ID = '__DatadogApiKeySharedSecret__';
22
23
  const CREDENTIALS_RESOURCE_ID = '__DatadogCredentialsSharedSecret__';
23
- /**
24
- * A custom resource that resolves the secret ARN based on the organization ID.
25
- */
26
- class DatadogSharedSecret extends constructs.Construct {
27
- /**
28
- * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.
29
- */
30
- static apiKeySecret(scope) {
31
- const id = API_KEY_RESOURCE_ID;
32
- const stack = cdk.Stack.of(scope);
33
- if (stack.node.tryFindChild(id)) {
34
- return stack.node.findChild(id);
35
- }
36
- return new DatadogSharedSecret(stack, id, { secretName: 'shared-api-key' });
37
- }
38
- /**
39
- * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].
40
- */
41
- static credentialsSecret(scope) {
42
- const id = CREDENTIALS_RESOURCE_ID;
43
- const stack = cdk.Stack.of(scope);
44
- if (stack.node.tryFindChild(id)) {
45
- return stack.node.findChild(id);
46
- }
47
- return new DatadogSharedSecret(scope, id, { secretName: 'shared-credentials' });
48
- }
24
+ class SharedSecret extends constructs.Construct {
49
25
  static setupCustomResource(stack) {
50
26
  const secretLocatorLambda = new lambda.Function(stack, 'ResolveSecretArnHandler', {
51
27
  code: lambda.Code.fromAsset(path.join(__dirname, 'secret-locator-custom-resource'), {
@@ -79,11 +55,11 @@ class DatadogSharedSecret extends constructs.Construct {
79
55
  new cdk.Tag('Watchful', 'false').visit(provider.node.findChild('framework-onEvent').node.defaultChild);
80
56
  return provider;
81
57
  }
82
- constructor(scope, id, props) {
58
+ constructor(scope, id, secretName) {
83
59
  super(scope, id);
84
60
  const stack = cdk.Stack.of(this);
85
61
  if (!stack.node.tryFindChild(RESOURCE_ID)) {
86
- this.customResource = DatadogSharedSecret.setupCustomResource(stack);
62
+ this.customResource = SharedSecret.setupCustomResource(stack);
87
63
  }
88
64
  else {
89
65
  this.customResource = stack.node.findChild(RESOURCE_ID);
@@ -92,7 +68,7 @@ class DatadogSharedSecret extends constructs.Construct {
92
68
  serviceToken: this.customResource.serviceToken,
93
69
  pascalCaseProperties: true,
94
70
  properties: {
95
- secretName: props.secretName,
71
+ secretName: secretName,
96
72
  },
97
73
  });
98
74
  this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());
@@ -156,7 +132,53 @@ class DatadogSharedSecret extends constructs.Construct {
156
132
  throw new Error('Method not allowed.');
157
133
  }
158
134
  }
135
+ /**
136
+ * A custom resource that resolves the Datadog API keys from a shared secret
137
+ * @example
138
+ * const datadogApiKey = DatadogSharedSecret.apiKeySecret(this);
139
+ *
140
+ * const datadogSecret = DatadogSharedSecret.credentialsSecret(this);
141
+ * const datadogSite = datadogSecret.getSecret('Site');
142
+ * const datadogApiKey = datadogSecret.getSecret('ApiKey');
143
+ * const datadogApiKeyValue = datadogSecret.getSecretValue('ApiKey');
144
+ * const datadogApiKeyValue = datadogSecret.getSecretValue('ApplicationKey');
145
+ */
146
+ class DatadogSharedSecret extends SharedSecret {
147
+ /**
148
+ * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.
149
+ */
150
+ static apiKeySecret(scope) {
151
+ const id = API_KEY_RESOURCE_ID;
152
+ const stack = cdk.Stack.of(scope);
153
+ if (stack.node.tryFindChild(id)) {
154
+ return stack.node.findChild(id);
155
+ }
156
+ return new DatadogSharedSecret(stack, id, 'shared-api-key');
157
+ }
158
+ /**
159
+ * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].
160
+ */
161
+ static credentialsSecret(scope) {
162
+ const id = CREDENTIALS_RESOURCE_ID;
163
+ const stack = cdk.Stack.of(scope);
164
+ if (stack.node.tryFindChild(id)) {
165
+ return stack.node.findChild(id);
166
+ }
167
+ return new DatadogSharedCredentials(scope, id, 'shared-credentials');
168
+ }
169
+ }
159
170
  exports.DatadogSharedSecret = DatadogSharedSecret;
160
171
  _a = JSII_RTTI_SYMBOL_1;
161
172
  DatadogSharedSecret[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedSecret", version: "0.0.0" };
162
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-shared-secrets.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-shared-secrets.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\n\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as sec from 'aws-cdk-lib/aws-secretsmanager';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport * as constructs from 'constructs';\nimport { DEFAULT_NODE_RUNTIME } from '../constants';\n\n\nconst EU_LANDING_ZONE_ORG_ID: string = 'o-r5jfl7mbr9';\nconst LATAM_LANDING_ZONE_ORG_ID: string = 'o-5j12ut524w';\n\nconst DEVELOPER_TOOLS_ACCOUNT_ID: string = '577146897785';\n\nconst sharedLatamSecretArnPrefix = (region: string) => `arn:aws:secretsmanager:${region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/latam`;\nconst sharedEuSecretArnPrefix = (region: string) => `arn:aws:secretsmanager:${region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/eu`;\n\nconst RESOURCE_ID = '__OrgCredentialsSecret__';\nconst API_KEY_RESOURCE_ID = '__DatadogApiKeySharedSecret__';\nconst CREDENTIALS_RESOURCE_ID = '__DatadogCredentialsSharedSecret__';\n\n/**\n * A custom resource that resolves the secret ARN based on the organization ID.\n */\nexport class DatadogSharedSecret extends constructs.Construct implements sec.ISecret {\n\n  /**\n   * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.\n   */\n  static apiKeySecret(scope: constructs.Construct) {\n    const id = API_KEY_RESOURCE_ID;\n    const stack = cdk.Stack.of(scope);\n    if (stack.node.tryFindChild(id)) {\n      return stack.node.findChild(id) as DatadogSharedSecret;\n    }\n    return new DatadogSharedSecret(stack, id, { secretName: 'shared-api-key' });\n  }\n\n  /**\n   * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].\n   */\n  static credentialsSecret(scope: constructs.Construct) {\n    const id = CREDENTIALS_RESOURCE_ID;\n    const stack = cdk.Stack.of(scope);\n    if (stack.node.tryFindChild(id)) {\n      return stack.node.findChild(id) as DatadogSharedSecret;\n    }\n    return new DatadogSharedSecret(scope, id, { secretName: 'shared-credentials' });\n  }\n\n  private static setupCustomResource(stack: cdk.Stack): cr.Provider {\n    const secretLocatorLambda = new lambda.Function(stack, 'ResolveSecretArnHandler', {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'secret-locator-custom-resource'), {\n        exclude: ['*.js', '*.d.ts'],\n      }),\n      handler: 'on-create.handler',\n      runtime: DEFAULT_NODE_RUNTIME,\n      architecture: lambda.Architecture.ARM_64,\n      logGroup: new logs.LogGroup(stack, 'DatadogSharedSecretHandlerLogGroup', {\n        retention: logs.RetentionDays.ONE_WEEK,\n      }),\n      timeout: cdk.Duration.minutes(6),\n      environment: {\n        SHARED_LATAM_SECRET_ARN_PREFIX: sharedLatamSecretArnPrefix(stack.region),\n        SHARED_EU_SECRET_ARN_PREFIX: sharedEuSecretArnPrefix(stack.region),\n        LATAM_LANDING_ZONE_ORG_ID: LATAM_LANDING_ZONE_ORG_ID,\n        EU_LANDING_ZONE_ORG_ID: EU_LANDING_ZONE_ORG_ID,\n      },\n    });\n    // to prevent issues with order of aspects in CDK, we need to add the tag directly.\n    new cdk.Tag('Watchful', 'false').visit(secretLocatorLambda.node.defaultChild!);\n\n    secretLocatorLambda.addToRolePolicy(new iam.PolicyStatement({ actions: ['organizations:DescribeOrganization'], resources: ['*'] }));\n    secretLocatorLambda.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: ['secretsmanager:DescribeSecret'],\n        resources: [`arn:aws:secretsmanager:${stack.region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:*`],\n      }),\n    );\n\n    const provider = new cr.Provider(stack, RESOURCE_ID, {\n      onEventHandler: secretLocatorLambda,\n    });\n    // to prevent issues with order of aspects in CDK, we need to add the tag directly.\n    new cdk.Tag('Watchful', 'false').visit(provider.node.findChild('framework-onEvent').node.defaultChild!);\n    return provider;\n  }\n\n  private secret: sec.ISecret;\n  private customResource: cr.Provider;\n\n  private constructor(scope: constructs.IConstruct, id: string, props: {secretName: string}) {\n    super(scope, id);\n\n    const stack = cdk.Stack.of(this);\n    if (!stack.node.tryFindChild(RESOURCE_ID)) {\n      this.customResource = DatadogSharedSecret.setupCustomResource(stack);\n    } else {\n      this.customResource = stack.node.findChild(RESOURCE_ID) as cr.Provider;\n    }\n\n    const secretLocator = new cdk.CustomResource(this, 'DatadogSharedSecret', {\n      serviceToken: this.customResource.serviceToken,\n      pascalCaseProperties: true,\n      properties: {\n        secretName: props.secretName,\n      },\n    });\n\n    this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());\n  }\n\n  get stack(): cdk.Stack {\n    return this.secret.stack;\n  }\n\n  get env(): cdk.ResourceEnvironment {\n    return this.secret.env;\n  }\n\n  get encryptionKey() : cdk.aws_kms.IKey | undefined {\n    return undefined;\n  }\n\n  get secretArn(): string {\n    return this.secret.secretArn;\n  };\n\n  get secretFullArn(): string | undefined {\n    return this.secret.secretFullArn;\n  }\n\n  get secretName(): string {\n    return this.secret.secretName;\n  }\n\n  get secretValue(): cdk.SecretValue {\n    return this.secret.secretValue;\n  }\n\n  secretValueFromJson(key: string): cdk.SecretValue {\n    return this.secret.secretValueFromJson(key);\n  }\n\n  grantRead(grantee: iam.IGrantable, versionStages?: string[]): iam.Grant {\n    const result = grantee.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['kms:Decrypt'],\n      resources: [`arn:aws:kms:*:${DEVELOPER_TOOLS_ACCOUNT_ID}:key/*`],\n      conditions: {\n        'ForAnyValue:StringLike': {\n          'kms:ResourceAliases': 'alias/datadog-integration-shared-credentials-key',\n        },\n      },\n    }));\n    if (!result.statementAdded) {\n      cdk.Annotations.of(this).addWarning('Could not add statement to the principal policy.');\n    }\n    return this.secret.grantRead(grantee, versionStages);\n  }\n\n  grantWrite(_grantee: iam.IGrantable): iam.Grant {\n    throw new Error('Method not allowed.');\n  }\n\n  addRotationSchedule(_id: string, _options: sec.RotationScheduleOptions): sec.RotationSchedule {\n    throw new Error('Method not allowed.');\n  }\n\n  addToResourcePolicy(_statement: iam.PolicyStatement): iam.AddToResourcePolicyResult {\n    throw new Error('Method not allowed.');\n  }\n\n  denyAccountRootDelete(): void {\n    throw new Error('Method not allowed.');\n  }\n\n  attach(_target: sec.ISecretAttachmentTarget): sec.ISecret {\n    throw new Error('Method not allowed.');\n  }\n\n  applyRemovalPolicy(_policy: cdk.RemovalPolicy): void {\n    throw new Error('Method not allowed.');\n  }\n\n}\n"]}
173
+ class DatadogSharedCredentials extends SharedSecret {
174
+ getSecretValue(field) {
175
+ return this.secret.secretValueFromJson(field);
176
+ }
177
+ getSecret(field) {
178
+ return ecs.Secret.fromSecretsManager(this.secret, field);
179
+ }
180
+ }
181
+ exports.DatadogSharedCredentials = DatadogSharedCredentials;
182
+ _b = JSII_RTTI_SYMBOL_1;
183
+ DatadogSharedCredentials[_b] = { fqn: "@rio-cloud/cdk-v2-constructs.datadogv2.DatadogSharedCredentials", version: "0.0.0" };
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-shared-secrets.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-shared-secrets.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\n\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as sec from 'aws-cdk-lib/aws-secretsmanager';\nimport * as cr from 'aws-cdk-lib/custom-resources';\nimport * as constructs from 'constructs';\nimport { DEFAULT_NODE_RUNTIME } from '../constants';\n\n\nconst EU_LANDING_ZONE_ORG_ID: string = 'o-r5jfl7mbr9';\nconst LATAM_LANDING_ZONE_ORG_ID: string = 'o-5j12ut524w';\n\nconst DEVELOPER_TOOLS_ACCOUNT_ID: string = '577146897785';\n\nconst sharedLatamSecretArnPrefix = (region: string) => `arn:aws:secretsmanager:${region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/latam`;\nconst sharedEuSecretArnPrefix = (region: string) => `arn:aws:secretsmanager:${region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:/datadog-integration/eu`;\n\nconst RESOURCE_ID = '__OrgCredentialsSecret__';\nconst API_KEY_RESOURCE_ID = '__DatadogApiKeySharedSecret__';\nconst CREDENTIALS_RESOURCE_ID = '__DatadogCredentialsSharedSecret__';\n\nabstract class SharedSecret extends constructs.Construct implements sec.ISecret {\n  private static setupCustomResource(stack: cdk.Stack): cr.Provider {\n    const secretLocatorLambda = new lambda.Function(stack, 'ResolveSecretArnHandler', {\n      code: lambda.Code.fromAsset(path.join(__dirname, 'secret-locator-custom-resource'), {\n        exclude: ['*.js', '*.d.ts'],\n      }),\n      handler: 'on-create.handler',\n      runtime: DEFAULT_NODE_RUNTIME,\n      architecture: lambda.Architecture.ARM_64,\n      logGroup: new logs.LogGroup(stack, 'DatadogSharedSecretHandlerLogGroup', {\n        retention: logs.RetentionDays.ONE_WEEK,\n      }),\n      timeout: cdk.Duration.minutes(6),\n      environment: {\n        SHARED_LATAM_SECRET_ARN_PREFIX: sharedLatamSecretArnPrefix(stack.region),\n        SHARED_EU_SECRET_ARN_PREFIX: sharedEuSecretArnPrefix(stack.region),\n        LATAM_LANDING_ZONE_ORG_ID: LATAM_LANDING_ZONE_ORG_ID,\n        EU_LANDING_ZONE_ORG_ID: EU_LANDING_ZONE_ORG_ID,\n      },\n    });\n    // to prevent issues with order of aspects in CDK, we need to add the tag directly.\n    new cdk.Tag('Watchful', 'false').visit(secretLocatorLambda.node.defaultChild!);\n\n    secretLocatorLambda.addToRolePolicy(new iam.PolicyStatement({ actions: ['organizations:DescribeOrganization'], resources: ['*'] }));\n    secretLocatorLambda.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: ['secretsmanager:DescribeSecret'],\n        resources: [`arn:aws:secretsmanager:${stack.region}:${DEVELOPER_TOOLS_ACCOUNT_ID}:secret:*`],\n      }),\n    );\n\n    const provider = new cr.Provider(stack, RESOURCE_ID, {\n      onEventHandler: secretLocatorLambda,\n    });\n    // to prevent issues with order of aspects in CDK, we need to add the tag directly.\n    new cdk.Tag('Watchful', 'false').visit(provider.node.findChild('framework-onEvent').node.defaultChild!);\n    return provider;\n  }\n  protected readonly secret: sec.ISecret;\n\n  private customResource: cr.Provider;\n\n  protected constructor(scope: constructs.IConstruct, id: string, secretName: string ) {\n    super(scope, id);\n\n    const stack = cdk.Stack.of(this);\n    if (!stack.node.tryFindChild(RESOURCE_ID)) {\n      this.customResource = SharedSecret.setupCustomResource(stack);\n    } else {\n      this.customResource = stack.node.findChild(RESOURCE_ID) as cr.Provider;\n    }\n\n    const secretLocator = new cdk.CustomResource(this, 'DatadogSharedSecret', {\n      serviceToken: this.customResource.serviceToken,\n      pascalCaseProperties: true,\n      properties: {\n        secretName: secretName,\n      },\n    });\n\n    this.secret = sec.Secret.fromSecretCompleteArn(this, 'Resource', secretLocator.getAtt('SecretArn').toString());\n  }\n\n  get stack(): cdk.Stack {\n    return this.secret.stack;\n  }\n\n  get env(): cdk.ResourceEnvironment {\n    return this.secret.env;\n  }\n\n  get encryptionKey() : cdk.aws_kms.IKey | undefined {\n    return undefined;\n  }\n\n  get secretArn(): string {\n    return this.secret.secretArn;\n  };\n\n  get secretFullArn(): string | undefined {\n    return this.secret.secretFullArn;\n  }\n\n  get secretName(): string {\n    return this.secret.secretName;\n  }\n\n  get secretValue(): cdk.SecretValue {\n    return this.secret.secretValue;\n  }\n\n  secretValueFromJson(key: string): cdk.SecretValue {\n    return this.secret.secretValueFromJson(key);\n  }\n\n  grantRead(grantee: iam.IGrantable, versionStages?: string[]): iam.Grant {\n    const result = grantee.grantPrincipal.addToPrincipalPolicy(new iam.PolicyStatement({\n      actions: ['kms:Decrypt'],\n      resources: [`arn:aws:kms:*:${DEVELOPER_TOOLS_ACCOUNT_ID}:key/*`],\n      conditions: {\n        'ForAnyValue:StringLike': {\n          'kms:ResourceAliases': 'alias/datadog-integration-shared-credentials-key',\n        },\n      },\n    }));\n    if (!result.statementAdded) {\n      cdk.Annotations.of(this).addWarning('Could not add statement to the principal policy.');\n    }\n    return this.secret.grantRead(grantee, versionStages);\n  }\n\n  grantWrite(_grantee: iam.IGrantable): iam.Grant {\n    throw new Error('Method not allowed.');\n  }\n\n  addRotationSchedule(_id: string, _options: sec.RotationScheduleOptions): sec.RotationSchedule {\n    throw new Error('Method not allowed.');\n  }\n\n  addToResourcePolicy(_statement: iam.PolicyStatement): iam.AddToResourcePolicyResult {\n    throw new Error('Method not allowed.');\n  }\n\n  denyAccountRootDelete(): void {\n    throw new Error('Method not allowed.');\n  }\n\n  attach(_target: sec.ISecretAttachmentTarget): sec.ISecret {\n    throw new Error('Method not allowed.');\n  }\n\n  applyRemovalPolicy(_policy: cdk.RemovalPolicy): void {\n    throw new Error('Method not allowed.');\n  }\n}\n\n/**\n * A custom resource that resolves the Datadog API keys from a shared secret\n * @example\n * const datadogApiKey = DatadogSharedSecret.apiKeySecret(this);\n *\n * const datadogSecret = DatadogSharedSecret.credentialsSecret(this);\n * const datadogSite = datadogSecret.getSecret('Site');\n * const datadogApiKey = datadogSecret.getSecret('ApiKey');\n * const datadogApiKeyValue = datadogSecret.getSecretValue('ApiKey');\n * const datadogApiKeyValue = datadogSecret.getSecretValue('ApplicationKey');\n */\nexport class DatadogSharedSecret extends SharedSecret {\n\n  /**\n   * This static function resolves to the plain api-key secret, that can be used for the log forwarder or the Lambda instrumentation.\n   */\n  static apiKeySecret(scope: constructs.Construct): DatadogSharedSecret {\n    const id = API_KEY_RESOURCE_ID;\n    const stack = cdk.Stack.of(scope);\n    if (stack.node.tryFindChild(id)) {\n      return stack.node.findChild(id) as DatadogSharedSecret;\n    }\n    return new DatadogSharedSecret(stack, id, 'shared-api-key');\n  }\n\n  /**\n   * This static function resolves to the json credentials secret that contains ['ApiKey', 'ApplicationKey', 'Site'].\n   */\n  static credentialsSecret(scope: constructs.Construct): DatadogSharedCredentials {\n    const id = CREDENTIALS_RESOURCE_ID;\n    const stack = cdk.Stack.of(scope);\n    if (stack.node.tryFindChild(id)) {\n      return stack.node.findChild(id) as DatadogSharedCredentials;\n    }\n    return new DatadogSharedCredentials(scope, id, 'shared-credentials');\n  }\n\n}\n\ntype Field = 'ApplicationKey' | 'Site' | 'ApiKey'\n\nexport class DatadogSharedCredentials extends SharedSecret {\n\n  getSecretValue(field: Field) {\n    return this.secret.secretValueFromJson(field);\n  }\n\n  getSecret(field: Field) {\n    return ecs.Secret.fromSecretsManager(this.secret, field);\n\n  }\n\n}"]}
@@ -1,5 +1,4 @@
1
1
  import * as ecs from 'aws-cdk-lib/aws-ecs';
2
- import * as ssm from 'aws-cdk-lib/aws-ssm';
3
2
  import { Construct } from 'constructs';
4
3
  import { DataDogLoggingMode, RioFargateService } from './rio-fargate-service';
5
4
  import { RioFargateServiceBlueGreenAlpha } from './rio-fargate-service-blue-green-alpha';
@@ -15,11 +14,11 @@ export declare class DataDog {
15
14
  static getFargateDockerLabels(stage: string, serviceName: string, version: string): {
16
15
  [key: string]: string;
17
16
  };
18
- static addDatadogSidecar(scope: Construct, taskDefinition: ecs.TaskDefinition, accountName: string, teamName: string, teamIdentifier: string, stage: string, serviceName: string, version: string, datadogApiKeyParameter: ssm.IStringParameter, datadogSite: string, datadogLoggingMode: DataDogLoggingMode, apmGetResourcesToIgnore: string[], cpu: number, memoryLimitMiB: number, essential: boolean, containerTag: string, additionalTags: {
17
+ static addDatadogSidecar(scope: Construct, taskDefinition: ecs.TaskDefinition, accountName: string, teamName: string, teamIdentifier: string, stage: string, serviceName: string, version: string, datadogApiKey: ecs.Secret, datadogSite: string, datadogLoggingMode: DataDogLoggingMode, apmGetResourcesToIgnore: string[], cpu: number, memoryLimitMiB: number, essential: boolean, containerTag: string, additionalTags: {
19
18
  [k: string]: string;
20
19
  } | undefined, enableRestartPolicy: boolean, restartIgnoredExitCodes: number[]): ecs.ContainerDefinition;
21
20
  static addFireLensLogRouter(taskDefinition: ecs.TaskDefinition, cpu: number, memoryLimitMiB: number, firelensConfigFilePath: string, firelensConfigBucketArn: string, serviceName: string): ecs.ContainerDefinition;
22
- static setupLogging(scope: Construct, accountName: string, teamName: string, teamIdentifier: string, stage: string, serviceName: string, version: string, datadogApiKeyParameter: ssm.IStringParameter, datadogLoggingMode: DataDogLoggingMode, datadogSite: string, containerType: 'service' | 'datadog-sidecar', additionalTags: {
21
+ static setupLogging(scope: Construct, accountName: string, teamName: string, teamIdentifier: string, stage: string, serviceName: string, version: string, datadogApiKey: ecs.Secret, datadogLoggingMode: DataDogLoggingMode, datadogSite: string, containerType: 'service' | 'datadog-sidecar', additionalTags: {
23
22
  [k: string]: string;
24
23
  } | undefined): ecs.LogDriver;
25
24
  static ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService): void;
@@ -54,7 +53,7 @@ export declare function addDatadogSidecar(props: {
54
53
  stage: string;
55
54
  serviceName: string;
56
55
  version: string;
57
- datadogApiKeyParameter: ssm.IStringParameter;
56
+ datadogApiKey: ecs.Secret;
58
57
  datadogSite: string;
59
58
  datadogLoggingMode: DataDogLoggingMode;
60
59
  apmGetResourcesToIgnore: string[];
@@ -88,7 +87,7 @@ export declare function setupLogging(props: {
88
87
  stage: string;
89
88
  serviceName: string;
90
89
  version: string;
91
- datadogApiKeyParameter: ssm.IStringParameter;
90
+ datadogApiKey: ecs.Secret;
92
91
  datadogLoggingMode: DataDogLoggingMode;
93
92
  datadogSite: string;
94
93
  containerType: 'service' | 'datadog-sidecar';
@@ -35,7 +35,7 @@ class DataDog {
35
35
  static getFargateDockerLabels(stage, serviceName, version) {
36
36
  return getFargateDockerLabels({ stage, serviceName, version });
37
37
  }
38
- static addDatadogSidecar(scope, taskDefinition, accountName, teamName, teamIdentifier, stage, serviceName, version, datadogApiKeyParameter, datadogSite, datadogLoggingMode, apmGetResourcesToIgnore, cpu, memoryLimitMiB, essential, containerTag, additionalTags, enableRestartPolicy, restartIgnoredExitCodes) {
38
+ static addDatadogSidecar(scope, taskDefinition, accountName, teamName, teamIdentifier, stage, serviceName, version, datadogApiKey, datadogSite, datadogLoggingMode, apmGetResourcesToIgnore, cpu, memoryLimitMiB, essential, containerTag, additionalTags, enableRestartPolicy, restartIgnoredExitCodes) {
39
39
  return addDatadogSidecar({
40
40
  scope,
41
41
  taskDefinition,
@@ -45,7 +45,7 @@ class DataDog {
45
45
  stage,
46
46
  serviceName,
47
47
  version,
48
- datadogApiKeyParameter,
48
+ datadogApiKey,
49
49
  datadogSite,
50
50
  datadogLoggingMode,
51
51
  apmGetResourcesToIgnore,
@@ -61,7 +61,7 @@ class DataDog {
61
61
  static addFireLensLogRouter(taskDefinition, cpu, memoryLimitMiB, firelensConfigFilePath, firelensConfigBucketArn, serviceName) {
62
62
  return addFireLensLogRouter({ taskDefinition, cpu, memoryLimitMiB, firelensConfigFilePath, firelensConfigBucketArn, serviceName });
63
63
  }
64
- static setupLogging(scope, accountName, teamName, teamIdentifier, stage, serviceName, version, datadogApiKeyParameter, datadogLoggingMode, datadogSite, containerType, additionalTags) {
64
+ static setupLogging(scope, accountName, teamName, teamIdentifier, stage, serviceName, version, datadogApiKey, datadogLoggingMode, datadogSite, containerType, additionalTags) {
65
65
  return setupLogging({
66
66
  scope,
67
67
  accountName,
@@ -70,7 +70,7 @@ class DataDog {
70
70
  stage,
71
71
  serviceName,
72
72
  version,
73
- datadogApiKeyParameter,
73
+ datadogApiKey,
74
74
  datadogLoggingMode,
75
75
  datadogSite,
76
76
  containerType,
@@ -156,7 +156,7 @@ function addDatadogSidecar(props) {
156
156
  command: ['CMD-SHELL', '/probe.sh'],
157
157
  },
158
158
  secrets: {
159
- DD_API_KEY: ecs.Secret.fromSsmParameter(props.datadogApiKeyParameter),
159
+ DD_API_KEY: props.datadogApiKey,
160
160
  },
161
161
  essential: props.essential,
162
162
  });
@@ -267,7 +267,7 @@ function setupLogging(props) {
267
267
  Match: '*',
268
268
  Host: `http-intake.logs.${props.datadogSite}`,
269
269
  TLS: 'on',
270
- apikey: props.datadogApiKeyParameter.stringValue,
270
+ apiKey: props.datadogApiKey.toString(),
271
271
  compress: 'gzip',
272
272
  dd_service: logGroupName,
273
273
  dd_source: 'rio-fargate',
@@ -333,4 +333,4 @@ function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService
333
333
  }
334
334
  }
335
335
  }
336
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog.js","sourceRoot":"","sources":["../../src/fargate/datadog.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Fn, Size, Stack, Tags } from 'aws-cdk-lib';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { AwsLogDriverMode } from 'aws-cdk-lib/aws-ecs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { DataDogLoggingMode, RioFargateService } from './rio-fargate-service';\nimport { RioFargateServiceBlueGreenAlpha } from './rio-fargate-service-blue-green-alpha';\n\n/**\n * @deprecated Moved out static methods and imporoved signature. Use named import instead.\n */\nexport class DataDog {\n\n  public static getFargateContainerEnvironmentVariables(\n    scope: Construct,\n    stage: string,\n    serviceName: string,\n    version: string,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    additionalTags: { [k: string]: string} | undefined,\n  ): { [key: string]: string } {\n    return getFargateContainerEnvironmentVariables({\n      scope,\n      stage,\n      serviceName,\n      version,\n      accountName,\n      teamName,\n      teamIdentifier,\n      additionalTags,\n    });\n  }\n\n  public static getFargateDockerLabels(stage: string, serviceName: string, version: string): { [key: string]: string } {\n    return getFargateDockerLabels({ stage, serviceName, version });\n  }\n\n  public static addDatadogSidecar(\n    scope: Construct,\n    taskDefinition: ecs.TaskDefinition,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    stage: string,\n    serviceName: string,\n    version: string,\n    datadogApiKeyParameter: ssm.IStringParameter,\n    datadogSite: string,\n    datadogLoggingMode: DataDogLoggingMode,\n    apmGetResourcesToIgnore: string[],\n    cpu: number,\n    memoryLimitMiB: number,\n    essential: boolean,\n    containerTag: string,\n    additionalTags: { [k: string]: string} | undefined,\n    enableRestartPolicy: boolean,\n    restartIgnoredExitCodes: number[],\n  ): ecs.ContainerDefinition {\n\n    return addDatadogSidecar({\n      scope,\n      taskDefinition,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKeyParameter,\n      datadogSite,\n      datadogLoggingMode,\n      apmGetResourcesToIgnore,\n      cpu,\n      memoryLimitMiB,\n      essential,\n      containerTag,\n      additionalTags,\n      enableRestartPolicy,\n      restartIgnoredExitCodes,\n    });\n  }\n\n  public static addFireLensLogRouter(\n    taskDefinition: ecs.TaskDefinition,\n    cpu: number,\n    memoryLimitMiB: number,\n    firelensConfigFilePath: string,\n    firelensConfigBucketArn: string,\n    serviceName: string,\n  ): ecs.ContainerDefinition {\n    return addFireLensLogRouter({ taskDefinition, cpu, memoryLimitMiB, firelensConfigFilePath, firelensConfigBucketArn, serviceName });\n  }\n\n  public static setupLogging(\n    scope: Construct,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    stage: string,\n    serviceName: string,\n    version: string,\n    datadogApiKeyParameter: ssm.IStringParameter,\n    datadogLoggingMode: DataDogLoggingMode,\n    datadogSite: string,\n    containerType: 'service' | 'datadog-sidecar',\n    additionalTags: { [k: string]: string} | undefined,\n  ): ecs.LogDriver {\n\n    return setupLogging({\n      scope,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKeyParameter,\n      datadogLoggingMode,\n      datadogSite,\n      containerType,\n      additionalTags,\n    });\n  }\n\n  public static ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService) {\n    ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService);\n  }\n}\n\nexport function getFargateContainerEnvironmentVariables(props: {\n  scope: Construct;\n  stage: string;\n  serviceName: string;\n  version: string;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  additionalTags: { [k: string]: string} | undefined;\n}): { [key: string]: string } {\n\n  const { account: accountId, region } = Stack.of(props.scope);\n\n  return {\n    // unified tagging, see https://docs.datadoghq.com/getting_started/tagging/unified_service_tagging/?tab=ecs\n    DD_ENV: props.stage,\n    DD_SERVICE: props.serviceName,\n    DD_VERSION: props.version,\n    // APM and tracing, see https://docs.datadoghq.com/tracing/setup_overview/setup/java/?tab=containers\n    DD_LOGS_INJECTION: 'true',\n    DD_SERVICE_MAPPING: getApmServiceMappingEnvironmentVariableValue(props.serviceName),\n    DD_TAGS: getTagsEnvironmentVariableValue({\n      ...props,\n      containerType: 'service',\n      accountId,\n      region,\n    }),\n    DD_TRACE_SAMPLE_RATE: '1.0', // see https://ddtrace.readthedocs.io/en/stable/configuration.html\n  };\n}\n\n// we add all possible service mappings here even if not used in a particular service to get globally unique names\nfunction getApmServiceMappingEnvironmentVariableValue(serviceName: string): string {\n\n  const serviceMapping = {\n    'database': `${serviceName}-aurora`,\n    'java-aws-sdk': `${serviceName}-aws-sdk`,\n    'kafka': `${serviceName}-kafka`,\n    'mysql': `${serviceName}-aurora`,\n    'redis': `${serviceName}-redis`,\n  };\n\n  return Object.entries(serviceMapping)\n    .map(([key, value]) => `${key}:${value}`)\n    .join(',');\n}\n\nexport function getFargateDockerLabels(props: {stage: string; serviceName: string; version: string}): { [key: string]: string } {\n  return {\n    'com.datadoghq.tags.env': props.stage,\n    'com.datadoghq.tags.service': props.serviceName,\n    'com.datadoghq.tags.version': props.version,\n  };\n}\n\nexport function addDatadogSidecar(props: {\n  scope: Construct;\n  taskDefinition: ecs.TaskDefinition;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  datadogApiKeyParameter: ssm.IStringParameter;\n  datadogSite: string;\n  datadogLoggingMode: DataDogLoggingMode;\n  apmGetResourcesToIgnore: string[];\n  cpu: number;\n  memoryLimitMiB: number;\n  essential: boolean;\n  containerTag: string;\n  additionalTags: { [k: string]: string} | undefined;\n  enableRestartPolicy: boolean;\n  restartIgnoredExitCodes: number[] | undefined;\n}): ecs.ContainerDefinition {\n\n  const { account: accountId, region } = Stack.of(props.scope);\n  const datadogSidecar = props.taskDefinition.addContainer('datadog-agent', {\n    image: ecs.ContainerImage.fromRegistry(`public.ecr.aws/datadog/agent:${props.containerTag}`),\n    enableRestartPolicy: props.enableRestartPolicy,\n    restartIgnoredExitCodes: props.restartIgnoredExitCodes,\n    logging: setupLogging({ ...props, containerType: 'datadog-sidecar' }),\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\n    environment: {\n      // unified tagging, see https://docs.datadoghq.com/getting_started/tagging/unified_service_tagging/?tab=ecs\n      DD_ENV: props.stage,\n      DD_SERVICE: props.serviceName,\n      DD_VERSION: props.version,\n      // APM and tracing see https://docs.datadoghq.com/agent/docker/apm/?tab=linux\n      DD_APM_ENABLED: 'true',\n      DD_APM_IGNORE_RESOURCES: props.apmGetResourcesToIgnore\n        .map((apmGetResourceToIgnore) => `GET ${apmGetResourceToIgnore}`)\n        .join(','),\n      // general settings\n      DD_SITE: props.datadogSite,\n      DD_TAGS: getTagsEnvironmentVariableValue({ ...props, accountId, region, containerType: 'datadog-sidecar' }),\n      ECS_FARGATE: 'true',\n      DD_CLOUD_PROVIDER_METADATA: 'aws',\n      DD_REMOTE_CONFIGURATION_ENABLED: 'false',\n    },\n    // see https://github.com/DataDog/datadog-agent/blob/master/Dockerfiles/agent/amd64/Dockerfile#L171-L172\n    healthCheck: {\n      startPeriod: Duration.minutes(2),\n      interval: Duration.seconds(30),\n      timeout: Duration.seconds(5),\n      retries: 2,\n      command: ['CMD-SHELL', '/probe.sh'],\n    },\n    secrets: {\n      DD_API_KEY: ecs.Secret.fromSsmParameter(props.datadogApiKeyParameter),\n    },\n    essential: props.essential,\n  });\n\n  datadogSidecar.addPortMappings({\n    containerPort: 8125,\n    protocol: ecs.Protocol.UDP,\n  });\n\n  datadogSidecar.addPortMappings({\n    containerPort: 8126,\n    protocol: ecs.Protocol.TCP,\n  });\n\n  return datadogSidecar;\n}\n\nexport function addFirelensConfigUploadFromS3Permissions(props: {\n  taskDefinition: ecs.TaskDefinition;\n  firelensConfigBucketArn: string;\n}) {\n  props.taskDefinition.addToTaskRolePolicy(new iam.PolicyStatement({\n    resources: [props.firelensConfigBucketArn, `${props.firelensConfigBucketArn}/*`],\n    actions: ['s3:Get*'],\n    effect: iam.Effect.ALLOW,\n  }));\n}\n\nfunction getTagsEnvironmentVariableValue(props: {\n  accountId: string;\n  accountName: string;\n  region: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  containerType: 'service' | 'datadog-sidecar' | 'fluent-bit';\n  additionalTags: { [k: string]: string} | undefined;\n}): string {\n\n  const separator = determineSeparator(props.containerType);\n\n  const tags = {\n    // unified tagging\n    // overridden by dedicated settings (environment variables/tags)\n    // duplicated here to ensure they are used (and sometimes, not all three values are supported)\n    env: props.stage,\n    service: props.serviceName,\n    version: props.version,\n    // account/team specific parts\n    account_id: props.accountId,\n    account_name: props.accountName,\n    region: props.region,\n    team: props.teamName,\n    team_identifier: props.teamIdentifier,\n  };\n  return Object.entries({ ...tags, ...props.additionalTags })\n    .map(([key, value]) => `${key}:${value}`)\n    .join(separator);\n}\n\nfunction determineSeparator(containerType: 'service' | 'datadog-sidecar' | 'fluent-bit') {\n  if (containerType === 'datadog-sidecar') {\n    return ' ';\n  } else {\n    return ',';\n  }\n}\n\nexport function addFireLensLogRouter(props: {\n  taskDefinition: ecs.TaskDefinition;\n  cpu: number;\n  memoryLimitMiB: number;\n  firelensConfigBucketArn: string;\n  firelensConfigFilePath: string;\n  serviceName: string;\n}): ecs.ContainerDefinition {\n  const fluentBitS3ConfigFile = props.firelensConfigBucketArn + props.firelensConfigFilePath;\n\n  const fireLensLogRouterImage = ssm.StringParameter.fromStringParameterAttributes(props.taskDefinition, 'FluentBitImageTag', {\n    parameterName: '/aws/service/aws-for-fluent-bit/init-2.32.2.20240820',\n    // If this property is not set, it will always return the latest version.\n    // This leads to a non-deterministic behavior.\n    // Updating this name/version is a potential breaking change\n    version: 1,\n  }).stringValue;\n\n  return props.taskDefinition.addFirelensLogRouter('firelens-log-router', {\n    image: ecs.ContainerImage.fromRegistry(fireLensLogRouterImage),\n    firelensConfig: {\n      type: ecs.FirelensLogRouterType.FLUENTBIT,\n      options: {\n        enableECSLogMetadata: true,\n      },\n    },\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\n    logging: ecs.LogDrivers.awsLogs({\n      logGroup: new logs.LogGroup(props.taskDefinition, 'FirelensLogRouterLogGroup', {\n        logGroupName: `${props.serviceName}-firelens-log-router`,\n      }),\n      streamPrefix: 'firelens-log-router',\n      mode: AwsLogDriverMode.NON_BLOCKING,\n    }),\n    healthCheck: {\n      command: ['CMD-SHELL', 'curl --fail --silent http://127.0.0.1:2020/api/v1/health || exit 1'],\n    },\n    environment: {\n      aws_fluent_bit_init_s3_1: fluentBitS3ConfigFile,\n    },\n  });\n}\n\nexport function setupLogging(props: {\n  scope: Construct;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  datadogApiKeyParameter: ssm.IStringParameter;\n  datadogLoggingMode: DataDogLoggingMode;\n  datadogSite: string;\n  containerType: 'service' | 'datadog-sidecar';\n  additionalTags: { [k: string]: string} | undefined;\n}): ecs.LogDriver {\n\n  let logGroupName: string;\n  let logGroupId: string;\n  let containerTypeCamelCase;\n\n  switch (props.containerType) {\n\n    case 'service':\n      logGroupId = 'LogGroupForService';\n      logGroupName = props.serviceName;\n      containerTypeCamelCase = 'Service';\n      break;\n\n    case 'datadog-sidecar':\n      logGroupId = 'LogGroupForDatadogSidecar';\n      logGroupName = `${props.serviceName}-${props.containerType}`;\n      containerTypeCamelCase = 'DatadogSidecar';\n      break;\n  }\n\n  const { account: accountId, region } = Stack.of(props.scope);\n\n  switch (props.datadogLoggingMode) {\n\n    case DataDogLoggingMode.AWS_FIRE_LENS:\n      // TODO can we use `secretOptions` here as well, e.g. as in https://github.com/aws-samples/amazon-ecs-firelens-examples/blob/mainline/examples/fluent-bit/datadog/task-definition.json#L33-L36\n      // Probably not, see https://github.com/aws/aws-cdk/issues/8174\n      return ecs.LogDrivers.firelens({\n        // see https://docs.datadoghq.com/integrations/fluentbit/#configuration-parameters\n        options: {\n          Name: 'datadog',\n          Match: '*',\n          Host: `http-intake.logs.${props.datadogSite}`,\n          TLS: 'on',\n          apikey: props.datadogApiKeyParameter.stringValue,\n          compress: 'gzip',\n          dd_service: logGroupName,\n          dd_source: 'rio-fargate',\n          dd_message_key: 'log',\n          dd_tags: getTagsEnvironmentVariableValue({ ...props, accountId, region, containerType: 'fluent-bit' }),\n          provider: 'ecs',\n        },\n      });\n\n    case DataDogLoggingMode.FORWARDER_LAMBDA:\n    case DataDogLoggingMode.DATADOG_FORWARDER_LAMBDA:\n      const logGroupForForwardingLambda = new logs.LogGroup(props.scope, logGroupId, {\n        logGroupName,\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      Tags.of(logGroupForForwardingLambda).add('service', props.serviceName);\n      const logForwarderLambdaArnOutputName = props.datadogLoggingMode === DataDogLoggingMode.DATADOG_FORWARDER_LAMBDA ? 'datadog-forwarder-ForwarderArn' : 'custom-resource-datadog-logforwarder-function-arn';\n      const logForwarderLambdaArn = Fn.importValue(logForwarderLambdaArnOutputName);\n      const cfnPermission = new lambda.CfnPermission(props.scope, `LogForwarderPermission${containerTypeCamelCase}`, {\n        action: 'lambda:InvokeFunction',\n        functionName: logForwarderLambdaArn,\n        principal: `logs.${region}.amazonaws.com`,\n        sourceArn: logGroupForForwardingLambda.logGroupArn,\n      });\n      const cfnSubscriptionFilter = new logs.CfnSubscriptionFilter(\n        props.scope,\n        `LogForwarderSubscriptionFilter${containerTypeCamelCase}`,\n        {\n          destinationArn: logForwarderLambdaArn,\n          filterPattern: '',\n          logGroupName: logGroupForForwardingLambda.logGroupName,\n        },\n      );\n      cfnSubscriptionFilter.addDependency(cfnPermission);\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupForForwardingLambda,\n        mode: ecs.AwsLogDriverMode.NON_BLOCKING,\n        maxBufferSize: Size.mebibytes(25),\n      });\n\n    case DataDogLoggingMode.NONE:\n      const logGroupInCloudwatchOnly = new logs.LogGroup(props.scope, logGroupId, {\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupInCloudwatchOnly,\n        mode: ecs.AwsLogDriverMode.NON_BLOCKING,\n        maxBufferSize: Size.mebibytes(25),\n      });\n  }\n}\n\nexport function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService | RioFargateServiceBlueGreenAlpha): void {\n\n  rioFargateService.serviceContainerDefinition.addContainerDependencies({\n    container: rioFargateService.datadogSideCarContainerDefinition,\n    condition: ecs.ContainerDependencyCondition.HEALTHY,\n  });\n\n  if (rioFargateService.logRouterContainerDefinition) {\n    rioFargateService.serviceContainerDefinition.addContainerDependencies({\n      container: rioFargateService.logRouterContainerDefinition,\n      condition: ecs.ContainerDependencyCondition.START,\n    });\n\n    if (rioFargateService.datadogSideCarContainerDefinition.logDriverConfig?.logDriver === 'awsfirelens') {\n      rioFargateService.datadogSideCarContainerDefinition.addContainerDependencies({\n        container: rioFargateService.logRouterContainerDefinition,\n        condition: ecs.ContainerDependencyCondition.START,\n      });\n    }\n  }\n}\n"]}
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog.js","sourceRoot":"","sources":["../../src/fargate/datadog.ts"],"names":[],"mappings":";;;AAsIA,0FA6BC;AAkBD,wDAMC;AAED,8CAwEC;AAED,4FASC;AA4CD,oDA0CC;AAED,oCAqGC;AAED,sHAoBC;AAneD,6CAA8D;AAC9D,2CAA2C;AAC3C,iDAAuD;AACvD,2CAA2C;AAC3C,iDAAiD;AACjD,6CAA6C;AAC7C,2CAA2C;AAE3C,+DAA8E;AAG9E;;GAEG;AACH,MAAa,OAAO;IAEX,MAAM,CAAC,uCAAuC,CACnD,KAAgB,EAChB,KAAa,EACb,WAAmB,EACnB,OAAe,EACf,WAAmB,EACnB,QAAgB,EAChB,cAAsB,EACtB,cAAkD;QAElD,OAAO,uCAAuC,CAAC;YAC7C,KAAK;YACL,KAAK;YACL,WAAW;YACX,OAAO;YACP,WAAW;YACX,QAAQ;YACR,cAAc;YACd,cAAc;SACf,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,sBAAsB,CAAC,KAAa,EAAE,WAAmB,EAAE,OAAe;QACtF,OAAO,sBAAsB,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,CAAC;IACjE,CAAC;IAEM,MAAM,CAAC,iBAAiB,CAC7B,KAAgB,EAChB,cAAkC,EAClC,WAAmB,EACnB,QAAgB,EAChB,cAAsB,EACtB,KAAa,EACb,WAAmB,EACnB,OAAe,EACf,aAAyB,EACzB,WAAmB,EACnB,kBAAsC,EACtC,uBAAiC,EACjC,GAAW,EACX,cAAsB,EACtB,SAAkB,EAClB,YAAoB,EACpB,cAAkD,EAClD,mBAA4B,EAC5B,uBAAiC;QAGjC,OAAO,iBAAiB,CAAC;YACvB,KAAK;YACL,cAAc;YACd,WAAW;YACX,QAAQ;YACR,cAAc;YACd,KAAK;YACL,WAAW;YACX,OAAO;YACP,aAAa;YACb,WAAW;YACX,kBAAkB;YAClB,uBAAuB;YACvB,GAAG;YACH,cAAc;YACd,SAAS;YACT,YAAY;YACZ,cAAc;YACd,mBAAmB;YACnB,uBAAuB;SACxB,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAChC,cAAkC,EAClC,GAAW,EACX,cAAsB,EACtB,sBAA8B,EAC9B,uBAA+B,EAC/B,WAAmB;QAEnB,OAAO,oBAAoB,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,cAAc,EAAE,sBAAsB,EAAE,uBAAuB,EAAE,WAAW,EAAE,CAAC,CAAC;IACrI,CAAC;IAEM,MAAM,CAAC,YAAY,CACxB,KAAgB,EAChB,WAAmB,EACnB,QAAgB,EAChB,cAAsB,EACtB,KAAa,EACb,WAAmB,EACnB,OAAe,EACf,aAAyB,EACzB,kBAAsC,EACtC,WAAmB,EACnB,aAA4C,EAC5C,cAAkD;QAGlD,OAAO,YAAY,CAAC;YAClB,KAAK;YACL,WAAW;YACX,QAAQ;YACR,cAAc;YACd,KAAK;YACL,WAAW;YACX,OAAO;YACP,aAAa;YACb,kBAAkB;YAClB,WAAW;YACX,aAAa;YACb,cAAc;SACf,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,qDAAqD,CAAC,iBAAoC;QACtG,qDAAqD,CAAC,iBAAiB,CAAC,CAAC;IAC3E,CAAC;CACF;AAtHD,0BAsHC;AAED,SAAgB,uCAAuC,CAAC,KASvD;IAEC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAE7D,OAAO;QACL,2GAA2G;QAC3G,MAAM,EAAE,KAAK,CAAC,KAAK;QACnB,UAAU,EAAE,KAAK,CAAC,WAAW;QAC7B,UAAU,EAAE,KAAK,CAAC,OAAO;QACzB,oGAAoG;QACpG,iBAAiB,EAAE,MAAM;QACzB,kBAAkB,EAAE,4CAA4C,CAAC,KAAK,CAAC,WAAW,CAAC;QACnF,OAAO,EAAE,+BAA+B,CAAC;YACvC,GAAG,KAAK;YACR,aAAa,EAAE,SAAS;YACxB,SAAS;YACT,MAAM;SACP,CAAC;QACF,oBAAoB,EAAE,KAAK,EAAE,kEAAkE;KAChG,CAAC;AACJ,CAAC;AAED,kHAAkH;AAClH,SAAS,4CAA4C,CAAC,WAAmB;IAEvE,MAAM,cAAc,GAAG;QACrB,UAAU,EAAE,GAAG,WAAW,SAAS;QACnC,cAAc,EAAE,GAAG,WAAW,UAAU;QACxC,OAAO,EAAE,GAAG,WAAW,QAAQ;QAC/B,OAAO,EAAE,GAAG,WAAW,SAAS;QAChC,OAAO,EAAE,GAAG,WAAW,QAAQ;KAChC,CAAC;IAEF,OAAO,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC;SAClC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;SACxC,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC;AAED,SAAgB,sBAAsB,CAAC,KAA4D;IACjG,OAAO;QACL,wBAAwB,EAAE,KAAK,CAAC,KAAK;QACrC,4BAA4B,EAAE,KAAK,CAAC,WAAW;QAC/C,4BAA4B,EAAE,KAAK,CAAC,OAAO;KAC5C,CAAC;AACJ,CAAC;AAED,SAAgB,iBAAiB,CAAC,KAoBjC;IAEC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC7D,MAAM,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,eAAe,EAAE;QACxE,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,gCAAgC,KAAK,CAAC,YAAY,EAAE,CAAC;QAC5F,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;QAC9C,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;QACtD,OAAO,EAAE,YAAY,CAAC,EAAE,GAAG,KAAK,EAAE,aAAa,EAAE,iBAAiB,EAAE,CAAC;QACrE,GAAG,EAAE,KAAK,CAAC,GAAG;QACd,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,WAAW,EAAE;YACX,2GAA2G;YAC3G,MAAM,EAAE,KAAK,CAAC,KAAK;YACnB,UAAU,EAAE,KAAK,CAAC,WAAW;YAC7B,UAAU,EAAE,KAAK,CAAC,OAAO;YACzB,6EAA6E;YAC7E,cAAc,EAAE,MAAM;YACtB,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;iBACnD,GAAG,CAAC,CAAC,sBAAsB,EAAE,EAAE,CAAC,OAAO,sBAAsB,EAAE,CAAC;iBAChE,IAAI,CAAC,GAAG,CAAC;YACZ,mBAAmB;YACnB,OAAO,EAAE,KAAK,CAAC,WAAW;YAC1B,OAAO,EAAE,+BAA+B,CAAC,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,iBAAiB,EAAE,CAAC;YAC3G,WAAW,EAAE,MAAM;YACnB,0BAA0B,EAAE,KAAK;YACjC,+BAA+B,EAAE,OAAO;SACzC;QACD,wGAAwG;QACxG,WAAW,EAAE;YACX,WAAW,EAAE,sBAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAChC,QAAQ,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,OAAO,EAAE,sBAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAC5B,OAAO,EAAE,CAAC;YACV,OAAO,EAAE,CAAC,WAAW,EAAE,WAAW,CAAC;SACpC;QACD,OAAO,EAAE;YACP,UAAU,EAAE,KAAK,CAAC,aAAa;SAChC;QACD,SAAS,EAAE,KAAK,CAAC,SAAS;KAC3B,CAAC,CAAC;IAEH,cAAc,CAAC,eAAe,CAAC;QAC7B,aAAa,EAAE,IAAI;QACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,GAAG;KAC3B,CAAC,CAAC;IAEH,cAAc,CAAC,eAAe,CAAC;QAC7B,aAAa,EAAE,IAAI;QACnB,QAAQ,EAAE,GAAG,CAAC,QAAQ,CAAC,GAAG;KAC3B,CAAC,CAAC;IAEH,OAAO,cAAc,CAAC;AACxB,CAAC;AAED,SAAgB,wCAAwC,CAAC,KAGxD;IACC,KAAK,CAAC,cAAc,CAAC,mBAAmB,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC;QAC/D,SAAS,EAAE,CAAC,KAAK,CAAC,uBAAuB,EAAE,GAAG,KAAK,CAAC,uBAAuB,IAAI,CAAC;QAChF,OAAO,EAAE,CAAC,SAAS,CAAC;QACpB,MAAM,EAAE,GAAG,CAAC,MAAM,CAAC,KAAK;KACzB,CAAC,CAAC,CAAC;AACN,CAAC;AAED,SAAS,+BAA+B,CAAC,KAWxC;IAEC,MAAM,SAAS,GAAG,kBAAkB,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IAE1D,MAAM,IAAI,GAAG;QACX,kBAAkB;QAClB,gEAAgE;QAChE,8FAA8F;QAC9F,GAAG,EAAE,KAAK,CAAC,KAAK;QAChB,OAAO,EAAE,KAAK,CAAC,WAAW;QAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,8BAA8B;QAC9B,UAAU,EAAE,KAAK,CAAC,SAAS;QAC3B,YAAY,EAAE,KAAK,CAAC,WAAW;QAC/B,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,IAAI,EAAE,KAAK,CAAC,QAAQ;QACpB,eAAe,EAAE,KAAK,CAAC,cAAc;KACtC,CAAC;IACF,OAAO,MAAM,CAAC,OAAO,CAAC,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC,cAAc,EAAE,CAAC;SACxD,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;SACxC,IAAI,CAAC,SAAS,CAAC,CAAC;AACrB,CAAC;AAED,SAAS,kBAAkB,CAAC,aAA2D;IACrF,IAAI,aAAa,KAAK,iBAAiB,EAAE,CAAC;QACxC,OAAO,GAAG,CAAC;IACb,CAAC;SAAM,CAAC;QACN,OAAO,GAAG,CAAC;IACb,CAAC;AACH,CAAC;AAED,SAAgB,oBAAoB,CAAC,KAOpC;IACC,MAAM,qBAAqB,GAAG,KAAK,CAAC,uBAAuB,GAAG,KAAK,CAAC,sBAAsB,CAAC;IAE3F,MAAM,sBAAsB,GAAG,GAAG,CAAC,eAAe,CAAC,6BAA6B,CAAC,KAAK,CAAC,cAAc,EAAE,mBAAmB,EAAE;QAC1H,aAAa,EAAE,sDAAsD;QACrE,yEAAyE;QACzE,8CAA8C;QAC9C,4DAA4D;QAC5D,OAAO,EAAE,CAAC;KACX,CAAC,CAAC,WAAW,CAAC;IAEf,OAAO,KAAK,CAAC,cAAc,CAAC,oBAAoB,CAAC,qBAAqB,EAAE;QACtE,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,sBAAsB,CAAC;QAC9D,cAAc,EAAE;YACd,IAAI,EAAE,GAAG,CAAC,qBAAqB,CAAC,SAAS;YACzC,OAAO,EAAE;gBACP,oBAAoB,EAAE,IAAI;aAC3B;SACF;QACD,GAAG,EAAE,KAAK,CAAC,GAAG;QACd,cAAc,EAAE,KAAK,CAAC,cAAc;QACpC,OAAO,EAAE,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC;YAC9B,QAAQ,EAAE,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,EAAE,2BAA2B,EAAE;gBAC7E,YAAY,EAAE,GAAG,KAAK,CAAC,WAAW,sBAAsB;aACzD,CAAC;YACF,YAAY,EAAE,qBAAqB;YACnC,IAAI,EAAE,0BAAgB,CAAC,YAAY;SACpC,CAAC;QACF,WAAW,EAAE;YACX,OAAO,EAAE,CAAC,WAAW,EAAE,oEAAoE,CAAC;SAC7F;QACD,WAAW,EAAE;YACX,wBAAwB,EAAE,qBAAqB;SAChD;KACF,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,YAAY,CAAC,KAa5B;IAEC,IAAI,YAAoB,CAAC;IACzB,IAAI,UAAkB,CAAC;IACvB,IAAI,sBAAsB,CAAC;IAE3B,QAAQ,KAAK,CAAC,aAAa,EAAE,CAAC;QAE5B,KAAK,SAAS;YACZ,UAAU,GAAG,oBAAoB,CAAC;YAClC,YAAY,GAAG,KAAK,CAAC,WAAW,CAAC;YACjC,sBAAsB,GAAG,SAAS,CAAC;YACnC,MAAM;QAER,KAAK,iBAAiB;YACpB,UAAU,GAAG,2BAA2B,CAAC;YACzC,YAAY,GAAG,GAAG,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;YAC7D,sBAAsB,GAAG,gBAAgB,CAAC;YAC1C,MAAM;IACV,CAAC;IAED,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,mBAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAE7D,QAAQ,KAAK,CAAC,kBAAkB,EAAE,CAAC;QAEjC,KAAK,wCAAkB,CAAC,aAAa;YACnC,8LAA8L;YAC9L,+DAA+D;YAC/D,OAAO,GAAG,CAAC,UAAU,CAAC,QAAQ,CAAC;gBAC7B,kFAAkF;gBAClF,OAAO,EAAE;oBACP,IAAI,EAAE,SAAS;oBACf,KAAK,EAAE,GAAG;oBACV,IAAI,EAAE,oBAAoB,KAAK,CAAC,WAAW,EAAE;oBAC7C,GAAG,EAAE,IAAI;oBACT,MAAM,EAAE,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE;oBACtC,QAAQ,EAAE,MAAM;oBAChB,UAAU,EAAE,YAAY;oBACxB,SAAS,EAAE,aAAa;oBACxB,cAAc,EAAE,KAAK;oBACrB,OAAO,EAAE,+BAA+B,CAAC,EAAE,GAAG,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,CAAC;oBACtG,QAAQ,EAAE,KAAK;iBAChB;aACF,CAAC,CAAC;QAEL,KAAK,wCAAkB,CAAC,gBAAgB,CAAC;QACzC,KAAK,wCAAkB,CAAC,wBAAwB;YAC9C,MAAM,2BAA2B,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,EAAE,UAAU,EAAE;gBAC7E,YAAY;gBACZ,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;aACvC,CAAC,CAAC;YACH,kBAAI,CAAC,EAAE,CAAC,2BAA2B,CAAC,CAAC,GAAG,CAAC,SAAS,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;YACvE,MAAM,+BAA+B,GAAG,KAAK,CAAC,kBAAkB,KAAK,wCAAkB,CAAC,wBAAwB,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,mDAAmD,CAAC;YAC1M,MAAM,qBAAqB,GAAG,gBAAE,CAAC,WAAW,CAAC,+BAA+B,CAAC,CAAC;YAC9E,MAAM,aAAa,GAAG,IAAI,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,EAAE,yBAAyB,sBAAsB,EAAE,EAAE;gBAC7G,MAAM,EAAE,uBAAuB;gBAC/B,YAAY,EAAE,qBAAqB;gBACnC,SAAS,EAAE,QAAQ,MAAM,gBAAgB;gBACzC,SAAS,EAAE,2BAA2B,CAAC,WAAW;aACnD,CAAC,CAAC;YACH,MAAM,qBAAqB,GAAG,IAAI,IAAI,CAAC,qBAAqB,CAC1D,KAAK,CAAC,KAAK,EACX,iCAAiC,sBAAsB,EAAE,EACzD;gBACE,cAAc,EAAE,qBAAqB;gBACrC,aAAa,EAAE,EAAE;gBACjB,YAAY,EAAE,2BAA2B,CAAC,YAAY;aACvD,CACF,CAAC;YACF,qBAAqB,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;YACnD,OAAO,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC;gBAC5B,YAAY,EAAE,KAAK,CAAC,aAAa;gBACjC,QAAQ,EAAE,2BAA2B;gBACrC,IAAI,EAAE,GAAG,CAAC,gBAAgB,CAAC,YAAY;gBACvC,aAAa,EAAE,kBAAI,CAAC,SAAS,CAAC,EAAE,CAAC;aAClC,CAAC,CAAC;QAEL,KAAK,wCAAkB,CAAC,IAAI;YAC1B,MAAM,wBAAwB,GAAG,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,EAAE,UAAU,EAAE;gBAC1E,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;aACvC,CAAC,CAAC;YACH,OAAO,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC;gBAC5B,YAAY,EAAE,KAAK,CAAC,aAAa;gBACjC,QAAQ,EAAE,wBAAwB;gBAClC,IAAI,EAAE,GAAG,CAAC,gBAAgB,CAAC,YAAY;gBACvC,aAAa,EAAE,kBAAI,CAAC,SAAS,CAAC,EAAE,CAAC;aAClC,CAAC,CAAC;IACP,CAAC;AACH,CAAC;AAED,SAAgB,qDAAqD,CAAC,iBAAsE;IAE1I,iBAAiB,CAAC,0BAA0B,CAAC,wBAAwB,CAAC;QACpE,SAAS,EAAE,iBAAiB,CAAC,iCAAiC;QAC9D,SAAS,EAAE,GAAG,CAAC,4BAA4B,CAAC,OAAO;KACpD,CAAC,CAAC;IAEH,IAAI,iBAAiB,CAAC,4BAA4B,EAAE,CAAC;QACnD,iBAAiB,CAAC,0BAA0B,CAAC,wBAAwB,CAAC;YACpE,SAAS,EAAE,iBAAiB,CAAC,4BAA4B;YACzD,SAAS,EAAE,GAAG,CAAC,4BAA4B,CAAC,KAAK;SAClD,CAAC,CAAC;QAEH,IAAI,iBAAiB,CAAC,iCAAiC,CAAC,eAAe,EAAE,SAAS,KAAK,aAAa,EAAE,CAAC;YACrG,iBAAiB,CAAC,iCAAiC,CAAC,wBAAwB,CAAC;gBAC3E,SAAS,EAAE,iBAAiB,CAAC,4BAA4B;gBACzD,SAAS,EAAE,GAAG,CAAC,4BAA4B,CAAC,KAAK;aAClD,CAAC,CAAC;QACL,CAAC;IACH,CAAC;AACH,CAAC","sourcesContent":["import { Duration, Fn, Size, Stack, Tags } from 'aws-cdk-lib';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { AwsLogDriverMode } from 'aws-cdk-lib/aws-ecs';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct } from 'constructs';\nimport { DataDogLoggingMode, RioFargateService } from './rio-fargate-service';\nimport { RioFargateServiceBlueGreenAlpha } from './rio-fargate-service-blue-green-alpha';\n\n/**\n * @deprecated Moved out static methods and imporoved signature. Use named import instead.\n */\nexport class DataDog {\n\n  public static getFargateContainerEnvironmentVariables(\n    scope: Construct,\n    stage: string,\n    serviceName: string,\n    version: string,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    additionalTags: { [k: string]: string} | undefined,\n  ): { [key: string]: string } {\n    return getFargateContainerEnvironmentVariables({\n      scope,\n      stage,\n      serviceName,\n      version,\n      accountName,\n      teamName,\n      teamIdentifier,\n      additionalTags,\n    });\n  }\n\n  public static getFargateDockerLabels(stage: string, serviceName: string, version: string): { [key: string]: string } {\n    return getFargateDockerLabels({ stage, serviceName, version });\n  }\n\n  public static addDatadogSidecar(\n    scope: Construct,\n    taskDefinition: ecs.TaskDefinition,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    stage: string,\n    serviceName: string,\n    version: string,\n    datadogApiKey: ecs.Secret,\n    datadogSite: string,\n    datadogLoggingMode: DataDogLoggingMode,\n    apmGetResourcesToIgnore: string[],\n    cpu: number,\n    memoryLimitMiB: number,\n    essential: boolean,\n    containerTag: string,\n    additionalTags: { [k: string]: string} | undefined,\n    enableRestartPolicy: boolean,\n    restartIgnoredExitCodes: number[],\n  ): ecs.ContainerDefinition {\n\n    return addDatadogSidecar({\n      scope,\n      taskDefinition,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKey,\n      datadogSite,\n      datadogLoggingMode,\n      apmGetResourcesToIgnore,\n      cpu,\n      memoryLimitMiB,\n      essential,\n      containerTag,\n      additionalTags,\n      enableRestartPolicy,\n      restartIgnoredExitCodes,\n    });\n  }\n\n  public static addFireLensLogRouter(\n    taskDefinition: ecs.TaskDefinition,\n    cpu: number,\n    memoryLimitMiB: number,\n    firelensConfigFilePath: string,\n    firelensConfigBucketArn: string,\n    serviceName: string,\n  ): ecs.ContainerDefinition {\n    return addFireLensLogRouter({ taskDefinition, cpu, memoryLimitMiB, firelensConfigFilePath, firelensConfigBucketArn, serviceName });\n  }\n\n  public static setupLogging(\n    scope: Construct,\n    accountName: string,\n    teamName: string,\n    teamIdentifier: string,\n    stage: string,\n    serviceName: string,\n    version: string,\n    datadogApiKey: ecs.Secret,\n    datadogLoggingMode: DataDogLoggingMode,\n    datadogSite: string,\n    containerType: 'service' | 'datadog-sidecar',\n    additionalTags: { [k: string]: string} | undefined,\n  ): ecs.LogDriver {\n\n    return setupLogging({\n      scope,\n      accountName,\n      teamName,\n      teamIdentifier,\n      stage,\n      serviceName,\n      version,\n      datadogApiKey,\n      datadogLoggingMode,\n      datadogSite,\n      containerType,\n      additionalTags,\n    });\n  }\n\n  public static ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService) {\n    ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService);\n  }\n}\n\nexport function getFargateContainerEnvironmentVariables(props: {\n  scope: Construct;\n  stage: string;\n  serviceName: string;\n  version: string;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  additionalTags: { [k: string]: string} | undefined;\n}): { [key: string]: string } {\n\n  const { account: accountId, region } = Stack.of(props.scope);\n\n  return {\n    // unified tagging, see https://docs.datadoghq.com/getting_started/tagging/unified_service_tagging/?tab=ecs\n    DD_ENV: props.stage,\n    DD_SERVICE: props.serviceName,\n    DD_VERSION: props.version,\n    // APM and tracing, see https://docs.datadoghq.com/tracing/setup_overview/setup/java/?tab=containers\n    DD_LOGS_INJECTION: 'true',\n    DD_SERVICE_MAPPING: getApmServiceMappingEnvironmentVariableValue(props.serviceName),\n    DD_TAGS: getTagsEnvironmentVariableValue({\n      ...props,\n      containerType: 'service',\n      accountId,\n      region,\n    }),\n    DD_TRACE_SAMPLE_RATE: '1.0', // see https://ddtrace.readthedocs.io/en/stable/configuration.html\n  };\n}\n\n// we add all possible service mappings here even if not used in a particular service to get globally unique names\nfunction getApmServiceMappingEnvironmentVariableValue(serviceName: string): string {\n\n  const serviceMapping = {\n    'database': `${serviceName}-aurora`,\n    'java-aws-sdk': `${serviceName}-aws-sdk`,\n    'kafka': `${serviceName}-kafka`,\n    'mysql': `${serviceName}-aurora`,\n    'redis': `${serviceName}-redis`,\n  };\n\n  return Object.entries(serviceMapping)\n    .map(([key, value]) => `${key}:${value}`)\n    .join(',');\n}\n\nexport function getFargateDockerLabels(props: {stage: string; serviceName: string; version: string}): { [key: string]: string } {\n  return {\n    'com.datadoghq.tags.env': props.stage,\n    'com.datadoghq.tags.service': props.serviceName,\n    'com.datadoghq.tags.version': props.version,\n  };\n}\n\nexport function addDatadogSidecar(props: {\n  scope: Construct;\n  taskDefinition: ecs.TaskDefinition;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  datadogApiKey: ecs.Secret;\n  datadogSite: string;\n  datadogLoggingMode: DataDogLoggingMode;\n  apmGetResourcesToIgnore: string[];\n  cpu: number;\n  memoryLimitMiB: number;\n  essential: boolean;\n  containerTag: string;\n  additionalTags: { [k: string]: string} | undefined;\n  enableRestartPolicy: boolean;\n  restartIgnoredExitCodes: number[] | undefined;\n}): ecs.ContainerDefinition {\n\n  const { account: accountId, region } = Stack.of(props.scope);\n  const datadogSidecar = props.taskDefinition.addContainer('datadog-agent', {\n    image: ecs.ContainerImage.fromRegistry(`public.ecr.aws/datadog/agent:${props.containerTag}`),\n    enableRestartPolicy: props.enableRestartPolicy,\n    restartIgnoredExitCodes: props.restartIgnoredExitCodes,\n    logging: setupLogging({ ...props, containerType: 'datadog-sidecar' }),\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\n    environment: {\n      // unified tagging, see https://docs.datadoghq.com/getting_started/tagging/unified_service_tagging/?tab=ecs\n      DD_ENV: props.stage,\n      DD_SERVICE: props.serviceName,\n      DD_VERSION: props.version,\n      // APM and tracing see https://docs.datadoghq.com/agent/docker/apm/?tab=linux\n      DD_APM_ENABLED: 'true',\n      DD_APM_IGNORE_RESOURCES: props.apmGetResourcesToIgnore\n        .map((apmGetResourceToIgnore) => `GET ${apmGetResourceToIgnore}`)\n        .join(','),\n      // general settings\n      DD_SITE: props.datadogSite,\n      DD_TAGS: getTagsEnvironmentVariableValue({ ...props, accountId, region, containerType: 'datadog-sidecar' }),\n      ECS_FARGATE: 'true',\n      DD_CLOUD_PROVIDER_METADATA: 'aws',\n      DD_REMOTE_CONFIGURATION_ENABLED: 'false',\n    },\n    // see https://github.com/DataDog/datadog-agent/blob/master/Dockerfiles/agent/amd64/Dockerfile#L171-L172\n    healthCheck: {\n      startPeriod: Duration.minutes(2),\n      interval: Duration.seconds(30),\n      timeout: Duration.seconds(5),\n      retries: 2,\n      command: ['CMD-SHELL', '/probe.sh'],\n    },\n    secrets: {\n      DD_API_KEY: props.datadogApiKey,\n    },\n    essential: props.essential,\n  });\n\n  datadogSidecar.addPortMappings({\n    containerPort: 8125,\n    protocol: ecs.Protocol.UDP,\n  });\n\n  datadogSidecar.addPortMappings({\n    containerPort: 8126,\n    protocol: ecs.Protocol.TCP,\n  });\n\n  return datadogSidecar;\n}\n\nexport function addFirelensConfigUploadFromS3Permissions(props: {\n  taskDefinition: ecs.TaskDefinition;\n  firelensConfigBucketArn: string;\n}) {\n  props.taskDefinition.addToTaskRolePolicy(new iam.PolicyStatement({\n    resources: [props.firelensConfigBucketArn, `${props.firelensConfigBucketArn}/*`],\n    actions: ['s3:Get*'],\n    effect: iam.Effect.ALLOW,\n  }));\n}\n\nfunction getTagsEnvironmentVariableValue(props: {\n  accountId: string;\n  accountName: string;\n  region: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  containerType: 'service' | 'datadog-sidecar' | 'fluent-bit';\n  additionalTags: { [k: string]: string} | undefined;\n}): string {\n\n  const separator = determineSeparator(props.containerType);\n\n  const tags = {\n    // unified tagging\n    // overridden by dedicated settings (environment variables/tags)\n    // duplicated here to ensure they are used (and sometimes, not all three values are supported)\n    env: props.stage,\n    service: props.serviceName,\n    version: props.version,\n    // account/team specific parts\n    account_id: props.accountId,\n    account_name: props.accountName,\n    region: props.region,\n    team: props.teamName,\n    team_identifier: props.teamIdentifier,\n  };\n  return Object.entries({ ...tags, ...props.additionalTags })\n    .map(([key, value]) => `${key}:${value}`)\n    .join(separator);\n}\n\nfunction determineSeparator(containerType: 'service' | 'datadog-sidecar' | 'fluent-bit') {\n  if (containerType === 'datadog-sidecar') {\n    return ' ';\n  } else {\n    return ',';\n  }\n}\n\nexport function addFireLensLogRouter(props: {\n  taskDefinition: ecs.TaskDefinition;\n  cpu: number;\n  memoryLimitMiB: number;\n  firelensConfigBucketArn: string;\n  firelensConfigFilePath: string;\n  serviceName: string;\n}): ecs.ContainerDefinition {\n  const fluentBitS3ConfigFile = props.firelensConfigBucketArn + props.firelensConfigFilePath;\n\n  const fireLensLogRouterImage = ssm.StringParameter.fromStringParameterAttributes(props.taskDefinition, 'FluentBitImageTag', {\n    parameterName: '/aws/service/aws-for-fluent-bit/init-2.32.2.20240820',\n    // If this property is not set, it will always return the latest version.\n    // This leads to a non-deterministic behavior.\n    // Updating this name/version is a potential breaking change\n    version: 1,\n  }).stringValue;\n\n  return props.taskDefinition.addFirelensLogRouter('firelens-log-router', {\n    image: ecs.ContainerImage.fromRegistry(fireLensLogRouterImage),\n    firelensConfig: {\n      type: ecs.FirelensLogRouterType.FLUENTBIT,\n      options: {\n        enableECSLogMetadata: true,\n      },\n    },\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\n    logging: ecs.LogDrivers.awsLogs({\n      logGroup: new logs.LogGroup(props.taskDefinition, 'FirelensLogRouterLogGroup', {\n        logGroupName: `${props.serviceName}-firelens-log-router`,\n      }),\n      streamPrefix: 'firelens-log-router',\n      mode: AwsLogDriverMode.NON_BLOCKING,\n    }),\n    healthCheck: {\n      command: ['CMD-SHELL', 'curl --fail --silent http://127.0.0.1:2020/api/v1/health || exit 1'],\n    },\n    environment: {\n      aws_fluent_bit_init_s3_1: fluentBitS3ConfigFile,\n    },\n  });\n}\n\nexport function setupLogging(props: {\n  scope: Construct;\n  accountName: string;\n  teamName: string;\n  teamIdentifier: string;\n  stage: string;\n  serviceName: string;\n  version: string;\n  datadogApiKey: ecs.Secret;\n  datadogLoggingMode: DataDogLoggingMode;\n  datadogSite: string;\n  containerType: 'service' | 'datadog-sidecar';\n  additionalTags: { [k: string]: string} | undefined;\n}): ecs.LogDriver {\n\n  let logGroupName: string;\n  let logGroupId: string;\n  let containerTypeCamelCase;\n\n  switch (props.containerType) {\n\n    case 'service':\n      logGroupId = 'LogGroupForService';\n      logGroupName = props.serviceName;\n      containerTypeCamelCase = 'Service';\n      break;\n\n    case 'datadog-sidecar':\n      logGroupId = 'LogGroupForDatadogSidecar';\n      logGroupName = `${props.serviceName}-${props.containerType}`;\n      containerTypeCamelCase = 'DatadogSidecar';\n      break;\n  }\n\n  const { account: accountId, region } = Stack.of(props.scope);\n\n  switch (props.datadogLoggingMode) {\n\n    case DataDogLoggingMode.AWS_FIRE_LENS:\n      // TODO can we use `secretOptions` here as well, e.g. as in https://github.com/aws-samples/amazon-ecs-firelens-examples/blob/mainline/examples/fluent-bit/datadog/task-definition.json#L33-L36\n      // Probably not, see https://github.com/aws/aws-cdk/issues/8174\n      return ecs.LogDrivers.firelens({\n        // see https://docs.datadoghq.com/integrations/fluentbit/#configuration-parameters\n        options: {\n          Name: 'datadog',\n          Match: '*',\n          Host: `http-intake.logs.${props.datadogSite}`,\n          TLS: 'on',\n          apiKey: props.datadogApiKey.toString(),\n          compress: 'gzip',\n          dd_service: logGroupName,\n          dd_source: 'rio-fargate',\n          dd_message_key: 'log',\n          dd_tags: getTagsEnvironmentVariableValue({ ...props, accountId, region, containerType: 'fluent-bit' }),\n          provider: 'ecs',\n        },\n      });\n\n    case DataDogLoggingMode.FORWARDER_LAMBDA:\n    case DataDogLoggingMode.DATADOG_FORWARDER_LAMBDA:\n      const logGroupForForwardingLambda = new logs.LogGroup(props.scope, logGroupId, {\n        logGroupName,\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      Tags.of(logGroupForForwardingLambda).add('service', props.serviceName);\n      const logForwarderLambdaArnOutputName = props.datadogLoggingMode === DataDogLoggingMode.DATADOG_FORWARDER_LAMBDA ? 'datadog-forwarder-ForwarderArn' : 'custom-resource-datadog-logforwarder-function-arn';\n      const logForwarderLambdaArn = Fn.importValue(logForwarderLambdaArnOutputName);\n      const cfnPermission = new lambda.CfnPermission(props.scope, `LogForwarderPermission${containerTypeCamelCase}`, {\n        action: 'lambda:InvokeFunction',\n        functionName: logForwarderLambdaArn,\n        principal: `logs.${region}.amazonaws.com`,\n        sourceArn: logGroupForForwardingLambda.logGroupArn,\n      });\n      const cfnSubscriptionFilter = new logs.CfnSubscriptionFilter(\n        props.scope,\n        `LogForwarderSubscriptionFilter${containerTypeCamelCase}`,\n        {\n          destinationArn: logForwarderLambdaArn,\n          filterPattern: '',\n          logGroupName: logGroupForForwardingLambda.logGroupName,\n        },\n      );\n      cfnSubscriptionFilter.addDependency(cfnPermission);\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupForForwardingLambda,\n        mode: ecs.AwsLogDriverMode.NON_BLOCKING,\n        maxBufferSize: Size.mebibytes(25),\n      });\n\n    case DataDogLoggingMode.NONE:\n      const logGroupInCloudwatchOnly = new logs.LogGroup(props.scope, logGroupId, {\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupInCloudwatchOnly,\n        mode: ecs.AwsLogDriverMode.NON_BLOCKING,\n        maxBufferSize: Size.mebibytes(25),\n      });\n  }\n}\n\nexport function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService | RioFargateServiceBlueGreenAlpha): void {\n\n  rioFargateService.serviceContainerDefinition.addContainerDependencies({\n    container: rioFargateService.datadogSideCarContainerDefinition,\n    condition: ecs.ContainerDependencyCondition.HEALTHY,\n  });\n\n  if (rioFargateService.logRouterContainerDefinition) {\n    rioFargateService.serviceContainerDefinition.addContainerDependencies({\n      container: rioFargateService.logRouterContainerDefinition,\n      condition: ecs.ContainerDependencyCondition.START,\n    });\n\n    if (rioFargateService.datadogSideCarContainerDefinition.logDriverConfig?.logDriver === 'awsfirelens') {\n      rioFargateService.datadogSideCarContainerDefinition.addContainerDependencies({\n        container: rioFargateService.logRouterContainerDefinition,\n        condition: ecs.ContainerDependencyCondition.START,\n      });\n    }\n  }\n}\n"]}