@rio-cloud/cdk-v2-constructs 6.18.3 → 6.20.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/docs/API.md CHANGED
@@ -2469,10 +2469,6 @@ This is equal to `secretArn` in most cases, but is undefined when a full ARN is
2469
2469
 
2470
2470
  ### DatadogUsageMonitoring <a name="DatadogUsageMonitoring" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring"></a>
2471
2471
 
2472
- This is a beta construct and is likely to have breaking changes.
2473
-
2474
- The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
2475
-
2476
2472
  #### Initializers <a name="Initializers" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.Initializer"></a>
2477
2473
 
2478
2474
  ```typescript
@@ -2515,7 +2511,7 @@ new DatadogUsageMonitoring(scope: Construct, id: string, props: DatadogUsageMoni
2515
2511
 
2516
2512
  ---
2517
2513
 
2518
- ##### `toString` <a name="toString" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.toString"></a>
2514
+ ##### ~~`toString`~~ <a name="toString" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.toString"></a>
2519
2515
 
2520
2516
  ```typescript
2521
2517
  public toString(): string
@@ -2531,7 +2527,7 @@ Returns a string representation of this construct.
2531
2527
 
2532
2528
  ---
2533
2529
 
2534
- ##### `isConstruct` <a name="isConstruct" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.isConstruct"></a>
2530
+ ##### ~~`isConstruct`~~ <a name="isConstruct" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.isConstruct"></a>
2535
2531
 
2536
2532
  ```typescript
2537
2533
  import { DatadogUsageMonitoring } from '@rio-cloud/cdk-v2-constructs'
@@ -2571,7 +2567,11 @@ Any object.
2571
2567
 
2572
2568
  ---
2573
2569
 
2574
- ##### `node`<sup>Required</sup> <a name="node" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.property.node"></a>
2570
+ ##### ~~`node`~~<sup>Required</sup> <a name="node" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoring.property.node"></a>
2571
+
2572
+ - *Deprecated:* This interface will be removed in the next major version
2573
+ This is a beta construct and is likely to have breaking changes.
2574
+ The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
2575
2575
 
2576
2576
  ```typescript
2577
2577
  public readonly node: Node;
@@ -12039,6 +12039,7 @@ const datadogMonitorProps: datadogv2.DatadogMonitorProps = { ... }
12039
12039
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.query">query</a></code> | <code>string</code> | The monitors search query. |
12040
12040
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.serviceName">serviceName</a></code> | <code>string</code> | The name of the service to which the monitor belongs. |
12041
12041
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.extraTags">extraTags</a></code> | <code>string[]</code> | Tags to be appended to the monitor in addition to the RIO default tags. |
12042
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.lowercaseQuery">lowercaseQuery</a></code> | <code>boolean</code> | Convert the query string to lower case. |
12042
12043
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.notification">notification</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.INotification</code> | To explicitly disable notifications use {@link NoNotification }. |
12043
12044
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.optionOverrides">optionOverrides</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions</code> | Specific options to override the default monitor options. |
12044
12045
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.priority">priority</a></code> | <code>number</code> | The alert priority of the monitor. |
@@ -12127,6 +12128,24 @@ Tags to be appended to the monitor in addition to the RIO default tags.
12127
12128
 
12128
12129
  ---
12129
12130
 
