@rio-cloud/cdk-v2-constructs 4.33.5 → 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 CHANGED
@@ -11652,7 +11652,7 @@
11652
11652
  "kind": "interface",
11653
11653
  "locationInModule": {
11654
11654
  "filename": "src/datadogv2/datadog-monitor.ts",
11655
- "line": 125
11655
+ "line": 137
11656
11656
  },
11657
11657
  "name": "CfnDatadogMonitorOptions",
11658
11658
  "namespace": "datadogv2",
@@ -11666,7 +11666,7 @@
11666
11666
  "immutable": true,
11667
11667
  "locationInModule": {
11668
11668
  "filename": "src/datadogv2/datadog-monitor.ts",
11669
- "line": 130
11669
+ "line": 142
11670
11670
  },
11671
11671
  "name": "enableLogsSample",
11672
11672
  "optional": true,
@@ -11674,6 +11674,24 @@
11674
11674
  "primitive": "boolean"
11675
11675
  }
11676
11676
  },
11677
+ {
11678
+ "abstract": true,
11679
+ "docs": {
11680
+ "remarks": "This is only used by CI Test and Pipeline monitors.",
11681
+ "stability": "stable",
11682
+ "summary": "Whether or not to send a list of samples when the monitor triggers."
11683
+ },
11684
+ "immutable": true,
11685
+ "locationInModule": {
11686
+ "filename": "src/datadogv2/datadog-monitor.ts",
11687
+ "line": 149
11688
+ },
11689
+ "name": "enableSamples",
11690
+ "optional": true,
11691
+ "type": {
11692
+ "primitive": "boolean"
11693
+ }
11694
+ },
11677
11695
  {
11678
11696
  "abstract": true,
11679
11697
  "docs": {
@@ -11683,7 +11701,7 @@
11683
11701
  "immutable": true,
11684
11702
  "locationInModule": {
11685
11703
  "filename": "src/datadogv2/datadog-monitor.ts",
11686
- "line": 135
11704
+ "line": 154
11687
11705
  },
11688
11706
  "name": "escalationMessage",
11689
11707
  "optional": true,
@@ -11700,7 +11718,7 @@
11700
11718
  "immutable": true,
11701
11719
  "locationInModule": {
11702
11720
  "filename": "src/datadogv2/datadog-monitor.ts",
11703
- "line": 141
11721
+ "line": 160
11704
11722
  },
11705
11723
  "name": "evaluationDelay",
11706
11724
  "optional": true,
@@ -11708,6 +11726,24 @@
11708
11726
  "primitive": "number"
11709
11727
  }
11710
11728
  },
