@rio-cloud/cdk-v2-constructs 4.33.5 → 4.34.1

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/API.md CHANGED
@@ -6311,8 +6311,10 @@ const cfnDatadogMonitorOptions: datadogv2.CfnDatadogMonitorOptions = { ... }
6311
6311
  | **Name** | **Type** | **Description** |
6312
6312
  | --- | --- | --- |
6313
6313
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.enableLogsSample">enableLogsSample</a></code> | <code>boolean</code> | Whether or not to include a sample of the logs. |
6314
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.enableSamples">enableSamples</a></code> | <code>boolean</code> | Whether or not to send a list of samples when the monitor triggers. |
6314
6315
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.escalationMessage">escalationMessage</a></code> | <code>string</code> | Message to include with a re-notification when renotify_interval is set. |
6315
6316
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.evaluationDelay">evaluationDelay</a></code> | <code>number</code> | Time in seconds to delay evaluation. |
6317
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.groupRetentionDuration">groupRetentionDuration</a></code> | <code>string</code> | The time span after which groups with missing data are dropped from the monitor state. |
6316
6318
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.includeTags">includeTags</a></code> | <code>boolean</code> | Whether or not to include triggering tags into notification title'. |
6317
6319
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.locked">locked</a></code> | <code>boolean</code> | Whether or not changes to this monitor should be restricted to the creator or admins. |
6318
6320
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.minFailureDuration">minFailureDuration</a></code> | <code>number</code> | How long the test should be in failure before alerting (integer, number of seconds, max 7200). |
@@ -6322,11 +6324,14 @@ const cfnDatadogMonitorOptions: datadogv2.CfnDatadogMonitorOptions = { ... }
6322
6324
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.newHostDelay">newHostDelay</a></code> | <code>number</code> | Time in seconds to allow a host to start reporting data before starting the evaluation of monitor results. |
6323
6325
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.noDataTimeframe">noDataTimeframe</a></code> | <code>number</code> | Number of minutes data stopped reporting before notifying. |
6324
6326
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.notifyAudit">notifyAudit</a></code> | <code>boolean</code> | Whether or not to notify tagged users when changes are made to the monitor. |
6327
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.notifyBy">notifyBy</a></code> | <code>string[]</code> | Controls what granularity a monitor alerts on. |
6325
6328
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.notifyNoData">notifyNoData</a></code> | <code>boolean</code> | Whether or not to notify when data stops reporting. |
6329
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.onMissingData">onMissingData</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData</code> | Controls how groups or monitors are treated if an evaluation does not return any data points. |
6326
6330
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.renotifyInterval">renotifyInterval</a></code> | <code>number</code> | Number of minutes after the last notification before the monitor re-notifies on the current status. |
6327
6331
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.renotifyOccurrences">renotifyOccurrences</a></code> | <code>number</code> | The number of times re-notification messages should be sent on the current status at the provided re-notification interval. |
6328
6332
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.renotifyStatuses">renotifyStatuses</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.RenotifyStatuses[]</code> | The types of monitor statuses for which re-notification messages are sent. |
6329
6333
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.requireFullWindow">requireFullWindow</a></code> | <code>boolean</code> | Whether or not the monitor requires a full window of data before it is evaluated. |
6334
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.schedulingOptions">schedulingOptions</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions</code> | Configuration options for scheduling. |
6330
6335
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.syntheticsCheckID">syntheticsCheckID</a></code> | <code>number</code> | ID of the corresponding synthetics check. |
6331
6336
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.thresholds">thresholds</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorThresholds</code> | *No description.* |
6332
6337
  | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.thresholdWindows">thresholdWindows</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorThresholdWindows</code> | *No description.* |
@@ -6347,6 +6352,20 @@ Whether or not to include a sample of the logs.
6347
6352
 
6348
6353
  ---
6349
6354
 
6355
+ ##### `enableSamples`<sup>Optional</sup> <a name="enableSamples" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.enableSamples"></a>
6356
+
6357
+ ```typescript
6358
+ public readonly enableSamples: boolean;
6359
+ ```
6360
+
6361
+ - *Type:* boolean
6362
+
6363
+ Whether or not to send a list of samples when the monitor triggers.
6364
+
6365
+ This is only used by CI Test and Pipeline monitors.
6366
+
6367
+ ---
6368
+
6350
6369
  ##### `escalationMessage`<sup>Optional</sup> <a name="escalationMessage" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.escalationMessage"></a>
6351
6370
 
6352
6371
  ```typescript
@@ -6371,6 +6390,22 @@ Time in seconds to delay evaluation.
6371
6390
 
6372
6391
  ---
6373
6392
 
6393
+ ##### `groupRetentionDuration`<sup>Optional</sup> <a name="groupRetentionDuration" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.groupRetentionDuration"></a>
6394
+
6395
+ ```typescript
6396
+ public readonly groupRetentionDuration: string;
6397
+ ```
6398
+
6399
+ - *Type:* string
6400
+
6401
+ The time span after which groups with missing data are dropped from the monitor state.
6402
+
6403
+ The minimum value is one hour, and the maximum value is 72 hours.
6404
+ Example values are: "60m", "1h", and "2d".
6405
+ This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.
6406
+
6407
+ ---
6408
+
6374
6409
  ##### `includeTags`<sup>Optional</sup> <a name="includeTags" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.includeTags"></a>
6375
6410
 
6376
6411
  ```typescript