12131
+ ##### `lowercaseQuery`<sup>Optional</sup> <a name="lowercaseQuery" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.lowercaseQuery"></a>
12132
+
12133
+ ```typescript
12134
+ public readonly lowercaseQuery: boolean;
12135
+ ```
12136
+
12137
+ - *Type:* boolean
12138
+
12139
+ Convert the query string to lower case.
12140
+
12141
+ This is useful for passing in AWS resource names into metric queries (metric names are automatically
12142
+ lowercased in Datadog, but the monitor queries not).
12143
+ Defaults to false.
12144
+
12145
+ > [https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/docs/cloudformationoptions.md#lowercasequery](https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/docs/cloudformationoptions.md#lowercasequery)
12146
+
12147
+ ---
12148
+
12130
12149
  ##### `notification`<sup>Optional</sup> <a name="notification" id="@rio-cloud/cdk-v2-constructs.datadogv2.DatadogMonitorProps.property.notification"></a>
12131
12150
 
12132
12151
  ```typescript
@@ -12301,7 +12320,9 @@ const datadogUsageMonitoringProps: DatadogUsageMonitoringProps = { ... }
12301
12320
 
12302
12321
  ---
12303
12322
 
12304
- ##### `organization`<sup>Required</sup> <a name="organization" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.organization"></a>
12323
+ ##### ~~`organization`~~<sup>Required</sup> <a name="organization" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.organization"></a>
12324
+
12325
+ - *Deprecated:* This interface will be removed in the next major version
12305
12326
 
12306
12327
  ```typescript
12307
12328
  public readonly organization: string;
@@ -12311,7 +12332,9 @@ public readonly organization: string;
12311
12332
 
12312
12333
  ---
12313
12334
 
12314
- ##### `serviceName`<sup>Required</sup> <a name="serviceName" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.serviceName"></a>
12335
+ ##### ~~`serviceName`~~<sup>Required</sup> <a name="serviceName" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.serviceName"></a>
12336
+
12337
+ - *Deprecated:* This interface will be removed in the next major version
12315
12338
 
12316
12339
  ```typescript
12317
12340
  public readonly serviceName: string;
@@ -12333,7 +12356,9 @@ public readonly alertType: string;
12333
12356
 
12334
12357
  ---
12335
12358
 
12336
- ##### `notification`<sup>Optional</sup> <a name="notification" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.notification"></a>
12359
+ ##### ~~`notification`~~<sup>Optional</sup> <a name="notification" id="@rio-cloud/cdk-v2-constructs.DatadogUsageMonitoringProps.property.notification"></a>
12360
+
12361
+ - *Deprecated:* This interface will be removed in the next major version
12337
12362
 
12338
12363
  ```typescript
12339
12364
  public readonly notification: INotification;
@@ -13274,9 +13299,9 @@ Indicates if the producer will restore the data in case of a disaster or not.
13274
13299
 
13275
13300
  ### KafkaTopicProps <a name="KafkaTopicProps" id="@rio-cloud/cdk-v2-constructs.KafkaTopicProps"></a>
13276
13301
 
13277
- The current service limits can be found in the topic limits configuration of the topic manager.
13302
+ The current service limits are configured in the topic manager.
13278
13303
 
13279
- > [https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml](https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml)
13304
+ If you need to increase the limits for your service, please contact CLAID.
13280
13305
 
13281
13306
  #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.KafkaTopicProps.Initializer"></a>
13282
13307
 
@@ -13297,6 +13322,7 @@ const kafkaTopicProps: KafkaTopicProps = { ... }
13297
13322
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.numberOfPartitions">numberOfPartitions</a></code> | <code>number</code> | Defines degree of parallelism of the topic; |
13298
13323
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.instantDeletionEnabled">instantDeletionEnabled</a></code> | <code>boolean</code> | If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion. |
13299
13324
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.logCompactionProperties">logCompactionProperties</a></code> | <code>@rio-cloud/cdk-v2-constructs.kafka.LogCompactionProperties</code> | Must only be provided if 'isLogCompacted' is 'true'. |
13325
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.maxCompactionLagMs">maxCompactionLagMs</a></code> | <code>number</code> | The maximum compaction lag in milliseconds. |
13300
13326
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.replicationFactor">replicationFactor</a></code> | <code>number</code> | Defines degree of replication of messages; |
13301
13327
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.retention">retention</a></code> | <code>aws-cdk-lib.Duration</code> | Time how long messages are retained on Kafka cluster; |
13302
13328
 
@@ -13396,6 +13422,21 @@ Must only be provided if 'isLogCompacted' is 'true'.
13396
13422
 
13397
13423
  ---
13398
13424
 
13425
+ ##### `maxCompactionLagMs`<sup>Optional</sup> <a name="maxCompactionLagMs" id="@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.maxCompactionLagMs"></a>
13426
+
13427
+ ```typescript
13428
+ public readonly maxCompactionLagMs: number;
13429
+ ```
13430
+
13431
+ - *Type:* number
13432
+ - *Default:* 9223372036854775807
13433
+
13434
+ The maximum compaction lag in milliseconds.
13435
+
13436
+ The maximum time a message can be delayed before it is compacted.
13437
+
13438
+ ---
13439
+
13399
13440
  ##### `replicationFactor`<sup>Optional</sup> <a name="replicationFactor" id="@rio-cloud/cdk-v2-constructs.KafkaTopicProps.property.replicationFactor"></a>
13400
13441
 
13401
13442
  ```typescript
@@ -13429,9 +13470,9 @@ The soft limit is 3 to 30 days but can be increased upon requests.
13429
13470
 
13430
13471
  ### KafkaTopicProps <a name="KafkaTopicProps" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps"></a>
13431
13472
 
13432
- The current service limits can be found in the topic limits configuration of the topic manager.
13473
+ The current service limits are configured in the topic manager.
13433
13474
 
13434
- > [https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml](https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml)
13475
+ If you need to increase the limits for your service, please contact CLAID.
13435
13476
 
13436
13477
  #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.Initializer"></a>
13437
13478
 
@@ -13452,6 +13493,7 @@ const kafkaTopicProps: kafka.KafkaTopicProps = { ... }
13452
13493
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.numberOfPartitions">numberOfPartitions</a></code> | <code>number</code> | Defines degree of parallelism of the topic; |
13453
13494
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.instantDeletionEnabled">instantDeletionEnabled</a></code> | <code>boolean</code> | If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion. |
13454
13495
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.logCompactionProperties">logCompactionProperties</a></code> | <code>@rio-cloud/cdk-v2-constructs.kafka.LogCompactionProperties</code> | Must only be provided if 'isLogCompacted' is 'true'. |
13496
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.maxCompactionLagMs">maxCompactionLagMs</a></code> | <code>number</code> | The maximum compaction lag in milliseconds. |
13455
13497
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.replicationFactor">replicationFactor</a></code> | <code>number</code> | Defines degree of replication of messages; |
13456
13498
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.retention">retention</a></code> | <code>aws-cdk-lib.Duration</code> | Time how long messages are retained on Kafka cluster; |
13457
13499
 
@@ -13551,6 +13593,21 @@ Must only be provided if 'isLogCompacted' is 'true'.
13551
13593
 
13552
13594
  ---
13553
13595
 
13596
+ ##### `maxCompactionLagMs`<sup>Optional</sup> <a name="maxCompactionLagMs" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.maxCompactionLagMs"></a>
13597
+
13598
+ ```typescript
13599
+ public readonly maxCompactionLagMs: number;
13600
+ ```
13601
+
13602
+ - *Type:* number
13603
+ - *Default:* 9223372036854775807
13604
+
13605
+ The maximum compaction lag in milliseconds.
13606
+
13607
+ The maximum time a message can be delayed before it is compacted.
13608
+
13609
+ ---
13610
+
13554
13611
  ##### `replicationFactor`<sup>Optional</sup> <a name="replicationFactor" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicProps.property.replicationFactor"></a>
13555
13612
 
13556
13613
  ```typescript
@@ -13584,9 +13641,9 @@ The soft limit is 3 to 30 days but can be increased upon requests.
13584
13641
 
13585
13642
  ### KafkaTopicV4Props <a name="KafkaTopicV4Props" id="@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props"></a>
13586
13643
 
13587
- The current service limits can be found in the topic limits configuration of the topic manager.
13644
+ The current service limits are configured in the topic manager.
13588
13645
 
13589
- > [https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml](https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml)
13646
+ If you need to increase the limits for your service, please contact CLAID.
13590
13647
 
13591
13648
  #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.Initializer"></a>
13592
13649
 
@@ -13608,6 +13665,7 @@ const kafkaTopicV4Props: KafkaTopicV4Props = { ... }
13608
13665
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.instantDeletionEnabled">instantDeletionEnabled</a></code> | <code>boolean</code> | If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion. |
13609
13666
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.logCompactionProperties">logCompactionProperties</a></code> | <code>@rio-cloud/cdk-v2-constructs.kafka.LogCompactionProperties</code> | Must only be provided if 'isLogCompacted' is 'true'. |
13610
13667
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.managedBackupEnabled">managedBackupEnabled</a></code> | <code>boolean</code> | Specify whether the topic should be backed up automatically or not. |
13668
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.maxCompactionLagMs">maxCompactionLagMs</a></code> | <code>number</code> | The maximum compaction lag in milliseconds. |
13611
13669
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.replicationFactor">replicationFactor</a></code> | <code>number</code> | Defines degree of replication of messages; |
13612
13670
  | <code><a href="#@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.retention">retention</a></code> | <code>aws-cdk-lib.Duration</code> | Time how long messages are retained on Kafka cluster; |
13613
13671
 
@@ -13722,6 +13780,21 @@ It could just be enabled, if the topic is compacted and the RecoveryPolicy is 'r
13722
13780
 
13723
13781
  ---
13724
13782
 
13783
+ ##### `maxCompactionLagMs`<sup>Optional</sup> <a name="maxCompactionLagMs" id="@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.maxCompactionLagMs"></a>
13784
+
13785
+ ```typescript
13786
+ public readonly maxCompactionLagMs: number;
13787
+ ```
13788
+
13789
+ - *Type:* number
13790
+ - *Default:* 9223372036854775807
13791
+
13792
+ The maximum compaction lag in milliseconds.
13793
+
13794
+ The maximum time a message can be delayed before it is compacted.
13795
+
13796
+ ---
13797
+
13725
13798
  ##### `replicationFactor`<sup>Optional</sup> <a name="replicationFactor" id="@rio-cloud/cdk-v2-constructs.KafkaTopicV4Props.property.replicationFactor"></a>
13726
13799
 
13727
13800
  ```typescript
@@ -13755,9 +13828,9 @@ The soft limit is 3 to 30 days but can be increased upon requests.
13755
13828
 
13756
13829
  ### KafkaTopicV4Props <a name="KafkaTopicV4Props" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props"></a>
13757
13830
 
13758
- The current service limits can be found in the topic limits configuration of the topic manager.
13831
+ The current service limits are configured in the topic manager.
13759
13832
 
13760
- > [https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml](https://bitbucket.collaboration-man.com/projects/RSEVTBU/repos/topic-manager/browse/config/topic-service-limits.yaml)
13833
+ If you need to increase the limits for your service, please contact CLAID.
13761
13834
 
13762
13835
  #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.Initializer"></a>
13763
13836
 
@@ -13779,6 +13852,7 @@ const kafkaTopicV4Props: kafka.KafkaTopicV4Props = { ... }
13779
13852
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.instantDeletionEnabled">instantDeletionEnabled</a></code> | <code>boolean</code> | If set to 'false, the topic's data will be deleted on Kafka 10 days after stack deletion. |
13780
13853
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.logCompactionProperties">logCompactionProperties</a></code> | <code>@rio-cloud/cdk-v2-constructs.kafka.LogCompactionProperties</code> | Must only be provided if 'isLogCompacted' is 'true'. |
13781
13854
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.managedBackupEnabled">managedBackupEnabled</a></code> | <code>boolean</code> | Specify whether the topic should be backed up automatically or not. |
13855
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.maxCompactionLagMs">maxCompactionLagMs</a></code> | <code>number</code> | The maximum compaction lag in milliseconds. |
13782
13856
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.replicationFactor">replicationFactor</a></code> | <code>number</code> | Defines degree of replication of messages; |
13783
13857
  | <code><a href="#@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.retention">retention</a></code> | <code>aws-cdk-lib.Duration</code> | Time how long messages are retained on Kafka cluster; |
13784
13858
 
@@ -13893,6 +13967,21 @@ It could just be enabled, if the topic is compacted and the RecoveryPolicy is 'r
13893
13967
 
13894
13968
  ---
13895
13969
 
13970
+ ##### `maxCompactionLagMs`<sup>Optional</sup> <a name="maxCompactionLagMs" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.maxCompactionLagMs"></a>
13971
+
13972
+ ```typescript
13973
+ public readonly maxCompactionLagMs: number;
13974
+ ```
13975
+
13976
+ - *Type:* number
13977
+ - *Default:* 9223372036854775807
13978
+
13979
+ The maximum compaction lag in milliseconds.
13980
+
13981
+ The maximum time a message can be delayed before it is compacted.
13982
+
13983
+ ---
13984
+
13896
13985
  ##### `replicationFactor`<sup>Optional</sup> <a name="replicationFactor" id="@rio-cloud/cdk-v2-constructs.kafka.KafkaTopicV4Props.property.replicationFactor"></a>
13897
13986
 
13898
13987
  ```typescript
package/docs/changelog.md CHANGED
@@ -2,6 +2,28 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
4
4
 
5
+ ## [6.20.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.19.0&sourceBranch=refs%2Ftags%2Fv6.20.0) (2025-02-27)
6
+
7
+
8
+ ### Features
9
+
10
+ * Add lowercaseQuery flag to DatadogMonitor ([b5a3a51](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/b5a3a5101a751890173713a00957173bd198ceb5))
11
+
12
+ ## 6.20.0 TODO claid please add release
13
+
14
+ ### Features
15
+
16
+ * Add `lowercaseQuery` flag to the [`DatadogMonitor`](src/datadogv2/datadog-monitor.ts). This will ensure the `query` parameter is lowercased before creating the datadog monitor.
17
+ This is useful when passing autogenerated names into metric queries, as metric names are lowercased by datadog, but monitor queries are not.
18
+ It is a drop-in replacement for the `upperToLower` lambda function we used before.
19
+
20
+ ## [6.19.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.18.3&sourceBranch=refs%2Ftags%2Fv6.19.0) (2025-02-25)
21
+
22
+
23
+ ### Features
24
+
25
+ * the setting max.compaction.lag.ms can now be configured for a kafka topic ([551ad7b](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/551ad7bc1b7fd826f4da3fbcb9a82540cb4eada5))
26
+
5
27
  ## [6.18.3](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv6.18.2&sourceBranch=refs%2Ftags%2Fv6.18.3) (2025-02-18)
6
28
 
7
29
 
@@ -1,7 +1,9 @@
1
1
  import * as constructs from 'constructs';
2
- import { DatadogOrganization } from '../../../datadog';
3
- import { DatadogAlertType } from '../../../datadog/datadog-monitor';
2
+ import { DatadogOrganization, DatadogAlertType } from '../../../datadog';
4
3
  import { INotification } from '../../../datadogv2';
4
+ /**
5
+ * @deprecated This interface will be removed in the next major version
6
+ */
5
7
  export interface DatadogUsageMonitoringProps {
6
8
  readonly serviceName: string;
7
9
  /**
@@ -12,6 +14,7 @@ export interface DatadogUsageMonitoringProps {
12
14
  readonly organization: DatadogOrganization;
13
15
  }
14
16
  /**
17
+ * @deprecated This interface will be removed in the next major version
15
18
  * This is a beta construct and is likely to have breaking changes.
16
19
  * The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
17
20
  */
@@ -9,6 +9,7 @@ const datadog_1 = require("../../../datadog");
9
9
  const datadogv2_1 = require("../../../datadogv2");
10
10
  const rio_claidometer_1 = require("../../../rio-claidometer");
11
11
  /**
12
+ * @deprecated This interface will be removed in the next major version
12
13
  * This is a beta construct and is likely to have breaking changes.
13
14
  * The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources
14
15
  */
@@ -143,4 +144,4 @@ function addClaidometer(scope) {
143
144
  version: '0.0.8',
144
145
  });
145
146
  }
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-usage-monitoring.js","sourceRoot":"","sources":["../../../../src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as constructs from 'constructs';\nimport { DatadogOrganization, getOrganizationUrlPrefix } from '../../../datadog';\nimport { DatadogAlertType } from '../../../datadog/datadog-monitor';\nimport { INotification, DefaultSlackNotification, DatadogMonitor, DatadogMonitorQueryAlertType } from '../../../datadogv2';\nimport { Claidometer, ClaidometerProduct } from '../../../rio-claidometer';\n\ninterface UsageSpikeMonitor {\n  humanReadableName: string;\n  query: string;\n  additionalMessage?: string;\n}\n\nexport interface DatadogUsageMonitoringProps {\n  readonly serviceName: string;\n  /**\n   * @deprecated not supported anymore. use `notification` instead.\n   */\n  readonly alertType?: DatadogAlertType;\n  readonly notification?: INotification;\n  readonly organization: DatadogOrganization;\n}\n\n/**\n * This is a beta construct and is likely to have breaking changes.\n * The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources\n */\nexport class DatadogUsageMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: DatadogUsageMonitoringProps) {\n    super(scope, id);\n\n    const infrastructureUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'infrastructure hosts',\n        query: 'sum:datadog.estimated_usage.hosts{*}',\n      },\n      {\n        humanReadableName: \"infrastructure hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.hosts{*} by {child_org_name}',\n      },\n      { humanReadableName: 'Fargate tasks', query: 'sum:datadog.apm.fargate_task_instance{*}' },\n      { humanReadableName: 'profiled Fargate tasks', query: 'sum:datadog.profiling.fargate{*}' },\n      {\n        humanReadableName: 'custom metrics',\n        query: 'sum:datadog.estimated_usage.metrics.custom{*}',\n      },\n      {\n        humanReadableName: \"custom metrics for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.metrics.custom{*} by {child_org_name}',\n      },\n    ];\n\n    const additionalMessageLogManagementForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage for more details.`;\n    const additionalMessageLogManagementForLogIndexScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage?tpl_var_datadog_index={{datadog_index.name}} for more details.`;\n    const logManagementUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'log ingestion',\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log ingestion for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n      {\n        humanReadableName: 'log indexing',\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log indexing for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n    ];\n\n    const additionalMessageApmForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage for more details.`;\n    const additionalMessageApmForEnvScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage?tpl_var_env={{env.name}} for more details.`;\n    const apmUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      { humanReadableName: 'APM hosts', query: 'sum:datadog.estimated_usage.apm_hosts{*}' },\n      {\n        humanReadableName: \"APM hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm_hosts{*} by {child_org_name}',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: 'span ingestion',\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*}.as_count()',\n      },\n      {\n        humanReadableName: \"span ingestion for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n      {\n        humanReadableName: 'span indexing',\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*}.as_count()',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"span indexing for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n    ];\n\n    const syntheticUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'Synthetic API tests',\n        query: 'sum:datadog.estimated_usage.synthetics.api_test_runs{*}.as_count()',\n      },\n    ];\n\n    const serverlessUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'serverless functions',\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*}',\n      },\n      {\n        humanReadableName: \"serverless functions for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*} by {child_org_name}',\n      },\n    ];\n\n    const notification = props.notification ?? new DefaultSlackNotification();\n    for (const usageSpikeMonitor of ([] as UsageSpikeMonitor[]).concat(\n      infrastructureUsageSpikeMonitors,\n      logManagementUsageSpikeMonitors,\n      apmUsageSpikeMonitors,\n      serverlessUsageSpikeMonitors,\n      syntheticUsageSpikeMonitors,\n    )) {\n      this.createAnomalyMonitorForSpikes(props.serviceName, usageSpikeMonitor, notification);\n    }\n\n    if (props.organization === 'EU') {\n      addClaidometer(this);\n    }\n  }\n\n  private createAnomalyMonitorForSpikes(\n    serviceName: string,\n    usageSpikeMonitor: UsageSpikeMonitor,\n    notification: INotification,\n  ): DatadogMonitor {\n    return new DatadogMonitor(this, usageSpikeMonitor.humanReadableName, {\n      name: `${usageSpikeMonitor.humanReadableName} spike`,\n      serviceName,\n      notification,\n      message: `[P4] ${usageSpikeMonitor.humanReadableName} are getting out-of-control. ${\n        usageSpikeMonitor.additionalMessage ?? ''\n      }`,\n      monitorType: DatadogMonitorQueryAlertType.QUERY_ALERT,\n      query: `avg(last_12h):anomalies(${usageSpikeMonitor.query}, 'agile', 3, direction='above', interval=120, alert_window='last_30m', seasonality='weekly', timezone='europe/berlin', count_default_zero='true') >= 1`,\n      optionOverrides: {\n        includeTags: false,\n        notifyNoData: false,\n        thresholdWindows: {\n          triggerWindow: 'last_30m',\n          recoveryWindow: 'last_15m',\n        },\n      },\n    });\n  }\n}\n\nfunction addClaidometer(scope: constructs.Construct) {\n  const [feature, packageName] = __dirname.split(path.sep).reverse();\n  new Claidometer(scope, 'Claidometer', {\n    product: ClaidometerProduct.CDK_CONTRIBUTION,\n    packageName,\n    feature,\n    version: '0.0.8',\n  });\n}\n"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-usage-monitoring.js","sourceRoot":"","sources":["../../../../src/contributions/team-claid/datadog-usage-monitoring/datadog-usage-monitoring.ts"],"names":[],"mappings":";;;;;AAAA,6BAA6B;AAC7B,yCAAyC;AACzC,8CAAmG;AACnG,kDAA2H;AAC3H,8DAA2E;AAqB3E;;;;GAIG;AACH,MAAa,sBAAuB,SAAQ,UAAU,CAAC,SAAS;IAC9D,YAAY,KAA2B,EAAE,EAAU,EAAE,KAAkC;QACrF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,MAAM,gCAAgC,GAAwB;YAC5D;gBACE,iBAAiB,EAAE,sBAAsB;gBACzC,KAAK,EAAE,sCAAsC;aAC9C;YACD;gBACE,iBAAiB,EAAE,oDAAoD;gBACvE,KAAK,EAAE,0DAA0D;aAClE;YACD,EAAE,iBAAiB,EAAE,eAAe,EAAE,KAAK,EAAE,0CAA0C,EAAE;YACzF,EAAE,iBAAiB,EAAE,wBAAwB,EAAE,KAAK,EAAE,kCAAkC,EAAE;YAC1F;gBACE,iBAAiB,EAAE,gBAAgB;gBACnC,KAAK,EAAE,+CAA+C;aACvD;YACD;gBACE,iBAAiB,EAAE,8CAA8C;gBACjE,KAAK,EAAE,mEAAmE;aAC3E;SACF,CAAC;QAEF,MAAM,uDAAuD,GAAG,0BAA0B,IAAA,kCAAwB,EAChH,KAAK,CAAC,YAAY,CACnB,qFAAqF,CAAC;QACvF,MAAM,uDAAuD,GAAG,0BAA0B,IAAA,kCAAwB,EAChH,KAAK,CAAC,YAAY,CACnB,kIAAkI,CAAC;QACpI,MAAM,+BAA+B,GAAwB;YAC3D;gBACE,iBAAiB,EAAE,eAAe;gBAClC,KAAK,EAAE,+DAA+D;gBACtE,iBAAiB,EAAE,uDAAuD;aAC3E;YACD;gBACE,iBAAiB,EAAE,4CAA4C;gBAC/D,KAAK,EAAE,kFAAkF;gBACzF,iBAAiB,EAAE,uDAAuD;aAC3E;YACD;gBACE,iBAAiB,EAAE,cAAc;gBACjC,KAAK,EAAE,wFAAwF;gBAC/F,iBAAiB,EAAE,uDAAuD;aAC3E;YACD;gBACE,iBAAiB,EAAE,2CAA2C;gBAC9D,KAAK,EAAE,2GAA2G;gBAClH,iBAAiB,EAAE,uDAAuD;aAC3E;SACF,CAAC;QAEF,MAAM,6CAA6C,GAAG,0BAA0B,IAAA,kCAAwB,EACtG,KAAK,CAAC,YAAY,CACnB,iFAAiF,CAAC;QACnF,MAAM,wCAAwC,GAAG,0BAA0B,IAAA,kCAAwB,EACjG,KAAK,CAAC,YAAY,CACnB,0GAA0G,CAAC;QAC5G,MAAM,qBAAqB,GAAwB;YACjD,EAAE,iBAAiB,EAAE,WAAW,EAAE,KAAK,EAAE,0CAA0C,EAAE;YACrF;gBACE,iBAAiB,EAAE,yCAAyC;gBAC5D,KAAK,EAAE,8DAA8D;gBACrE,iBAAiB,EAAE,6CAA6C;aACjE;YACD;gBACE,iBAAiB,EAAE,gBAAgB;gBACnC,KAAK,EAAE,8DAA8D;aACtE;YACD;gBACE,iBAAiB,EAAE,mCAAmC;gBACtD,KAAK,EAAE,uEAAuE;gBAC9E,iBAAiB,EAAE,wCAAwC;aAC5D;YACD;gBACE,iBAAiB,EAAE,eAAe;gBAClC,KAAK,EAAE,6DAA6D;gBACpE,iBAAiB,EAAE,6CAA6C;aACjE;YACD;gBACE,iBAAiB,EAAE,kCAAkC;gBACrD,KAAK,EAAE,sEAAsE;gBAC7E,iBAAiB,EAAE,wCAAwC;aAC5D;SACF,CAAC;QAEF,MAAM,2BAA2B,GAAwB;YACvD;gBACE,iBAAiB,EAAE,qBAAqB;gBACxC,KAAK,EAAE,oEAAoE;aAC5E;SACF,CAAC;QAEF,MAAM,4BAA4B,GAAwB;YACxD;gBACE,iBAAiB,EAAE,sBAAsB;gBACzC,KAAK,EAAE,gEAAgE;aACxE;YACD;gBACE,iBAAiB,EAAE,oDAAoD;gBACvE,KAAK,EAAE,oFAAoF;aAC5F;SACF,CAAC;QAEF,MAAM,YAAY,GAAG,KAAK,CAAC,YAAY,IAAI,IAAI,oCAAwB,EAAE,CAAC;QAC1E,KAAK,MAAM,iBAAiB,IAAK,EAA0B,CAAC,MAAM,CAChE,gCAAgC,EAChC,+BAA+B,EAC/B,qBAAqB,EACrB,4BAA4B,EAC5B,2BAA2B,CAC5B,EAAE,CAAC;YACF,IAAI,CAAC,6BAA6B,CAAC,KAAK,CAAC,WAAW,EAAE,iBAAiB,EAAE,YAAY,CAAC,CAAC;QACzF,CAAC;QAED,IAAI,KAAK,CAAC,YAAY,KAAK,IAAI,EAAE,CAAC;YAChC,cAAc,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAEO,6BAA6B,CACnC,WAAmB,EACnB,iBAAoC,EACpC,YAA2B;QAE3B,OAAO,IAAI,0BAAc,CAAC,IAAI,EAAE,iBAAiB,CAAC,iBAAiB,EAAE;YACnE,IAAI,EAAE,GAAG,iBAAiB,CAAC,iBAAiB,QAAQ;YACpD,WAAW;YACX,YAAY;YACZ,OAAO,EAAE,QAAQ,iBAAiB,CAAC,iBAAiB,gCAClD,iBAAiB,CAAC,iBAAiB,IAAI,EACzC,EAAE;YACF,WAAW,EAAE,wCAA4B,CAAC,WAAW;YACrD,KAAK,EAAE,2BAA2B,iBAAiB,CAAC,KAAK,yJAAyJ;YAClN,eAAe,EAAE;gBACf,WAAW,EAAE,KAAK;gBAClB,YAAY,EAAE,KAAK;gBACnB,gBAAgB,EAAE;oBAChB,aAAa,EAAE,UAAU;oBACzB,cAAc,EAAE,UAAU;iBAC3B;aACF;SACF,CAAC,CAAC;IACL,CAAC;;AAjJH,wDAkJC;;;AAED,SAAS,cAAc,CAAC,KAA2B;IACjD,MAAM,CAAC,OAAO,EAAE,WAAW,CAAC,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;IACnE,IAAI,6BAAW,CAAC,KAAK,EAAE,aAAa,EAAE;QACpC,OAAO,EAAE,oCAAkB,CAAC,gBAAgB;QAC5C,WAAW;QACX,OAAO;QACP,OAAO,EAAE,OAAO;KACjB,CAAC,CAAC;AACL,CAAC","sourcesContent":["import * as path from 'path';\nimport * as constructs from 'constructs';\nimport { DatadogOrganization, DatadogAlertType, getOrganizationUrlPrefix } from '../../../datadog';\nimport { INotification, DefaultSlackNotification, DatadogMonitor, DatadogMonitorQueryAlertType } from '../../../datadogv2';\nimport { Claidometer, ClaidometerProduct } from '../../../rio-claidometer';\n\ninterface UsageSpikeMonitor {\n  humanReadableName: string;\n  query: string;\n  additionalMessage?: string;\n}\n\n/**\n * @deprecated This interface will be removed in the next major version\n */\nexport interface DatadogUsageMonitoringProps {\n  readonly serviceName: string;\n  /**\n   * @deprecated not supported anymore. use `notification` instead.\n   */\n  readonly alertType?: DatadogAlertType;\n  readonly notification?: INotification;\n  readonly organization: DatadogOrganization;\n}\n\n/**\n * @deprecated This interface will be removed in the next major version\n * This is a beta construct and is likely to have breaking changes.\n * The construct creates monitoring (based on anomaly detection) for the usage of the most relevant Datadog resources\n */\nexport class DatadogUsageMonitoring extends constructs.Construct {\n  constructor(scope: constructs.Construct, id: string, props: DatadogUsageMonitoringProps) {\n    super(scope, id);\n\n    const infrastructureUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'infrastructure hosts',\n        query: 'sum:datadog.estimated_usage.hosts{*}',\n      },\n      {\n        humanReadableName: \"infrastructure hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.hosts{*} by {child_org_name}',\n      },\n      { humanReadableName: 'Fargate tasks', query: 'sum:datadog.apm.fargate_task_instance{*}' },\n      { humanReadableName: 'profiled Fargate tasks', query: 'sum:datadog.profiling.fargate{*}' },\n      {\n        humanReadableName: 'custom metrics',\n        query: 'sum:datadog.estimated_usage.metrics.custom{*}',\n      },\n      {\n        humanReadableName: \"custom metrics for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.metrics.custom{*} by {child_org_name}',\n      },\n    ];\n\n    const additionalMessageLogManagementForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage for more details.`;\n    const additionalMessageLogManagementForLogIndexScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/465/log-management-estimated-usage?tpl_var_datadog_index={{datadog_index.name}} for more details.`;\n    const logManagementUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'log ingestion',\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log ingestion for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_bytes{*} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n      {\n        humanReadableName: 'log indexing',\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false}.as_count()',\n        additionalMessage: additionalMessageLogManagementForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"log indexing for '{{datadog_index.name}}'\",\n        query: 'sum:datadog.estimated_usage.logs.ingested_events{datadog_is_excluded:false} by {datadog_index}.as_count()',\n        additionalMessage: additionalMessageLogManagementForLogIndexScopedMonitors,\n      },\n    ];\n\n    const additionalMessageApmForGloballyScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage for more details.`;\n    const additionalMessageApmForEnvScopedMonitors = `Take a look at https://${getOrganizationUrlPrefix(\n      props.organization,\n    )}.datadoghq.eu/dash/integration/489/apm-traces-estimated-usage?tpl_var_env={{env.name}} for more details.`;\n    const apmUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      { humanReadableName: 'APM hosts', query: 'sum:datadog.estimated_usage.apm_hosts{*}' },\n      {\n        humanReadableName: \"APM hosts for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm_hosts{*} by {child_org_name}',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: 'span ingestion',\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*}.as_count()',\n      },\n      {\n        humanReadableName: \"span ingestion for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.ingested_bytes{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n      {\n        humanReadableName: 'span indexing',\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*}.as_count()',\n        additionalMessage: additionalMessageApmForGloballyScopedMonitors,\n      },\n      {\n        humanReadableName: \"span indexing for '{{env.name}}'\",\n        query: 'sum:datadog.estimated_usage.apm.indexed_spans{*} by {env}.as_count()',\n        additionalMessage: additionalMessageApmForEnvScopedMonitors,\n      },\n    ];\n\n    const syntheticUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'Synthetic API tests',\n        query: 'sum:datadog.estimated_usage.synthetics.api_test_runs{*}.as_count()',\n      },\n    ];\n\n    const serverlessUsageSpikeMonitors: UsageSpikeMonitor[] = [\n      {\n        humanReadableName: 'serverless functions',\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*}',\n      },\n      {\n        humanReadableName: \"serverless functions for '{{child_org_name.name}}'\",\n        query: 'sum:datadog.estimated_usage.serverless.aws_lambda_functions{*} by {child_org_name}',\n      },\n    ];\n\n    const notification = props.notification ?? new DefaultSlackNotification();\n    for (const usageSpikeMonitor of ([] as UsageSpikeMonitor[]).concat(\n      infrastructureUsageSpikeMonitors,\n      logManagementUsageSpikeMonitors,\n      apmUsageSpikeMonitors,\n      serverlessUsageSpikeMonitors,\n      syntheticUsageSpikeMonitors,\n    )) {\n      this.createAnomalyMonitorForSpikes(props.serviceName, usageSpikeMonitor, notification);\n    }\n\n    if (props.organization === 'EU') {\n      addClaidometer(this);\n    }\n  }\n\n  private createAnomalyMonitorForSpikes(\n    serviceName: string,\n    usageSpikeMonitor: UsageSpikeMonitor,\n    notification: INotification,\n  ): DatadogMonitor {\n    return new DatadogMonitor(this, usageSpikeMonitor.humanReadableName, {\n      name: `${usageSpikeMonitor.humanReadableName} spike`,\n      serviceName,\n      notification,\n      message: `[P4] ${usageSpikeMonitor.humanReadableName} are getting out-of-control. ${\n        usageSpikeMonitor.additionalMessage ?? ''\n      }`,\n      monitorType: DatadogMonitorQueryAlertType.QUERY_ALERT,\n      query: `avg(last_12h):anomalies(${usageSpikeMonitor.query}, 'agile', 3, direction='above', interval=120, alert_window='last_30m', seasonality='weekly', timezone='europe/berlin', count_default_zero='true') >= 1`,\n      optionOverrides: {\n        includeTags: false,\n        notifyNoData: false,\n        thresholdWindows: {\n          triggerWindow: 'last_30m',\n          recoveryWindow: 'last_15m',\n        },\n      },\n    });\n  }\n}\n\nfunction addClaidometer(scope: constructs.Construct) {\n  const [feature, packageName] = __dirname.split(path.sep).reverse();\n  new Claidometer(scope, 'Claidometer', {\n    product: ClaidometerProduct.CDK_CONTRIBUTION,\n    packageName,\n    feature,\n    version: '0.0.8',\n  });\n}\n"]}
@@ -10,6 +10,7 @@ class DatadogPipelineErrorAlert extends datadogv2_1.DatadogMonitor {
10
10
  monitorType: datadogv2_1.DatadogMonitorQueryAlertType.QUERY_ALERT,
11
11
  extraTags: ['cicd'],
12
12
  query: `min(last_5m):min:deployment.codepipeline.executions{pipeline_name:${props.pipelineName},account_id:${props.accountId}} < 1`,
13
+ lowercaseQuery: true,
13
14
  name: 'CI pipeline status',
14
15
  message: '{{#is_alert}}\\nThe CI build is broken\\n{{/is_alert}} \\n\\n{{#is_alert_recovery}}\\nThe CI build works again.\\n{{/is_alert_recovery}}',
15
16
  priority: 5,
@@ -29,6 +30,7 @@ class DataDogPipelineErrorAlertForVulnerabilityChecks extends datadogv2_1.Datado
29
30
  monitorType: datadogv2_1.DatadogMonitorQueryAlertType.QUERY_ALERT,
30
31
  extraTags: ['cicd'],
31
32
  query: `min(last_5m):min:deployment.codepipeline.executions{pipeline_name:${props.pipelineName},account_id:${props.accountId}} < 1`,
33
+ lowercaseQuery: true,
32
34
  name: 'Vulnerability checks',
33
35
  message: 'Vulnerabilities detected',
34
36
  priority: 3,
@@ -40,4 +42,4 @@ class DataDogPipelineErrorAlertForVulnerabilityChecks extends datadogv2_1.Datado
40
42
  }