11729
+ {
11730
+ "abstract": true,
11731
+ "docs": {
11732
+ "remarks": "The minimum value is one hour, and the maximum value is 72 hours.\nExample values are: \"60m\", \"1h\", and \"2d\".\nThis option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.",
11733
+ "stability": "stable",
11734
+ "summary": "The time span after which groups with missing data are dropped from the monitor state."
11735
+ },
11736
+ "immutable": true,
11737
+ "locationInModule": {
11738
+ "filename": "src/datadogv2/datadog-monitor.ts",
11739
+ "line": 169
11740
+ },
11741
+ "name": "groupRetentionDuration",
11742
+ "optional": true,
11743
+ "type": {
11744
+ "primitive": "string"
11745
+ }
11746
+ },
11711
11747
  {
11712
11748
  "abstract": true,
11713
11749
  "docs": {
@@ -11718,7 +11754,7 @@
11718
11754
  "immutable": true,
11719
11755
  "locationInModule": {
11720
11756
  "filename": "src/datadogv2/datadog-monitor.ts",
11721
- "line": 148
11757
+ "line": 176
11722
11758
  },
11723
11759
  "name": "includeTags",
11724
11760
  "optional": true,
@@ -11735,7 +11771,7 @@
11735
11771
  "immutable": true,
11736
11772
  "locationInModule": {
11737
11773
  "filename": "src/datadogv2/datadog-monitor.ts",
11738
- "line": 153
11774
+ "line": 181
11739
11775
  },
11740
11776
  "name": "locked",
11741
11777
  "optional": true,
@@ -11752,7 +11788,7 @@
11752
11788
  "immutable": true,
11753
11789
  "locationInModule": {
11754
11790
  "filename": "src/datadogv2/datadog-monitor.ts",
11755
- "line": 221
11791
+ "line": 275
11756
11792
  },
11757
11793
  "name": "minFailureDuration",
11758
11794
  "optional": true,
@@ -11769,7 +11805,7 @@
11769
11805
  "immutable": true,
11770
11806
  "locationInModule": {
11771
11807
  "filename": "src/datadogv2/datadog-monitor.ts",
11772
- "line": 158
11808
+ "line": 186
11773
11809
  },
11774
11810
  "name": "minLocationFailed",
11775
11811
  "optional": true,
@@ -11787,7 +11823,7 @@
11787
11823
  "immutable": true,
11788
11824
  "locationInModule": {
11789
11825
  "filename": "src/datadogv2/datadog-monitor.ts",
11790
- "line": 228
11826
+ "line": 282
11791
11827
  },
11792
11828
  "name": "monitorNotificationPresetName",
11793
11829
  "optional": true,
@@ -11805,7 +11841,7 @@
11805
11841
  "immutable": true,
11806
11842
  "locationInModule": {
11807
11843
  "filename": "src/datadogv2/datadog-monitor.ts",
11808
- "line": 233
11844
+ "line": 287
11809
11845
  },
11810
11846
  "name": "newGroupDelay",
11811
11847
  "optional": true,
@@ -11822,7 +11858,7 @@
11822
11858
  "immutable": true,
11823
11859
  "locationInModule": {
11824
11860
  "filename": "src/datadogv2/datadog-monitor.ts",
11825
- "line": 163
11861
+ "line": 191
11826
11862
  },
11827
11863
  "name": "newHostDelay",
11828
11864
  "optional": true,
@@ -11839,7 +11875,7 @@
11839
11875
  "immutable": true,
11840
11876
  "locationInModule": {
11841
11877
  "filename": "src/datadogv2/datadog-monitor.ts",
11842
- "line": 168
11878
+ "line": 196
11843
11879
  },
11844
11880
  "name": "noDataTimeframe",
11845
11881
  "optional": true,
@@ -11856,7 +11892,7 @@
11856
11892
  "immutable": true,
11857
11893
  "locationInModule": {
11858
11894
  "filename": "src/datadogv2/datadog-monitor.ts",
11859
- "line": 173
11895
+ "line": 201
11860
11896
  },
11861
11897
  "name": "notifyAudit",
11862
11898
  "optional": true,
@@ -11864,6 +11900,29 @@
11864
11900
  "primitive": "boolean"
11865
11901
  }
11866
11902
  },
11903
+ {
11904
+ "abstract": true,
11905
+ "docs": {
11906
+ "remarks": "Only available for monitors with groupings.\nFor 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\"]`.\nTags mentioned in `notify_by` must be a subset of the grouping tags in the query.\nFor example, a query grouped by `cluster` and `namespace` cannot notify on `region`.\nSetting `notify_by` to `[*]` configures the monitor to notify as a simple-alert.",
11907
+ "stability": "stable",
11908
+ "summary": "Controls what granularity a monitor alerts on."
11909
+ },
11910
+ "immutable": true,
11911
+ "locationInModule": {
11912
+ "filename": "src/datadogv2/datadog-monitor.ts",
11913
+ "line": 212
11914
+ },
11915
+ "name": "notifyBy",
11916
+ "optional": true,
11917
+ "type": {
11918
+ "collection": {
11919
+ "elementtype": {
11920
+ "primitive": "string"
11921
+ },
11922
+ "kind": "array"
11923
+ }
11924
+ }
11925
+ },
11867
11926
  {
11868
11927
  "abstract": true,
11869
11928
  "docs": {
@@ -11874,7 +11933,7 @@
11874
11933
  "immutable": true,
11875
11934
  "locationInModule": {
11876
11935
  "filename": "src/datadogv2/datadog-monitor.ts",
11877
- "line": 180
11936
+ "line": 219
11878
11937
  },
11879
11938
  "name": "notifyNoData",
11880
11939
  "optional": true,
@@ -11882,6 +11941,24 @@
11882
11941
  "primitive": "boolean"
11883
11942
  }
11884
11943
  },