@@ -6483,6 +6518,24 @@ Whether or not to notify tagged users when changes are made to the monitor.
6483
6518
 
6484
6519
  ---
6485
6520
 
6521
+ ##### `notifyBy`<sup>Optional</sup> <a name="notifyBy" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.notifyBy"></a>
6522
+
6523
+ ```typescript
6524
+ public readonly notifyBy: string[];
6525
+ ```
6526
+
6527
+ - *Type:* string[]
6528
+
6529
+ Controls what granularity a monitor alerts on.
6530
+
6531
+ Only available for monitors with groupings.
6532
+ For instance, a monitor grouped by `cluster`, `namespace`, and `pod` can be configured to only notify on each new `cluster` violating the alert conditions by setting `notify_by` to `["cluster"]`.
6533
+ Tags mentioned in `notify_by` must be a subset of the grouping tags in the query.
6534
+ For example, a query grouped by `cluster` and `namespace` cannot notify on `region`.
6535
+ Setting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.
6536
+
6537
+ ---
6538
+
6486
6539
  ##### `notifyNoData`<sup>Optional</sup> <a name="notifyNoData" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.notifyNoData"></a>
6487
6540
 
6488
6541
  ```typescript
@@ -6496,6 +6549,23 @@ Whether or not to notify when data stops reporting.
6496
6549
 
6497
6550
  ---
6498
6551
 
6552
+ ##### `onMissingData`<sup>Optional</sup> <a name="onMissingData" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.onMissingData"></a>
6553
+
6554
+ ```typescript
6555
+ public readonly onMissingData: MonitorOnMissingData;
6556
+ ```
6557
+
6558
+ - *Type:* @rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData
6559
+
6560
+ Controls how groups or monitors are treated if an evaluation does not return any data points.
6561
+
6562
+ The default option results in different behavior depending on the monitor query type.
6563
+ For monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.
6564
+ For monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.
6565
+ This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.
6566
+
6567
+ ---
6568
+
6499
6569
  ##### `renotifyInterval`<sup>Optional</sup> <a name="renotifyInterval" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.renotifyInterval"></a>
6500
6570
 
6501
6571
  ```typescript
@@ -6545,6 +6615,18 @@ Whether or not the monitor requires a full window of data before it is evaluated
6545
6615
 
6546
6616
  ---
6547
6617
 
6618
+ ##### `schedulingOptions`<sup>Optional</sup> <a name="schedulingOptions" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.schedulingOptions"></a>
6619
+
6620
+ ```typescript
6621
+ public readonly schedulingOptions: MonitorSchedulingOptions;
6622
+ ```
6623
+
6624
+ - *Type:* @rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions
6625
+
6626
+ Configuration options for scheduling.
6627
+
6628
+ ---
6629
+
6548
6630
  ##### `syntheticsCheckID`<sup>Optional</sup> <a name="syntheticsCheckID" id="@rio-cloud/cdk-v2-constructs.datadogv2.CfnDatadogMonitorOptions.property.syntheticsCheckID"></a>
6549
6631
 