41
43
  }
42
44
  exports.DataDogPipelineErrorAlertForVulnerabilityChecks = DataDogPipelineErrorAlertForVulnerabilityChecks;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWRvZy1tb25pdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZS9kYXRhZG9nLW1vbml0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLGtEQUFpSDtBQVNqSCxNQUFhLHlCQUEwQixTQUFRLDBCQUFjO0lBQzNELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0Q7UUFDaEcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsWUFBWSxFQUFFLElBQUksMEJBQWMsRUFBRTtZQUNsQyxXQUFXLEVBQUUsd0NBQTRCLENBQUMsV0FBVztZQUNyRCxTQUFTLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDbkIsS0FBSyxFQUFFLHFFQUFxRSxLQUFLLENBQUMsWUFBWSxlQUFlLEtBQUssQ0FBQyxTQUFTLE9BQU87WUFDbkksSUFBSSxFQUFFLG9CQUFvQjtZQUMxQixPQUFPLEVBQUUsMElBQTBJO1lBQ25KLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZUFBZSxFQUFFO2dCQUNmLGlCQUFpQixFQUFFLEtBQUs7Z0JBQ3hCLGVBQWUsRUFBRSxDQUFDO2FBQ25CO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBakJELDhEQWlCQztBQUVELE1BQWEsK0NBQWdELFNBQVEsMEJBQWM7SUFDakYsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFrQztRQUMxRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVztZQUM5QixZQUFZLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDaEMsV0FBVyxFQUFFLHdDQUE0QixDQUFDLFdBQVc7WUFDckQsU0FBUyxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ25CLEtBQUssRUFBRSxxRUFBcUUsS0FBSyxDQUFDLFlBQVksZUFBZSxLQUFLLENBQUMsU0FBUyxPQUFPO1lBQ25JLElBQUksRUFBRSxzQkFBc0I7WUFDNUIsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUUsQ0FBQztZQUNYLGVBQWUsRUFBRTtnQkFDZixpQkFBaUIsRUFBRSxLQUFLO2dCQUN4QixlQUFlLEVBQUUsQ0FBQzthQUNuQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWpCRCwwR0FpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWZlcmVuY2UgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IERhdGFkb2dNb25pdG9yLCBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLCBJTm90aWZpY2F0aW9uLCBOb05vdGlmaWNhdGlvbiB9IGZyb20gJy4uLy4uLy4uL2RhdGFkb2d2Mic7XG5cbmludGVyZmFjZSBEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMge1xuICBwaXBlbGluZU5hbWU6IHN0cmluZyB8IFJlZmVyZW5jZTtcbiAgc2VydmljZU5hbWU6IHN0cmluZztcbiAgYWNjb3VudElkOiBzdHJpbmc7XG4gIG5vdGlmaWNhdGlvbj86IElOb3RpZmljYXRpb247XG59XG5cbmV4cG9ydCBjbGFzcyBEYXRhZG9nUGlwZWxpbmVFcnJvckFsZXJ0IGV4dGVuZHMgRGF0YWRvZ01vbml0b3Ige1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogT21pdDxEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMsICdub3RpZmljYXRpb24nPikge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgbm90aWZpY2F0aW9uOiBuZXcgTm9Ob3RpZmljYXRpb24oKSxcbiAgICAgIG1vbml0b3JUeXBlOiBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLlFVRVJZX0FMRVJULFxuICAgICAgZXh0cmFUYWdzOiBbJ2NpY2QnXSxcbiAgICAgIHF1ZXJ5OiBgbWluKGxhc3RfNW0pOm1pbjpkZXBsb3ltZW50LmNvZGVwaXBlbGluZS5leGVjdXRpb25ze3BpcGVsaW5lX25hbWU6JHtwcm9wcy5waXBlbGluZU5hbWV9LGFjY291bnRfaWQ6JHtwcm9wcy5hY2NvdW50SWR9fSA8IDFgLFxuICAgICAgbmFtZTogJ0NJIHBpcGVsaW5lIHN0YXR1cycsXG4gICAgICBtZXNzYWdlOiAne3sjaXNfYWxlcnR9fVxcXFxuVGhlIENJIGJ1aWxkIGlzIGJyb2tlblxcXFxue3svaXNfYWxlcnR9fSBcXFxcblxcXFxue3sjaXNfYWxlcnRfcmVjb3Zlcnl9fVxcXFxuVGhlIENJIGJ1aWxkIHdvcmtzIGFnYWluLlxcXFxue3svaXNfYWxlcnRfcmVjb3Zlcnl9fScsXG4gICAgICBwcmlvcml0eTogNSxcbiAgICAgIG9wdGlvbk92ZXJyaWRlczoge1xuICAgICAgICByZXF1aXJlRnVsbFdpbmRvdzogZmFsc2UsXG4gICAgICAgIGV2YWx1YXRpb25EZWxheTogMCxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIERhdGFEb2dQaXBlbGluZUVycm9yQWxlcnRGb3JWdWxuZXJhYmlsaXR5Q2hlY2tzIGV4dGVuZHMgRGF0YWRvZ01vbml0b3Ige1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRGF0YWRvZ1BpcGVsaW5lTW9uaXRvclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBzZXJ2aWNlTmFtZTogcHJvcHMuc2VydmljZU5hbWUsXG4gICAgICBub3RpZmljYXRpb246IHByb3BzLm5vdGlmaWNhdGlvbixcbiAgICAgIG1vbml0b3JUeXBlOiBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLlFVRVJZX0FMRVJULFxuICAgICAgZXh0cmFUYWdzOiBbJ2NpY2QnXSxcbiAgICAgIHF1ZXJ5OiBgbWluKGxhc3RfNW0pOm1pbjpkZXBsb3ltZW50LmNvZGVwaXBlbGluZS5leGVjdXRpb25ze3BpcGVsaW5lX25hbWU6JHtwcm9wcy5waXBlbGluZU5hbWV9LGFjY291bnRfaWQ6JHtwcm9wcy5hY2NvdW50SWR9fSA8IDFgLFxuICAgICAgbmFtZTogJ1Z1bG5lcmFiaWxpdHkgY2hlY2tzJyxcbiAgICAgIG1lc3NhZ2U6ICdWdWxuZXJhYmlsaXRpZXMgZGV0ZWN0ZWQnLFxuICAgICAgcHJpb3JpdHk6IDMsXG4gICAgICBvcHRpb25PdmVycmlkZXM6IHtcbiAgICAgICAgcmVxdWlyZUZ1bGxXaW5kb3c6IGZhbHNlLFxuICAgICAgICBldmFsdWF0aW9uRGVsYXk6IDAsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWRvZy1tb25pdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZS9kYXRhZG9nLW1vbml0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLGtEQUFpSDtBQVNqSCxNQUFhLHlCQUEwQixTQUFRLDBCQUFjO0lBQzNELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0Q7UUFDaEcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsWUFBWSxFQUFFLElBQUksMEJBQWMsRUFBRTtZQUNsQyxXQUFXLEVBQUUsd0NBQTRCLENBQUMsV0FBVztZQUNyRCxTQUFTLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDbkIsS0FBSyxFQUFFLHFFQUFxRSxLQUFLLENBQUMsWUFBWSxlQUFlLEtBQUssQ0FBQyxTQUFTLE9BQU87WUFDbkksY0FBYyxFQUFFLElBQUk7WUFDcEIsSUFBSSxFQUFFLG9CQUFvQjtZQUMxQixPQUFPLEVBQUUsMElBQTBJO1lBQ25KLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZUFBZSxFQUFFO2dCQUNmLGlCQUFpQixFQUFFLEtBQUs7Z0JBQ3hCLGVBQWUsRUFBRSxDQUFDO2FBQ25CO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBbEJELDhEQWtCQztBQUVELE1BQWEsK0NBQWdELFNBQVEsMEJBQWM7SUFDakYsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFrQztRQUMxRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVztZQUM5QixZQUFZLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDaEMsV0FBVyxFQUFFLHdDQUE0QixDQUFDLFdBQVc7WUFDckQsU0FBUyxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ25CLEtBQUssRUFBRSxxRUFBcUUsS0FBSyxDQUFDLFlBQVksZUFBZSxLQUFLLENBQUMsU0FBUyxPQUFPO1lBQ25JLGNBQWMsRUFBRSxJQUFJO1lBQ3BCLElBQUksRUFBRSxzQkFBc0I7WUFDNUIsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUUsQ0FBQztZQUNYLGVBQWUsRUFBRTtnQkFDZixpQkFBaUIsRUFBRSxLQUFLO2dCQUN4QixlQUFlLEVBQUUsQ0FBQzthQUNuQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWxCRCwwR0FrQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWZlcmVuY2UgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IERhdGFkb2dNb25pdG9yLCBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLCBJTm90aWZpY2F0aW9uLCBOb05vdGlmaWNhdGlvbiB9IGZyb20gJy4uLy4uLy4uL2RhdGFkb2d2Mic7XG5cbmludGVyZmFjZSBEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMge1xuICBwaXBlbGluZU5hbWU6IHN0cmluZyB8IFJlZmVyZW5jZTtcbiAgc2VydmljZU5hbWU6IHN0cmluZztcbiAgYWNjb3VudElkOiBzdHJpbmc7XG4gIG5vdGlmaWNhdGlvbj86IElOb3RpZmljYXRpb247XG59XG5cbmV4cG9ydCBjbGFzcyBEYXRhZG9nUGlwZWxpbmVFcnJvckFsZXJ0IGV4dGVuZHMgRGF0YWRvZ01vbml0b3Ige1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogT21pdDxEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMsICdub3RpZmljYXRpb24nPikge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgbm90aWZpY2F0aW9uOiBuZXcgTm9Ob3RpZmljYXRpb24oKSxcbiAgICAgIG1vbml0b3JUeXBlOiBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLlFVRVJZX0FMRVJULFxuICAgICAgZXh0cmFUYWdzOiBbJ2NpY2QnXSxcbiAgICAgIHF1ZXJ5OiBgbWluKGxhc3RfNW0pOm1pbjpkZXBsb3ltZW50LmNvZGVwaXBlbGluZS5leGVjdXRpb25ze3BpcGVsaW5lX25hbWU6JHtwcm9wcy5waXBlbGluZU5hbWV9LGFjY291bnRfaWQ6JHtwcm9wcy5hY2NvdW50SWR9fSA8IDFgLFxuICAgICAgbG93ZXJjYXNlUXVlcnk6IHRydWUsXG4gICAgICBuYW1lOiAnQ0kgcGlwZWxpbmUgc3RhdHVzJyxcbiAgICAgIG1lc3NhZ2U6ICd7eyNpc19hbGVydH19XFxcXG5UaGUgQ0kgYnVpbGQgaXMgYnJva2VuXFxcXG57ey9pc19hbGVydH19IFxcXFxuXFxcXG57eyNpc19hbGVydF9yZWNvdmVyeX19XFxcXG5UaGUgQ0kgYnVpbGQgd29ya3MgYWdhaW4uXFxcXG57ey9pc19hbGVydF9yZWNvdmVyeX19JyxcbiAgICAgIHByaW9yaXR5OiA1LFxuICAgICAgb3B0aW9uT3ZlcnJpZGVzOiB7XG4gICAgICAgIHJlcXVpcmVGdWxsV2luZG93OiBmYWxzZSxcbiAgICAgICAgZXZhbHVhdGlvbkRlbGF5OiAwLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgRGF0YURvZ1BpcGVsaW5lRXJyb3JBbGVydEZvclZ1bG5lcmFiaWxpdHlDaGVja3MgZXh0ZW5kcyBEYXRhZG9nTW9uaXRvciB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHNlcnZpY2VOYW1lOiBwcm9wcy5zZXJ2aWNlTmFtZSxcbiAgICAgIG5vdGlmaWNhdGlvbjogcHJvcHMubm90aWZpY2F0aW9uLFxuICAgICAgbW9uaXRvclR5cGU6IERhdGFkb2dNb25pdG9yUXVlcnlBbGVydFR5cGUuUVVFUllfQUxFUlQsXG4gICAgICBleHRyYVRhZ3M6IFsnY2ljZCddLFxuICAgICAgcXVlcnk6IGBtaW4obGFzdF81bSk6bWluOmRlcGxveW1lbnQuY29kZXBpcGVsaW5lLmV4ZWN1dGlvbnN7cGlwZWxpbmVfbmFtZToke3Byb3BzLnBpcGVsaW5lTmFtZX0sYWNjb3VudF9pZDoke3Byb3BzLmFjY291bnRJZH19IDwgMWAsXG4gICAgICBsb3dlcmNhc2VRdWVyeTogdHJ1ZSxcbiAgICAgIG5hbWU6ICdWdWxuZXJhYmlsaXR5IGNoZWNrcycsXG4gICAgICBtZXNzYWdlOiAnVnVsbmVyYWJpbGl0aWVzIGRldGVjdGVkJyxcbiAgICAgIHByaW9yaXR5OiAzLFxuICAgICAgb3B0aW9uT3ZlcnJpZGVzOiB7XG4gICAgICAgIHJlcXVpcmVGdWxsV2luZG93OiBmYWxzZSxcbiAgICAgICAgZXZhbHVhdGlvbkRlbGF5OiAwLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -1,7 +1,7 @@
