@rio-cloud/cdk-v2-constructs 4.7.0 → 4.9.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.
package/.jsii CHANGED
@@ -3068,7 +3068,7 @@
3068
3068
  "kind": "interface",
3069
3069
  "locationInModule": {
3070
3070
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3071
- "line": 99
3071
+ "line": 122
3072
3072
  },
3073
3073
  "name": "AppStackProps",
3074
3074
  "properties": [
@@ -3080,7 +3080,7 @@
3080
3080
  "immutable": true,
3081
3081
  "locationInModule": {
3082
3082
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3083
- "line": 100
3083
+ "line": 123
3084
3084
  },
3085
3085
  "name": "serviceName",
3086
3086
  "type": {
@@ -3095,7 +3095,7 @@
3095
3095
  "immutable": true,
3096
3096
  "locationInModule": {
3097
3097
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3098
- "line": 101
3098
+ "line": 124
3099
3099
  },
3100
3100
  "name": "version",
3101
3101
  "type": {
@@ -3229,6 +3229,53 @@
3229
3229
  "name": "AwsBackupOverallMonitoring",
3230
3230
  "symbolId": "src/contributions/team-claid/aws-backup-monitoring/aws-backup-monitoring:AwsBackupOverallMonitoring"
3231
3231
  },
3232
+ "@rio-cloud/cdk-v2-constructs.BackupPolicy": {
3233
+ "assembly": "@rio-cloud/cdk-v2-constructs",
3234
+ "docs": {
3235
+ "stability": "stable",
3236
+ "summary": "Helper function to tag constructs with correct backup values to be picked up by the rio landing zone backup solution."
3237
+ },
3238
+ "fqn": "@rio-cloud/cdk-v2-constructs.BackupPolicy",
3239
+ "initializer": {
3240
+ "docs": {
3241
+ "stability": "stable"
3242
+ }
3243
+ },
3244
+ "kind": "class",
3245
+ "locationInModule": {
3246
+ "filename": "src/backup/backup-policy.ts",
3247
+ "line": 17
3248
+ },
3249
+ "methods": [
3250
+ {
3251
+ "docs": {
3252
+ "stability": "stable"
3253
+ },
3254
+ "locationInModule": {
3255
+ "filename": "src/backup/backup-policy.ts",
3256
+ "line": 18
3257
+ },
3258
+ "name": "apply",
3259
+ "parameters": [
3260
+ {
3261
+ "name": "target",
3262
+ "type": {
3263
+ "fqn": "constructs.IConstruct"
3264
+ }
3265
+ },
3266
+ {
3267
+ "name": "criticality",
3268
+ "type": {
3269
+ "fqn": "@rio-cloud/cdk-v2-constructs.Criticality"
3270
+ }
3271
+ }
3272
+ ],
3273
+ "static": true
3274
+ }
3275
+ ],
3276
+ "name": "BackupPolicy",
3277
+ "symbolId": "src/backup/backup-policy:BackupPolicy"
3278
+ },
3232
3279
  "@rio-cloud/cdk-v2-constructs.Claidometer": {
3233
3280
  "assembly": "@rio-cloud/cdk-v2-constructs",
3234
3281
  "base": "constructs.Construct",
@@ -3436,7 +3483,7 @@
3436
3483
  "kind": "interface",
3437
3484
  "locationInModule": {
3438
3485
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3439
- "line": 161
3486
+ "line": 197
3440
3487
  },
3441
3488
  "name": "CodeBuildOptions",
3442
3489
  "properties": [
@@ -3448,7 +3495,7 @@
3448
3495
  "immutable": true,
3449
3496
  "locationInModule": {
3450
3497
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3451
- "line": 163
3498
+ "line": 199
3452
3499
  },
3453
3500
  "name": "buildEnvironment",
3454
3501
  "optional": true,
@@ -3464,7 +3511,7 @@
3464
3511
  "immutable": true,
3465
3512
  "locationInModule": {
3466
3513
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
3467
- "line": 162
3514
+ "line": 198
3468
3515
  },
3469
3516
  "name": "partialBuildSpecPath",
3470
3517
  "optional": true,
@@ -3614,6 +3661,41 @@
3614
3661
  ],
3615
3662
  "symbolId": "src/fargate/rio-fargate-service:ContainerDefinitionOptions"
3616
3663
  },
3664
+ "@rio-cloud/cdk-v2-constructs.Criticality": {
3665
+ "assembly": "@rio-cloud/cdk-v2-constructs",
3666
+ "docs": {
3667
+ "stability": "stable",
3668
+ "summary": "The allowed values for backup criticality levels."
3669
+ },
3670
+ "fqn": "@rio-cloud/cdk-v2-constructs.Criticality",
3671
+ "kind": "enum",
3672
+ "locationInModule": {
3673
+ "filename": "src/backup/backup-policy.ts",
3674
+ "line": 7
3675
+ },
3676
+ "members": [
3677
+ {
3678
+ "docs": {
3679
+ "stability": "stable"
3680
+ },
3681
+ "name": "LOW"
3682
+ },
3683
+ {
3684
+ "docs": {
3685
+ "stability": "stable"
3686
+ },
3687
+ "name": "MEDIUM"
3688
+ },
3689
+ {
3690
+ "docs": {
3691
+ "stability": "stable"
3692
+ },
3693
+ "name": "HIGH"
3694
+ }
3695
+ ],
3696
+ "name": "Criticality",
3697
+ "symbolId": "src/backup/backup-policy:Criticality"
3698
+ },
3617
3699
  "@rio-cloud/cdk-v2-constructs.DataDogLogAlarm": {
3618
3700
  "assembly": "@rio-cloud/cdk-v2-constructs",
3619
3701
  "base": "constructs.Construct",
@@ -4541,7 +4623,7 @@
4541
4623
  "kind": "interface",
4542
4624
  "locationInModule": {
4543
4625
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
4544
- "line": 89
4626
+ "line": 112
4545
4627
  },
4546
4628
  "methods": [
4547
4629
  {
@@ -4552,7 +4634,7 @@
4552
4634
  },
4553
4635
  "locationInModule": {
4554
4636
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
4555
- "line": 96
4637
+ "line": 119
4556
4638
  },
4557
4639
  "name": "create",
4558
4640
  "parameters": [
@@ -5693,6 +5775,55 @@
5693
5775
  ],
5694
5776
  "symbolId": "src/watchful/metric-alarm:MetricAlarmProps"
5695
5777
  },
5778
+ "@rio-cloud/cdk-v2-constructs.PipelineSchedulesProps": {
5779
+ "assembly": "@rio-cloud/cdk-v2-constructs",
5780
+ "datatype": true,
5781
+ "docs": {
5782
+ "stability": "stable"
5783
+ },
5784
+ "fqn": "@rio-cloud/cdk-v2-constructs.PipelineSchedulesProps",
5785
+ "kind": "interface",
5786
+ "locationInModule": {
5787
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5788
+ "line": 28
5789
+ },
5790
+ "name": "PipelineSchedulesProps",
5791
+ "properties": [
5792
+ {
5793
+ "abstract": true,
5794
+ "docs": {
5795
+ "stability": "stable"
5796
+ },
5797
+ "immutable": true,
5798
+ "locationInModule": {
5799
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5800
+ "line": 29
5801
+ },
5802
+ "name": "mainPipeline",
5803
+ "optional": true,
5804
+ "type": {
5805
+ "primitive": "string"
5806
+ }
5807
+ },
5808
+ {
5809
+ "abstract": true,
5810
+ "docs": {
5811
+ "stability": "stable"
5812
+ },
5813
+ "immutable": true,
5814
+ "locationInModule": {
5815
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5816
+ "line": 30
5817
+ },
5818
+ "name": "vulnerabilityPipeline",
5819
+ "optional": true,
5820
+ "type": {
5821
+ "primitive": "string"
5822
+ }
5823
+ }
5824
+ ],
5825
+ "symbolId": "src/contributions/team-transport-two/pipeline/pipeline-stack:PipelineSchedulesProps"
5826
+ },
5696
5827
  "@rio-cloud/cdk-v2-constructs.PipelineStack": {
5697
5828
  "assembly": "@rio-cloud/cdk-v2-constructs",
5698
5829
  "base": "aws-cdk-lib.Stack",
@@ -5706,7 +5837,7 @@
5706
5837
  },
5707
5838
  "locationInModule": {
5708
5839
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5709
- "line": 187
5840
+ "line": 224
5710
5841
  },
5711
5842
  "parameters": [
5712
5843
  {
@@ -5732,7 +5863,7 @@
5732
5863
  "kind": "class",
5733
5864
  "locationInModule": {
5734
5865
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5735
- "line": 166
5866
+ "line": 202
5736
5867
  },
5737
5868
  "name": "PipelineStack",
5738
5869
  "properties": [
@@ -5743,7 +5874,7 @@
5743
5874
  "immutable": true,
5744
5875
  "locationInModule": {
5745
5876
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5746
- "line": 235
5877
+ "line": 272
5747
5878
  },
5748
5879
  "name": "branchCodeBuildProject",
5749
5880
  "type": {
@@ -5757,7 +5888,7 @@
5757
5888
  "immutable": true,
5758
5889
  "locationInModule": {
5759
5890
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5760
- "line": 231
5891
+ "line": 268
5761
5892
  },
5762
5893
  "name": "mainCodebuildProject",
5763
5894
  "type": {
@@ -5780,7 +5911,7 @@
5780
5911
  "kind": "interface",
5781
5912
  "locationInModule": {
5782
5913
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5783
- "line": 29
5914
+ "line": 36
5784
5915
  },
5785
5916
  "name": "PipelineStackProps",
5786
5917
  "properties": [
@@ -5794,7 +5925,7 @@
5794
5925
  "immutable": true,
5795
5926
  "locationInModule": {
5796
5927
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5797
- "line": 46
5928
+ "line": 53
5798
5929
  },
5799
5930
  "name": "appStackFactory",
5800
5931
  "type": {
@@ -5810,7 +5941,7 @@
5810
5941
  "immutable": true,
5811
5942
  "locationInModule": {
5812
5943
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5813
- "line": 51
5944
+ "line": 58
5814
5945
  },
5815
5946
  "name": "pipelineType",
5816
5947
  "type": {
@@ -5827,7 +5958,7 @@
5827
5958
  "immutable": true,
5828
5959
  "locationInModule": {
5829
5960
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5830
- "line": 39
5961
+ "line": 46
5831
5962
  },
5832
5963
  "name": "serviceName",
5833
5964
  "type": {
@@ -5843,7 +5974,7 @@
5843
5974
  "immutable": true,
5844
5975
  "locationInModule": {
5845
5976
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5846
- "line": 65
5977
+ "line": 84
5847
5978
  },
5848
5979
  "name": "codeBuildOptions",
5849
5980
  "optional": true,
@@ -5851,6 +5982,41 @@
5851
5982
  "fqn": "@rio-cloud/cdk-v2-constructs.CodeBuildOptions"
5852
5983
  }
5853
5984
  },
5985
+ {
5986
+ "abstract": true,
5987
+ "docs": {
5988
+ "stability": "stable",
5989
+ "summary": "If present, the capability monitoring deploy step is added to the pipeline."
5990
+ },
5991
+ "immutable": true,
5992
+ "locationInModule": {
5993
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5994
+ "line": 88
5995
+ },
5996
+ "name": "monitoringDeployStepProps",
5997
+ "optional": true,
5998
+ "type": {
5999
+ "fqn": "@rio-cloud/cdk-v2-constructs.PipelineStackRioMonitoringDeployStepProps"
6000
+ }
6001
+ },
6002
+ {
6003
+ "abstract": true,
6004
+ "docs": {
6005
+ "remarks": "See https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n\nDefault values:\n- main pipeline: cron(0 9 ? * 2#1 *)\n- vulnerability pipeline: cron(0 5 ? * MON-FRI *)",
6006
+ "stability": "stable",
6007
+ "summary": "Defines how often the pipeline is triggered automatically. Is defined via a cron expression."
6008
+ },
6009
+ "immutable": true,
6010
+ "locationInModule": {
6011
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
6012
+ "line": 69
6013
+ },
6014
+ "name": "pipelineSchedules",
6015
+ "optional": true,
6016
+ "type": {
6017
+ "fqn": "@rio-cloud/cdk-v2-constructs.PipelineSchedulesProps"
6018
+ }
6019
+ },
5854
6020
  {
5855
6021
  "abstract": true,
5856
6022
  "docs": {
@@ -5861,7 +6027,7 @@
5861
6027
  "immutable": true,
5862
6028
  "locationInModule": {
5863
6029
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5864
- "line": 60
6030
+ "line": 79
5865
6031
  },
5866
6032
  "name": "secretsDeployStepProps",
5867
6033
  "optional": true,
@@ -5872,6 +6038,49 @@
5872
6038
  ],
5873
6039
  "symbolId": "src/contributions/team-transport-two/pipeline/pipeline-stack:PipelineStackProps"
5874
6040
  },
6041
+ "@rio-cloud/cdk-v2-constructs.PipelineStackRioMonitoringDeployStepProps": {
6042
+ "assembly": "@rio-cloud/cdk-v2-constructs",
6043
+ "datatype": true,
6044
+ "docs": {
6045
+ "stability": "stable"
6046
+ },
6047
+ "fqn": "@rio-cloud/cdk-v2-constructs.PipelineStackRioMonitoringDeployStepProps",
6048
+ "kind": "interface",
6049
+ "locationInModule": {
6050
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
6051
+ "line": 137
6052
+ },
6053
+ "name": "PipelineStackRioMonitoringDeployStepProps",
6054
+ "properties": [
6055
+ {
6056
+ "abstract": true,
6057
+ "docs": {
6058
+ "stability": "stable",
6059
+ "summary": "Map {directory: filenames} containing .jar or .zip files created in main build step to be uploaded to the monitoring-testsuite-runner bucket, e.g. ``` { 'availability-monitoring/build/libs': ['foo-availability.jar'], 'performance-monitoring/build/libs': ['api-check.zip', 'foo-performance.jar'], } ```."
6060
+ },
6061
+ "immutable": true,
6062
+ "locationInModule": {
6063
+ "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
6064
+ "line": 147
6065
+ },
6066
+ "name": "monitoringArtifacts",
6067
+ "type": {
6068
+ "collection": {
6069
+ "elementtype": {
6070
+ "collection": {
6071
+ "elementtype": {
6072
+ "primitive": "string"
6073
+ },
6074
+ "kind": "array"
6075
+ }
6076
+ },
6077
+ "kind": "map"
6078
+ }
6079
+ }
6080
+ }
6081
+ ],
6082
+ "symbolId": "src/contributions/team-transport-two/pipeline/pipeline-stack:PipelineStackRioMonitoringDeployStepProps"
6083
+ },
5875
6084
  "@rio-cloud/cdk-v2-constructs.PipelineStackRioSecretsDeployStepProps": {
5876
6085
  "assembly": "@rio-cloud/cdk-v2-constructs",
5877
6086
  "datatype": true,
@@ -5884,7 +6093,7 @@
5884
6093
  "kind": "interface",
5885
6094
  "locationInModule": {
5886
6095
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5887
- "line": 110
6096
+ "line": 133
5888
6097
  },
5889
6098
  "name": "PipelineStackRioSecretsDeployStepProps",
5890
6099
  "properties": [
@@ -5896,7 +6105,7 @@
5896
6105
  "immutable": true,
5897
6106
  "locationInModule": {
5898
6107
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5899
- "line": 111
6108
+ "line": 134
5900
6109
  },
5901
6110
  "name": "secretsFilePath",
5902
6111
  "type": {
@@ -5915,7 +6124,7 @@
5915
6124
  "kind": "enum",
5916
6125
  "locationInModule": {
5917
6126
  "filename": "src/contributions/team-transport-two/pipeline/pipeline-stack.ts",
5918
- "line": 114
6127
+ "line": 150
5919
6128
  },
5920
6129
  "members": [
5921
6130
  {
@@ -8910,5 +9119,5 @@
8910
9119
  }
8911
9120
  },
8912
9121
  "version": "0.0.0",
8913
- "fingerprint": "E71gt2YKcrOqhstpq70kOwy1kYE2NYX74FuJwJjVa40="
9122
+ "fingerprint": "XqI3BKPd29R50MTtLRmsGV3c+mqGjunvDu3HJ4OOe0s="
8914
9123
  }
package/CHANGELOG.md CHANGED
@@ -2,6 +2,22 @@
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
+ ## [4.9.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.8.0&sourceBranch=refs%2Ftags%2Fv4.9.0) (2023-04-25)
6
+
7
+
8
+ ### Features
9
+
10
+ * **pipeline:** Add optional capability monitoring deploy step ([26eea3b](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/26eea3bb372164ef7190da355c24a7da0070af9f))
11
+
12
+ ## [4.8.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.7.0&sourceBranch=refs%2Ftags%2Fv4.8.0) (2023-04-06)
13
+
14
+
15
+ ### Features
16
+
17
+ * add backup policy method ([4602a77](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/4602a77997d9e5af0468a66ffa8692b3ead934f7))
18
+ * **fargate:** Set DD_CLOUD_PROVIDER_METADATA to aws ([a768096](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/a76809650282b930525c61b8cc5a96c74ec8859b)), closes [/github.com/DataDog/datadog-agent/blob/547a3fef69dadf4cc300f60e796e7eecb6ec45c2/pkg/config/config_template.yaml#L337-L363](https://collaboration.msi.audi.com/jira/browse/L337-L363)
19
+ * **pipeline:** allow to set the pipeline schedules ([d71881e](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/d71881e51530f237301a8f4a8f1f97aaeb548a94))
20
+
5
21
  ## [4.7.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.6.0&sourceBranch=refs%2Ftags%2Fv4.7.0) (2023-03-16)
6
22
 
7
23
 
@@ -0,0 +1,16 @@
1
+ import { IConstruct } from 'constructs';
2
+ /**
3
+ * The allowed values for backup criticality levels
4
+ */
5
+ export declare enum Criticality {
6
+ LOW = "low",
7
+ MEDIUM = "medium",
8
+ HIGH = "high"
9
+ }
10
+ /**
11
+ * Helper function to tag constructs with correct backup values to be picked
12
+ * up by the rio landing zone backup solution.
13
+ */
14
+ export declare class BackupPolicy {
15
+ static apply(target: IConstruct, criticality: Criticality): void;
16
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.BackupPolicy = exports.Criticality = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ /**
8
+ * The allowed values for backup criticality levels
9
+ */
10
+ var Criticality;
11
+ (function (Criticality) {
12
+ Criticality["LOW"] = "low";
13
+ Criticality["MEDIUM"] = "medium";
14
+ Criticality["HIGH"] = "high";
15
+ })(Criticality = exports.Criticality || (exports.Criticality = {}));
16
+ /**
17
+ * Helper function to tag constructs with correct backup values to be picked
18
+ * up by the rio landing zone backup solution.
19
+ */
20
+ class BackupPolicy {
21
+ static apply(target, criticality) {
22
+ aws_cdk_lib_1.Tags.of(target).add('rio-lz-backup-criticality-level', criticality);
23
+ }
24
+ }
25
+ exports.BackupPolicy = BackupPolicy;
26
+ _a = JSII_RTTI_SYMBOL_1;
27
+ BackupPolicy[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.BackupPolicy", version: "0.0.0" };
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFja3VwLXBvbGljeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9iYWNrdXAvYmFja3VwLXBvbGljeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUFtQztBQUduQzs7R0FFRztBQUNILElBQVksV0FJWDtBQUpELFdBQVksV0FBVztJQUNyQiwwQkFBVyxDQUFBO0lBQ1gsZ0NBQWlCLENBQUE7SUFDakIsNEJBQWEsQ0FBQTtBQUNmLENBQUMsRUFKVyxXQUFXLEdBQVgsbUJBQVcsS0FBWCxtQkFBVyxRQUl0QjtBQUVEOzs7R0FHRztBQUNILE1BQWEsWUFBWTtJQUN2QixNQUFNLENBQUMsS0FBSyxDQUFDLE1BQWtCLEVBQUUsV0FBd0I7UUFDdkQsa0JBQUksQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLGlDQUFpQyxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7O0FBSEgsb0NBSUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUYWdzIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgSUNvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuXG4vKipcbiAqIFRoZSBhbGxvd2VkIHZhbHVlcyBmb3IgYmFja3VwIGNyaXRpY2FsaXR5IGxldmVsc1xuICovXG5leHBvcnQgZW51bSBDcml0aWNhbGl0eSB7XG4gIExPVyA9ICdsb3cnLFxuICBNRURJVU0gPSAnbWVkaXVtJyxcbiAgSElHSCA9ICdoaWdoJ1xufVxuXG4vKipcbiAqIEhlbHBlciBmdW5jdGlvbiB0byB0YWcgY29uc3RydWN0cyB3aXRoIGNvcnJlY3QgYmFja3VwIHZhbHVlcyB0byBiZSBwaWNrZWRcbiAqIHVwIGJ5IHRoZSByaW8gbGFuZGluZyB6b25lIGJhY2t1cCBzb2x1dGlvbi5cbiAqL1xuZXhwb3J0IGNsYXNzIEJhY2t1cFBvbGljeSB7XG4gIHN0YXRpYyBhcHBseSh0YXJnZXQ6IElDb25zdHJ1Y3QsIGNyaXRpY2FsaXR5OiBDcml0aWNhbGl0eSkge1xuICAgIFRhZ3Mub2YodGFyZ2V0KS5hZGQoJ3Jpby1sei1iYWNrdXAtY3JpdGljYWxpdHktbGV2ZWwnLCBjcml0aWNhbGl0eSk7XG4gIH1cbn0iXX0=
@@ -0,0 +1 @@
1
+ export * from './backup-policy';
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ __exportStar(require("./backup-policy"), exports);
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYmFja3VwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztBQUFBLGtEQUFnQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFja3VwLXBvbGljeSc7Il19
@@ -0,0 +1,12 @@
1
+ import * as pipelines from 'aws-cdk-lib/pipelines';
2
+ import { Construct } from 'constructs';
3
+ export interface RioCapabilityMonitoringArtifacts {
4
+ input: pipelines.IFileSetProducer;
5
+ files: string[];
6
+ }
7
+ export interface RioCapabilityMonitoringDeployStepProps {
8
+ monitoringArtifacts: RioCapabilityMonitoringArtifacts[];
9
+ }
10
+ export declare class RioCapabilityMonitoringDeployStep extends pipelines.CodeBuildStep {
11
+ constructor(scope: Construct, id: string, props: RioCapabilityMonitoringDeployStepProps);
12
+ }
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RioCapabilityMonitoringDeployStep = void 0;
4
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
5
+ const pipelines = require("aws-cdk-lib/pipelines");
6
+ class RioCapabilityMonitoringDeployStep extends pipelines.CodeBuildStep {
7
+ constructor(scope, id, props) {
8
+ super(id, {
9
+ additionalInputs: props.monitoringArtifacts.reduce((result, item) => ({ ...result, [`${Object.keys(result).length}`]: item.input }), {}),
10
+ commands: props.monitoringArtifacts.map((item, index) => item.files.map((file) => [
11
+ `echo "Uploading ${index}/${file}" to S3`,
12
+ `aws s3 cp "${index}/${file}" s3://monitoring-testsuite-runner-${aws_cdk_lib_1.Stack.of(scope).account}`,
13
+ ])).flat(2),
14
+ });
15
+ }
16
+ }
17
+ exports.RioCapabilityMonitoringDeployStep = RioCapabilityMonitoringDeployStep;
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uaXRvcmluZy1kZXBsb3ktc3RlcC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZS9tb25pdG9yaW5nLWRlcGxveS1zdGVwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZDQUFvQztBQUNwQyxtREFBbUQ7QUFZbkQsTUFBYSxpQ0FBa0MsU0FBUSxTQUFTLENBQUMsYUFBYTtJQUM1RSxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTZDO1FBQ3JGLEtBQUssQ0FBQyxFQUFFLEVBQUU7WUFDUixnQkFBZ0IsRUFBRSxLQUFLLENBQUMsbUJBQW1CLENBQUMsTUFBTSxDQUNoRCxDQUFDLE1BQVcsRUFBRSxJQUFzQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxNQUFNLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7WUFDOUgsUUFBUSxFQUFFLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFzQyxFQUFFLEtBQWEsRUFBRSxFQUFFLENBQ2hHLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUNaLENBQUMsSUFBWSxFQUFFLEVBQUUsQ0FBQztnQkFDaEIsbUJBQW1CLEtBQUssSUFBSSxJQUFJLFNBQVM7Z0JBQ3pDLGNBQWMsS0FBSyxJQUFJLElBQUksc0NBQXNDLG1CQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLE9BQU8sRUFBRTthQUMzRixDQUNGLENBQ0YsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1NBQ1YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBZkQsOEVBZUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdGFjayB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIHBpcGVsaW5lcyBmcm9tICdhd3MtY2RrLWxpYi9waXBlbGluZXMnO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSAnY29uc3RydWN0cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmlvQ2FwYWJpbGl0eU1vbml0b3JpbmdBcnRpZmFjdHMge1xuICBpbnB1dDogcGlwZWxpbmVzLklGaWxlU2V0UHJvZHVjZXI7XG4gIGZpbGVzOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSaW9DYXBhYmlsaXR5TW9uaXRvcmluZ0RlcGxveVN0ZXBQcm9wcyB7XG4gIG1vbml0b3JpbmdBcnRpZmFjdHM6IFJpb0NhcGFiaWxpdHlNb25pdG9yaW5nQXJ0aWZhY3RzW107XG59XG5cbmV4cG9ydCBjbGFzcyBSaW9DYXBhYmlsaXR5TW9uaXRvcmluZ0RlcGxveVN0ZXAgZXh0ZW5kcyBwaXBlbGluZXMuQ29kZUJ1aWxkU3RlcCB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBSaW9DYXBhYmlsaXR5TW9uaXRvcmluZ0RlcGxveVN0ZXBQcm9wcykge1xuICAgIHN1cGVyKGlkLCB7XG4gICAgICBhZGRpdGlvbmFsSW5wdXRzOiBwcm9wcy5tb25pdG9yaW5nQXJ0aWZhY3RzLnJlZHVjZShcbiAgICAgICAgKHJlc3VsdDogYW55LCBpdGVtOiBSaW9DYXBhYmlsaXR5TW9uaXRvcmluZ0FydGlmYWN0cykgPT4gKHsgLi4ucmVzdWx0LCBbYCR7T2JqZWN0LmtleXMocmVzdWx0KS5sZW5ndGh9YF06IGl0ZW0uaW5wdXQgfSksIHt9KSxcbiAgICAgIGNvbW1hbmRzOiBwcm9wcy5tb25pdG9yaW5nQXJ0aWZhY3RzLm1hcCgoaXRlbTogUmlvQ2FwYWJpbGl0eU1vbml0b3JpbmdBcnRpZmFjdHMsIGluZGV4OiBudW1iZXIpID0+XG4gICAgICAgIGl0ZW0uZmlsZXMubWFwKFxuICAgICAgICAgIChmaWxlOiBzdHJpbmcpID0+IFtcbiAgICAgICAgICAgIGBlY2hvIFwiVXBsb2FkaW5nICR7aW5kZXh9LyR7ZmlsZX1cIiB0byBTM2AsXG4gICAgICAgICAgICBgYXdzIHMzIGNwIFwiJHtpbmRleH0vJHtmaWxlfVwiIHMzOi8vbW9uaXRvcmluZy10ZXN0c3VpdGUtcnVubmVyLSR7U3RhY2sub2Yoc2NvcGUpLmFjY291bnR9YCxcbiAgICAgICAgICBdLFxuICAgICAgICApLFxuICAgICAgKS5mbGF0KDIpLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -3,6 +3,10 @@ import { Stack, StackProps } from 'aws-cdk-lib';
3
3
  import { BuildEnvironment } from 'aws-cdk-lib/aws-codebuild';
4
4
  import { CodeBuildStep } from 'aws-cdk-lib/pipelines';
5
5
  import { Construct } from 'constructs';
6
+ export interface PipelineSchedulesProps {
7
+ readonly mainPipeline?: string;
8
+ readonly vulnerabilityPipeline?: string;
9
+ }
6
10
  /**
7
11
  * @struct
8
12
  */
@@ -27,6 +31,16 @@ export interface PipelineStackProps extends StackProps {
27
31
  * Defines which kind of pipeline is deployed.
28
32
  */
29
33
  readonly pipelineType: PipelineType;
34
+ /**
35
+ * Defines how often the pipeline is triggered automatically. Is defined via a cron expression.
36
+ *
37
+ * See https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html
38
+ *
39
+ * Default values:
40
+ * - main pipeline: cron(0 9 ? * 2#1 *)
41
+ * - vulnerability pipeline: cron(0 5 ? * MON-FRI *)
42
+ */
43
+ readonly pipelineSchedules?: PipelineSchedulesProps;
30
44
  /**
31
45
  * Path to secrets file containing encrypted secrets.
32
46
  *
@@ -39,6 +53,10 @@ export interface PipelineStackProps extends StackProps {
39
53
  * CodeBuild options overriding the rio-specific defaults.
40
54
  */
41
55
  readonly codeBuildOptions?: CodeBuildOptions;
56
+ /**
57
+ * If present, the capability monitoring deploy step is added to the pipeline.
58
+ */
59
+ readonly monitoringDeployStepProps?: PipelineStackRioMonitoringDeployStepProps;
42
60
  }
43
61
  /**
44
62
  * Provider interface to create the AppStack within the specific scope
@@ -83,6 +101,20 @@ export interface AppStackProps extends StackProps {
83
101
  export interface PipelineStackRioSecretsDeployStepProps {
84
102
  readonly secretsFilePath: string;
85
103
  }
104
+ export interface PipelineStackRioMonitoringDeployStepProps {
105
+ /**
106
+ * Map {directory: filenames} containing .jar or .zip files created in main build step to be uploaded to the monitoring-testsuite-runner bucket, e.g.
107
+ * ```
108
+ * {
109
+ * 'availability-monitoring/build/libs': ['foo-availability.jar'],
110
+ * 'performance-monitoring/build/libs': ['api-check.zip', 'foo-performance.jar'],
111
+ * }
112
+ * ```
113
+ */
114
+ readonly monitoringArtifacts: {
115
+ [directory: string]: string[];
116
+ };
117
+ }
86
118
  export declare enum PipelineType {
87
119
  /**
88
120
  * Self-mutating codepipeline deploying the provided AppStack. Be aware: The provided service won't have access to Kafka.
@@ -153,6 +185,7 @@ export declare class PipelineStack extends Stack {
153
185
  private addMainPipeline;
154
186
  private addBranchPipeline;
155
187
  private addVulnerabilityPipeline;
188
+ private createCapabilityMonitoringDeployStep;
156
189
  private resolveDefaultBuildSpec;
157
190
  private grantPermissionsForKafkaIntegration;
158
191
  private loadBuildSpecFromFile;
@@ -13,6 +13,7 @@ const events = require("aws-cdk-lib/aws-events");
13
13
  const targets = require("aws-cdk-lib/aws-events-targets");
14
14
  const aws_iam_1 = require("aws-cdk-lib/aws-iam");
15
15
  const s3 = require("aws-cdk-lib/aws-s3");
16
+ const aws_s3_1 = require("aws-cdk-lib/aws-s3");
16
17
  const ssm = require("aws-cdk-lib/aws-ssm");
17
18
  const pipelines = require("aws-cdk-lib/pipelines");
18
19
  const pipelines_1 = require("aws-cdk-lib/pipelines");
@@ -23,6 +24,7 @@ const upperToLower_1 = require("../../../watchful/upperToLower");
23
24
  const application_stage_1 = require("./application-stage");
24
25
  const build_project_1 = require("./build-project");
25
26
  const datadog_monitors_1 = require("./datadog-monitors");
27
+ const monitoring_deploy_step_1 = require("./monitoring-deploy-step");
26
28
  var PipelineType;
27
29
  (function (PipelineType) {
28
30
  /**
@@ -98,7 +100,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
98
100
  product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
99
101
  packageName,
100
102
  feature,
101
- version: '0.0.7',
103
+ version: '0.0.8',
102
104
  });
103
105
  }
104
106
  static addLifecycleRuleArtifactBucket(pipeline) {
@@ -147,6 +149,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
147
149
  ],
148
150
  });
149
151
  pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });
152
+ const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);
150
153
  pipeline.addStage(new application_stage_1.Application(this, 'DeployApplicationStacks', {
151
154
  appStackFactory: props.appStackFactory,
152
155
  serviceName: props.serviceName,
@@ -158,9 +161,16 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
158
161
  input: this._inputMasterTriggerFile,
159
162
  }),
160
163
  ] : undefined,
164
+ post: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,
161
165
  });
162
166
  pipeline.buildPipeline();
163
- const rule = new events.Rule(this, 'PipelineSchedule', { schedule: events.Schedule.expression('cron(0 9 ? * 2#1 *)') });
167
+ if (capabilityMonitoringDeployStep) {
168
+ const monitoringTestsuiteRunnerBucket = aws_s3_1.Bucket.fromBucketName(this, 'MonitoringTestsuiteRunnerBucket', `monitoring-testsuite-runner-${this.account}`);
169
+ monitoringTestsuiteRunnerBucket.grantWrite(capabilityMonitoringDeployStep);
170
+ }
171
+ const rule = new events.Rule(this, 'PipelineSchedule', {
172
+ schedule: events.Schedule.expression(props.pipelineSchedules?.mainPipeline || 'cron(0 9 ? * 2#1 *)'),
173
+ });
164
174
  rule.addTarget(new targets.CodePipeline(pipeline.pipeline));
165
175
  PipelineStack.addLifecycleRuleArtifactBucket(pipeline);
166
176
  this._ossLicensesBucket.grantReadWrite(mainBuild);
@@ -212,7 +222,9 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
212
222
  vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);
213
223
  vulnerabilityPipeline.buildPipeline();
214
224
  this._nistDataMirrorUrl.grantRead(vulnerabilityBuild);
215
- const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', { schedule: events.Schedule.expression('cron(0 5 ? * MON-FRI *)') });
225
+ const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', {
226
+ schedule: events.Schedule.expression(props.pipelineSchedules?.vulnerabilityPipeline || 'cron(0 5 ? * MON-FRI *)'),
227
+ });
216
228
  vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));
217
229
  PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);
218
230
  new datadog_monitors_1.DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {
@@ -221,6 +233,23 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
221
233
  accountId: this.account,
222
234
  });
223
235
  }
236
+ createCapabilityMonitoringDeployStep(mainBuild, props) {
237
+ if (props.monitoringDeployStepProps) {
238
+ const monitoringArtifacts = Object.keys(props.monitoringDeployStepProps.monitoringArtifacts).map((key) => {
239
+ const output = mainBuild.addOutputDirectory(key);
240
+ return {
241
+ input: output,
242
+ files: props.monitoringDeployStepProps.monitoringArtifacts[key],
243
+ };
244
+ });
245
+ return new monitoring_deploy_step_1.RioCapabilityMonitoringDeployStep(this, 'DeployCapabilityMonitoring', {
246
+ monitoringArtifacts: monitoringArtifacts,
247
+ });
248
+ }
249
+ else {
250
+ return undefined;
251
+ }
252
+ }
224
253
  resolveDefaultBuildSpec(pipelineType) {
225
254
  switch (pipelineType) {
226
255
  case PipelineType.STANDARD_GRADLE:
@@ -257,4 +286,4 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
257
286
  exports.PipelineStack = PipelineStack;
258
287
  _a = JSII_RTTI_SYMBOL_1;
259
288
  PipelineStack[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.PipelineStack", version: "0.0.0" };
260
- //# 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 fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, Stack, StackProps } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, LinuxBuildImage } from 'aws-cdk-lib/aws-codebuild';\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 { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\nimport { IHostedZone } from 'aws-cdk-lib/aws-route53';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { IBucket } from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { IStringParameter } from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep, CodePipelineSource } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioCodeBuildProject } 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 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   * CodeBuild options overriding the rio-specific defaults.\n   */\n  readonly codeBuildOptions?: CodeBuildOptions;\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 definition\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   * Self-mutating codepipeline deploying the provided AppStack with additional steps needed to access 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   * - request a certificate to authenticate against Kafka via mutual TLS\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_KAFKA = 'STANDARD_GRADLE_KAFKA',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack.\n   *\n   * Comes with a pre-defined buildspec.yaml to synthesize the AppStack.\n   * No branch or vulnerability pipeline is created.\n   */\n  STANDARD_INFRASTRUCTURE = 'STANDARD_INFRASTRUCTURE',\n}\n\n/**\n * @param partialBuildSpecPath Path to a custom build-spec file to use for the main and branch pipeline.\n * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n * @param buildEnvironment Custom CodeBuild build environment overriding the rio-specific defaults. The defaults are:\n *          buildImage: AMAZON_LINUX_2_4\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\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  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _hostedZone: IHostedZone;\n  private readonly _inputMasterTriggerFile: CodePipelineSource;\n  private readonly _inputBranchTriggerFile: CodePipelineSource;\n  private readonly _ossLicensesBucketParameter: IStringParameter;\n  private readonly _ossLicensesBucket: IBucket;\n  private readonly _serviceKeystorePassword: IStringParameter;\n  private readonly _accountNameParameter: IStringParameter;\n  private readonly _nistDataMirrorUrl: IStringParameter;\n  private readonly _codeBuildDefaults: CodeBuildOptions;\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // populate external parameters\n    this._bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    this._hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    this._inputMasterTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    this._inputBranchTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    this._ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', { parameterName: '/config/oss-licenses/bucket-name' });\n    this._ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', this._ossLicensesBucketParameter.stringValue);\n    this._serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    this._accountNameParameter = ssm.StringParameter.fromStringParameterName(this, 'AccountNameParameter', '/config/account/name');\n    this._nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'NistDataMirrorUrl', {\n      parameterName: '/config/nist-data-mirror/url',\n      version: 1,\n    });\n    this._codeBuildDefaults = {\n      buildEnvironment: {\n        buildImage: LinuxBuildImage.STANDARD_6_0,\n      },\n    };\n\n    this._mainCodeBuildProject = this.createRioCodeBuildProject('MainBuild', this._inputMasterTriggerFile, props);\n    this.addMainPipeline(props, this._mainCodeBuildProject);\n\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);\n      this.addBranchPipeline(props, this._branchCodeBuildProject);\n      this.addVulnerabilityPipeline(props);\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.7',\n    });\n  }\n\n  public get mainCodebuildProject() {\n    return this._mainCodeBuildProject;\n  }\n\n  public get branchCodeBuildProject(): CodeBuildStep {\n    if (this._branchCodeBuildProject == undefined) {\n      throw Error('The pipeline type you have selected does not support a branch codebuild project');\n    }\n    return this._branchCodeBuildProject;\n  }\n\n  private createRioCodeBuildProject(name: string, triggerFile: CodePipelineSource, props: PipelineStackProps) {\n    return new RioCodeBuildProject(this, name, {\n      input: triggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||\n          this.resolveDefaultBuildSpec(props.pipelineType)),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n  }\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: mainBuild,\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: process.env.PIPELINE_EXECUTION_ID ?? 'PIPELINE_EXECUTION_ID not set',\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n          ...props.secretsDeployStepProps,\n          input: this._inputMasterTriggerFile,\n        }),\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    this._ossLicensesBucket.grantReadWrite(mainBuild);\n    this._ossLicensesBucketParameter.grantRead(mainBuild);\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._serviceKeystorePassword.grantRead(mainBuild);\n    }\n    this._accountNameParameter.grantRead(mainBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');\n    }\n    pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n  }\n\n  private addBranchPipeline(props: PipelineStackProps, branchBuild: CodeBuildStep) {\n\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\n    this._ossLicensesBucket.grantReadWrite(branchBuild);\n    this._ossLicensesBucketParameter.grantRead(branchBuild);\n    this._serviceKeystorePassword.grantRead(branchBuild);\n    this._accountNameParameter.grantRead(branchBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');\n    }\n  }\n\n  private addVulnerabilityPipeline(props: PipelineStackProps) {\n    const vulnerabilityBuild = new RioCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: this._inputMasterTriggerFile,\n      partialBuildSpec: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    this._nistDataMirrorUrl.grantRead(vulnerabilityBuild);\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    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n    });\n  }\n\n  private resolveDefaultBuildSpec(pipelineType: PipelineType) {\n    switch (pipelineType) {\n      case PipelineType.STANDARD_GRADLE:\n        return path.resolve(__dirname, 'buildspecs/buildspec.yaml');\n      case PipelineType.STANDARD_GRADLE_KAFKA:\n        return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');\n      case PipelineType.STANDARD_INFRASTRUCTURE:\n        return path.resolve(__dirname, 'buildspecs/buildspec_infrastructure.yaml');\n    }\n  }\n\n  private grantPermissionsForKafkaIntegration(buildProject: RioCodeBuildProject, policyId: string) {\n    const buildProjectRole = buildProject.project.role;\n    if (buildProjectRole) {\n      buildProjectRole.addManagedPolicy(\n        ManagedPolicy.fromManagedPolicyArn(this,\n          policyId,\n          Fn.importValue('kafka-integration-policy-arn'),\n        ),\n      );\n    } else {\n      throw Error(`Could not add managed policy for kafka-integration to CodeBuild project of ${buildProject.id} due to missing role.`);\n    }\n  }\n\n  private loadBuildSpecFromFile(buildSpecPath: string): BuildSpec {\n    return BuildSpec.fromObject(yaml.load(fs.readFileSync(buildSpecPath, { encoding: 'utf-8' })) as Object);\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"]}
289
+ //# 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 fs from 'fs';\nimport * as path from 'path';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration, Fn, Reference, Stack, StackProps } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, LinuxBuildImage } from 'aws-cdk-lib/aws-codebuild';\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 { ManagedPolicy } from 'aws-cdk-lib/aws-iam';\nimport { IHostedZone } from 'aws-cdk-lib/aws-route53';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { Bucket, IBucket } from 'aws-cdk-lib/aws-s3';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { IStringParameter } from 'aws-cdk-lib/aws-ssm';\nimport * as pipelines from 'aws-cdk-lib/pipelines';\nimport { CodeBuildStep, CodePipelineSource } from 'aws-cdk-lib/pipelines';\nimport { Construct } from 'constructs';\nimport * as yaml from 'js-yaml';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful/upperToLower';\nimport { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\nimport { RioCapabilityMonitoringDeployStep } from './monitoring-deploy-step';\n\n\nexport interface PipelineSchedulesProps {\n  readonly mainPipeline?: string;\n  readonly vulnerabilityPipeline?: string;\n}\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   * Defines how often the pipeline is triggered automatically. Is defined via a cron expression.\n   *\n   * See https://docs.aws.amazon.com/AmazonCloudWatch/latest/events/ScheduledEvents.html\n   *\n   * Default values:\n   * - main pipeline: cron(0 9 ? * 2#1 *)\n   * - vulnerability pipeline: cron(0 5 ? * MON-FRI *)\n   */\n  readonly pipelineSchedules?: PipelineSchedulesProps;\n\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   * CodeBuild options overriding the rio-specific defaults.\n   */\n  readonly codeBuildOptions?: CodeBuildOptions;\n  /**\n   * If present, the capability monitoring deploy step is added to the pipeline.\n   */\n  readonly monitoringDeployStepProps?: PipelineStackRioMonitoringDeployStepProps;\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 definition\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 interface PipelineStackRioMonitoringDeployStepProps {\n  /**\n   * Map {directory: filenames} containing  .jar or .zip files created in main build step to be uploaded to the monitoring-testsuite-runner bucket, e.g.\n   * ```\n   * {\n   *  'availability-monitoring/build/libs': ['foo-availability.jar'],\n   *  'performance-monitoring/build/libs': ['api-check.zip', 'foo-performance.jar'],\n   * }\n   * ```\n   */\n  readonly monitoringArtifacts: { [directory: string]: 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   * Self-mutating codepipeline deploying the provided AppStack with additional steps needed to access 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   * - request a certificate to authenticate against Kafka via mutual TLS\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_KAFKA = 'STANDARD_GRADLE_KAFKA',\n  /**\n   * Self-mutating codepipeline deploying the provided AppStack.\n   *\n   * Comes with a pre-defined buildspec.yaml to synthesize the AppStack.\n   * No branch or vulnerability pipeline is created.\n   */\n  STANDARD_INFRASTRUCTURE = 'STANDARD_INFRASTRUCTURE',\n}\n\n/**\n * @param partialBuildSpecPath Path to a custom build-spec file to use for the main and branch pipeline.\n * A pre-defined buildspec.yaml fitting the pipelineType is used if not provided.\n * @param buildEnvironment Custom CodeBuild build environment overriding the rio-specific defaults. The defaults are:\n *          buildImage: AMAZON_LINUX_2_4\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\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  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _hostedZone: IHostedZone;\n  private readonly _inputMasterTriggerFile: CodePipelineSource;\n  private readonly _inputBranchTriggerFile: CodePipelineSource;\n  private readonly _ossLicensesBucketParameter: IStringParameter;\n  private readonly _ossLicensesBucket: IBucket;\n  private readonly _serviceKeystorePassword: IStringParameter;\n  private readonly _accountNameParameter: IStringParameter;\n  private readonly _nistDataMirrorUrl: IStringParameter;\n  private readonly _codeBuildDefaults: CodeBuildOptions;\n\n  constructor(scope: Construct, id: string, props: PipelineStackProps) {\n    super(scope, id, props);\n\n    // populate external parameters\n    this._bucket = s3.Bucket.fromBucketName(this, 'TriggerBucket', Fn.importValue('bitbucket-integration-s3-bucket'));\n    this._hostedZone = rio.RioLandingZone.getDefaultHostedZone(this);\n    this._inputMasterTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.MASTER_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n    this._inputBranchTriggerFile = pipelines.CodePipelineSource.s3(this._bucket, `${props.serviceName}/trigger/${rio.TriggerKey.BRANCH_REPO}`, { trigger: codepipeline_actions.S3Trigger.EVENTS });\n\n    this._ossLicensesBucketParameter = ssm.StringParameter.fromStringParameterAttributes(this, 'OssLicensesBucketParameter', { parameterName: '/config/oss-licenses/bucket-name' });\n    this._ossLicensesBucket = s3.Bucket.fromBucketName(this, 'OssLicensesBucket', this._ossLicensesBucketParameter.stringValue);\n    this._serviceKeystorePassword = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'KeystorePassword', {\n      parameterName: `/config/${props.serviceName}/service-keystore-password`,\n      version: 1,\n    });\n    this._accountNameParameter = ssm.StringParameter.fromStringParameterName(this, 'AccountNameParameter', '/config/account/name');\n    this._nistDataMirrorUrl = ssm.StringParameter.fromSecureStringParameterAttributes(this, 'NistDataMirrorUrl', {\n      parameterName: '/config/nist-data-mirror/url',\n      version: 1,\n    });\n    this._codeBuildDefaults = {\n      buildEnvironment: {\n        buildImage: LinuxBuildImage.STANDARD_6_0,\n      },\n    };\n\n    this._mainCodeBuildProject = this.createRioCodeBuildProject('MainBuild', this._inputMasterTriggerFile, props);\n    this.addMainPipeline(props, this._mainCodeBuildProject);\n\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._branchCodeBuildProject = this.createRioCodeBuildProject('BranchBuild', this._inputBranchTriggerFile, props);\n      this.addBranchPipeline(props, this._branchCodeBuildProject);\n      this.addVulnerabilityPipeline(props);\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.8',\n    });\n  }\n\n  public get mainCodebuildProject() {\n    return this._mainCodeBuildProject;\n  }\n\n  public get branchCodeBuildProject(): CodeBuildStep {\n    if (this._branchCodeBuildProject == undefined) {\n      throw Error('The pipeline type you have selected does not support a branch codebuild project');\n    }\n    return this._branchCodeBuildProject;\n  }\n\n  private createRioCodeBuildProject(name: string, triggerFile: CodePipelineSource, props: PipelineStackProps) {\n    return new RioCodeBuildProject(this, name, {\n      input: triggerFile,\n      cdkOutDirectory: 'infrastructure/cdk.out',\n      partialBuildSpec: this.loadBuildSpecFromFile(props?.codeBuildOptions?.partialBuildSpecPath ||\n        this.resolveDefaultBuildSpec(props.pipelineType)),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: mainBuild,\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    const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);\n\n    pipeline.addStage(new Application(this, 'DeployApplicationStacks', {\n      appStackFactory: props.appStackFactory,\n      serviceName: props.serviceName,\n      version: process.env.PIPELINE_EXECUTION_ID ?? 'PIPELINE_EXECUTION_ID not set',\n    }), {\n      pre: props.secretsDeployStepProps ? [\n        new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n          ...props.secretsDeployStepProps,\n          input: this._inputMasterTriggerFile,\n        }),\n      ] : undefined,\n      post: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    if (capabilityMonitoringDeployStep) {\n      const monitoringTestsuiteRunnerBucket = Bucket.fromBucketName(this, 'MonitoringTestsuiteRunnerBucket', `monitoring-testsuite-runner-${this.account}`);\n      monitoringTestsuiteRunnerBucket.grantWrite(capabilityMonitoringDeployStep);\n    }\n\n    const rule = new events.Rule(this, 'PipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.mainPipeline || 'cron(0 9 ? * 2#1 *)'),\n    });\n    rule.addTarget(new targets.CodePipeline(pipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(pipeline);\n    this._ossLicensesBucket.grantReadWrite(mainBuild);\n    this._ossLicensesBucketParameter.grantRead(mainBuild);\n    if (props.pipelineType !== PipelineType.STANDARD_INFRASTRUCTURE) {\n      this._serviceKeystorePassword.grantRead(mainBuild);\n    }\n    this._accountNameParameter.grantRead(mainBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(mainBuild, 'KafkaIntegrationPolicy');\n    }\n    pipeline.pipeline.artifactBucket.grantReadWrite(stripAssetsStep.project);\n\n    new DatadogPipelineErrorAlert(this, 'DatadogPipelineErrorMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(pipeline),\n      accountId: this.account,\n    });\n  }\n\n  private addBranchPipeline(props: PipelineStackProps, branchBuild: CodeBuildStep) {\n\n    const branchPipeline = new pipelines.CodePipeline(this, 'BranchPipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    PipelineStack.addLifecycleRuleArtifactBucket(branchPipeline);\n    this._ossLicensesBucket.grantReadWrite(branchBuild);\n    this._ossLicensesBucketParameter.grantRead(branchBuild);\n    this._serviceKeystorePassword.grantRead(branchBuild);\n    this._accountNameParameter.grantRead(branchBuild);\n    if (props.pipelineType === PipelineType.STANDARD_GRADLE_KAFKA) {\n      this.grantPermissionsForKafkaIntegration(branchBuild, 'BranchKafkaIntegrationPolicy');\n    }\n  }\n\n  private addVulnerabilityPipeline(props: PipelineStackProps) {\n    const vulnerabilityBuild = new RioCodeBuildProject(this, 'VulnerabilityChecks', {\n      input: this._inputMasterTriggerFile,\n      partialBuildSpec: this.loadBuildSpecFromFile(path.resolve(__dirname, 'buildspecs/buildspec-vulnerability-checks.yaml')),\n      buildEnvironment: props?.codeBuildOptions?.buildEnvironment,\n      hostedZoneName: this._hostedZone.zoneName,\n      serviceName: props.serviceName,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      codeBuildDefaults: this._codeBuildDefaults,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    this._nistDataMirrorUrl.grantRead(vulnerabilityBuild);\n\n    const vulnerabilityRule = new events.Rule(this, 'VulnerabilityPipelineSchedule', {\n      schedule: events.Schedule.expression(props.pipelineSchedules?.vulnerabilityPipeline || 'cron(0 5 ? * MON-FRI *)'),\n    });\n    vulnerabilityRule.addTarget(new targets.CodePipeline(vulnerabilityPipeline.pipeline));\n\n    PipelineStack.addLifecycleRuleArtifactBucket(vulnerabilityPipeline);\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n    });\n  }\n\n  private createCapabilityMonitoringDeployStep(mainBuild: CodeBuildStep, props: PipelineStackProps): CodeBuildStep | undefined {\n    if (props.monitoringDeployStepProps) {\n      const monitoringArtifacts = Object.keys(props.monitoringDeployStepProps.monitoringArtifacts).map((key) => {\n        const output = mainBuild.addOutputDirectory(key);\n        return {\n          input: output,\n          files: props.monitoringDeployStepProps!.monitoringArtifacts[key],\n        };\n      });\n      return new RioCapabilityMonitoringDeployStep(this, 'DeployCapabilityMonitoring', {\n        monitoringArtifacts: monitoringArtifacts,\n      });\n    } else {\n      return undefined;\n    }\n  }\n\n  private resolveDefaultBuildSpec(pipelineType: PipelineType) {\n    switch (pipelineType) {\n      case PipelineType.STANDARD_GRADLE:\n        return path.resolve(__dirname, 'buildspecs/buildspec.yaml');\n      case PipelineType.STANDARD_GRADLE_KAFKA:\n        return path.resolve(__dirname, 'buildspecs/buildspec_kafka.yaml');\n      case PipelineType.STANDARD_INFRASTRUCTURE:\n        return path.resolve(__dirname, 'buildspecs/buildspec_infrastructure.yaml');\n    }\n  }\n\n  private grantPermissionsForKafkaIntegration(buildProject: RioCodeBuildProject, policyId: string) {\n    const buildProjectRole = buildProject.project.role;\n    if (buildProjectRole) {\n      buildProjectRole.addManagedPolicy(\n        ManagedPolicy.fromManagedPolicyArn(this,\n          policyId,\n          Fn.importValue('kafka-integration-policy-arn'),\n        ),\n      );\n    } else {\n      throw Error(`Could not add managed policy for kafka-integration to CodeBuild project of ${buildProject.id} due to missing role.`);\n    }\n  }\n\n  private loadBuildSpecFromFile(buildSpecPath: string): BuildSpec {\n    return BuildSpec.fromObject(yaml.load(fs.readFileSync(buildSpecPath, { encoding: 'utf-8' })) as Object);\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"]}
@@ -132,7 +132,7 @@ function addDatadogSidecar(props) {
132
132
  DD_SITE: props.datadogSite,
133
133
  DD_TAGS: getTagsEnvironmentVariableValue({ ...props, accountId, region, containerType: 'datadog-sidecar' }),
134
134
  ECS_FARGATE: 'true',
135
- DD_COLLECT_GCE_TAGS: 'false',
135
+ DD_CLOUD_PROVIDER_METADATA: 'aws',
136
136
  },
137
137
  // see https://github.com/DataDog/datadog-agent/blob/master/Dockerfiles/agent/amd64/Dockerfile#L171-L172
138
138
  healthCheck: {
@@ -291,4 +291,4 @@ function ensureLoggingAndMonitoringAreReadyBeforeServiceStarts(rioFargateService
291
291
  }
292
292
  }
293
293
  exports.ensureLoggingAndMonitoringAreReadyBeforeServiceStarts = ensureLoggingAndMonitoringAreReadyBeforeServiceStarts;
294
- //# 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: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"]}
294
+ //# 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_CLOUD_PROVIDER_METADATA: 'aws',\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"]}
package/lib/index.d.ts CHANGED
@@ -23,3 +23,4 @@ export * from './contributions/cop-frontend/cloudfront';
23
23
  export * from './contributions/team-transport-two/pipeline';
24
24
  export * from './contributions/team-claid/aws-backup-monitoring';
25
25
  export * from './contributions/team-claid/datadog-usage-monitoring';
26
+ export * from './backup';
package/lib/index.js CHANGED
@@ -35,4 +35,5 @@ __exportStar(require("./contributions/cop-frontend/cloudfront"), exports);
35
35
  __exportStar(require("./contributions/team-transport-two/pipeline"), exports);
36
36
  __exportStar(require("./contributions/team-claid/aws-backup-monitoring"), exports);
37
37
  __exportStar(require("./contributions/team-claid/datadog-usage-monitoring"), exports);
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaURBQStCO0FBQy9CLG9EQUFrQztBQUNsQyxpREFBK0I7QUFDL0IsbURBQWlDO0FBQ2pDLHNEQUFvQztBQUNwQyxvREFBa0M7QUFDbEMseURBQXVDO0FBQ3ZDLGtFQUFnRDtBQUNoRCwrREFBNkM7QUFDN0Msc0RBQW9DO0FBQ3BDLDBEQUF3QztBQUN4QyxpREFBK0I7QUFDL0Isd0RBQXNDO0FBRXRDLHFEQUFtQztBQUNuQyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBRWxDLGdFQUE4QztBQUU5Qyx5RUFBdUQ7QUFDdkQsOEVBQTREO0FBRTVELDBDQUF3QjtBQUV4Qiw0Q0FBMEI7QUFFMUIsMEVBQXdEO0FBRXhELDhFQUE0RDtBQUU1RCxtRkFBaUU7QUFDakUsc0ZBQW9FIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9hbGInO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9hc3BlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9lY3MnO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9kb2NkYic7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsL2R5bmFtb2RiJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvbGFtYmRhJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvdGFyZ2V0Z3JvdXAnO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9kYXRhZG9nLW1ldHJpYy1hbGFybSc7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsL2RhdGFkb2ctbG9nLWFsYXJtJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvd2F0Y2hmdWwnO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9tZXRyaWMtYWxhcm0nO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9yZHMnO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9jbG91ZGZyb250JztcblxuZXhwb3J0ICogZnJvbSAnLi9yaW8tbGFuZGluZy16b25lJztcbmV4cG9ydCAqIGZyb20gJy4vcmlvLWxvYWQtYmFsYW5jZXInO1xuZXhwb3J0ICogZnJvbSAnLi9yaW8tY2xhaWRvbWV0ZXInO1xuXG5leHBvcnQgKiBmcm9tICcuL2ZhcmdhdGUvcmlvLWZhcmdhdGUtc2VydmljZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUvcmlvLWJpdGJ1Y2tldC1zb3VyY2UtYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZWxpbmUvcmlvLWJhY2t1cC1zZWNyZXRzLXJlc3RvcmUtc3RhZ2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL2thZmthJztcblxuZXhwb3J0ICogZnJvbSAnLi9kYXRhZG9nJztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL2NvcC1mcm9udGVuZC9jbG91ZGZyb250JztcblxuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29udHJpYnV0aW9ucy90ZWFtLWNsYWlkL2F3cy1iYWNrdXAtbW9uaXRvcmluZyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS1jbGFpZC9kYXRhZG9nLXVzYWdlLW1vbml0b3JpbmcnO1xuIl19
38
+ __exportStar(require("./backup"), exports);
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsaURBQStCO0FBQy9CLG9EQUFrQztBQUNsQyxpREFBK0I7QUFDL0IsbURBQWlDO0FBQ2pDLHNEQUFvQztBQUNwQyxvREFBa0M7QUFDbEMseURBQXVDO0FBQ3ZDLGtFQUFnRDtBQUNoRCwrREFBNkM7QUFDN0Msc0RBQW9DO0FBQ3BDLDBEQUF3QztBQUN4QyxpREFBK0I7QUFDL0Isd0RBQXNDO0FBRXRDLHFEQUFtQztBQUNuQyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBRWxDLGdFQUE4QztBQUU5Qyx5RUFBdUQ7QUFDdkQsOEVBQTREO0FBRTVELDBDQUF3QjtBQUV4Qiw0Q0FBMEI7QUFFMUIsMEVBQXdEO0FBRXhELDhFQUE0RDtBQUU1RCxtRkFBaUU7QUFDakUsc0ZBQW9FO0FBRXBFLDJDQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvYWxiJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvYXNwZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvZWNzJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvZG9jZGInO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsL2xhbWJkYSc7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsL3RhcmdldGdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvZGF0YWRvZy1tZXRyaWMtYWxhcm0nO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bC9kYXRhZG9nLWxvZy1hbGFybSc7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsL3dhdGNoZnVsJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvbWV0cmljLWFsYXJtJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvcmRzJztcbmV4cG9ydCAqIGZyb20gJy4vd2F0Y2hmdWwvY2xvdWRmcm9udCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vcmlvLWxhbmRpbmctem9uZSc7XG5leHBvcnQgKiBmcm9tICcuL3Jpby1sb2FkLWJhbGFuY2VyJztcbmV4cG9ydCAqIGZyb20gJy4vcmlvLWNsYWlkb21ldGVyJztcblxuZXhwb3J0ICogZnJvbSAnLi9mYXJnYXRlL3Jpby1mYXJnYXRlLXNlcnZpY2UnO1xuXG5leHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lL3Jpby1iaXRidWNrZXQtc291cmNlLWFjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVsaW5lL3Jpby1iYWNrdXAtc2VjcmV0cy1yZXN0b3JlLXN0YWdlJztcblxuZXhwb3J0ICogZnJvbSAnLi9rYWZrYSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZGF0YWRvZyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29udHJpYnV0aW9ucy9jb3AtZnJvbnRlbmQvY2xvdWRmcm9udCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vY29udHJpYnV0aW9ucy90ZWFtLXRyYW5zcG9ydC10d28vcGlwZWxpbmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL2NvbnRyaWJ1dGlvbnMvdGVhbS1jbGFpZC9hd3MtYmFja3VwLW1vbml0b3JpbmcnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250cmlidXRpb25zL3RlYW0tY2xhaWQvZGF0YWRvZy11c2FnZS1tb25pdG9yaW5nJztcblxuZXhwb3J0ICogZnJvbSAnLi9iYWNrdXAnOyJdfQ==
package/package.json CHANGED
@@ -15,7 +15,7 @@
15
15
  ],
16
16
  "main": "lib/index.js",
17
17
  "license": "Apache-2.0",
18
- "version": "4.7.0",
18
+ "version": "4.9.0",
19
19
  "types": "lib/index.d.ts",
20
20
  "stability": "stable",
21
21
  "jsii": {
package/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "4.7.0"
2
+ "version": "4.9.0"
3
3
  }