@rio-cloud/cdk-v2-constructs 2.2.0 → 2.3.2
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.
- package/.jsii +109 -73
- package/CHANGELOG.md +14 -0
- package/CONTRIBUTION.md +122 -9
- package/MIGRATION_GUIDE.md +1 -1
- package/lib/contributions/team-transport-two/pipeline/buildspec-vulnerability-checks.yaml +25 -0
- package/lib/contributions/team-transport-two/pipeline/buildspec.yaml +58 -0
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +10 -2
- package/lib/fargate/datadog.js +2 -2
- package/lib/fargate/rio-fargate-service.d.ts +6 -0
- package/lib/fargate/rio-fargate-service.js +16 -12
- package/lib/rio-claidometer.d.ts +4 -1
- package/lib/rio-claidometer.js +4 -1
- package/package.json +4 -2
- package/version.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,20 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
### [2.3.2](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.3.1&sourceBranch=refs%2Ftags%2Fv2.3.2) (2022-07-06)
|
|
6
|
+
|
|
7
|
+
### [2.3.1](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.3.0&sourceBranch=refs%2Ftags%2Fv2.3.1) (2022-07-04)
|
|
8
|
+
|
|
9
|
+
## [2.3.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.2.0&sourceBranch=refs%2Ftags%2Fv2.3.0) (2022-06-21)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Features
|
|
13
|
+
|
|
14
|
+
* **contributions:** Provide more information on contributions in general ([535b600](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/535b60081f90914b0519f8ade15b4c5b49aac01a))
|
|
15
|
+
* **contributions:** Provide more information on contributions in general ([f87d671](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/f87d67157029bc5f8e9d35b7feaea205b4914e28))
|
|
16
|
+
* **fargate-template:** Support ARM ([b451bc2](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/b451bc2c05b0988183288669dec79947c89a22de))
|
|
17
|
+
* **fargate-template:** Support ARM ([cc3e84f](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/cc3e84f8f6521d20c110be2b3a3cd9a481b2619d))
|
|
18
|
+
|
|
5
19
|
## [2.2.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv2.1.0&sourceBranch=refs%2Ftags%2Fv2.2.0) (2022-06-14)
|
|
6
20
|
|
|
7
21
|
|
package/CONTRIBUTION.md
CHANGED
|
@@ -1,15 +1,128 @@
|
|
|
1
|
-
|
|
1
|
+
# Developing CDK libraries
|
|
2
|
+
|
|
3
|
+
We generally distinguish between two kinds of constructs: "core constructs" and "contributions".
|
|
4
|
+
Core constructs are officially provided and maintained by team CLAID while contributions are provided and maintained by teams/groups of developers at RIO/MAN.
|
|
5
|
+
|
|
6
|
+
## Difference between core constructs and contributions
|
|
7
|
+
|
|
8
|
+
### Core constructs
|
|
9
|
+
|
|
10
|
+
* Are officially provided and maintained by team CLAID.
|
|
11
|
+
* You can safely use any of them if there is no explicit deprecation and beta warning available.
|
|
12
|
+
* If you miss a feature or functionality, simply create a ticket at [team CLAID's feature request board](https://collaboration.msi.audi.com/jira/secure/RapidBoard.jspa?rapidView=7682).
|
|
13
|
+
* If you find a bug or have general question on the usage of the constructs, please create a platform support request in the [#rio-platform-support Slack channel](https://my-rio.slack.com/archives/C034WAG3QUA).
|
|
14
|
+
|
|
15
|
+
### Contributions
|
|
16
|
+
|
|
17
|
+
* Are provided by third parties, e.g., teams or groups of developer at RIO.
|
|
18
|
+
* Usage of these constructs is at you own risk. Get in contact with the owning team/group to find out if the construct stable and thus ready to use for you.
|
|
19
|
+
* For any feedback, improvements, or bug tickets, please read the construct's `CONTRIBUTION.md` file.
|
|
20
|
+
* Team CLAID does not guarantee any backward compatibility/stability for these constructs. We will try our very best to avoid any breaking changes, but if we are blocked by such a construct, we will simply (temporarily) remove it from a new version.
|
|
21
|
+
|
|
22
|
+
## Committing code
|
|
2
23
|
|
|
3
24
|
Provide commit messages according to [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/). This library uses [standard-version](https://github.com/conventional-changelog/standard-version) to generate the changelog and publish a new version.
|
|
4
|
-
Example commit message
|
|
5
|
-
```
|
|
6
|
-
|
|
7
|
-
|
|
25
|
+
Example commit message are
|
|
26
|
+
```text
|
|
27
|
+
feat(pipeline): added new stage for secrets deployment
|
|
28
|
+
|
|
29
|
+
* RIOCLAID-1932 RIOCLAID-1934
|
|
30
|
+
```
|
|
31
|
+
and
|
|
32
|
+
```text
|
|
33
|
+
chore: Relax CDK dependency resolution to ease usage for customers
|
|
34
|
+
|
|
35
|
+
* Now the teams can use their own CDK version (at least 2.20.0) and must not explicitly use ours
|
|
36
|
+
* RIOCLAID-2510
|
|
8
37
|
```
|
|
9
38
|
|
|
10
|
-
|
|
39
|
+
Moreover, you need to sign your commits using GPG, see the [Bitbucket documentation](https://confluence.atlassian.com/bitbucketserver/using-gpg-keys-913477014.html#UsingGPGkeys-SigncommitsandtagswithaGPGkey).
|
|
40
|
+
|
|
41
|
+
## Contributions
|
|
42
|
+
|
|
43
|
+
First of all, thank you for considering a contribution to the CDK constructs library.
|
|
44
|
+
We as team CLAID welcome any contribution and are happy to help you with building the construct.
|
|
45
|
+
|
|
46
|
+
We support providing custom constructs provided by you.
|
|
47
|
+
You can, of course, always use any other mechanism to share commonly used constructs, but adding them to the RIO CDK constructs removes some burden from you.
|
|
48
|
+
* We take care of the release process for you, i.e., we release the project to `npm` and make sure that the construct is `jsii`-compatible (which allows us to eventually release the constructs in another language, e.g., Java, later if needed).
|
|
49
|
+
* We run all the tests in our CI/CD pipeline and make sure that the construct works well with core constructs.
|
|
50
|
+
* You can use our Claidometer infrastructure to track the usage of your constructs for free, e.g., how often is it currently being used and which versions are out there.
|
|
51
|
+
* If needed, we consult you in building the construct as early as in the design phase.
|
|
52
|
+
* You get a peer review by a developer from team CLAID.
|
|
53
|
+
|
|
54
|
+
There is no free lunch and thus providing contributions also comes with some (hopefully neglectable) costs compared to the benefits.
|
|
55
|
+
In the case of contributions, we ask you to follow some rules.
|
|
56
|
+
|
|
57
|
+
### Respect the folder structure
|
|
58
|
+
|
|
59
|
+
We require you to define a team/group owning the construct and use that name as the top-level folder in the `src/contributions` folder.
|
|
60
|
+
For each high-level construct you provide, we recommend adding a separate folder named by the construct.
|
|
61
|
+
|
|
62
|
+
As an example, you team/group's folder structure might look as follows (only showing the mandatory files).
|
|
63
|
+
```text
|
|
64
|
+
src/contributions # the place for all contributions
|
|
65
|
+
└── team-super-awesome # the name of the team/group providing the construct
|
|
66
|
+
├── CONTRIBUTION.md # contribution information, e.g., contact details
|
|
67
|
+
├── super-awesome-construct # the name of the construct
|
|
68
|
+
│ ├── .
|
|
69
|
+
│ ├── .
|
|
70
|
+
│ ├── .
|
|
71
|
+
│ ├── CHANGELOG.md # a changelog for the semantically versioned releases
|
|
72
|
+
│ └── README.md # general information for the construct, e.g., how to use it
|
|
73
|
+
└── yet-another-construct # the name of the construct
|
|
74
|
+
├── .
|
|
75
|
+
├── .
|
|
76
|
+
├── .
|
|
77
|
+
├── CHANGELOG.md # a changelog for the semantically versioned releases
|
|
78
|
+
└── README.md # general information for the construct, e.g., how to use it
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
#### Provide a `CONTRIBUTION.md` file
|
|
82
|
+
|
|
83
|
+
The file must contain the following information.
|
|
84
|
+
* Who are you?
|
|
85
|
+
* How can persons contact you if they want to contribute to the construct?
|
|
86
|
+
* What is the preferred way of contributing? Do you, e.g., prefer PRs or a ticket?
|
|
87
|
+
|
|
88
|
+
#### Provide a `CHANGELOG.md` file
|
|
89
|
+
|
|
90
|
+
* Use [semantic versioning](https://semver.org/) (make sure to update the `Claidometer` construct accordingly on new relases)
|
|
91
|
+
* Describe the changes, e.g.,
|
|
92
|
+
> * 🎉 new feature released
|
|
93
|
+
> * 🐛 bug squashed
|
|
94
|
+
> * 📚 documentation improved
|
|
95
|
+
> * ⚠️ deprecation warning/breaking change including steps how to resolve it
|
|
96
|
+
|
|
97
|
+
### Use Claidometer to track the usage of your constructs
|
|
98
|
+
|
|
99
|
+
Simply add the `Claidometer` construct and provide the following information.
|
|
100
|
+
* `product`: Use `ClaidometerProduct.CDK_CONTRIBUTION` here
|
|
101
|
+
* `packageName`: We recommend to use the owning team/group here
|
|
102
|
+
* `feature`: We recommend to use the name of the feature
|
|
103
|
+
* `version`: The current version of the construct (should be aligned with the `CHANGELOG.md`)
|
|
104
|
+
If you follow the recommended folder structure, you can derive both the `packageName` and the `feature` from it, e.g.
|
|
105
|
+
```typescript
|
|
106
|
+
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
107
|
+
new Claidometer(this, 'Claidometer', {
|
|
108
|
+
product: ClaidometerProduct.CDK_CONTRIBUTION,
|
|
109
|
+
packageName,
|
|
110
|
+
feature,
|
|
111
|
+
version: '0.0.1',
|
|
112
|
+
});
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
This enables you to track the usage of the construct and the versions in use over time.
|
|
116
|
+
Claidometer makes sure that each usage of the construct is stored in the data lake and allows CLAID to query/visualize the Data in Athena and/or Quicksight.
|
|
117
|
+
Contact team CLAID if you want to get insights into the data or need access to it.
|
|
118
|
+
|
|
119
|
+
### Think about your commitment
|
|
11
120
|
|
|
12
|
-
|
|
121
|
+
Be aware that, even though it is hopefully quite easy to release a CDK contribution, other developers can see the code and might want to use it or improve upon it.
|
|
122
|
+
Therefore, clearly state the usage and your expectations in the `README.md` and `CONTRIBUTION.md`.
|
|
123
|
+
If your intention is to share some highly team-specific code between your team's CDK services but do not want others to use that solution, clearly state it there.
|
|
124
|
+
(Though we highly discourage you from doing that as we think that the option to collaborate and share constructs is one of the key benefits from CDK.)
|
|
125
|
+
Please also react to any feedback of developers using the stated feedback channels.
|
|
13
126
|
|
|
14
|
-
|
|
15
|
-
|
|
127
|
+
Finally, we as team CLAID might need to change or even remove your constructs in future CDK releases if it blocks us, e.g., to release a critical feature.
|
|
128
|
+
We will try to contact you upfront in case of non-trivial changes and do our best to avoid removing the construct.
|
package/MIGRATION_GUIDE.md
CHANGED
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
3. **add `constructs`**: `npm install constructs@10`
|
|
14
14
|
4. **replace imports**: `$ npx -p aws-cdk-migration rewrite-imports-v2 <your-source-root-here>/**/*.ts`
|
|
15
15
|
5. update `cdk.json` (e.g., by generating a new CDKv2 app in another folder with `npx cdk@2 init app --language=typescript` and comparing its `cdk.json` with yours)
|
|
16
|
-
6. replace `@aws-cdk/assert` with `aws-cdk-lib/assertions`
|
|
16
|
+
6. replace `@aws-cdk/assert` with `aws-cdk-lib/assertions` and migrate expectations to `Template.fromStack(...).hasResource`
|
|
17
17
|
* additional information: [Official Migration Guide](https://docs.aws.amazon.com/cdk/v2/guide/migrating-v2.html)
|
|
18
18
|
5. Replace `@rioclaid/cdk-constructs` with `@rio-cloud/cdk-v2-constructs`
|
|
19
19
|
* **add `@rio-cloud/cdk-v2-constructs`**: `npm install @rio-cloud/cdk-v2-constructs`
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
version: 0.2
|
|
2
|
+
env:
|
|
3
|
+
variables:
|
|
4
|
+
LANG: C.UTF-8
|
|
5
|
+
JAVA_HOME: /usr/lib/jvm/java-17-amazon-corretto.x86_64
|
|
6
|
+
parameter-store:
|
|
7
|
+
NIST_DATA_MIRROR_URL: /config/nist-data-mirror/url
|
|
8
|
+
phases:
|
|
9
|
+
pre_build:
|
|
10
|
+
commands:
|
|
11
|
+
- yum install --assumeyes --quiet java-17-amazon-corretto-devel
|
|
12
|
+
- alternatives --set java /usr/lib/jvm/java-17-amazon-corretto.x86_64/bin/java
|
|
13
|
+
build:
|
|
14
|
+
commands:
|
|
15
|
+
# Keep this echo statement for identifying the default buildspec in our test
|
|
16
|
+
- echo "Using standard gradle build spec for vulnerability checks..."
|
|
17
|
+
|
|
18
|
+
# RUNNING OWASP VULNERABILITY CHECK
|
|
19
|
+
- ./gradlew dependencyCheckAnalyze
|
|
20
|
+
cache:
|
|
21
|
+
paths:
|
|
22
|
+
- /root/.cache/**/*
|
|
23
|
+
- /root/.gradle/caches/**/*
|
|
24
|
+
- /root/.gradle/wrapper/**/*
|
|
25
|
+
- /root/.gradle/dependency-check-data/**/*
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
version: '0.2'
|
|
2
|
+
env:
|
|
3
|
+
parameter-store:
|
|
4
|
+
SERVICE_KEYSTORE_PASSWORD: /config/${SERVICE_NAME}/service-keystore-password
|
|
5
|
+
LICENSE_BUCKET_NAME: /config/oss-licenses/bucket-name
|
|
6
|
+
ACCOUNT_NAME: /config/account/name
|
|
7
|
+
variables:
|
|
8
|
+
JAVA_HOME: /usr/lib/jvm/java-17-amazon-corretto.x86_64
|
|
9
|
+
phases:
|
|
10
|
+
pre_build:
|
|
11
|
+
commands:
|
|
12
|
+
- yum install --assumeyes --quiet java-17-amazon-corretto-devel
|
|
13
|
+
- alternatives --set java /usr/lib/jvm/java-17-amazon-corretto.x86_64/bin/java
|
|
14
|
+
build:
|
|
15
|
+
commands:
|
|
16
|
+
# Keep this echo statement for identifying the default buildspec in our test
|
|
17
|
+
- echo "Using standard gradle build spec..."
|
|
18
|
+
|
|
19
|
+
# BUILD AND TEST
|
|
20
|
+
- ./gradlew clean build
|
|
21
|
+
|
|
22
|
+
# LICENSE CHECKING
|
|
23
|
+
- set -u; aws s3 cp s3://${LICENSE_BUCKET_NAME}/whitelist-gradle.txt licenses/approved_licenses.txt
|
|
24
|
+
- ./gradlew checkLicenses
|
|
25
|
+
- set -u; aws s3 cp licenses/licenses.txt s3://${LICENSE_BUCKET_NAME}/reports/${ACCOUNT_NAME}/${SERVICE_NAME}.txt
|
|
26
|
+
|
|
27
|
+
# SELF CERT SIGNING
|
|
28
|
+
- keytool -genkey -alias InternalServiceCertificate -keyalg RSA -keystore containerfiles/service-keystore.p12 -validity 3650 -storetype PKCS12 -dname "CN=internal.service.${SERVICE_NAME}.${HOSTED_ZONE_NAME}, OU=Logistics, O=Rio, L=Munich, ST=BY, C=DE" -keypass ${SERVICE_KEYSTORE_PASSWORD} -storepass ${SERVICE_KEYSTORE_PASSWORD}
|
|
29
|
+
|
|
30
|
+
# DOCKER IMAGE BUILD
|
|
31
|
+
- ./gradlew jibBuildTar --quiet
|
|
32
|
+
|
|
33
|
+
# npm synth action
|
|
34
|
+
- cd infrastructure
|
|
35
|
+
- npm install npm@8.12.1 --global
|
|
36
|
+
- npm ci
|
|
37
|
+
# mute stdout of cdk synth to not dump the resulting Cfn template in logs
|
|
38
|
+
- npm run cdk synth 1> /dev/null
|
|
39
|
+
|
|
40
|
+
# In pipeline: Error parsing reference: is not a valid repository/tag: invalid reference format.
|
|
41
|
+
# workaround due to https://github.com/aws/aws-cdk/issues/18044',
|
|
42
|
+
- find ./ -type f -name "*DeployApplicationStacks*.assets.json" -print0 | xargs -0 sed --in-place 's|docker load -i asset.|docker load -i ../asset.|g'
|
|
43
|
+
|
|
44
|
+
- cd ..
|
|
45
|
+
reports:
|
|
46
|
+
JunitTestResults:
|
|
47
|
+
files:
|
|
48
|
+
- '**/*'
|
|
49
|
+
base-directory: build/test-results
|
|
50
|
+
|
|
51
|
+
cache:
|
|
52
|
+
paths:
|
|
53
|
+
- /cert/**/*
|
|
54
|
+
- /root/.cache/**/*
|
|
55
|
+
- /root/.gradle/caches/**/*
|
|
56
|
+
- /root/.gradle/wrapper/**/*
|
|
57
|
+
- /root/google-cloud-tools-java/jib/**/*
|
|
58
|
+
- target/jib-cache/**/*
|
|
@@ -15,6 +15,7 @@ const ssm = require("aws-cdk-lib/aws-ssm");
|
|
|
15
15
|
const pipelines = require("aws-cdk-lib/pipelines");
|
|
16
16
|
const pipelines_1 = require("aws-cdk-lib/pipelines");
|
|
17
17
|
const rio = require("../../../index");
|
|
18
|
+
const index_1 = require("../../../index");
|
|
18
19
|
const upperToLower_1 = require("../../../watchful/upperToLower");
|
|
19
20
|
const application_stage_1 = require("./application-stage");
|
|
20
21
|
const build_project_1 = require("./build-project");
|
|
@@ -117,7 +118,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
117
118
|
// Vulnerability Pipeline
|
|
118
119
|
const vulnerabilityBuild = new build_project_1.RioGradleCodeBuildProject(this, 'VulnerabilityChecks', {
|
|
119
120
|
input: inputMasterTriggerFile,
|
|
120
|
-
buildSpecPath:
|
|
121
|
+
buildSpecPath: path.resolve(__dirname, 'buildspec-vulnerability-checks.yaml'),
|
|
121
122
|
hostedZoneName: hostedZone.zoneName,
|
|
122
123
|
serviceName: props.serviceName,
|
|
123
124
|
});
|
|
@@ -140,6 +141,13 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
140
141
|
pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),
|
|
141
142
|
accountId: this.account,
|
|
142
143
|
});
|
|
144
|
+
const [feature, packageName] = __dirname.split(path.sep).reverse();
|
|
145
|
+
new index_1.Claidometer(this, 'Claidometer', {
|
|
146
|
+
product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
|
|
147
|
+
packageName,
|
|
148
|
+
feature,
|
|
149
|
+
version: '0.0.1',
|
|
150
|
+
});
|
|
143
151
|
}
|
|
144
152
|
static addLifecycleRuleArtifactBucket(pipeline) {
|
|
145
153
|
const artifactsBucket = pipeline.pipeline.artifactBucket;
|
|
@@ -162,4 +170,4 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
|
|
|
162
170
|
exports.PipelineStack = PipelineStack;
|
|
163
171
|
_a = JSII_RTTI_SYMBOL_1;
|
|
164
172
|
PipelineStack[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.PipelineStack", version: "0.0.0" };
|
|
165
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-stack.js","sourceRoot":"","sources":["../../../../src/contributions/team-transport-two/pipeline/pipeline-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, Stack, StackProps } from 'aws-cdk-lib';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as rio from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioGradleCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\n\n/**\n  * @struct\n */\nexport interface PipelineStackProps extends StackProps {\n  /**\n   * The name of the service\n   * - This has to be the same name as the repository as the s3 trigger file created by the bitbucket-integration uses this as a prefix\n   * - The serviceName is available as an environment variable SERVICE_NAME in the CodeBuildStep\n   * - The serviceName is available in the AppStackProps in the appStackFactory\n   * - The serviceName is available as stackName property in the AppStackProps in the appStackFactory. I.e. the stack is named after the service\n   * - The serviceName is handed over to all Datadog monitors\n   * - RIO convention is that uploaded license-check-files are named after the service, i.e. serviceName.txt\n   */\n  readonly serviceName: string;\n\n  /**\n   * Provider for appStack to be deployed.\n   *\n   * This acts as a wrapper for all resources you want to deploy via the pipeline.\n   */\n  readonly appStackFactory: IAppStackFactory;\n\n  /**\n   * Defines which kind of pipeline is deployed.\n   */\n  readonly pipelineType: PipelineType;\n\n  /**\n   * Path to a custom buildspec.yaml that is used if provided.\n   *\n   * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n   */\n  readonly customBuildspecPath?: string;\n\n  /**\n   * Path to secrets file containing encrypted secrets.\n   *\n   * The RioSecretsDeployStep is added prior to deployment of the AppStack if a path is provided.\n   *\n   * No secrets are deployed if no path is provided.\n   */\n  readonly secretsDeployStepProps?: PipelineStackRioSecretsDeployStepProps;\n}\n\n/**\n * Provider interface to create the AppStack within the specific scope\n *\n * Simply place the AppStack creation into the create-method:\n * @example\n *\n * // Use e.g. within ApplicationProps as JSONObject:\n * { create: (construct, props) => new Stack(construct, 'AppStack', props) }\n *\n * // or simply as class interface within your stack implementation:\n * class PipelineStage extends Stage implements IAppStackFactory {\n *   constructor(scope: Construct, id: string, props: StageProps) {\n *     super(scope, id, props);\n *     // your stage definitiom\n *   }\n *\n *   create(scope: Construct, props: AppStackProps): void {\n *     // app stack initiation goes in here\n *   }\n * }\n */\nexport interface IAppStackFactory {\n  /**\n   * Factory method, being invoked with the specific scope during pipeline instantiation\n   *\n   * @param scope the parent construct for the app stack\n   * @param props the app stacks properties\n   */\n  create(scope: Construct, props: AppStackProps ): void;\n}\n\nexport interface AppStackProps extends StackProps {\n  readonly serviceName: string;\n  readonly version: string;\n}\n\n/**\n * Selected properties being handed over to RioSecretsDeployStep.\n *\n * @see rio.RioSecretsDeployStep\n * @see rio.RioSecretsDeployStepProps\n */\nexport interface PipelineStackRioSecretsDeployStepProps {\n  readonly secretsFilePath: string;\n}\n\nexport enum PipelineType {\n\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack. Be aware: The provided service won't have access to Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE = 'STANDARD_GRADLE',\n}\n\nexport class PipelineStack extends Stack {\n  private static addLifecycleRuleArtifactBucket(pipeline: pipelines.CodePipeline) {\n    const artifactsBucket = pipeline.pipeline.artifactBucket;\n    (artifactsBucket as s3.Bucket).addLifecycleRule({\n      enabled: true,\n      expiration: Duration.days(90),\n    });\n  }\n\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // Creating the main pipeline\n    const bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    const hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    const inputMasterTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    const inputBranchTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    const ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(\n      this,\n      'OssLicensesBucketParameter',\n      {\n        parameterName: '/config/oss-licenses/bucket-name',\n      },\n    );\n    const ossLicensesBucket = s3.Bucket.fromBucketName(\n      this,\n      'OssLicensesBucket',\n      ossLicensesBucketParameter.stringValue,\n    );\n    const serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    const accountNameParameter = ssm.StringParameter.fromStringParameterName(\n      this,\n      'AccountNameParameter',\n      '/config/account/name',\n    );\n\n    const gradlebuild = new RioGradleCodeBuildProject(this, 'GradleBuild', {\n      input: inputMasterTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      buildSpecPath: props.customBuildspecPath || path.resolve(__dirname, 'buildspec.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      synth: gradlebuild,\n    });\n\n    // CloudAssemblyArtifacts must be smaller than 256MB. Due to the gradle artifact we are exceeding this limit and pipeline fails in deployment step.\n    // Issue is known and not fixed for already some years. See: https://github.com/aws/aws-cdk/issues/9917\n    // Dirty fix: Assets are already uploaded and thus not needed. Remove them from pipeline artifact.\n    const stripAssetsStep = new CodeBuildStep(\n      'StripAssetsFromAssembly', {\n        input: pipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          'ZIP_ARCHIVE=$(basename $S3_PATH)',\n          'rm -rfv asset.*',\n          'zip -r -q -A $ZIP_ARCHIVE *',\n          'aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH',\n        ],\n      },\n    );\n\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    pipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: codepipeline.GlobalVariables.executionId,\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', { ...props.secretsDeployStepProps, input: inputMasterTriggerFile }),\n      ] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });\n    rule.addTarget(new targets.CodePipeline(pipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(pipeline);\n    ossLicensesBucket.grantReadWrite(gradlebuild);\n    ossLicensesBucketParameter.grantRead(gradlebuild);\n    serviceKeystorePassword.grantRead(gradlebuild);\n    accountNameParameter.grantRead(gradlebuild);\n    pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    // Branch pipeline\n    const branchBuild = new RioGradleCodeBuildProject(this, 'BranchBuild', {\n      input: inputBranchTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      buildSpecPath: props.customBuildspecPath || path.resolve(__dirname, 'buildspec.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\n    ossLicensesBucket.grantReadWrite(branchBuild);\n    ossLicensesBucketParameter.grantRead(branchBuild);\n    serviceKeystorePassword.grantRead(branchBuild);\n    accountNameParameter.grantRead(branchBuild);\n\n    // Vulnerability Pipeline\n    const vulnerabilityBuild = new RioGradleCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: inputMasterTriggerFile,\n      buildSpecPath: props.customBuildspecPath || path.resolve(__dirname, 'buildspec-vulnerability-checks.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n    });\n  }\n\n  private renamePipelineToLowerCase(pipeline: pipelines.CodePipeline): Reference {\n    const upperToLowerCr = new cdk.CustomResource(this, `${pipeline.node.id}-UpperToLower`, {\n      resourceType: 'Custom::UpperToLower',\n      serviceToken: UpperToLower.getOrCreate(this).provider.serviceToken,\n      properties: {\n        Upper: pipeline.pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n}\n"]}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pipeline-stack.js","sourceRoot":"","sources":["../../../../src/contributions/team-transport-two/pipeline/pipeline-stack.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, Stack, StackProps } from 'aws-cdk-lib';\nimport * as codepipeline from 'aws-cdk-lib/aws-codepipeline';\nimport * as codepipeline_actions from 'aws-cdk-lib/aws-codepipeline-actions';\nimport * as events from 'aws-cdk-lib/aws-events';\nimport * as targets from 'aws-cdk-lib/aws-events-targets';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioGradleCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\n\n/**\n  * @struct\n */\nexport interface PipelineStackProps extends StackProps {\n  /**\n   * The name of the service\n   * - This has to be the same name as the repository as the s3 trigger file created by the bitbucket-integration uses this as a prefix\n   * - The serviceName is available as an environment variable SERVICE_NAME in the CodeBuildStep\n   * - The serviceName is available in the AppStackProps in the appStackFactory\n   * - The serviceName is available as stackName property in the AppStackProps in the appStackFactory. I.e. the stack is named after the service\n   * - The serviceName is handed over to all Datadog monitors\n   * - RIO convention is that uploaded license-check-files are named after the service, i.e. serviceName.txt\n   */\n  readonly serviceName: string;\n\n  /**\n   * Provider for appStack to be deployed.\n   *\n   * This acts as a wrapper for all resources you want to deploy via the pipeline.\n   */\n  readonly appStackFactory: IAppStackFactory;\n\n  /**\n   * Defines which kind of pipeline is deployed.\n   */\n  readonly pipelineType: PipelineType;\n\n  /**\n   * Path to a custom buildspec.yaml that is used if provided.\n   *\n   * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n   */\n  readonly customBuildspecPath?: string;\n\n  /**\n   * Path to secrets file containing encrypted secrets.\n   *\n   * The RioSecretsDeployStep is added prior to deployment of the AppStack if a path is provided.\n   *\n   * No secrets are deployed if no path is provided.\n   */\n  readonly secretsDeployStepProps?: PipelineStackRioSecretsDeployStepProps;\n}\n\n/**\n * Provider interface to create the AppStack within the specific scope\n *\n * Simply place the AppStack creation into the create-method:\n * @example\n *\n * // Use e.g. within ApplicationProps as JSONObject:\n * { create: (construct, props) => new Stack(construct, 'AppStack', props) }\n *\n * // or simply as class interface within your stack implementation:\n * class PipelineStage extends Stage implements IAppStackFactory {\n *   constructor(scope: Construct, id: string, props: StageProps) {\n *     super(scope, id, props);\n *     // your stage definitiom\n *   }\n *\n *   create(scope: Construct, props: AppStackProps): void {\n *     // app stack initiation goes in here\n *   }\n * }\n */\nexport interface IAppStackFactory {\n  /**\n   * Factory method, being invoked with the specific scope during pipeline instantiation\n   *\n   * @param scope the parent construct for the app stack\n   * @param props the app stacks properties\n   */\n  create(scope: Construct, props: AppStackProps ): void;\n}\n\nexport interface AppStackProps extends StackProps {\n  readonly serviceName: string;\n  readonly version: string;\n}\n\n/**\n * Selected properties being handed over to RioSecretsDeployStep.\n *\n * @see rio.RioSecretsDeployStep\n * @see rio.RioSecretsDeployStepProps\n */\nexport interface PipelineStackRioSecretsDeployStepProps {\n  readonly secretsFilePath: string;\n}\n\nexport enum PipelineType {\n\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack. Be aware: The provided service won't have access to Kafka.\n   *\n   * Comes with a pre-defined buildspec.yaml for a gradle project. This buildspec.yaml is used for both the main and\n   * branch pipeline and includes the following steps\n   * - build and test of the artifact via command \"./gradlew clean build\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - license-check and upload of license-check-file via command \"./gradlew checkLicenses\".\n   * <p> This gradle command must be provided by the gradle project.\n   * - create a self-signed certificate to make TLS communication possible, e.g. with a loadbalancer.\n   * - build the container image via command \"./gradlew jibBuildTar\".\n   * <p> This gradle command must be provided by the gradle project.\n   */\n  STANDARD_GRADLE = 'STANDARD_GRADLE',\n}\n\nexport class PipelineStack extends Stack {\n  private static addLifecycleRuleArtifactBucket(pipeline: pipelines.CodePipeline) {\n    const artifactsBucket = pipeline.pipeline.artifactBucket;\n    (artifactsBucket as s3.Bucket).addLifecycleRule({\n      enabled: true,\n      expiration: Duration.days(90),\n    });\n  }\n\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // Creating the main pipeline\n    const bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    const hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    const inputMasterTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    const inputBranchTriggerFile = pipelines.CodePipelineSource.s3(bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    const ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(\n      this,\n      'OssLicensesBucketParameter',\n      {\n        parameterName: '/config/oss-licenses/bucket-name',\n      },\n    );\n    const ossLicensesBucket = s3.Bucket.fromBucketName(\n      this,\n      'OssLicensesBucket',\n      ossLicensesBucketParameter.stringValue,\n    );\n    const serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    const accountNameParameter = ssm.StringParameter.fromStringParameterName(\n      this,\n      'AccountNameParameter',\n      '/config/account/name',\n    );\n\n    const gradlebuild = new RioGradleCodeBuildProject(this, 'GradleBuild', {\n      input: inputMasterTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      buildSpecPath: props.customBuildspecPath || path.resolve(__dirname, 'buildspec.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      synth: gradlebuild,\n    });\n\n    // CloudAssemblyArtifacts must be smaller than 256MB. Due to the gradle artifact we are exceeding this limit and pipeline fails in deployment step.\n    // Issue is known and not fixed for already some years. See: https://github.com/aws/aws-cdk/issues/9917\n    // Dirty fix: Assets are already uploaded and thus not needed. Remove them from pipeline artifact.\n    const stripAssetsStep = new CodeBuildStep(\n      'StripAssetsFromAssembly', {\n        input: pipeline.cloudAssemblyFileSet,\n        commands: [\n          'S3_PATH=${CODEBUILD_SOURCE_VERSION#\"arn:aws:s3:::\"}',\n          'ZIP_ARCHIVE=$(basename $S3_PATH)',\n          'rm -rfv asset.*',\n          'zip -r -q -A $ZIP_ARCHIVE *',\n          'aws s3 cp $ZIP_ARCHIVE s3://$S3_PATH',\n        ],\n      },\n    );\n\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    pipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: codepipeline.GlobalVariables.executionId,\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', { ...props.secretsDeployStepProps, input: inputMasterTriggerFile }),\n      ] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });\n    rule.addTarget(new targets.CodePipeline(pipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(pipeline);\n    ossLicensesBucket.grantReadWrite(gradlebuild);\n    ossLicensesBucketParameter.grantRead(gradlebuild);\n    serviceKeystorePassword.grantRead(gradlebuild);\n    accountNameParameter.grantRead(gradlebuild);\n    pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    // Branch pipeline\n    const branchBuild = new RioGradleCodeBuildProject(this, 'BranchBuild', {\n      input: inputBranchTriggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      buildSpecPath: props.customBuildspecPath || path.resolve(__dirname, 'buildspec.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\n    ossLicensesBucket.grantReadWrite(branchBuild);\n    ossLicensesBucketParameter.grantRead(branchBuild);\n    serviceKeystorePassword.grantRead(branchBuild);\n    accountNameParameter.grantRead(branchBuild);\n\n    // Vulnerability Pipeline\n    const vulnerabilityBuild = new RioGradleCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: inputMasterTriggerFile,\n      buildSpecPath: path.resolve(__dirname, 'buildspec-vulnerability-checks.yaml'),\n      hostedZoneName: hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n    });\n\n    const [feature, packageName] = __dirname.split(path.sep).reverse();\n    new Claidometer(this, 'Claidometer', {\n      product: ClaidometerProduct.CDK_CONTRIBUTION,\n      packageName,\n      feature,\n      version: '0.0.1',\n    });\n  }\n\n  private renamePipelineToLowerCase(pipeline: pipelines.CodePipeline): Reference {\n    const upperToLowerCr = new cdk.CustomResource(this, `${pipeline.node.id}-UpperToLower`, {\n      resourceType: 'Custom::UpperToLower',\n      serviceToken: UpperToLower.getOrCreate(this).provider.serviceToken,\n      properties: {\n        Upper: pipeline.pipeline.pipelineName,\n      },\n    });\n    return upperToLowerCr.getAtt('Lower');\n  }\n}\n"]}
|
package/lib/fargate/datadog.js
CHANGED
|
@@ -188,7 +188,7 @@ function determineSeparator(containerType) {
|
|
|
188
188
|
}
|
|
189
189
|
function addFireLensLogRouter(props) {
|
|
190
190
|
return props.taskDefinition.addFirelensLogRouter('firelens-log-router', {
|
|
191
|
-
image: ecs.ContainerImage.fromRegistry('public.ecr.aws/aws-observability/aws-for-fluent-bit:
|
|
191
|
+
image: ecs.ContainerImage.fromRegistry('public.ecr.aws/aws-observability/aws-for-fluent-bit:stable'),
|
|
192
192
|
firelensConfig: {
|
|
193
193
|
type: ecs.FirelensLogRouterType.FLUENTBIT,
|
|
194
194
|
options: {
|
|
@@ -292,4 +292,4 @@ function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService
|
|
|
292
292
|
}
|
|
293
293
|
}
|
|
294
294
|
exports.ensureLoggingAndMonitoringAreReadyBeforeServiceStarts = ensureLoggingAndMonitoringAreReadyBeforeServiceStarts;
|
|
295
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog.js","sourceRoot":"","sources":["../../src/fargate/datadog.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, Duration, Fn } from 'aws-cdk-lib';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\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';\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  ): 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    });\n  }\n\n  public static addFireLensLogRouter(\n    taskDefinition: ecs.TaskDefinition,\n    cpu: number,\n    memoryLimitMiB: number,\n  ): ecs.ContainerDefinition {\n    return addFireLensLogRouter({ taskDefinition, cpu, memoryLimitMiB });\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}): 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    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_COLLECT_GCE_TAGS: '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\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}): ecs.ContainerDefinition {\n\n  return props.taskDefinition.addFirelensLogRouter('firelens-log-router', {\n    image: ecs.ContainerImage.fromRegistry('public.ecr.aws/aws-observability/aws-for-fluent-bit:latest'),\n    firelensConfig: {\n      type: ecs.FirelensLogRouterType.FLUENTBIT,\n      options: {\n        configFileType: ecs.FirelensConfigFileType.FILE,\n        configFileValue: '/fluent-bit/configs/parse-json.conf',\n        enableECSLogMetadata: true,\n      },\n    },\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\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      const logGroupForForwardingLambda = new logs.LogGroup(props.scope, logGroupId, {\n        logGroupName,\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      const logForwarderLambdaArn = Fn.importValue('custom-resource-datadog-logforwarder-function-arn');\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.addDependsOn(cfnPermission);\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupForForwardingLambda,\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      });\n  }\n}\n\nexport function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService): 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"]}
|
|
295
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog.js","sourceRoot":"","sources":["../../src/fargate/datadog.ts"],"names":[],"mappings":";;;AAAA,6CAAkD;AAClD,2CAA2C;AAC3C,iDAAiD;AACjD,6CAA6C;AAG7C,+DAA8E;AAE9E;;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,sBAA4C,EAC5C,WAAmB,EACnB,kBAAsC,EACtC,uBAAiC,EACjC,GAAW,EACX,cAAsB,EACtB,SAAkB,EAClB,YAAoB,EACpB,cAAkD;QAGlD,OAAO,iBAAiB,CAAC;YACvB,KAAK;YACL,cAAc;YACd,WAAW;YACX,QAAQ;YACR,cAAc;YACd,KAAK;YACL,WAAW;YACX,OAAO;YACP,sBAAsB;YACtB,WAAW;YACX,kBAAkB;YAClB,uBAAuB;YACvB,GAAG;YACH,cAAc;YACd,SAAS;YACT,YAAY;YACZ,cAAc;SACf,CAAC,CAAC;IACL,CAAC;IAEM,MAAM,CAAC,oBAAoB,CAChC,cAAkC,EAClC,GAAW,EACX,cAAsB;QAEtB,OAAO,oBAAoB,CAAC,EAAE,cAAc,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;IACvE,CAAC;IAEM,MAAM,CAAC,YAAY,CACxB,KAAgB,EAChB,WAAmB,EACnB,QAAgB,EAChB,cAAsB,EACtB,KAAa,EACb,WAAmB,EACnB,OAAe,EACf,sBAA4C,EAC5C,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,sBAAsB;YACtB,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;AA/GD,0BA+GC;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;KAC5B,CAAC;AACJ,CAAC;AA7BD,0FA6BC;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;AAND,wDAMC;AAED,SAAgB,iBAAiB,CAAC,KAkBjC;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,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,mBAAmB,EAAE,OAAO;SAC7B;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,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,KAAK,CAAC,sBAAsB,CAAC;SACtE;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;AAnED,8CAmEC;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;QACvC,OAAO,GAAG,CAAC;KACZ;SAAM;QACL,OAAO,GAAG,CAAC;KACZ;AACH,CAAC;AAED,SAAgB,oBAAoB,CAAC,KAIpC;IAEC,OAAO,KAAK,CAAC,cAAc,CAAC,oBAAoB,CAAC,qBAAqB,EAAE;QACtE,KAAK,EAAE,GAAG,CAAC,cAAc,CAAC,YAAY,CAAC,4DAA4D,CAAC;QACpG,cAAc,EAAE;YACd,IAAI,EAAE,GAAG,CAAC,qBAAqB,CAAC,SAAS;YACzC,OAAO,EAAE;gBACP,cAAc,EAAE,GAAG,CAAC,sBAAsB,CAAC,IAAI;gBAC/C,eAAe,EAAE,qCAAqC;gBACtD,oBAAoB,EAAE,IAAI;aAC3B;SACF;QACD,GAAG,EAAE,KAAK,CAAC,GAAG;QACd,cAAc,EAAE,KAAK,CAAC,cAAc;KACrC,CAAC,CAAC;AACL,CAAC;AAnBD,oDAmBC;AAED,SAAgB,YAAY,CAAC,KAa5B;IAEC,IAAI,YAAoB,CAAC;IACzB,IAAI,UAAkB,CAAC;IACvB,IAAI,sBAAsB,CAAC;IAE3B,QAAQ,KAAK,CAAC,aAAa,EAAE;QAE3B,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;KACT;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;QAEhC,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,sBAAsB,CAAC,WAAW;oBAChD,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;YACtC,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,MAAM,qBAAqB,GAAG,gBAAE,CAAC,WAAW,CAAC,mDAAmD,CAAC,CAAC;YAClG,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,YAAY,CAAC,aAAa,CAAC,CAAC;YAClD,OAAO,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC;gBAC5B,YAAY,EAAE,KAAK,CAAC,aAAa;gBACjC,QAAQ,EAAE,2BAA2B;aACtC,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;aACnC,CAAC,CAAC;KACN;AACH,CAAC;AA9FD,oCA8FC;AAED,SAAgB,qDAAqD,CAAC,iBAAoC;;IAExG,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;QAClD,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,OAAA,iBAAiB,CAAC,iCAAiC,CAAC,eAAe,0CAAE,SAAS,MAAK,aAAa,EAAE;YACpG,iBAAiB,CAAC,iCAAiC,CAAC,wBAAwB,CAAC;gBAC3E,SAAS,EAAE,iBAAiB,CAAC,4BAA4B;gBACzD,SAAS,EAAE,GAAG,CAAC,4BAA4B,CAAC,KAAK;aAClD,CAAC,CAAC;SACJ;KACF;AACH,CAAC;AApBD,sHAoBC","sourcesContent":["import { Stack, Duration, Fn } from 'aws-cdk-lib';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\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';\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  ): 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    });\n  }\n\n  public static addFireLensLogRouter(\n    taskDefinition: ecs.TaskDefinition,\n    cpu: number,\n    memoryLimitMiB: number,\n  ): ecs.ContainerDefinition {\n    return addFireLensLogRouter({ taskDefinition, cpu, memoryLimitMiB });\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}): 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    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_COLLECT_GCE_TAGS: '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\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}): ecs.ContainerDefinition {\n\n  return props.taskDefinition.addFirelensLogRouter('firelens-log-router', {\n    image: ecs.ContainerImage.fromRegistry('public.ecr.aws/aws-observability/aws-for-fluent-bit:stable'),\n    firelensConfig: {\n      type: ecs.FirelensLogRouterType.FLUENTBIT,\n      options: {\n        configFileType: ecs.FirelensConfigFileType.FILE,\n        configFileValue: '/fluent-bit/configs/parse-json.conf',\n        enableECSLogMetadata: true,\n      },\n    },\n    cpu: props.cpu,\n    memoryLimitMiB: props.memoryLimitMiB,\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      const logGroupForForwardingLambda = new logs.LogGroup(props.scope, logGroupId, {\n        logGroupName,\n        retention: logs.RetentionDays.ONE_WEEK,\n      });\n      const logForwarderLambdaArn = Fn.importValue('custom-resource-datadog-logforwarder-function-arn');\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.addDependsOn(cfnPermission);\n      return ecs.LogDrivers.awsLogs({\n        streamPrefix: props.containerType,\n        logGroup: logGroupForForwardingLambda,\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      });\n  }\n}\n\nexport function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService: RioFargateService): 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"]}
|
|
@@ -142,6 +142,12 @@ export interface FargateTaskDefinitionProps {
|
|
|
142
142
|
* the current task number.
|
|
143
143
|
*/
|
|
144
144
|
readonly desiredCount?: number;
|
|
145
|
+
/**
|
|
146
|
+
* The operating system that your task definitions are running on.
|
|
147
|
+
*
|
|
148
|
+
* @default - Using ecs.OperatingSystemFamily.LINUX and ecs.CpuArchitecture.X86_64
|
|
149
|
+
*/
|
|
150
|
+
readonly runtimePlatform?: ecs.RuntimePlatform;
|
|
145
151
|
}
|
|
146
152
|
export interface ListenerRule {
|
|
147
153
|
readonly priority: number;
|