11944
+ {
11945
+ "abstract": true,
11946
+ "docs": {
11947
+ "remarks": "The default option results in different behavior depending on the monitor query type.\nFor monitors using Count queries, an empty monitor evaluation is treated as 0 and is compared to the threshold conditions.\nFor monitors using any query type other than Count, for example Gauge, Measure, or Rate, the monitor shows the last known status.\nThis option is only available for APM Trace Analytics, Audit Trail, CI, Error Tracking, Event, Logs, and RUM monitors.",
11948
+ "stability": "stable",
11949
+ "summary": "Controls how groups or monitors are treated if an evaluation does not return any data points."
11950
+ },
11951
+ "immutable": true,
11952
+ "locationInModule": {
11953
+ "filename": "src/datadogv2/datadog-monitor.ts",
11954
+ "line": 229
11955
+ },
11956
+ "name": "onMissingData",
11957
+ "optional": true,
11958
+ "type": {
11959
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData"
11960
+ }
11961
+ },
11885
11962
  {
11886
11963
  "abstract": true,
11887
11964
  "docs": {
@@ -11891,7 +11968,7 @@
11891
11968
  "immutable": true,
11892
11969
  "locationInModule": {
11893
11970
  "filename": "src/datadogv2/datadog-monitor.ts",
11894
- "line": 185
11971
+ "line": 234
11895
11972
  },
11896
11973
  "name": "renotifyInterval",
11897
11974
  "optional": true,
@@ -11908,7 +11985,7 @@
11908
11985
  "immutable": true,
11909
11986
  "locationInModule": {
11910
11987
  "filename": "src/datadogv2/datadog-monitor.ts",
11911
- "line": 211
11988
+ "line": 265
11912
11989
  },
11913
11990
  "name": "renotifyOccurrences",
11914
11991
  "optional": true,
@@ -11925,7 +12002,7 @@
11925
12002
  "immutable": true,
11926
12003
  "locationInModule": {
11927
12004
  "filename": "src/datadogv2/datadog-monitor.ts",
11928
- "line": 216
12005
+ "line": 270
11929
12006
  },
11930
12007
  "name": "renotifyStatuses",
11931
12008
  "optional": true,
@@ -11948,7 +12025,7 @@
11948
12025
  "immutable": true,
11949
12026
  "locationInModule": {
11950
12027
  "filename": "src/datadogv2/datadog-monitor.ts",
11951
- "line": 192
12028
+ "line": 241
11952
12029
  },
11953
12030
  "name": "requireFullWindow",
11954
12031
  "optional": true,
@@ -11956,6 +12033,23 @@
11956
12033
  "primitive": "boolean"
11957
12034
  }
11958
12035
  },