6550
6632
  ```typescript
@@ -10553,6 +10635,99 @@ Sets how this alarm is to handle missing data points.
10553
10635
 
10554
10636
  ---
10555
10637
 
10638
+ ### MonitorSchedulingOptions <a name="MonitorSchedulingOptions" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions"></a>
10639
+
10640
+ Configuration options for scheduling.
10641
+
10642
+ #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions.Initializer"></a>
10643
+
10644
+ ```typescript
10645
+ import { datadogv2 } from '@rio-cloud/cdk-v2-constructs'
10646
+
10647
+ const monitorSchedulingOptions: datadogv2.MonitorSchedulingOptions = { ... }
10648
+ ```
10649
+
10650
+ #### Properties <a name="Properties" id="Properties"></a>
10651
+
10652
+ | **Name** | **Type** | **Description** |
10653
+ | --- | --- | --- |
10654
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions.property.evaluationWindow">evaluationWindow</a></code> | <code>@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow</code> | *No description.* |
10655
+
10656
+ ---
10657
+
10658
+ ##### `evaluationWindow`<sup>Optional</sup> <a name="evaluationWindow" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions.property.evaluationWindow"></a>
10659
+
10660
+ ```typescript
10661
+ public readonly evaluationWindow: MonitorSchedulingOptionsEvaluationWindow;
10662
+ ```
10663
+
10664
+ - *Type:* @rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow
10665
+
10666
+ ---
10667
+
10668
+ ### MonitorSchedulingOptionsEvaluationWindow <a name="MonitorSchedulingOptionsEvaluationWindow" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow"></a>
10669
+
10670
+ Configuration options for the evaluation window.
10671
+
10672
+ If `hour_starts` is set, no other fields may be set.
10673
+ Otherwise, `day_starts` and `month_starts` must be set together.
10674
+
10675
+ #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.Initializer"></a>
10676
+
10677
+ ```typescript
10678
+ import { datadogv2 } from '@rio-cloud/cdk-v2-constructs'
10679
+
10680
+ const monitorSchedulingOptionsEvaluationWindow: datadogv2.MonitorSchedulingOptionsEvaluationWindow = { ... }
10681
+ ```
10682
+
10683
+ #### Properties <a name="Properties" id="Properties"></a>
10684
+
10685
+ | **Name** | **Type** | **Description** |
10686
+ | --- | --- | --- |
10687
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.dayStarts">dayStarts</a></code> | <code>string</code> | The time of the day at which a one day cumulative evaluation window starts. |
10688
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.hourStarts">hourStarts</a></code> | <code>number</code> | The minute of the hour at which a one hour cumulative evaluation window starts. |
10689
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.monthStarts">monthStarts</a></code> | <code>number</code> | The day of the month at which a one month cumulative evaluation window starts. |
10690
+
10691
+ ---
10692
+
10693
+ ##### `dayStarts`<sup>Optional</sup> <a name="dayStarts" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.dayStarts"></a>
10694
+
10695
+ ```typescript
10696
+ public readonly dayStarts: string;
10697
+ ```
10698
+
10699
+ - *Type:* string
10700
+
10701
+ The time of the day at which a one day cumulative evaluation window starts.
10702
+
10703
+ Must be defined in UTC time in `HH:mm` format.
10704
+
10705
+ ---
10706
+
10707
+ ##### `hourStarts`<sup>Optional</sup> <a name="hourStarts" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.hourStarts"></a>
10708
+
10709
+ ```typescript
10710
+ public readonly hourStarts: number;
10711
+ ```
10712
+
10713
+ - *Type:* number
10714
+
10715
+ The minute of the hour at which a one hour cumulative evaluation window starts.
10716
+
10717
+ ---
10718
+
10719
+ ##### `monthStarts`<sup>Optional</sup> <a name="monthStarts" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow.property.monthStarts"></a>
10720
+
10721
+ ```typescript
10722
+ public readonly monthStarts: number;
10723
+ ```
10724
+
10725
+ - *Type:* number
10726
+
10727
+ The day of the month at which a one month cumulative evaluation window starts.
10728
+
10729
+ ---
10730
+
10556
10731
  ### OverrideAlarmThresholdProps <a name="OverrideAlarmThresholdProps" id="@rio-cloud/cdk-v2-constructs.OverrideAlarmThresholdProps"></a>
10557
10732
 
10558
10733
  #### Initializer <a name="Initializer" id="@rio-cloud/cdk-v2-constructs.OverrideAlarmThresholdProps.Initializer"></a>
@@ -15805,6 +15980,43 @@ Well known notification presets supported by Datadog.
15805
15980
  ---
15806
15981
 
15807
15982
 
15983
+ ### MonitorOnMissingData <a name="MonitorOnMissingData" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData"></a>
15984
+
15985
+ Options for onMissingData supported by Datadog.
15986
+
15987
+ > [https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json](https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json)
15988
+
15989
+ #### Members <a name="Members" id="Members"></a>
15990
+
15991
+ | **Name** | **Description** |
15992
+ | --- | --- |
15993
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.DEFAULT">DEFAULT</a></code> | *No description.* |
15994
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.SHOW_NO_DATA">SHOW_NO_DATA</a></code> | *No description.* |
15995
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.SHOW_AND_NOTIFY_NO_DATA">SHOW_AND_NOTIFY_NO_DATA</a></code> | *No description.* |
15996
+ | <code><a href="#@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.RESOLVE">RESOLVE</a></code> | *No description.* |
15997
+
15998
+ ---
15999
+
16000
+ ##### `DEFAULT` <a name="DEFAULT" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.DEFAULT"></a>
16001
+
16002
+ ---
16003
+
16004
+
16005
+ ##### `SHOW_NO_DATA` <a name="SHOW_NO_DATA" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.SHOW_NO_DATA"></a>
16006
+
16007
+ ---
16008
+
16009
+
16010
+ ##### `SHOW_AND_NOTIFY_NO_DATA` <a name="SHOW_AND_NOTIFY_NO_DATA" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.SHOW_AND_NOTIFY_NO_DATA"></a>
16011
+
16012
+ ---
16013
+
16014
+
16015
+ ##### `RESOLVE` <a name="RESOLVE" id="@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData.RESOLVE"></a>
16016
+
16017
+ ---
16018
+
16019
+
15808
16020
  ### MonitorType <a name="MonitorType" id="@rio-cloud/cdk-v2-constructs.MonitorType"></a>
15809
16021
 
15810
16022
  #### Members <a name="Members" id="Members"></a>
package/CHANGELOG.md CHANGED
@@ -2,6 +2,20 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [commit-and-tag-version](https://github.com/absolute-version/commit-and-tag-version) for commit guidelines.
4
4
 
5
+ ## [4.34.1](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.34.0&sourceBranch=refs%2Ftags%2Fv4.34.1) (2024-05-23)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * **pipeline:** fix notification bug in main pipeline alert: ([a23db78](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/a23db78bb1ddbf143528afae98544c8026a23bed))
11
+
12
+ ## [4.34.0](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.33.5&sourceBranch=refs%2Ftags%2Fv4.34.0) (2024-05-22)
13
+
14
+
15
+ ### Features
16
+
17
+ * **datadog:** add support for all Datadog monitor options ([3582468](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/3582468227763acfe2be63a459e9d598a6c3bc8f))
18
+
5
19
  ## [4.33.5](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.33.4&sourceBranch=refs%2Ftags%2Fv4.33.5) (2024-05-21)
6
20
 
7
21
 
@@ -8,7 +8,7 @@ interface DatadogPipelineMonitorProps {
8
8
  notification?: INotification;
9
9
  }
10
10
  export declare class DatadogPipelineErrorAlert extends DatadogMonitor {
11
- constructor(scope: Construct, id: string, props: DatadogPipelineMonitorProps);
11
+ constructor(scope: Construct, id: string, props: Omit<DatadogPipelineMonitorProps, 'notification'>);
12
12
  }
13
13
  export declare class DataDogPipelineErrorAlertForVulnerabilityChecks extends DatadogMonitor {
14
14
  constructor(scope: Construct, id: string, props: DatadogPipelineMonitorProps);
@@ -6,7 +6,7 @@ class DatadogPipelineErrorAlert extends datadogv2_1.DatadogMonitor {
6
6
  constructor(scope, id, props) {
7
7
  super(scope, id, {
8
8
  serviceName: props.serviceName,
9
- notification: props.notification,
9
+ notification: new datadogv2_1.NoNotification(),
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`,
@@ -40,4 +40,4 @@ class DataDogPipelineErrorAlertForVulnerabilityChecks extends datadogv2_1.Datado
40
40
  }