1
- import * as cdk from 'aws-cdk-lib';
2
1
  import { Stack, StackProps } from 'aws-cdk-lib';
3
2
  import { BuildEnvironment } from 'aws-cdk-lib/aws-codebuild';
4
3
  import * as codepipeline from 'aws-cdk-lib/aws-codepipeline';
4
+ import * as pipelines from 'aws-cdk-lib/pipelines';
5
5
  import { CodeBuildStep } from 'aws-cdk-lib/pipelines';
6
6
  import { Construct } from 'constructs';
7
7
  import { DatadogAlertType } from '../../../datadog';
@@ -245,7 +245,7 @@ export declare class PipelineStack extends Stack {
245
245
  private readonly _nistDataMirrorUrl;
246
246
  private readonly _codePipelineType;
247
247
  constructor(scope: Construct, id: string, props: PipelineStackProps);
248
- get mainCodebuildProject(): cdk.pipelines.CodeBuildStep;
248
+ get mainCodebuildProject(): pipelines.CodeBuildStep;
249
249
  get branchCodeBuildProject(): CodeBuildStep;
250
250
  private parseFeatures;
251
251
  private createRioCodeBuildProject;
@@ -258,6 +258,5 @@ export declare class PipelineStack extends Stack {
258
258
  private createDeployFrontendDeployStep;
259
259
  private grantPermissionsForKafkaIntegration;
260
260
  private loadBuildSpecFromFile;
261
- private renamePipelineToLowerCase;
262
261
  private tagCodeBuildProject;
263
262
  }