12036
+ {
12037
+ "abstract": true,
12038
+ "docs": {
12039
+ "stability": "stable",
12040
+ "summary": "Configuration options for scheduling."
12041
+ },
12042
+ "immutable": true,
12043
+ "locationInModule": {
12044
+ "filename": "src/datadogv2/datadog-monitor.ts",
12045
+ "line": 246
12046
+ },
12047
+ "name": "schedulingOptions",
12048
+ "optional": true,
12049
+ "type": {
12050
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions"
12051
+ }
12052
+ },
11959
12053
  {
11960
12054
  "abstract": true,
11961
12055
  "docs": {
@@ -11965,7 +12059,7 @@
11965
12059
  "immutable": true,
11966
12060
  "locationInModule": {
11967
12061
  "filename": "src/datadogv2/datadog-monitor.ts",
11968
- "line": 197
12062
+ "line": 251
11969
12063
  },
11970
12064
  "name": "syntheticsCheckID",
11971
12065
  "optional": true,
@@ -11981,7 +12075,7 @@
11981
12075
  "immutable": true,
11982
12076
  "locationInModule": {
11983
12077
  "filename": "src/datadogv2/datadog-monitor.ts",
11984
- "line": 199
12078
+ "line": 253
11985
12079
  },
11986
12080
  "name": "thresholds",
11987
12081
  "optional": true,
@@ -11997,7 +12091,7 @@
11997
12091
  "immutable": true,
11998
12092
  "locationInModule": {
11999
12093
  "filename": "src/datadogv2/datadog-monitor.ts",
12000
- "line": 201
12094
+ "line": 255
12001
12095
  },
12002
12096
  "name": "thresholdWindows",
12003
12097
  "optional": true,
@@ -12014,7 +12108,7 @@
12014
12108
  "immutable": true,
12015
12109
  "locationInModule": {
12016
12110
  "filename": "src/datadogv2/datadog-monitor.ts",
12017
- "line": 206
12111
+ "line": 260
12018
12112
  },
12019
12113
  "name": "timeoutH",
12020
12114
  "optional": true,
@@ -12031,7 +12125,7 @@
12031
12125
  "immutable": true,
12032
12126
  "locationInModule": {
12033
12127
  "filename": "src/datadogv2/datadog-monitor.ts",
12034
- "line": 238
12128
+ "line": 292
12035
12129
  },
12036
12130
  "name": "variables",
12037
12131
  "optional": true,
@@ -12057,7 +12151,7 @@
12057
12151
  "kind": "interface",
12058
12152
  "locationInModule": {
12059
12153
  "filename": "src/datadogv2/datadog-monitor.ts",
12060
- "line": 269
12154
+ "line": 323
12061
12155
  },
12062
12156
  "name": "CfnDatadogMonitorThresholdWindows",
12063
12157
  "namespace": "datadogv2",
@@ -12071,7 +12165,7 @@
12071
12165
  "immutable": true,
12072
12166
  "locationInModule": {
12073
12167
  "filename": "src/datadogv2/datadog-monitor.ts",
12074
- "line": 279
12168
+ "line": 333
12075
12169
  },
12076
12170
  "name": "recoveryWindow",
12077
12171
  "optional": true,
@@ -12088,7 +12182,7 @@
12088
12182
  "immutable": true,
12089
12183
  "locationInModule": {
12090
12184
  "filename": "src/datadogv2/datadog-monitor.ts",
12091
- "line": 274
12185
+ "line": 328
12092
12186
  },
12093
12187
  "name": "triggerWindow",
12094
12188
  "optional": true,
@@ -12109,7 +12203,7 @@
12109
12203
  "kind": "interface",
12110
12204
  "locationInModule": {
12111
12205
  "filename": "src/datadogv2/datadog-monitor.ts",
12112
- "line": 241
12206
+ "line": 295
12113
12207
  },
12114
12208
  "name": "CfnDatadogMonitorThresholds",
12115
12209
  "namespace": "datadogv2",
@@ -12123,7 +12217,7 @@
12123
12217
  "immutable": true,
12124
12218
  "locationInModule": {
12125
12219
  "filename": "src/datadogv2/datadog-monitor.ts",
12126
- "line": 246
12220
+ "line": 300
12127
12221
  },
12128
12222
  "name": "critical",
12129
12223
  "optional": true,
@@ -12140,7 +12234,7 @@
12140
12234
  "immutable": true,
12141
12235
  "locationInModule": {
12142
12236
  "filename": "src/datadogv2/datadog-monitor.ts",
12143
- "line": 251
12237
+ "line": 305
12144
12238
  },
12145
12239
  "name": "criticalRecovery",
12146
12240
  "optional": true,
@@ -12157,7 +12251,7 @@
12157
12251
  "immutable": true,
12158
12252
  "locationInModule": {
12159
12253
  "filename": "src/datadogv2/datadog-monitor.ts",
12160
- "line": 256
12254
+ "line": 310
12161
12255
  },
12162
12256
  "name": "ok",
12163
12257
  "optional": true,
@@ -12174,7 +12268,7 @@
12174
12268
  "immutable": true,
12175
12269
  "locationInModule": {
12176
12270
  "filename": "src/datadogv2/datadog-monitor.ts",
12177
- "line": 261
12271
+ "line": 315
12178
12272
  },
12179
12273
  "name": "warning",
12180
12274
  "optional": true,
@@ -12191,7 +12285,7 @@
12191
12285
  "immutable": true,
12192
12286
  "locationInModule": {
12193
12287
  "filename": "src/datadogv2/datadog-monitor.ts",
12194
- "line": 266
12288
+ "line": 320
12195
12289
  },
12196
12290
  "name": "warningRecovery",
12197
12291
  "optional": true,
@@ -12587,7 +12681,7 @@
12587
12681
  },
12588
12682
  "locationInModule": {
12589
12683
  "filename": "src/datadogv2/datadog-monitor.ts",
12590
- "line": 300
12684
+ "line": 387
12591
12685
  },
12592
12686
  "parameters": [
12593
12687
  {
@@ -12613,7 +12707,7 @@
12613
12707
  "kind": "class",
12614
12708
  "locationInModule": {
12615
12709
  "filename": "src/datadogv2/datadog-monitor.ts",
12616
- "line": 289
12710
+ "line": 376
12617
12711
  },
12618
12712
  "name": "DatadogMonitor",
12619
12713
  "namespace": "datadogv2",
@@ -12627,7 +12721,7 @@
12627
12721
  "immutable": true,
12628
12722
  "locationInModule": {
12629
12723
  "filename": "src/datadogv2/datadog-monitor.ts",
12630
- "line": 293
12724
+ "line": 380
12631
12725
  },
12632
12726
  "name": "DEFAULT_PRIORITY",
12633
12727
  "static": true,
@@ -12644,7 +12738,7 @@
12644
12738
  "immutable": true,
12645
12739
  "locationInModule": {
12646
12740
  "filename": "src/datadogv2/datadog-monitor.ts",
12647
- "line": 353
12741
+ "line": 440
12648
12742
  },
12649
12743
  "name": "monitorId",
12650
12744
  "type": {
@@ -12658,7 +12752,7 @@
12658
12752
  "immutable": true,
12659
12753
  "locationInModule": {
12660
12754
  "filename": "src/datadogv2/datadog-monitor.ts",
12661
- "line": 295
12755
+ "line": 382
12662
12756
  },
12663
12757
  "name": "name",
12664
12758
  "type": {
@@ -12672,7 +12766,7 @@
12672
12766
  "immutable": true,
12673
12767
  "locationInModule": {
12674
12768
  "filename": "src/datadogv2/datadog-monitor.ts",
12675
- "line": 296
12769
+ "line": 383
12676
12770
  },
12677
12771
  "name": "priority",
12678
12772
  "type": {
@@ -13122,6 +13216,156 @@
13122
13216
  "namespace": "datadogv2",
13123
13217
  "symbolId": "src/datadogv2/datadog-monitor:MonitorNotificationPreset"
13124
13218
  },
13219
+ "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData": {
13220
+ "assembly": "@rio-cloud/cdk-v2-constructs",
13221
+ "docs": {
13222
+ "see": "https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json",
13223
+ "stability": "stable",
13224
+ "summary": "Options for onMissingData supported by Datadog."
13225
+ },
13226
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorOnMissingData",
13227
+ "kind": "enum",
13228
+ "locationInModule": {
13229
+ "filename": "src/datadogv2/datadog-monitor.ts",
13230
+ "line": 125
13231
+ },
13232
+ "members": [
13233
+ {
13234
+ "docs": {
13235
+ "stability": "stable"
13236
+ },
13237
+ "name": "DEFAULT"
13238
+ },
13239
+ {
13240
+ "docs": {
13241
+ "stability": "stable"
13242
+ },
13243
+ "name": "SHOW_NO_DATA"
13244
+ },
13245
+ {
13246
+ "docs": {
13247
+ "stability": "stable"
13248
+ },
13249
+ "name": "SHOW_AND_NOTIFY_NO_DATA"
13250
+ },
13251
+ {
13252
+ "docs": {
13253
+ "stability": "stable"
13254
+ },
13255
+ "name": "RESOLVE"
13256
+ }
13257
+ ],
13258
+ "name": "MonitorOnMissingData",
13259
+ "namespace": "datadogv2",
13260
+ "symbolId": "src/datadogv2/datadog-monitor:MonitorOnMissingData"
13261
+ },
13262
+ "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions": {
13263
+ "assembly": "@rio-cloud/cdk-v2-constructs",
13264
+ "datatype": true,
13265
+ "docs": {
13266
+ "stability": "stable",
13267
+ "summary": "Configuration options for scheduling."
13268
+ },
13269
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptions",
13270
+ "kind": "interface",
13271
+ "locationInModule": {
13272
+ "filename": "src/datadogv2/datadog-monitor.ts",
13273
+ "line": 339
13274
+ },
13275
+ "name": "MonitorSchedulingOptions",
13276
+ "namespace": "datadogv2",
13277
+ "properties": [
13278
+ {
13279
+ "abstract": true,
13280
+ "docs": {
13281
+ "stability": "stable"
13282
+ },
13283
+ "immutable": true,
13284
+ "locationInModule": {
13285
+ "filename": "src/datadogv2/datadog-monitor.ts",
13286
+ "line": 340
13287
+ },
13288
+ "name": "evaluationWindow",
13289
+ "optional": true,
13290
+ "type": {
13291
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow"
13292
+ }
13293
+ }
13294
+ ],
13295
+ "symbolId": "src/datadogv2/datadog-monitor:MonitorSchedulingOptions"
13296
+ },
13297
+ "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow": {
13298
+ "assembly": "@rio-cloud/cdk-v2-constructs",
13299
+ "datatype": true,
13300
+ "docs": {
13301
+ "remarks": "If `hour_starts` is set, no other fields may be set.\nOtherwise, `day_starts` and `month_starts` must be set together.",
13302
+ "stability": "stable",
13303
+ "summary": "Configuration options for the evaluation window."
13304
+ },
13305
+ "fqn": "@rio-cloud/cdk-v2-constructs.datadogv2.MonitorSchedulingOptionsEvaluationWindow",
13306
+ "kind": "interface",
13307
+ "locationInModule": {
13308
+ "filename": "src/datadogv2/datadog-monitor.ts",
13309
+ "line": 349
13310
+ },
13311
+ "name": "MonitorSchedulingOptionsEvaluationWindow",
13312
+ "namespace": "datadogv2",
13313
+ "properties": [
13314
+ {
13315
+ "abstract": true,
13316
+ "docs": {
13317
+ "remarks": "Must be defined in UTC time in `HH:mm` format.",
13318
+ "stability": "stable",
13319
+ "summary": "The time of the day at which a one day cumulative evaluation window starts."
13320
+ },
13321
+ "immutable": true,
13322
+ "locationInModule": {
13323
+ "filename": "src/datadogv2/datadog-monitor.ts",
13324
+ "line": 356
13325
+ },
13326
+ "name": "dayStarts",
13327
+ "optional": true,
13328
+ "type": {
13329
+ "primitive": "string"
13330
+ }
13331
+ },
13332
+ {
13333
+ "abstract": true,
13334
+ "docs": {
13335
+ "stability": "stable",
13336
+ "summary": "The minute of the hour at which a one hour cumulative evaluation window starts."
13337
+ },
13338
+ "immutable": true,
13339
+ "locationInModule": {
13340
+ "filename": "src/datadogv2/datadog-monitor.ts",
13341
+ "line": 366
13342
+ },
13343
+ "name": "hourStarts",
13344
+ "optional": true,
13345
+ "type": {
13346
+ "primitive": "number"
13347
+ }
13348
+ },
13349
+ {
13350
+ "abstract": true,
13351
+ "docs": {
13352
+ "stability": "stable",
13353
+ "summary": "The day of the month at which a one month cumulative evaluation window starts."
13354
+ },
13355
+ "immutable": true,
13356
+ "locationInModule": {
13357
+ "filename": "src/datadogv2/datadog-monitor.ts",
13358
+ "line": 361
13359
+ },
13360
+ "name": "monthStarts",
13361
+ "optional": true,
13362
+ "type": {
13363
+ "primitive": "number"
13364
+ }
13365
+ }
13366
+ ],
13367
+ "symbolId": "src/datadogv2/datadog-monitor:MonitorSchedulingOptionsEvaluationWindow"
13368
+ },
13125
13369
  "@rio-cloud/cdk-v2-constructs.datadogv2.NoNotification": {
13126
13370
  "assembly": "@rio-cloud/cdk-v2-constructs",
13127
13371
  "docs": {
@@ -15842,5 +16086,5 @@
15842
16086
  }
15843
16087
  },
15844
16088
  "version": "0.0.0",
15845
- "fingerprint": "70LvXJLOYza4edFMgTMby4XdszbhVdPZbcsTqf4VOOE="
16089
+ "fingerprint": "Re4Rh5OaECAVHg+YwBb9vxvtbwPbyaHdmY3zpCyc++4="
15846
16090
  }
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,13 @@
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
+
5
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)
6
13
 
7
14
 
@@ -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"]}
package/package.json CHANGED
@@ -15,7 +15,7 @@
15
15
  ],
16
16
  "main": "lib/index.js",
17
17
  "license": "Apache-2.0",
18
- "version": "4.33.5",
18
+ "version": "4.34.0",
19
19
  "types": "lib/index.d.ts",
20
20
  "stability": "stable",
21
21
  "exports": {
package/version.json CHANGED
@@ -1,3 +1,3 @@
1
1
  {
2
- "version": "4.33.5"
2
+ "version": "4.34.0"
3
3
  }