41
41
  }
42
42
  exports.DataDogPipelineErrorAlertForVulnerabilityChecks = DataDogPipelineErrorAlertForVulnerabilityChecks;
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWRvZy1tb25pdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZS9kYXRhZG9nLW1vbml0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLGtEQUFpRztBQVNqRyxNQUFhLHlCQUEwQixTQUFRLDBCQUFjO0lBQzNELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBa0M7UUFDMUUsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsWUFBWSxFQUFFLEtBQUssQ0FBQyxZQUFZO1lBQ2hDLFdBQVcsRUFBRSx3Q0FBNEIsQ0FBQyxXQUFXO1lBQ3JELFNBQVMsRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUNuQixLQUFLLEVBQUUscUVBQXFFLEtBQUssQ0FBQyxZQUFZLGVBQWUsS0FBSyxDQUFDLFNBQVMsT0FBTztZQUNuSSxJQUFJLEVBQUUsb0JBQW9CO1lBQzFCLE9BQU8sRUFBRSwwSUFBMEk7WUFDbkosUUFBUSxFQUFFLENBQUM7WUFDWCxlQUFlLEVBQUU7Z0JBQ2YsaUJBQWlCLEVBQUUsS0FBSztnQkFDeEIsZUFBZSxFQUFFLENBQUM7YUFDbkI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFqQkQsOERBaUJDO0FBRUQsTUFBYSwrQ0FBZ0QsU0FBUSwwQkFBYztJQUNqRixZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQWtDO1FBQzFFLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsV0FBVyxFQUFFLEtBQUssQ0FBQyxXQUFXO1lBQzlCLFlBQVksRUFBRSxLQUFLLENBQUMsWUFBWTtZQUNoQyxXQUFXLEVBQUUsd0NBQTRCLENBQUMsV0FBVztZQUNyRCxTQUFTLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDbkIsS0FBSyxFQUFFLHFFQUFxRSxLQUFLLENBQUMsWUFBWSxlQUFlLEtBQUssQ0FBQyxTQUFTLE9BQU87WUFDbkksSUFBSSxFQUFFLHNCQUFzQjtZQUM1QixPQUFPLEVBQUUsMEJBQTBCO1lBQ25DLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZUFBZSxFQUFFO2dCQUNmLGlCQUFpQixFQUFFLEtBQUs7Z0JBQ3hCLGVBQWUsRUFBRSxDQUFDO2FBQ25CO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBakJELDBHQWlCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlZmVyZW5jZSB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgRGF0YWRvZ01vbml0b3IsIERhdGFkb2dNb25pdG9yUXVlcnlBbGVydFR5cGUsIElOb3RpZmljYXRpb24gfSBmcm9tICcuLi8uLi8uLi9kYXRhZG9ndjInO1xuXG5pbnRlcmZhY2UgRGF0YWRvZ1BpcGVsaW5lTW9uaXRvclByb3BzIHtcbiAgcGlwZWxpbmVOYW1lOiBzdHJpbmcgfCBSZWZlcmVuY2U7XG4gIHNlcnZpY2VOYW1lOiBzdHJpbmc7XG4gIGFjY291bnRJZDogc3RyaW5nO1xuICBub3RpZmljYXRpb24/OiBJTm90aWZpY2F0aW9uO1xufVxuXG5leHBvcnQgY2xhc3MgRGF0YWRvZ1BpcGVsaW5lRXJyb3JBbGVydCBleHRlbmRzIERhdGFkb2dNb25pdG9yIHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IERhdGFkb2dQaXBlbGluZU1vbml0b3JQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgbm90aWZpY2F0aW9uOiBwcm9wcy5ub3RpZmljYXRpb24sXG4gICAgICBtb25pdG9yVHlwZTogRGF0YWRvZ01vbml0b3JRdWVyeUFsZXJ0VHlwZS5RVUVSWV9BTEVSVCxcbiAgICAgIGV4dHJhVGFnczogWydjaWNkJ10sXG4gICAgICBxdWVyeTogYG1pbihsYXN0XzVtKTptaW46ZGVwbG95bWVudC5jb2RlcGlwZWxpbmUuZXhlY3V0aW9uc3twaXBlbGluZV9uYW1lOiR7cHJvcHMucGlwZWxpbmVOYW1lfSxhY2NvdW50X2lkOiR7cHJvcHMuYWNjb3VudElkfX0gPCAxYCxcbiAgICAgIG5hbWU6ICdDSSBwaXBlbGluZSBzdGF0dXMnLFxuICAgICAgbWVzc2FnZTogJ3t7I2lzX2FsZXJ0fX1cXFxcblRoZSBDSSBidWlsZCBpcyBicm9rZW5cXFxcbnt7L2lzX2FsZXJ0fX0gXFxcXG5cXFxcbnt7I2lzX2FsZXJ0X3JlY292ZXJ5fX1cXFxcblRoZSBDSSBidWlsZCB3b3JrcyBhZ2Fpbi5cXFxcbnt7L2lzX2FsZXJ0X3JlY292ZXJ5fX0nLFxuICAgICAgcHJpb3JpdHk6IDUsXG4gICAgICBvcHRpb25PdmVycmlkZXM6IHtcbiAgICAgICAgcmVxdWlyZUZ1bGxXaW5kb3c6IGZhbHNlLFxuICAgICAgICBldmFsdWF0aW9uRGVsYXk6IDAsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBEYXRhRG9nUGlwZWxpbmVFcnJvckFsZXJ0Rm9yVnVsbmVyYWJpbGl0eUNoZWNrcyBleHRlbmRzIERhdGFkb2dNb25pdG9yIHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IERhdGFkb2dQaXBlbGluZU1vbml0b3JQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgbm90aWZpY2F0aW9uOiBwcm9wcy5ub3RpZmljYXRpb24sXG4gICAgICBtb25pdG9yVHlwZTogRGF0YWRvZ01vbml0b3JRdWVyeUFsZXJ0VHlwZS5RVUVSWV9BTEVSVCxcbiAgICAgIGV4dHJhVGFnczogWydjaWNkJ10sXG4gICAgICBxdWVyeTogYG1pbihsYXN0XzVtKTptaW46ZGVwbG95bWVudC5jb2RlcGlwZWxpbmUuZXhlY3V0aW9uc3twaXBlbGluZV9uYW1lOiR7cHJvcHMucGlwZWxpbmVOYW1lfSxhY2NvdW50X2lkOiR7cHJvcHMuYWNjb3VudElkfX0gPCAxYCxcbiAgICAgIG5hbWU6ICdWdWxuZXJhYmlsaXR5IGNoZWNrcycsXG4gICAgICBtZXNzYWdlOiAnVnVsbmVyYWJpbGl0aWVzIGRldGVjdGVkJyxcbiAgICAgIHByaW9yaXR5OiAzLFxuICAgICAgb3B0aW9uT3ZlcnJpZGVzOiB7XG4gICAgICAgIHJlcXVpcmVGdWxsV2luZG93OiBmYWxzZSxcbiAgICAgICAgZXZhbHVhdGlvbkRlbGF5OiAwLFxuICAgICAgfSxcbiAgICB9KTtcbiAgfVxufVxuIl19
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWRvZy1tb25pdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb250cmlidXRpb25zL3RlYW0tdHJhbnNwb3J0LXR3by9waXBlbGluZS9kYXRhZG9nLW1vbml0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLGtEQUFpSDtBQVNqSCxNQUFhLHlCQUEwQixTQUFRLDBCQUFjO0lBQzNELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0Q7UUFDaEcsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUU7WUFDZixXQUFXLEVBQUUsS0FBSyxDQUFDLFdBQVc7WUFDOUIsWUFBWSxFQUFFLElBQUksMEJBQWMsRUFBRTtZQUNsQyxXQUFXLEVBQUUsd0NBQTRCLENBQUMsV0FBVztZQUNyRCxTQUFTLEVBQUUsQ0FBQyxNQUFNLENBQUM7WUFDbkIsS0FBSyxFQUFFLHFFQUFxRSxLQUFLLENBQUMsWUFBWSxlQUFlLEtBQUssQ0FBQyxTQUFTLE9BQU87WUFDbkksSUFBSSxFQUFFLG9CQUFvQjtZQUMxQixPQUFPLEVBQUUsMElBQTBJO1lBQ25KLFFBQVEsRUFBRSxDQUFDO1lBQ1gsZUFBZSxFQUFFO2dCQUNmLGlCQUFpQixFQUFFLEtBQUs7Z0JBQ3hCLGVBQWUsRUFBRSxDQUFDO2FBQ25CO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBakJELDhEQWlCQztBQUVELE1BQWEsK0NBQWdELFNBQVEsMEJBQWM7SUFDakYsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFrQztRQUMxRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRTtZQUNmLFdBQVcsRUFBRSxLQUFLLENBQUMsV0FBVztZQUM5QixZQUFZLEVBQUUsS0FBSyxDQUFDLFlBQVk7WUFDaEMsV0FBVyxFQUFFLHdDQUE0QixDQUFDLFdBQVc7WUFDckQsU0FBUyxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ25CLEtBQUssRUFBRSxxRUFBcUUsS0FBSyxDQUFDLFlBQVksZUFBZSxLQUFLLENBQUMsU0FBUyxPQUFPO1lBQ25JLElBQUksRUFBRSxzQkFBc0I7WUFDNUIsT0FBTyxFQUFFLDBCQUEwQjtZQUNuQyxRQUFRLEVBQUUsQ0FBQztZQUNYLGVBQWUsRUFBRTtnQkFDZixpQkFBaUIsRUFBRSxLQUFLO2dCQUN4QixlQUFlLEVBQUUsQ0FBQzthQUNuQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQWpCRCwwR0FpQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWZlcmVuY2UgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IERhdGFkb2dNb25pdG9yLCBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLCBJTm90aWZpY2F0aW9uLCBOb05vdGlmaWNhdGlvbiB9IGZyb20gJy4uLy4uLy4uL2RhdGFkb2d2Mic7XG5cbmludGVyZmFjZSBEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMge1xuICBwaXBlbGluZU5hbWU6IHN0cmluZyB8IFJlZmVyZW5jZTtcbiAgc2VydmljZU5hbWU6IHN0cmluZztcbiAgYWNjb3VudElkOiBzdHJpbmc7XG4gIG5vdGlmaWNhdGlvbj86IElOb3RpZmljYXRpb247XG59XG5cbmV4cG9ydCBjbGFzcyBEYXRhZG9nUGlwZWxpbmVFcnJvckFsZXJ0IGV4dGVuZHMgRGF0YWRvZ01vbml0b3Ige1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogT21pdDxEYXRhZG9nUGlwZWxpbmVNb25pdG9yUHJvcHMsICdub3RpZmljYXRpb24nPikge1xuICAgIHN1cGVyKHNjb3BlLCBpZCwge1xuICAgICAgc2VydmljZU5hbWU6IHByb3BzLnNlcnZpY2VOYW1lLFxuICAgICAgbm90aWZpY2F0aW9uOiBuZXcgTm9Ob3RpZmljYXRpb24oKSxcbiAgICAgIG1vbml0b3JUeXBlOiBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLlFVRVJZX0FMRVJULFxuICAgICAgZXh0cmFUYWdzOiBbJ2NpY2QnXSxcbiAgICAgIHF1ZXJ5OiBgbWluKGxhc3RfNW0pOm1pbjpkZXBsb3ltZW50LmNvZGVwaXBlbGluZS5leGVjdXRpb25ze3BpcGVsaW5lX25hbWU6JHtwcm9wcy5waXBlbGluZU5hbWV9LGFjY291bnRfaWQ6JHtwcm9wcy5hY2NvdW50SWR9fSA8IDFgLFxuICAgICAgbmFtZTogJ0NJIHBpcGVsaW5lIHN0YXR1cycsXG4gICAgICBtZXNzYWdlOiAne3sjaXNfYWxlcnR9fVxcXFxuVGhlIENJIGJ1aWxkIGlzIGJyb2tlblxcXFxue3svaXNfYWxlcnR9fSBcXFxcblxcXFxue3sjaXNfYWxlcnRfcmVjb3Zlcnl9fVxcXFxuVGhlIENJIGJ1aWxkIHdvcmtzIGFnYWluLlxcXFxue3svaXNfYWxlcnRfcmVjb3Zlcnl9fScsXG4gICAgICBwcmlvcml0eTogNSxcbiAgICAgIG9wdGlvbk92ZXJyaWRlczoge1xuICAgICAgICByZXF1aXJlRnVsbFdpbmRvdzogZmFsc2UsXG4gICAgICAgIGV2YWx1YXRpb25EZWxheTogMCxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIERhdGFEb2dQaXBlbGluZUVycm9yQWxlcnRGb3JWdWxuZXJhYmlsaXR5Q2hlY2tzIGV4dGVuZHMgRGF0YWRvZ01vbml0b3Ige1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogRGF0YWRvZ1BpcGVsaW5lTW9uaXRvclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkLCB7XG4gICAgICBzZXJ2aWNlTmFtZTogcHJvcHMuc2VydmljZU5hbWUsXG4gICAgICBub3RpZmljYXRpb246IHByb3BzLm5vdGlmaWNhdGlvbixcbiAgICAgIG1vbml0b3JUeXBlOiBEYXRhZG9nTW9uaXRvclF1ZXJ5QWxlcnRUeXBlLlFVRVJZX0FMRVJULFxuICAgICAgZXh0cmFUYWdzOiBbJ2NpY2QnXSxcbiAgICAgIHF1ZXJ5OiBgbWluKGxhc3RfNW0pOm1pbjpkZXBsb3ltZW50LmNvZGVwaXBlbGluZS5leGVjdXRpb25ze3BpcGVsaW5lX25hbWU6JHtwcm9wcy5waXBlbGluZU5hbWV9LGFjY291bnRfaWQ6JHtwcm9wcy5hY2NvdW50SWR9fSA8IDFgLFxuICAgICAgbmFtZTogJ1Z1bG5lcmFiaWxpdHkgY2hlY2tzJyxcbiAgICAgIG1lc3NhZ2U6ICdWdWxuZXJhYmlsaXRpZXMgZGV0ZWN0ZWQnLFxuICAgICAgcHJpb3JpdHk6IDMsXG4gICAgICBvcHRpb25PdmVycmlkZXM6IHtcbiAgICAgICAgcmVxdWlyZUZ1bGxXaW5kb3c6IGZhbHNlLFxuICAgICAgICBldmFsdWF0aW9uRGVsYXk6IDAsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -105,7 +105,7 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
105
105
  product: index_1.ClaidometerProduct.CDK_CONTRIBUTION,
