@rio-cloud/cdk-v2-constructs 4.33.4 → 4.34.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +283 -39
- package/API.md +212 -0
- package/CHANGELOG.md +14 -0
- package/lib/datadogv2/datadog-monitor.d.ts +80 -4
- package/lib/datadogv2/datadog-monitor.js +31 -2
- package/lib/fargate/datadog.js +2 -1
- package/package.json +1 -1
- package/version.json +1 -1
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.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)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
* **datadog:** add support for all Datadog monitor options ([3582468](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/3582468227763acfe2be63a459e9d598a6c3bc8f))
|
|
11
|
+
|
|
12
|
+
## [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)
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
### Bug Fixes
|
|
16
|
+
|
|
17
|
+
* **fargate:** disable Datadog agent remote configuration to get rid of related log messages ([f852305](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/commits/f852305e7e9f109841fda303b4a6a7e2dc51e0b9))
|
|
18
|
+
|
|
5
19
|
## [4.33.4](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.33.2&sourceBranch=refs%2Ftags%2Fv4.33.4) (2024-05-02)
|
|
6
20
|
|
|
7
21
|
## [4.33.3](https://bitbucket.collaboration-man.com/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.33.2&sourceBranch=refs%2Ftags%2Fv4.33.3) (2024-05-02)
|
|
@@ -101,6 +101,17 @@ export declare enum MonitorNotificationPreset {
|
|
|
101
101
|
HIDE_HANDLES = "hide_handles",
|
|
102
102
|
HIDE_ALL = "hide_all"
|
|
103
103
|
}
|
|
104
|
+
/**
|
|
105
|
+
* Options for onMissingData supported by Datadog.
|
|
106
|
+
*
|
|
107
|
+
* @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json
|
|
108
|
+
*/
|
|
109
|
+
export declare enum MonitorOnMissingData {
|
|
110
|
+
DEFAULT = "default",
|
|
111
|
+
SHOW_NO_DATA = "show_no_data",
|
|
112
|
+
SHOW_AND_NOTIFY_NO_DATA = "show_and_notify_no_data",
|
|
113
|
+
RESOLVE = "resolve"
|
|
114
|
+
}
|
|
104
115
|
/**
|
|
105
116
|
* Options to override for Datadog monitors in case more specific settings are required.
|
|
106
117
|
*
|
|
@@ -111,6 +122,12 @@ export interface CfnDatadogMonitorOptions {
|
|
|
111
122
|
* Whether or not to include a sample of the logs
|
|
112
123
|
*/
|
|
113
124
|
readonly enableLogsSample?: boolean;
|
|
125
|
+
/**
|
|
126
|
+
* Whether or not to send a list of samples when the monitor triggers.
|
|
127
|
+
*
|
|
128
|
+
* This is only used by CI Test and Pipeline monitors.
|
|
129
|
+
*/
|
|
130
|
+
readonly enableSamples?: boolean;
|
|
114
131
|
/**
|
|
115
132
|
* Message to include with a re-notification when renotify_interval is set
|
|
116
133
|
*/
|
|
@@ -120,6 +137,14 @@ export interface CfnDatadogMonitorOptions {
|
|
|
120
137
|
*
|
|
121
138
|
*/
|
|
122
139
|
readonly evaluationDelay?: number;
|
|
140
|
+
/**
|
|
141
|
+
* The time span after which groups with missing data are dropped from the monitor state.
|
|
142
|
+
*
|
|
143
|
+
* The minimum value is one hour, and the maximum value is 72 hours.
|
|
144
|
+
* Example values are: "60m", "1h", and "2d".
|
|
145
|
+
* This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.
|
|
146
|
+
*/
|
|
147
|
+
readonly groupRetentionDuration?: string;
|
|
123
148
|
/**
|
|
124
149
|
* Whether or not to include triggering tags into notification title'
|
|
125
150
|
*
|
|
@@ -146,12 +171,31 @@ export interface CfnDatadogMonitorOptions {
|
|
|
146
171
|
* Whether or not to notify tagged users when changes are made to the monitor
|
|
147
172
|
*/
|
|
148
173
|
readonly notifyAudit?: boolean;
|
|
174
|
+
/**
|
|
175
|
+
* Controls what granularity a monitor alerts on.
|
|
176
|
+
*
|
|
177
|
+
* Only available for monitors with groupings.
|
|
178
|
+
* 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"]`.
|
|
179
|
+
* Tags mentioned in `notify_by` must be a subset of the grouping tags in the query.
|
|
180
|
+
* For example, a query grouped by `cluster` and `namespace` cannot notify on `region`.
|
|
181
|
+
* Setting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.
|
|
182
|
+
*/
|
|
183
|
+
readonly notifyBy?: string[];
|
|
149
184
|
/**
|
|
150
185
|
* Whether or not to notify when data stops reporting
|
|
151
186
|
*
|
|
152
187
|
* @defaultValue false
|
|
153
188
|
*/
|
|
154
189
|
readonly notifyNoData?: boolean;
|
|
190
|
+
/**
|
|
191
|
+
* Controls how groups or monitors are treated if an evaluation does not return any data points.
|
|
192
|
+
*
|
|
193
|
+
* The default option results in different behavior depending on the monitor query type.
|
|
194
|
+
* For monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.
|
|
195
|
+
* For monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.
|
|
196
|
+
* This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.
|
|
197
|
+
*/
|
|
198
|
+
readonly onMissingData?: MonitorOnMissingData;
|
|
155
199
|
/**
|
|
156
200
|
* Number of minutes after the last notification before the monitor re-notifies on the current status
|
|
157
201
|
*/
|
|
@@ -162,6 +206,10 @@ export interface CfnDatadogMonitorOptions {
|
|
|
162
206
|
* @defaultValue false
|
|
163
207
|
*/
|
|
164
208
|
readonly requireFullWindow?: boolean;
|
|
209
|
+
/**
|
|
210
|
+
* Configuration options for scheduling
|
|
211
|
+
*/
|
|
212
|
+
readonly schedulingOptions?: MonitorSchedulingOptions;
|
|
165
213
|
/**
|
|
166
214
|
* ID of the corresponding synthetics check
|
|
167
215
|
*/
|
|
@@ -201,19 +249,19 @@ export interface CfnDatadogMonitorOptions {
|
|
|
201
249
|
}
|
|
202
250
|
export interface CfnDatadogMonitorThresholds {
|
|
203
251
|
/**
|
|
204
|
-
*Threshold value for triggering an alert
|
|
252
|
+
* Threshold value for triggering an alert
|
|
205
253
|
*/
|
|
206
254
|
readonly critical?: number;
|
|
207
255
|
/**
|
|
208
|
-
*Threshold value for recovering from an alert state
|
|
256
|
+
* Threshold value for recovering from an alert state
|
|
209
257
|
*/
|
|
210
258
|
readonly criticalRecovery?: number;
|
|
211
259
|
/**
|
|
212
|
-
*Threshold value for recovering from an alert state
|
|
260
|
+
* Threshold value for recovering from an alert state
|
|
213
261
|
*/
|
|
214
262
|
readonly ok?: number;
|
|
215
263
|
/**
|
|
216
|
-
*Threshold value for triggering a warning
|
|
264
|
+
* Threshold value for triggering a warning
|
|
217
265
|
*/
|
|
218
266
|
readonly warning?: number;
|
|
219
267
|
/**
|
|
@@ -231,6 +279,34 @@ export interface CfnDatadogMonitorThresholdWindows {
|
|
|
231
279
|
*/
|
|
232
280
|
readonly recoveryWindow?: string;
|
|
233
281
|
}
|
|
282
|
+
/**
|
|
283
|
+
* Configuration options for scheduling
|
|
284
|
+
*/
|
|
285
|
+
export interface MonitorSchedulingOptions {
|
|
286
|
+
readonly evaluationWindow?: MonitorSchedulingOptionsEvaluationWindow;
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Configuration options for the evaluation window.
|
|
290
|
+
*
|
|
291
|
+
* If `hour_starts` is set, no other fields may be set.
|
|
292
|
+
* Otherwise, `day_starts` and `month_starts` must be set together.
|
|
293
|
+
*/
|
|
294
|
+
export interface MonitorSchedulingOptionsEvaluationWindow {
|
|
295
|
+
/**
|
|
296
|
+
* The time of the day at which a one day cumulative evaluation window starts.
|
|
297
|
+
*
|
|
298
|
+
* Must be defined in UTC time in `HH:mm` format.
|
|
299
|
+
*/
|
|
300
|
+
readonly dayStarts?: string;
|
|
301
|
+
/**
|
|
302
|
+
* The day of the month at which a one month cumulative evaluation window starts
|
|
303
|
+
*/
|
|
304
|
+
readonly monthStarts?: number;
|
|
305
|
+
/**
|
|
306
|
+
* The minute of the hour at which a one hour cumulative evaluation window starts
|
|
307
|
+
*/
|
|
308
|
+
readonly hourStarts?: number;
|
|
309
|
+
}
|
|
234
310
|
/**
|
|
235
311
|
* Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.
|
|
236
312
|
*
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var _a;
|
|
3
3
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.DatadogMonitor = exports.MonitorNotificationPreset = exports.RenotifyStatuses = exports.DatadogMonitorQueryAlertType = void 0;
|
|
4
|
+
exports.DatadogMonitor = exports.MonitorOnMissingData = exports.MonitorNotificationPreset = exports.RenotifyStatuses = exports.DatadogMonitorQueryAlertType = void 0;
|
|
5
5
|
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
6
|
const cdk = require("aws-cdk-lib");
|
|
7
7
|
const constructs_1 = require("constructs");
|
|
@@ -54,6 +54,18 @@ var MonitorNotificationPreset;
|
|
|
54
54
|
MonitorNotificationPreset["HIDE_HANDLES"] = "hide_handles";
|
|
55
55
|
MonitorNotificationPreset["HIDE_ALL"] = "hide_all";
|
|
56
56
|
})(MonitorNotificationPreset || (exports.MonitorNotificationPreset = MonitorNotificationPreset = {}));
|
|
57
|
+
/**
|
|
58
|
+
* Options for onMissingData supported by Datadog.
|
|
59
|
+
*
|
|
60
|
+
* @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json
|
|
61
|
+
*/
|
|
62
|
+
var MonitorOnMissingData;
|
|
63
|
+
(function (MonitorOnMissingData) {
|
|
64
|
+
MonitorOnMissingData["DEFAULT"] = "default";
|
|
65
|
+
MonitorOnMissingData["SHOW_NO_DATA"] = "show_no_data";
|
|
66
|
+
MonitorOnMissingData["SHOW_AND_NOTIFY_NO_DATA"] = "show_and_notify_no_data";
|
|
67
|
+
MonitorOnMissingData["RESOLVE"] = "resolve";
|
|
68
|
+
})(MonitorOnMissingData || (exports.MonitorOnMissingData = MonitorOnMissingData = {}));
|
|
57
69
|
/**
|
|
58
70
|
* Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.
|
|
59
71
|
*
|
|
@@ -125,17 +137,21 @@ DatadogMonitor.DEFAULT_PRIORITY = 4;
|
|
|
125
137
|
function mapMonitorOptions(source) {
|
|
126
138
|
return {
|
|
127
139
|
EnableLogsSample: source?.enableLogsSample,
|
|
140
|
+
EnableSamples: source?.enableSamples,
|
|
128
141
|
EscalationMessage: source?.escalationMessage,
|
|
129
142
|
EvaluationDelay: source?.evaluationDelay,
|
|
143
|
+
GroupRetentionDuration: source?.groupRetentionDuration,
|
|
130
144
|
IncludeTags: source?.includeTags ?? true,
|
|
131
145
|
Locked: source?.locked,
|
|
132
146
|
MinLocationFailed: source?.minLocationFailed,
|
|
133
147
|
NewHostDelay: source?.newHostDelay,
|
|
134
148
|
NoDataTimeframe: source?.noDataTimeframe,
|
|
135
149
|
NotifyAudit: source?.notifyAudit,
|
|
150
|
+
NotifyBy: source?.notifyBy,
|
|
136
151
|
NotifyNoData: source?.notifyNoData ?? false,
|
|
137
152
|
RenotifyInterval: source?.renotifyInterval,
|
|
138
153
|
RequireFullWindow: source?.requireFullWindow ?? false,
|
|
154
|
+
SchedulingOptions: mapSchedulingOptionsProperties(source?.schedulingOptions),
|
|
139
155
|
SyntheticsCheckID: source?.syntheticsCheckID,
|
|
140
156
|
Thresholds: mapThresholdsProperties(source?.thresholds),
|
|
141
157
|
ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),
|
|
@@ -146,9 +162,22 @@ function mapMonitorOptions(source) {
|
|
|
146
162
|
MinFailureDuration: source?.minFailureDuration,
|
|
147
163
|
NewGroupDelay: source?.newGroupDelay,
|
|
148
164
|
Variables: source?.variables,
|
|
165
|
+
OnMissingData: source?.onMissingData,
|
|
149
166
|
};
|
|
150
167
|
}
|
|
151
168
|
;
|
|
169
|
+
function mapSchedulingOptionsProperties(source) {
|
|
170
|
+
return source ? {
|
|
171
|
+
EvaluationWindow: mapSchedulingOptionsEvaluationWindowProperties(source.evaluationWindow),
|
|
172
|
+
} : undefined;
|
|
173
|
+
}
|
|
174
|
+
function mapSchedulingOptionsEvaluationWindowProperties(source) {
|
|
175
|
+
return source ? {
|
|
176
|
+
DayStarts: source.dayStarts,
|
|
177
|
+
MonthStarts: source.monthStarts,
|
|
178
|
+
HourStarts: source.hourStarts,
|
|
179
|
+
} : undefined;
|
|
180
|
+
}
|
|
152
181
|
function mapThresholdsProperties(source) {
|
|
153
182
|
return source ? {
|
|
154
183
|
Critical: source.critical,
|
|
@@ -164,4 +193,4 @@ function mapThresholdWindowsProperties(source) {
|
|
|
164
193
|
RecoveryWindow: source.recoveryWindow,
|
|
165
194
|
} : undefined;
|
|
166
195
|
}
|
|
167
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-monitor.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Well known monitor types supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/types/\n */\nexport enum DatadogMonitorQueryAlertType {\n  AUDIT_ALERT = 'audit alert',\n  COMPOSITE = 'composite',\n  EVENT_ALERT = 'event alert',\n  EVENT_V_2_ALERT = 'event-v2 alert',\n  LOG_ALERT = 'log alert',\n  METRIC_ALERT = 'metric alert',\n  PROCESS_ALERT = 'process alert',\n  QUERY_ALERT = 'query alert',\n  SERVICE_CHECK = 'service check',\n  SYNTHETICS_ALERT = 'synthetics alert',\n  TRACE_ANALYTICS_ALERT = 'trace-analytics alert',\n  SLO_ALERT = 'slo alert',\n  RUM_ALERT = 'rum alert',\n  CI_PIPELINES_ALERT = 'ci-pipelines alert',\n  ERROR_TRACKING_ALERT = 'error-tracking alert',\n  CI_TESTS_ALERT = 'ci-tests alert',\n}\n\n/**\n * Properties of {@link DatadogMonitor}\n */\nexport interface DatadogMonitorProps {\n\n  /**\n   * A name suffix to be appended to the monitors name.\n   *\n   * The monitor name is concatenated form `<TeamName> <serviceName property> <name property>`\n   */\n  readonly name: string;\n\n  /**\n   * The name of the service to which the monitor belongs.\n   *\n   * Used to generate the monitor name as well a apply the `service` tag.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The monitors type\n   *\n   * @see https://docs.datadoghq.com/monitors/types/\n   */\n  readonly monitorType: DatadogMonitorQueryAlertType;\n\n  /**\n   * The monitors search query\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#define-the-search-query\n   */\n  readonly query: string;\n\n  /**\n   * The message pattern for the monitor\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#message\n   */\n  readonly message: string;\n\n  /**\n   * To explicitly disable notifications use {@link NoNotification}.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   *\n   * @see https://docs.datadoghq.com/monitors/notify\n   */\n  readonly notification?: INotification;\n\n  /**\n   * The alert priority of the monitor\n   *\n   * @defaultValue 4\n   */\n  readonly priority?: number;\n\n  /**\n   * Specific options to override the default monitor options.\n   */\n  readonly optionOverrides?: CfnDatadogMonitorOptions;\n\n  /**\n   * Tags to be appended to the monitor in addition to the RIO default tags\n   */\n  readonly extraTags?: string[];\n}\n\n/**\n * Well known renotification settings supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/notify/#renotify\n */\nexport enum RenotifyStatuses {\n  ALERT = 'alert',\n  NO_DATA = 'no data',\n  WARN = 'warn'\n}\n\n/**\n * Well known notification presets supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorNotificationPreset {\n  SHOW_ALL = 'show_all',\n  HIDE_QUERY = 'hide_query',\n  HIDE_HANDLES = 'hide_handles',\n  HIDE_ALL = 'hide_all',\n}\n\n/**\n * Options to override for Datadog monitors in case more specific settings are required.\n *\n * {@link https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json}\n */\nexport interface CfnDatadogMonitorOptions {\n\n  /**\n   * Whether or not to include a sample of the logs\n   */\n  readonly enableLogsSample?: boolean;\n\n  /**\n   * Message to include with a re-notification when renotify_interval is set\n   */\n  readonly escalationMessage?: string;\n\n  /**\n   * Time in seconds to delay evaluation\n   *\n   */\n  readonly evaluationDelay?: number;\n\n  /**\n   * Whether or not to include triggering tags into notification title'\n   *\n   * @defaultValue true\n   */\n  readonly includeTags?: boolean;\n\n  /**\n   * Whether or not changes to this monitor should be restricted to the creator or admins\n   */\n  readonly locked?: boolean;\n\n  /**\n   * Number of locations allowed to fail before triggering alert\n   */\n  readonly minLocationFailed?: number;\n\n  /**\n   * Time in seconds to allow a host to start reporting data before starting the evaluation of monitor results\n   */\n  readonly newHostDelay?: number;\n\n  /**\n   * Number of minutes data stopped reporting before notifying\n   */\n  readonly noDataTimeframe?: number;\n\n  /**\n   * Whether or not to notify tagged users when changes are made to the monitor\n   */\n  readonly notifyAudit?: boolean;\n\n  /**\n   * Whether or not to notify when data stops reporting\n   *\n   * @defaultValue false\n   */\n  readonly notifyNoData?: boolean;\n\n  /**\n   * Number of minutes after the last notification before the monitor re-notifies on the current status\n   */\n  readonly renotifyInterval?: number;\n\n  /**\n   * Whether or not the monitor requires a full window of data before it is evaluated\n   *\n   * @defaultValue false\n   */\n  readonly requireFullWindow?: boolean;\n\n  /**\n   * ID of the corresponding synthetics check\n   */\n  readonly syntheticsCheckID?: number;\n\n  readonly thresholds?: CfnDatadogMonitorThresholds;\n\n  readonly thresholdWindows?: CfnDatadogMonitorThresholdWindows;\n\n  /**\n   * Number of hours of the monitor not reporting data before it automatically resolves\n   */\n  readonly timeoutH?: number;\n\n  /**\n   * The number of times re-notification messages should be sent on the current status at the provided re-notification interval.\n   */\n  readonly renotifyOccurrences?: number;\n\n  /**\n   * The types of monitor statuses for which re-notification messages are sent.\n   */\n  readonly renotifyStatuses?: RenotifyStatuses[];\n\n  /**\n   * How long the test should be in failure before alerting (integer, number of seconds, max 7200).\n   */\n  readonly minFailureDuration?: number;\n\n  /**\n   * Controls which information should be added/lett out from the notification.\n   *\n   * @defaultValue {@link MonitorNotificationPreset.SHOW_ALL}\n   */\n  readonly monitorNotificationPresetName?: MonitorNotificationPreset;\n\n  /**\n   * Time (in seconds) to skip evaluations for new groups. For example, this option can be used to skip evaluations for new hosts while they initialize. Must be a non negative integer.\n   */\n  readonly newGroupDelay?: number;\n\n  /**\n   * List of requests that can be used in the monitor query.\n   */\n  readonly variables?: object[];\n}\n\nexport interface CfnDatadogMonitorThresholds {\n\n  /**\n   *Threshold value for triggering an alert\n   */\n  readonly critical?: number;\n\n  /**\n   *Threshold value for recovering from an alert state\n   */\n  readonly criticalRecovery?: number;\n\n  /**\n   *Threshold value for recovering from an alert state\n   */\n  readonly ok?: number;\n\n  /**\n   *Threshold value for triggering a warning\n   */\n  readonly warning?: number;\n\n  /**\n   * Threshold value for recovering from a warning state\n   */\n  readonly warningRecovery?: number;\n}\n\nexport interface CfnDatadogMonitorThresholdWindows {\n\n  /**\n   * How long a metric must be anomalous before triggering an alert\n   */\n  readonly triggerWindow?: string;\n\n  /**\n   * How long an anomalous metric must be normal before recovering from an alert state\n   */\n  readonly recoveryWindow?: string;\n}\n\n/**\n * Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.\n *\n * To use this the Datadog resources have to be {@link https://docs.datadoghq.com/integrations/guide/amazon_cloudformation/\n * |enabled in the CloudFormation registry} of the corresponding AWS account. Usually this is done\n * automatically by the Datadog Integrations (account module AND ServiceCatalog) provided by CLAID.\n */\nexport class DatadogMonitor extends Construct {\n  /**\n   * Default priority of a monitor\n   */\n  static readonly DEFAULT_PRIORITY = 4;\n\n  readonly name: string;\n  readonly priority: number;\n\n  private readonly monitor: cdk.CfnResource;\n\n  constructor(scope: Construct, id: string, props: DatadogMonitorProps) {\n    super(scope, id);\n    this.priority = props.priority ?? DatadogMonitor.DEFAULT_PRIORITY;\n    this.name = props.name;\n\n    const teamName = RioLandingZone.getTeamNameParameter(this);\n    const teamIdentifier = RioLandingZone.getTeamIdentifierParameter(this);\n    const accountName = RioLandingZone.getAccountNameParameter(this);\n\n    const notification = props.notification ? props.notification : new DefaultSlackNotification();\n\n    const isAwsMetrikMonitor = (props.monitorType === DatadogMonitorQueryAlertType.METRIC_ALERT || props.monitorType === DatadogMonitorQueryAlertType.QUERY_ALERT) && props.query.indexOf('aws.') > -1;\n    const optionOverrides = {\n      ...props.optionOverrides,\n    };\n\n    if (isAwsMetrikMonitor && optionOverrides.evaluationDelay === undefined) {\n      optionOverrides.evaluationDelay = 900;\n      const annotations = cdk.Annotations.of(cdk.Stack.of(this));\n      annotations.addWarningV2(\n        `@rio-cloud/cdk-v2-constructs/datadogv2/DatadogMonitor/${id}/CloudMetricEvaluationDelay`,\n        '\\n ❌ Your monitor is alerting on Cloud Metrics but you haven\\'t set an \\'optionOverrides.evaluationDelay\\'.\\n ✅ It\\'s automatically set to 15 minutes, but please provide a suitable value on your own.\\n',\n      );\n    }\n\n    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    this.monitor = new cdk.CfnResource(this, 'Monitor', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Type: props.monitorType,\n        Query: props.query,\n        Name: `${teamName.stringValue} ${props.serviceName} ${props.name}`,\n        Message: this.concatenateMessage({ message: props.message, notification }),\n        Priority: this.priority,\n        Options: mapMonitorOptions(optionOverrides),\n        Tags: [\n          ...(props.extraTags ?? []),\n          `account_id:${cdk.Stack.of(this).account}`,\n          `account_name:${accountName.stringValue}`,\n          `service:${props.serviceName}`,\n          `team:${teamName.stringValue}`,\n          `team_identifier:${teamIdentifier.stringValue}`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Obtain the monitor_id as used in Datadog\n   * See https://docs.datadoghq.com/api/latest/monitors/#get-a-monitors-details\n   *\n   * This allows referencing this monitor in other constructs/resources (e.g. SLOs)\n   */\n  get monitorId() {\n    // return Ref as it returns the Id as string instead of the GetAtt(Id) wihch returns the id as number\n    // https://my-rio.slack.com/archives/C034WAG3QUA/p1708419871398949\n    return cdk.Fn.ref(this.monitor.logicalId);\n  }\n\n  private concatenateMessage(props: {message: string; notification: INotification}) {\n    return `${props.message}\\n\\n${props.notification.generateMessageAnnotation(this)}`;\n  }\n\n}\n\nfunction mapMonitorOptions(source: CfnDatadogMonitorOptions | undefined) {\n  return {\n    EnableLogsSample: source?.enableLogsSample,\n    EscalationMessage: source?.escalationMessage,\n    EvaluationDelay: source?.evaluationDelay,\n    IncludeTags: source?.includeTags ?? true,\n    Locked: source?.locked,\n    MinLocationFailed: source?.minLocationFailed,\n    NewHostDelay: source?.newHostDelay,\n    NoDataTimeframe: source?.noDataTimeframe,\n    NotifyAudit: source?.notifyAudit,\n    NotifyNoData: source?.notifyNoData ?? false,\n    RenotifyInterval: source?.renotifyInterval,\n    RequireFullWindow: source?.requireFullWindow ?? false,\n    SyntheticsCheckID: source?.syntheticsCheckID,\n    Thresholds: mapThresholdsProperties(source?.thresholds),\n    ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),\n    MonitorNotificationPresetName: source?.monitorNotificationPresetName,\n    TimeoutH: source?.timeoutH,\n    RenotifyOccurrences: source?.renotifyOccurrences,\n    RenotifyStatuses: source?.renotifyStatuses,\n    MinFailureDuration: source?.minFailureDuration,\n    NewGroupDelay: source?.newGroupDelay,\n    Variables: source?.variables,\n  };\n};\n\n\nfunction mapThresholdsProperties(source: CfnDatadogMonitorThresholds | undefined) {\n  return source ? {\n    Critical: source.critical,\n    CriticalRecovery: source.criticalRecovery,\n    OK: source.ok,\n    Warning: source.warning,\n    WarningRecovery: source.warningRecovery,\n  } : undefined;\n}\n\nfunction mapThresholdWindowsProperties(source: CfnDatadogMonitorThresholdWindows | undefined) {\n  return source ? {\n    TriggerWindow: source.triggerWindow,\n    RecoveryWindow: source.recoveryWindow,\n  } : undefined;\n}\n"]}
|
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-monitor.js","sourceRoot":"","sources":["../../src/datadogv2/datadog-monitor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\nimport { RioLandingZone } from '../rio-landing-zone';\n\n/**\n * Well known monitor types supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/types/\n */\nexport enum DatadogMonitorQueryAlertType {\n  AUDIT_ALERT = 'audit alert',\n  COMPOSITE = 'composite',\n  EVENT_ALERT = 'event alert',\n  EVENT_V_2_ALERT = 'event-v2 alert',\n  LOG_ALERT = 'log alert',\n  METRIC_ALERT = 'metric alert',\n  PROCESS_ALERT = 'process alert',\n  QUERY_ALERT = 'query alert',\n  SERVICE_CHECK = 'service check',\n  SYNTHETICS_ALERT = 'synthetics alert',\n  TRACE_ANALYTICS_ALERT = 'trace-analytics alert',\n  SLO_ALERT = 'slo alert',\n  RUM_ALERT = 'rum alert',\n  CI_PIPELINES_ALERT = 'ci-pipelines alert',\n  ERROR_TRACKING_ALERT = 'error-tracking alert',\n  CI_TESTS_ALERT = 'ci-tests alert',\n}\n\n/**\n * Properties of {@link DatadogMonitor}\n */\nexport interface DatadogMonitorProps {\n\n  /**\n   * A name suffix to be appended to the monitors name.\n   *\n   * The monitor name is concatenated form `<TeamName> <serviceName property> <name property>`\n   */\n  readonly name: string;\n\n  /**\n   * The name of the service to which the monitor belongs.\n   *\n   * Used to generate the monitor name as well a apply the `service` tag.\n   */\n  readonly serviceName: string;\n\n  /**\n   * The monitors type\n   *\n   * @see https://docs.datadoghq.com/monitors/types/\n   */\n  readonly monitorType: DatadogMonitorQueryAlertType;\n\n  /**\n   * The monitors search query\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#define-the-search-query\n   */\n  readonly query: string;\n\n  /**\n   * The message pattern for the monitor\n   *\n   * @see https://docs.datadoghq.com/monitors/configuration/#message\n   */\n  readonly message: string;\n\n  /**\n   * To explicitly disable notifications use {@link NoNotification}.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   *\n   * @see https://docs.datadoghq.com/monitors/notify\n   */\n  readonly notification?: INotification;\n\n  /**\n   * The alert priority of the monitor\n   *\n   * @defaultValue 4\n   */\n  readonly priority?: number;\n\n  /**\n   * Specific options to override the default monitor options.\n   */\n  readonly optionOverrides?: CfnDatadogMonitorOptions;\n\n  /**\n   * Tags to be appended to the monitor in addition to the RIO default tags\n   */\n  readonly extraTags?: string[];\n}\n\n/**\n * Well known renotification settings supported by Datadog.\n *\n * @see https://docs.datadoghq.com/monitors/notify/#renotify\n */\nexport enum RenotifyStatuses {\n  ALERT = 'alert',\n  NO_DATA = 'no data',\n  WARN = 'warn'\n}\n\n/**\n * Well known notification presets supported by Datadog.\n *\n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorNotificationPreset {\n  SHOW_ALL = 'show_all',\n  HIDE_QUERY = 'hide_query',\n  HIDE_HANDLES = 'hide_handles',\n  HIDE_ALL = 'hide_all',\n}\n\n/**\n * Options for onMissingData supported by Datadog.\n * \n * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n */\nexport enum MonitorOnMissingData {\n  DEFAULT = 'default',\n  SHOW_NO_DATA = 'show_no_data',\n  SHOW_AND_NOTIFY_NO_DATA = 'show_and_notify_no_data',\n  RESOLVE = 'resolve',\n}\n\n/**\n * Options to override for Datadog monitors in case more specific settings are required.\n *\n * {@link https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json}\n */\nexport interface CfnDatadogMonitorOptions {\n\n  /**\n   * Whether or not to include a sample of the logs\n   */\n  readonly enableLogsSample?: boolean;\n\n  /**\n   * Whether or not to send a list of samples when the monitor triggers.\n   * \n   * This is only used by CI Test and Pipeline monitors.\n   */\n  readonly enableSamples?: boolean;\n\n  /**\n   * Message to include with a re-notification when renotify_interval is set\n   */\n  readonly escalationMessage?: string;\n\n  /**\n   * Time in seconds to delay evaluation\n   *\n   */\n  readonly evaluationDelay?: number;\n\n  /**\n   * The time span after which groups with missing data are dropped from the monitor state.\n   * \n   * The minimum value is one hour, and the maximum value is 72 hours.\n   * Example values are: \"60m\", \"1h\", and \"2d\".\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly groupRetentionDuration?: string;\n\n  /**\n   * Whether or not to include triggering tags into notification title'\n   *\n   * @defaultValue true\n   */\n  readonly includeTags?: boolean;\n\n  /**\n   * Whether or not changes to this monitor should be restricted to the creator or admins\n   */\n  readonly locked?: boolean;\n\n  /**\n   * Number of locations allowed to fail before triggering alert\n   */\n  readonly minLocationFailed?: number;\n\n  /**\n   * Time in seconds to allow a host to start reporting data before starting the evaluation of monitor results\n   */\n  readonly newHostDelay?: number;\n\n  /**\n   * Number of minutes data stopped reporting before notifying\n   */\n  readonly noDataTimeframe?: number;\n\n  /**\n   * Whether or not to notify tagged users when changes are made to the monitor\n   */\n  readonly notifyAudit?: boolean;\n\n  /**\n   * Controls what granularity a monitor alerts on.\n   * \n   * Only available for monitors with groupings.\n   * 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\"]`.\n   * Tags mentioned in `notify_by` must be a subset of the grouping tags in the query.\n   * For example, a query grouped by `cluster` and `namespace` cannot notify on `region`.\n   * Setting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.\n   */\n  readonly notifyBy?: string[];\n\n  /**\n   * Whether or not to notify when data stops reporting\n   *\n   * @defaultValue false\n   */\n  readonly notifyNoData?: boolean;\n\n  /**\n   * Controls how groups or monitors are treated if an evaluation does not return any data points.\n   * \n   * The default option results in different behavior depending on the monitor query type.\n   * For monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.\n   * For monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.\n   * This option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.\n   */\n  readonly onMissingData?: MonitorOnMissingData;\n\n  /**\n   * Number of minutes after the last notification before the monitor re-notifies on the current status\n   */\n  readonly renotifyInterval?: number;\n\n  /**\n   * Whether or not the monitor requires a full window of data before it is evaluated\n   *\n   * @defaultValue false\n   */\n  readonly requireFullWindow?: boolean;\n\n  /**\n   * Configuration options for scheduling\n   */\n  readonly schedulingOptions?: MonitorSchedulingOptions;\n\n  /**\n   * ID of the corresponding synthetics check\n   */\n  readonly syntheticsCheckID?: number;\n\n  readonly thresholds?: CfnDatadogMonitorThresholds;\n\n  readonly thresholdWindows?: CfnDatadogMonitorThresholdWindows;\n\n  /**\n   * Number of hours of the monitor not reporting data before it automatically resolves\n   */\n  readonly timeoutH?: number;\n\n  /**\n   * The number of times re-notification messages should be sent on the current status at the provided re-notification interval.\n   */\n  readonly renotifyOccurrences?: number;\n\n  /**\n   * The types of monitor statuses for which re-notification messages are sent.\n   */\n  readonly renotifyStatuses?: RenotifyStatuses[];\n\n  /**\n   * How long the test should be in failure before alerting (integer, number of seconds, max 7200).\n   */\n  readonly minFailureDuration?: number;\n\n  /**\n   * Controls which information should be added/lett out from the notification.\n   *\n   * @defaultValue {@link MonitorNotificationPreset.SHOW_ALL}\n   */\n  readonly monitorNotificationPresetName?: MonitorNotificationPreset;\n\n  /**\n   * Time (in seconds) to skip evaluations for new groups. For example, this option can be used to skip evaluations for new hosts while they initialize. Must be a non negative integer.\n   */\n  readonly newGroupDelay?: number;\n\n  /**\n   * List of requests that can be used in the monitor query.\n   */\n  readonly variables?: object[];\n}\n\nexport interface CfnDatadogMonitorThresholds {\n\n  /**\n   * Threshold value for triggering an alert\n   */\n  readonly critical?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly criticalRecovery?: number;\n\n  /**\n   * Threshold value for recovering from an alert state\n   */\n  readonly ok?: number;\n\n  /**\n   * Threshold value for triggering a warning\n   */\n  readonly warning?: number;\n\n  /**\n   * Threshold value for recovering from a warning state\n   */\n  readonly warningRecovery?: number;\n}\n\nexport interface CfnDatadogMonitorThresholdWindows {\n\n  /**\n   * How long a metric must be anomalous before triggering an alert\n   */\n  readonly triggerWindow?: string;\n\n  /**\n   * How long an anomalous metric must be normal before recovering from an alert state\n   */\n  readonly recoveryWindow?: string;\n}\n\n/**\n * Configuration options for scheduling\n */\nexport interface MonitorSchedulingOptions {\n  readonly evaluationWindow?: MonitorSchedulingOptionsEvaluationWindow;\n}\n\n/**\n * Configuration options for the evaluation window.\n * \n * If `hour_starts` is set, no other fields may be set.\n * Otherwise, `day_starts` and `month_starts` must be set together.\n */\nexport interface MonitorSchedulingOptionsEvaluationWindow {\n\n  /**\n   * The time of the day at which a one day cumulative evaluation window starts.\n   * \n   * Must be defined in UTC time in `HH:mm` format.\n   */\n  readonly dayStarts?: string;\n\n  /**\n   * The day of the month at which a one month cumulative evaluation window starts\n   */\n  readonly monthStarts?: number;\n\n  /**\n   * The minute of the hour at which a one hour cumulative evaluation window starts\n   */\n  readonly hourStarts?: number;\n}\n\n/**\n * Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.\n *\n * To use this the Datadog resources have to be {@link https://docs.datadoghq.com/integrations/guide/amazon_cloudformation/\n * |enabled in the CloudFormation registry} of the corresponding AWS account. Usually this is done\n * automatically by the Datadog Integrations (account module AND ServiceCatalog) provided by CLAID.\n */\nexport class DatadogMonitor extends Construct {\n  /**\n   * Default priority of a monitor\n   */\n  static readonly DEFAULT_PRIORITY = 4;\n\n  readonly name: string;\n  readonly priority: number;\n\n  private readonly monitor: cdk.CfnResource;\n\n  constructor(scope: Construct, id: string, props: DatadogMonitorProps) {\n    super(scope, id);\n    this.priority = props.priority ?? DatadogMonitor.DEFAULT_PRIORITY;\n    this.name = props.name;\n\n    const teamName = RioLandingZone.getTeamNameParameter(this);\n    const teamIdentifier = RioLandingZone.getTeamIdentifierParameter(this);\n    const accountName = RioLandingZone.getAccountNameParameter(this);\n\n    const notification = props.notification ? props.notification : new DefaultSlackNotification();\n\n    const isAwsMetrikMonitor = (props.monitorType === DatadogMonitorQueryAlertType.METRIC_ALERT || props.monitorType === DatadogMonitorQueryAlertType.QUERY_ALERT) && props.query.indexOf('aws.') > -1;\n    const optionOverrides = {\n      ...props.optionOverrides,\n    };\n\n    if (isAwsMetrikMonitor && optionOverrides.evaluationDelay === undefined) {\n      optionOverrides.evaluationDelay = 900;\n      const annotations = cdk.Annotations.of(cdk.Stack.of(this));\n      annotations.addWarningV2(\n        `@rio-cloud/cdk-v2-constructs/datadogv2/DatadogMonitor/${id}/CloudMetricEvaluationDelay`,\n        '\\n ❌ Your monitor is alerting on Cloud Metrics but you haven\\'t set an \\'optionOverrides.evaluationDelay\\'.\\n ✅ It\\'s automatically set to 15 minutes, but please provide a suitable value on your own.\\n',\n      );\n    }\n\n    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    this.monitor = new cdk.CfnResource(this, 'Monitor', {\n      type: 'Datadog::Monitors::Monitor',\n      properties: {\n        Type: props.monitorType,\n        Query: props.query,\n        Name: `${teamName.stringValue} ${props.serviceName} ${props.name}`,\n        Message: this.concatenateMessage({ message: props.message, notification }),\n        Priority: this.priority,\n        Options: mapMonitorOptions(optionOverrides),\n        Tags: [\n          ...(props.extraTags ?? []),\n          `account_id:${cdk.Stack.of(this).account}`,\n          `account_name:${accountName.stringValue}`,\n          `service:${props.serviceName}`,\n          `team:${teamName.stringValue}`,\n          `team_identifier:${teamIdentifier.stringValue}`,\n        ],\n      },\n    });\n  }\n\n  /**\n   * Obtain the monitor_id as used in Datadog\n   * See https://docs.datadoghq.com/api/latest/monitors/#get-a-monitors-details\n   *\n   * This allows referencing this monitor in other constructs/resources (e.g. SLOs)\n   */\n  get monitorId() {\n    // return Ref as it returns the Id as string instead of the GetAtt(Id) wihch returns the id as number\n    // https://my-rio.slack.com/archives/C034WAG3QUA/p1708419871398949\n    return cdk.Fn.ref(this.monitor.logicalId);\n  }\n\n  private concatenateMessage(props: {message: string; notification: INotification}) {\n    return `${props.message}\\n\\n${props.notification.generateMessageAnnotation(this)}`;\n  }\n\n}\n\nfunction mapMonitorOptions(source: CfnDatadogMonitorOptions | undefined) {\n  return {\n    EnableLogsSample: source?.enableLogsSample,\n    EnableSamples: source?.enableSamples,\n    EscalationMessage: source?.escalationMessage,\n    EvaluationDelay: source?.evaluationDelay,\n    GroupRetentionDuration: source?.groupRetentionDuration,\n    IncludeTags: source?.includeTags ?? true,\n    Locked: source?.locked,\n    MinLocationFailed: source?.minLocationFailed,\n    NewHostDelay: source?.newHostDelay,\n    NoDataTimeframe: source?.noDataTimeframe,\n    NotifyAudit: source?.notifyAudit,\n    NotifyBy: source?.notifyBy,\n    NotifyNoData: source?.notifyNoData ?? false,\n    RenotifyInterval: source?.renotifyInterval,\n    RequireFullWindow: source?.requireFullWindow ?? false,\n    SchedulingOptions: mapSchedulingOptionsProperties(source?.schedulingOptions),\n    SyntheticsCheckID: source?.syntheticsCheckID,\n    Thresholds: mapThresholdsProperties(source?.thresholds),\n    ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),\n    MonitorNotificationPresetName: source?.monitorNotificationPresetName,\n    TimeoutH: source?.timeoutH,\n    RenotifyOccurrences: source?.renotifyOccurrences,\n    RenotifyStatuses: source?.renotifyStatuses,\n    MinFailureDuration: source?.minFailureDuration,\n    NewGroupDelay: source?.newGroupDelay,\n    Variables: source?.variables,\n    OnMissingData: source?.onMissingData,\n  };\n};\n\nfunction mapSchedulingOptionsProperties(source: MonitorSchedulingOptions | undefined) {\n  return source ? {\n    EvaluationWindow: mapSchedulingOptionsEvaluationWindowProperties(source.evaluationWindow),\n  } : undefined;\n}\n\nfunction mapSchedulingOptionsEvaluationWindowProperties(source: MonitorSchedulingOptionsEvaluationWindow | undefined) {\n  return source ? {\n    DayStarts: source.dayStarts,\n    MonthStarts: source.monthStarts,\n    HourStarts: source.hourStarts,\n  } : undefined;\n} \n\nfunction mapThresholdsProperties(source: CfnDatadogMonitorThresholds | undefined) {\n  return source ? {\n    Critical: source.critical,\n    CriticalRecovery: source.criticalRecovery,\n    OK: source.ok,\n    Warning: source.warning,\n    WarningRecovery: source.warningRecovery,\n  } : undefined;\n}\n\nfunction mapThresholdWindowsProperties(source: CfnDatadogMonitorThresholdWindows | undefined) {\n  return source ? {\n    TriggerWindow: source.triggerWindow,\n    RecoveryWindow: source.recoveryWindow,\n  } : undefined;\n}\n"]}
|