106
106
  packageName,
107
107
  feature,
108
- version: '0.0.21',
108
+ version: '0.0.22',
109
109
  });
110
110
  }
111
111
  get mainCodebuildProject() {
@@ -315,4 +315,4 @@ class PipelineStack extends aws_cdk_lib_1.Stack {
315
315
  exports.PipelineStack = PipelineStack;
316
316
  _a = JSII_RTTI_SYMBOL_1;
317
317
  PipelineStack[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.PipelineStack", version: "0.0.0" };
318
- //# 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, RemovalPolicy, Stack, StackProps, Tags } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, ComputeType, LinuxLambdaBuildImage } 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 { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\nimport { RioCapabilityMonitoringDeployStep } from './monitoring-deploy-step';\nimport { DatadogAlertType } from '../../../datadog';\nimport { INotification } from '../../../datadogv2';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful';\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   * @deprecated Please use the `vulnerabilityNotification` property instead.\n   * If `opsgenie` is specified, an Exception is thrown, as this is not supported anymore.\n   */\n  readonly datadogAlertType?: DatadogAlertType;\n  /**\n   * Notification type for the auto-generated vulnerability pipeline monitor. Defaults to slack.\n   */\n  readonly vulnerabilityNotification?: INotification;\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_5\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _cacheBucket: 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\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._cacheBucket = new s3.Bucket(this, 'CacheBucket', {\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteObjects: true,\n      lifecycleRules: [\n        {\n          expiration: Duration.days(30),\n          abortIncompleteMultipartUploadAfter: Duration.days(7),\n        },\n      ],\n    });\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\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.21',\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      cacheBucket: this._cacheBucket,\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      artifactBucket: this._cacheBucket,\n      synth: mainBuild,\n    });\n    Tags.of(pipeline).add('pipeline_type', 'build');\n\n    const stripAssetsStep = this.createStripAssetsStep(pipeline);\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);\n    const secretsDeployStepProps = this.createSecretsDeployStep(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: secretsDeployStepProps ? [secretsDeployStepProps] : undefined,\n      post: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    this.tagCodeBuildProject(stripAssetsStep, 'project_type', 'strip_assets');\n    this.tagCodeBuildProject(secretsDeployStepProps, 'project_type', 'deploy_secrets');\n    this.tagCodeBuildProject(mainBuild, 'project_type', 'build');\n    this.tagCodeBuildProject(capabilityMonitoringDeployStep, 'project_type', 'deploy_capability_monitoring');\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    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      artifactBucket: this._cacheBucket,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    Tags.of(branchPipeline).add('pipeline_type', 'branch');\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    this.tagCodeBuildProject(branchBuild, 'project_type', 'branch_build');\n\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      cacheBucket: this._cacheBucket,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      artifactBucket: this._cacheBucket,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    Tags.of(vulnerabilityPipeline).add('pipeline_type', 'vulnerability');\n\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    Tags.of(vulnerabilityBuild.project).add('project_type', 'vulnerability_check');\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    if (props.datadogAlertType === 'opsgenie') {\n      throw Error('The OpsGenie alertType is not supported anymore. Please use the vulnerabilityNotification property instead.');\n    }\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n      notification: props.vulnerabilityNotification,\n    });\n  }\n\n  private createStripAssetsStep(pipeline: pipelines.CodePipeline): CodeBuildStep {\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    return 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        buildEnvironment: {\n          buildImage: LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,\n          computeType: ComputeType.LAMBDA_1GB,\n        },\n      },\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 createSecretsDeployStep(props: PipelineStackProps): rio.RioSecretsDeployStep | undefined {\n    if (props.secretsDeployStepProps) {\n      return new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n        ...props.secretsDeployStepProps,\n        input: this._inputMasterTriggerFile,\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  private tagCodeBuildProject(project: CodeBuildStep | undefined, key: string, value: string) {\n    if (project) {\n      Tags.of(project.project).add(key, value);\n    }\n  }\n}\n"]}
318
+ //# 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, RemovalPolicy, Stack, StackProps, Tags } from 'aws-cdk-lib';\nimport { BuildEnvironment, BuildSpec, ComputeType, LinuxLambdaBuildImage } 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 { Application } from './application-stage';\nimport { RioCodeBuildProject } from './build-project';\nimport { DatadogPipelineErrorAlert, DataDogPipelineErrorAlertForVulnerabilityChecks } from './datadog-monitors';\nimport { RioCapabilityMonitoringDeployStep } from './monitoring-deploy-step';\nimport { DatadogAlertType } from '../../../datadog';\nimport { INotification } from '../../../datadogv2';\nimport * as rio from '../../../index';\nimport { Claidometer, ClaidometerProduct } from '../../../index';\nimport { UpperToLower } from '../../../watchful';\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   * @deprecated Please use the `vulnerabilityNotification` property instead.\n   * If `opsgenie` is specified, an Exception is thrown, as this is not supported anymore.\n   */\n  readonly datadogAlertType?: DatadogAlertType;\n  /**\n   * Notification type for the auto-generated vulnerability pipeline monitor. Defaults to slack.\n   */\n  readonly vulnerabilityNotification?: INotification;\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_5\n *          computeType: LARGE\n */\nexport interface CodeBuildOptions {\n  readonly partialBuildSpecPath?: string;\n  readonly buildEnvironment?: BuildEnvironment;\n}\n\nexport class PipelineStack extends Stack {\n  private readonly _mainCodeBuildProject: CodeBuildStep;\n  private readonly _branchCodeBuildProject: CodeBuildStep | undefined;\n  private readonly _bucket: IBucket;\n  private readonly _cacheBucket: 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\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._cacheBucket = new s3.Bucket(this, 'CacheBucket', {\n      removalPolicy: RemovalPolicy.DESTROY,\n      autoDeleteObjects: true,\n      lifecycleRules: [\n        {\n          expiration: Duration.days(30),\n          abortIncompleteMultipartUploadAfter: Duration.days(7),\n        },\n      ],\n    });\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\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.22',\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      cacheBucket: this._cacheBucket,\n    });\n  }\n\n  private addMainPipeline(props: PipelineStackProps, mainBuild: CodeBuildStep) {\n\n    const pipeline = new pipelines.CodePipeline(this, 'Pipeline', {\n      artifactBucket: this._cacheBucket,\n      synth: mainBuild,\n    });\n    Tags.of(pipeline).add('pipeline_type', 'build');\n\n    const stripAssetsStep = this.createStripAssetsStep(pipeline);\n    pipeline.addWave('BeforeDeploy', { pre: [stripAssetsStep] });\n\n    const capabilityMonitoringDeployStep = this.createCapabilityMonitoringDeployStep(mainBuild, props);\n    const secretsDeployStepProps = this.createSecretsDeployStep(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: secretsDeployStepProps ? [secretsDeployStepProps] : undefined,\n      post: capabilityMonitoringDeployStep ? [capabilityMonitoringDeployStep] : undefined,\n    });\n    pipeline.buildPipeline();\n\n    this.tagCodeBuildProject(stripAssetsStep, 'project_type', 'strip_assets');\n    this.tagCodeBuildProject(secretsDeployStepProps, 'project_type', 'deploy_secrets');\n    this.tagCodeBuildProject(mainBuild, 'project_type', 'build');\n    this.tagCodeBuildProject(capabilityMonitoringDeployStep, 'project_type', 'deploy_capability_monitoring');\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    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      artifactBucket: this._cacheBucket,\n      synth: branchBuild,\n      selfMutation: false,\n    });\n    Tags.of(branchPipeline).add('pipeline_type', 'branch');\n    branchPipeline.addWave('BranchBuild').addPost(branchBuild);\n    branchPipeline.buildPipeline();\n\n    this.tagCodeBuildProject(branchBuild, 'project_type', 'branch_build');\n\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      cacheBucket: this._cacheBucket,\n    });\n    const vulnerabilityPipeline = new pipelines.CodePipeline(this, 'VulnerabilityPipeline', {\n      artifactBucket: this._cacheBucket,\n      synth: vulnerabilityBuild,\n      selfMutation: false,\n    });\n    Tags.of(vulnerabilityPipeline).add('pipeline_type', 'vulnerability');\n\n    vulnerabilityPipeline.addWave('VulnerabilityChecks').addPost(vulnerabilityBuild);\n    vulnerabilityPipeline.buildPipeline();\n    Tags.of(vulnerabilityBuild.project).add('project_type', 'vulnerability_check');\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    if (props.datadogAlertType === 'opsgenie') {\n      throw Error('The OpsGenie alertType is not supported anymore. Please use the vulnerabilityNotification property instead.');\n    }\n    new DataDogPipelineErrorAlertForVulnerabilityChecks(this, 'DataDogPipelineErrorForVulnerabilityChecksMonitor', {\n      serviceName: props.serviceName,\n      pipelineName: this.renamePipelineToLowerCase(vulnerabilityPipeline),\n      accountId: this.account,\n      notification: props.vulnerabilityNotification,\n    });\n  }\n\n  private createStripAssetsStep(pipeline: pipelines.CodePipeline): CodeBuildStep {\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    return 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        buildEnvironment: {\n          buildImage: LinuxLambdaBuildImage.AMAZON_LINUX_2023_NODE_20,\n          computeType: ComputeType.LAMBDA_1GB,\n        },\n      },\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 createSecretsDeployStep(props: PipelineStackProps): rio.RioSecretsDeployStep | undefined {\n    if (props.secretsDeployStepProps) {\n      return new rio.RioSecretsDeployStep(this, 'DeploySecrets', {\n        ...props.secretsDeployStepProps,\n        input: this._inputMasterTriggerFile,\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  private tagCodeBuildProject(project: CodeBuildStep | undefined, key: string, value: string) {\n    if (project) {\n      Tags.of(project.project).add(key, value);\n    }\n  }\n}\n"]}