@rio-cloud/cdk-v2-constructs 4.18.0 → 4.19.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/CHANGELOG.md CHANGED
@@ -2,6 +2,14 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ## [4.19.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.18.0&sourceBranch=refs%2Ftags%2Fv4.19.0) (2023-10-27)
6
+
7
+
8
+ ### Features
9
+
10
+ * :sparkles: Watcful override threshold interface has been updated. Because of refactoring of monitor ID's, the following monitors (if present) will be recreated. ([321fe7f](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/321fe7fe41adad55e2f22fcfe62384896fdc45f1))
11
+ * :sparkles: Watchful monitor thresholds can be updated using overrideAlarmThreshold function. Read the FAQ's for details. ([6257861](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/commits/6257861ad2a413afadd721f0a649e4c637cd72ad))
12
+
5
13
  ## [4.18.0](https://collaboration.msi.audi.com/stash/projects/RIODEV/repos/cdk-v2-constructs/compare/commits?targetBranch=refs%2Ftags%2Fv4.17.1&sourceBranch=refs%2Ftags%2Fv4.18.0) (2023-09-19)
6
14
 
7
15
 
package/README.md CHANGED
@@ -21,3 +21,19 @@ $ npm install --save @rio-cloud/cdk-v2-constructs
21
21
  * [How to contribut](./CONTRIBUTION.md)
22
22
  * [Changelog](./CHANGELOG.md)
23
23
  * [brief API desciption](./API.md)
24
+
25
+ ## FAQ's
26
+ - How can I udpate the thresholds of monitors created by watchful?
27
+
28
+ There is an `overrideAlarmThreshold` method which can be used to override the default watchful thresholds. Please make aure to use the method before the `watchscope` function.
29
+ Eg -
30
+ ```
31
+ ...
32
+ const dw = new Watchful(stack, 'Watchful', {});
33
+ dw.overrideAlarmThreshold({
34
+ monitoredResourceScope: lambdaA,
35
+ monitorType: MonitorType.ERRORS,
36
+ threshold: 5,
37
+ });
38
+ dw.watchScope(stack);
39
+ ```
@@ -90,6 +90,17 @@ export declare enum RenotifyStatuses {
90
90
  NO_DATA = "no data",
91
91
  WARN = "warn"
92
92
  }
93
+ /**
94
+ * Well known notification presets supported by Datadog.
95
+ *
96
+ * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json
97
+ */
98
+ export declare enum MonitorNotificationPreset {
99
+ SHOW_ALL = "show_all",
100
+ HIDE_QUERY = "hide_query",
101
+ HIDE_HANDLES = "hide_handles",
102
+ HIDE_ALL = "hide_all"
103
+ }
93
104
  /**
94
105
  * Options to override for Datadog monitors in case more specific settings are required.
95
106
  *
@@ -174,6 +185,12 @@ export interface CfnDatadogMonitorOptions {
174
185
  * How long the test should be in failure before alerting (integer, number of seconds, max 7200).
175
186
  */
176
187
  readonly minFailureDuration?: number;
188
+ /**
189
+ * Controls which information should be added/lett out from the notification.
190
+ *
191
+ * @defaultValue {@link MonitorNotificationPreset.SHOW_ALL}
192
+ */
193
+ readonly monitorNotificationPresetName?: MonitorNotificationPreset;
177
194
  /**
178
195
  * 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.
179
196
  */
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  var _a;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.DatadogMonitor = exports.RenotifyStatuses = exports.DatadogMonitorQueryAlertType = void 0;
4
+ exports.DatadogMonitor = 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");
@@ -42,6 +42,18 @@ var RenotifyStatuses;
42
42
  RenotifyStatuses["NO_DATA"] = "no data";
43
43
  RenotifyStatuses["WARN"] = "warn";
44
44
  })(RenotifyStatuses = exports.RenotifyStatuses || (exports.RenotifyStatuses = {}));
45
+ /**
46
+ * Well known notification presets supported by Datadog.
47
+ *
48
+ * @see https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json
49
+ */
50
+ var MonitorNotificationPreset;
51
+ (function (MonitorNotificationPreset) {
52
+ MonitorNotificationPreset["SHOW_ALL"] = "show_all";
53
+ MonitorNotificationPreset["HIDE_QUERY"] = "hide_query";
54
+ MonitorNotificationPreset["HIDE_HANDLES"] = "hide_handles";
55
+ MonitorNotificationPreset["HIDE_ALL"] = "hide_all";
56
+ })(MonitorNotificationPreset = exports.MonitorNotificationPreset || (exports.MonitorNotificationPreset = {}));
45
57
  /**
46
58
  * Wrapper around Datadog's CloudFormation `Datadog::Monitors::Monitor` with some RIO defaults applied.
47
59
  *
@@ -107,6 +119,7 @@ function mapMonitorOptions(source) {
107
119
  SyntheticsCheckID: source?.syntheticsCheckID,
108
120
  Thresholds: mapThresholdsProperties(source?.thresholds),
109
121
  ThresholdWindows: mapThresholdWindowsProperties(source?.thresholdWindows),
122
+ MonitorNotificationPresetName: source?.monitorNotificationPresetName,
110
123
  TimeoutH: source?.timeoutH,
111
124
  RenotifyOccurrences: source?.renotifyOccurrences,
112
125
  RenotifyStatuses: source?.renotifyStatuses,
@@ -131,4 +144,4 @@ function mapThresholdWindowsProperties(source) {
131
144
  RecoveryWindow: source.recoveryWindow,
132
145
  } : undefined;
133
146
  }
134
- //# 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 { RioLandingZone } from '../rio-landing-zone';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\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 * 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   * @defaultValue 900\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   * 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  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    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    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(props.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  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 ?? 900,\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    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}"]}
147
+ //# 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 { RioLandingZone } from '../rio-landing-zone';\nimport { DefaultSlackNotification, INotification } from './datadog-notification';\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   * @defaultValue 900\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  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    // https://github.com/DataDog/datadog-cloudformation-resources/blob/master/datadog-monitors-monitor-handler/datadog-monitors-monitor.json\n    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(props.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  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 ?? 900,\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"]}
@@ -7,6 +7,7 @@ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const cw = require("aws-cdk-lib/aws-cloudwatch");
8
8
  const elbv2 = require("aws-cdk-lib/aws-elasticloadbalancingv2");
9
9
  const constructs_1 = require("constructs");
10
+ const monitor_type_1 = require("./monitor-type");
10
11
  /**
11
12
  * A Construct which creates the following alarms for application load balancers:
12
13
  *
@@ -18,8 +19,8 @@ class WatchApplicationLoadBalancer extends constructs_1.Construct {
18
19
  super(scope, id);
19
20
  this.watchful = props.watchful;
20
21
  this.alb = props.alb;
21
- this.watchful.createAlarm(this, 'RejectedConnection', this.createRejectedConnectionMonitor(props.rejectedConnectionPerMinuteThreshold));
22
- this.watchful.createAlarm(this, 'HttpCode5xx', this.createHttpCode5xxMonitor(props.http5xxPerMinuteThreshold));
22
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.REJECTED_CONNECTION, this.createRejectedConnectionMonitor(props.rejectedConnectionPerMinuteThreshold));
23
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.HTTP_CODE5XX, this.createHttpCode5xxMonitor(props.http5xxPerMinuteThreshold));
23
24
  }
24
25
  createRejectedConnectionMonitor(rejectedConnectionPerMinuteThreshold = 0) {
25
26
  const rejectedMetric = this.alb.metricRejectedConnectionCount().with({ period: aws_cdk_lib_1.Duration.seconds(60) });
@@ -49,4 +50,4 @@ class WatchApplicationLoadBalancer extends constructs_1.Construct {
49
50
  exports.WatchApplicationLoadBalancer = WatchApplicationLoadBalancer;
50
51
  _a = JSII_RTTI_SYMBOL_1;
51
52
  WatchApplicationLoadBalancer[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchApplicationLoadBalancer", version: "0.0.0" };
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dhdGNoZnVsL2FsYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUF1QztBQUN2QyxpREFBaUQ7QUFDakQsZ0VBQWdFO0FBQ2hFLDJDQUF1QztBQXVDdkM7Ozs7O0dBS0c7QUFDSCxNQUFhLDRCQUE2QixTQUFRLHNCQUFTO0lBSXpELFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsS0FBd0M7UUFDaEYsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQyxRQUFRLENBQUM7UUFDL0IsSUFBSSxDQUFDLEdBQUcsR0FBRyxLQUFLLENBQUMsR0FBRyxDQUFDO1FBRXJCLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksRUFDNUIsb0JBQW9CLEVBQ3BCLElBQUksQ0FBQywrQkFBK0IsQ0FBQyxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FDakYsQ0FBQztRQUNGLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsSUFBSSxDQUFDLHdCQUF3QixDQUFDLEtBQUssQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDLENBQUM7SUFDakgsQ0FBQztJQUVPLCtCQUErQixDQUFDLG9DQUFvQyxHQUFHLENBQUM7UUFDOUUsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyw2QkFBNkIsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDdkcsT0FBTztZQUNMLE1BQU0sRUFBRSxjQUFjO1lBQ3RCLGdCQUFnQixFQUFFLFFBQVEsb0NBQW9DLGtDQUFrQztZQUNoRyxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsc0JBQXNCO1lBQ2hFLFNBQVMsRUFBRSxvQ0FBb0M7WUFDL0MsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLGFBQWE7WUFDbkQsaUJBQWlCLEVBQUUsQ0FBQztTQUNyQixDQUFDO0lBQ0osQ0FBQztJQUVPLHdCQUF3QixDQUFDLHlCQUF5QixHQUFHLENBQUM7UUFDNUQsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLEdBQUc7YUFDM0IsaUJBQWlCLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUM7YUFDbEQsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUMxQyxPQUFPO1lBQ0wsTUFBTSxFQUFFLGFBQWE7WUFDckIsZ0JBQWdCLEVBQUUsUUFBUSx5QkFBeUIsMEJBQTBCO1lBQzdFLGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDaEUsU0FBUyxFQUFFLHlCQUF5QjtZQUNwQyxnQkFBZ0IsRUFBRSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsYUFBYTtZQUNuRCxpQkFBaUIsRUFBRSxDQUFDO1NBQ3JCLENBQUM7SUFDSixDQUFDOztBQXpDSCxvRUEwQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEdXJhdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGN3IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcbmltcG9ydCAqIGFzIGVsYnYyIGZyb20gJ2F3cy1jZGstbGliL2F3cy1lbGFzdGljbG9hZGJhbGFuY2luZ3YyJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgTWV0cmljQWxhcm1Qcm9wcyB9IGZyb20gJy4vbWV0cmljLWFsYXJtJztcbmltcG9ydCB7IElXYXRjaGZ1bCB9IGZyb20gJy4vd2F0Y2hmdWwnO1xuXG4vKipcbiAqIE9wdGlvbnMgZm9yIGRlZmluaW5nIGFsYXJtcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIE51bWJlciBvZiBhbGxvd2VkIHJlamVjdGVkIGNvbm5lY3Rpb25zIHBlciBtaW51dGUuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDBcbiAgICAgKi9cbiAgcmVhZG9ubHkgcmVqZWN0ZWRDb25uZWN0aW9uUGVyTWludXRlVGhyZXNob2xkPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgICAqIE51bWJlciBvZiBhbGxvd2VkIEhUVFAgNXh4IHJlcXVlc3RzIHBlciBtaW51dGUuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDBcbiAgICAgKi9cbiAgcmVhZG9ubHkgaHR0cDV4eFBlck1pbnV0ZVRocmVzaG9sZD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIFdhdGNoQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMgZXh0ZW5kcyBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIFRoZSByZWZlcmVuY2UgdG8gSVdhdGNoZnVsIGNsYXNzLiBVc2VkIGludGVybmFsbHkuXG4gICAgICovXG4gIHJlYWRvbmx5IHdhdGNoZnVsOiBJV2F0Y2hmdWw7XG5cbiAgLyoqXG4gICAgICogVGhlIGFwcGxpY2F0aW9uIGxvYWQgYmFsYW5jZXIgdGhhdCBzaG91bGQgYmUgd2F0Y2hlZC5cbiAgICAgKiBbZGlzYWJsZS1hd3NsaW50OnJlZi12aWEtaW50ZXJmYWNlXVxuICAgICAqL1xuICByZWFkb25seSBhbGI6IGVsYnYyLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyO1xufVxuXG4vKipcbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgdGhlIGZvbGxvd2luZyBhbGFybXMgZm9yIGFwcGxpY2F0aW9uIGxvYWQgYmFsYW5jZXJzOlxuICpcbiAqIC0gcmVqZWN0ZWQgY29ubmVjdGlvbnNcbiAqIC0gaHR0cC1jb2RlIDV4eFxuICovXG5leHBvcnQgY2xhc3MgV2F0Y2hBcHBsaWNhdGlvbkxvYWRCYWxhbmNlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgd2F0Y2hmdWw6IElXYXRjaGZ1bDtcbiAgcHJpdmF0ZSByZWFkb25seSBhbGI6IGVsYnYyLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy53YXRjaGZ1bCA9IHByb3BzLndhdGNoZnVsO1xuICAgIHRoaXMuYWxiID0gcHJvcHMuYWxiO1xuXG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybSh0aGlzLFxuICAgICAgJ1JlamVjdGVkQ29ubmVjdGlvbicsXG4gICAgICB0aGlzLmNyZWF0ZVJlamVjdGVkQ29ubmVjdGlvbk1vbml0b3IocHJvcHMucmVqZWN0ZWRDb25uZWN0aW9uUGVyTWludXRlVGhyZXNob2xkKSxcbiAgICApO1xuICAgIHRoaXMud2F0Y2hmdWwuY3JlYXRlQWxhcm0odGhpcywgJ0h0dHBDb2RlNXh4JywgdGhpcy5jcmVhdGVIdHRwQ29kZTV4eE1vbml0b3IocHJvcHMuaHR0cDV4eFBlck1pbnV0ZVRocmVzaG9sZCkpO1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVSZWplY3RlZENvbm5lY3Rpb25Nb25pdG9yKHJlamVjdGVkQ29ubmVjdGlvblBlck1pbnV0ZVRocmVzaG9sZCA9IDApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCByZWplY3RlZE1ldHJpYyA9IHRoaXMuYWxiLm1ldHJpY1JlamVjdGVkQ29ubmVjdGlvbkNvdW50KCkud2l0aCh7IHBlcmlvZDogRHVyYXRpb24uc2Vjb25kcyg2MCkgfSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIG1ldHJpYzogcmVqZWN0ZWRNZXRyaWMsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgT3ZlciAke3JlamVjdGVkQ29ubmVjdGlvblBlck1pbnV0ZVRocmVzaG9sZH0gcmVqZWN0ZWQgY29ubmVjdGlvbnMgcGVyIG1pbnV0ZWAsXG4gICAgICBjb21wYXJpc29uT3BlcmF0b3I6IGN3LkNvbXBhcmlzb25PcGVyYXRvci5HUkVBVEVSX1RIQU5fVEhSRVNIT0xELFxuICAgICAgdGhyZXNob2xkOiByZWplY3RlZENvbm5lY3Rpb25QZXJNaW51dGVUaHJlc2hvbGQsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjdy5UcmVhdE1pc3NpbmdEYXRhLk5PVF9CUkVBQ0hJTkcsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICB9O1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVIdHRwQ29kZTV4eE1vbml0b3IoaHR0cDV4eFBlck1pbnV0ZVRocmVzaG9sZCA9IDApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCBodHRwNXh4TWV0cmljID0gdGhpcy5hbGJcbiAgICAgIC5tZXRyaWNIdHRwQ29kZUVsYihlbGJ2Mi5IdHRwQ29kZUVsYi5FTEJfNVhYX0NPVU5UKVxuICAgICAgLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLnNlY29uZHMoNjApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGh0dHA1eHhNZXRyaWMsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgT3ZlciAke2h0dHA1eHhQZXJNaW51dGVUaHJlc2hvbGR9IDV4eCByZXF1ZXN0cyBwZXIgbWludXRlYCxcbiAgICAgIGNvbXBhcmlzb25PcGVyYXRvcjogY3cuQ29tcGFyaXNvbk9wZXJhdG9yLkdSRUFURVJfVEhBTl9USFJFU0hPTEQsXG4gICAgICB0aHJlc2hvbGQ6IGh0dHA1eHhQZXJNaW51dGVUaHJlc2hvbGQsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjdy5UcmVhdE1pc3NpbmdEYXRhLk5PVF9CUkVBQ0hJTkcsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICB9O1xuICB9XG59XG4iXX0=
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxiLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dhdGNoZnVsL2FsYi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUF1QztBQUN2QyxpREFBaUQ7QUFDakQsZ0VBQWdFO0FBQ2hFLDJDQUF1QztBQUV2QyxpREFBNkM7QUFzQzdDOzs7OztHQUtHO0FBQ0gsTUFBYSw0QkFBNkIsU0FBUSxzQkFBUztJQUl6RCxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXdDO1FBQ2hGLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxHQUFHLEdBQUcsS0FBSyxDQUFDLEdBQUcsQ0FBQztRQUVyQixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQzVCLDBCQUFXLENBQUMsbUJBQW1CLEVBQy9CLElBQUksQ0FBQywrQkFBK0IsQ0FBQyxLQUFLLENBQUMsb0NBQW9DLENBQUMsQ0FDakYsQ0FBQztRQUNGLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUN2QixJQUFJLEVBQ0osMEJBQVcsQ0FBQyxZQUFZLEVBQ3hCLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FDL0QsQ0FBQztJQUNKLENBQUM7SUFFTywrQkFBK0IsQ0FBQyxvQ0FBb0MsR0FBRyxDQUFDO1FBQzlFLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsNkJBQTZCLEVBQUUsQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsc0JBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZHLE9BQU87WUFDTCxNQUFNLEVBQUUsY0FBYztZQUN0QixnQkFBZ0IsRUFBRSxRQUFRLG9DQUFvQyxrQ0FBa0M7WUFDaEcsa0JBQWtCLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLHNCQUFzQjtZQUNoRSxTQUFTLEVBQUUsb0NBQW9DO1lBQy9DLGdCQUFnQixFQUFFLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhO1lBQ25ELGlCQUFpQixFQUFFLENBQUM7U0FDckIsQ0FBQztJQUNKLENBQUM7SUFFTyx3QkFBd0IsQ0FBQyx5QkFBeUIsR0FBRyxDQUFDO1FBQzVELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxHQUFHO2FBQzNCLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDO2FBQ2xELElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDMUMsT0FBTztZQUNMLE1BQU0sRUFBRSxhQUFhO1lBQ3JCLGdCQUFnQixFQUFFLFFBQVEseUJBQXlCLDBCQUEwQjtZQUM3RSxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsc0JBQXNCO1lBQ2hFLFNBQVMsRUFBRSx5QkFBeUI7WUFDcEMsZ0JBQWdCLEVBQUUsRUFBRSxDQUFDLGdCQUFnQixDQUFDLGFBQWE7WUFDbkQsaUJBQWlCLEVBQUUsQ0FBQztTQUNyQixDQUFDO0lBQ0osQ0FBQzs7QUE3Q0gsb0VBOENDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBjdyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgKiBhcyBlbGJ2MiBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWxhc3RpY2xvYWRiYWxhbmNpbmd2Mic7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IE1ldHJpY0FsYXJtUHJvcHMgfSBmcm9tICcuL21ldHJpYy1hbGFybSc7XG5pbXBvcnQgeyBNb25pdG9yVHlwZSB9IGZyb20gJy4vbW9uaXRvci10eXBlJztcbmltcG9ydCB7IElXYXRjaGZ1bCB9IGZyb20gJy4vd2F0Y2hmdWwnO1xuXG4vKipcbiAqIE9wdGlvbnMgZm9yIGRlZmluaW5nIGFsYXJtcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIE51bWJlciBvZiBhbGxvd2VkIHJlamVjdGVkIGNvbm5lY3Rpb25zIHBlciBtaW51dGUuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDBcbiAgICAgKi9cbiAgcmVhZG9ubHkgcmVqZWN0ZWRDb25uZWN0aW9uUGVyTWludXRlVGhyZXNob2xkPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgICAqIE51bWJlciBvZiBhbGxvd2VkIEhUVFAgNXh4IHJlcXVlc3RzIHBlciBtaW51dGUuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDBcbiAgICAgKi9cbiAgcmVhZG9ubHkgaHR0cDV4eFBlck1pbnV0ZVRocmVzaG9sZD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIFdhdGNoQXBwbGljYXRpb25Mb2FkQmFsYW5jZXJcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMgZXh0ZW5kcyBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIFRoZSByZWZlcmVuY2UgdG8gSVdhdGNoZnVsIGNsYXNzLiBVc2VkIGludGVybmFsbHkuXG4gICAgICovXG4gIHJlYWRvbmx5IHdhdGNoZnVsOiBJV2F0Y2hmdWw7XG5cbiAgLyoqXG4gICAgICogVGhlIGFwcGxpY2F0aW9uIGxvYWQgYmFsYW5jZXIgdGhhdCBzaG91bGQgYmUgd2F0Y2hlZC5cbiAgICAgKiBbZGlzYWJsZS1hd3NsaW50OnJlZi12aWEtaW50ZXJmYWNlXVxuICAgICAqL1xuICByZWFkb25seSBhbGI6IGVsYnYyLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyO1xufVxuXG4vKipcbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgdGhlIGZvbGxvd2luZyBhbGFybXMgZm9yIGFwcGxpY2F0aW9uIGxvYWQgYmFsYW5jZXJzOlxuICpcbiAqIC0gcmVqZWN0ZWQgY29ubmVjdGlvbnNcbiAqIC0gaHR0cC1jb2RlIDV4eFxuICovXG5leHBvcnQgY2xhc3MgV2F0Y2hBcHBsaWNhdGlvbkxvYWRCYWxhbmNlciBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgd2F0Y2hmdWw6IElXYXRjaGZ1bDtcbiAgcHJpdmF0ZSByZWFkb25seSBhbGI6IGVsYnYyLkFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBXYXRjaEFwcGxpY2F0aW9uTG9hZEJhbGFuY2VyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy53YXRjaGZ1bCA9IHByb3BzLndhdGNoZnVsO1xuICAgIHRoaXMuYWxiID0gcHJvcHMuYWxiO1xuXG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybSh0aGlzLFxuICAgICAgTW9uaXRvclR5cGUuUkVKRUNURURfQ09OTkVDVElPTixcbiAgICAgIHRoaXMuY3JlYXRlUmVqZWN0ZWRDb25uZWN0aW9uTW9uaXRvcihwcm9wcy5yZWplY3RlZENvbm5lY3Rpb25QZXJNaW51dGVUaHJlc2hvbGQpLFxuICAgICk7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybShcbiAgICAgIHRoaXMsXG4gICAgICBNb25pdG9yVHlwZS5IVFRQX0NPREU1WFgsXG4gICAgICB0aGlzLmNyZWF0ZUh0dHBDb2RlNXh4TW9uaXRvcihwcm9wcy5odHRwNXh4UGVyTWludXRlVGhyZXNob2xkKSxcbiAgICApO1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVSZWplY3RlZENvbm5lY3Rpb25Nb25pdG9yKHJlamVjdGVkQ29ubmVjdGlvblBlck1pbnV0ZVRocmVzaG9sZCA9IDApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCByZWplY3RlZE1ldHJpYyA9IHRoaXMuYWxiLm1ldHJpY1JlamVjdGVkQ29ubmVjdGlvbkNvdW50KCkud2l0aCh7IHBlcmlvZDogRHVyYXRpb24uc2Vjb25kcyg2MCkgfSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIG1ldHJpYzogcmVqZWN0ZWRNZXRyaWMsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgT3ZlciAke3JlamVjdGVkQ29ubmVjdGlvblBlck1pbnV0ZVRocmVzaG9sZH0gcmVqZWN0ZWQgY29ubmVjdGlvbnMgcGVyIG1pbnV0ZWAsXG4gICAgICBjb21wYXJpc29uT3BlcmF0b3I6IGN3LkNvbXBhcmlzb25PcGVyYXRvci5HUkVBVEVSX1RIQU5fVEhSRVNIT0xELFxuICAgICAgdGhyZXNob2xkOiByZWplY3RlZENvbm5lY3Rpb25QZXJNaW51dGVUaHJlc2hvbGQsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjdy5UcmVhdE1pc3NpbmdEYXRhLk5PVF9CUkVBQ0hJTkcsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICB9O1xuICB9XG5cbiAgcHJpdmF0ZSBjcmVhdGVIdHRwQ29kZTV4eE1vbml0b3IoaHR0cDV4eFBlck1pbnV0ZVRocmVzaG9sZCA9IDApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCBodHRwNXh4TWV0cmljID0gdGhpcy5hbGJcbiAgICAgIC5tZXRyaWNIdHRwQ29kZUVsYihlbGJ2Mi5IdHRwQ29kZUVsYi5FTEJfNVhYX0NPVU5UKVxuICAgICAgLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLnNlY29uZHMoNjApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGh0dHA1eHhNZXRyaWMsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgT3ZlciAke2h0dHA1eHhQZXJNaW51dGVUaHJlc2hvbGR9IDV4eCByZXF1ZXN0cyBwZXIgbWludXRlYCxcbiAgICAgIGNvbXBhcmlzb25PcGVyYXRvcjogY3cuQ29tcGFyaXNvbk9wZXJhdG9yLkdSRUFURVJfVEhBTl9USFJFU0hPTEQsXG4gICAgICB0aHJlc2hvbGQ6IGh0dHA1eHhQZXJNaW51dGVUaHJlc2hvbGQsXG4gICAgICB0cmVhdE1pc3NpbmdEYXRhOiBjdy5UcmVhdE1pc3NpbmdEYXRhLk5PVF9CUkVBQ0hJTkcsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMSxcbiAgICB9O1xuICB9XG59XG4iXX0=
@@ -6,6 +6,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const cw = require("aws-cdk-lib/aws-cloudwatch");
8
8
  const constructs_1 = require("constructs");
9
+ const monitor_type_1 = require("./monitor-type");
9
10
  /**
10
11
  * A Construct which creates the following alarms for cloudfront distributions:
11
12
  *
@@ -17,8 +18,8 @@ class WatchCloudfrontDistribution extends constructs_1.Construct {
17
18
  super(scope, id);
18
19
  this.watchful = props.watchful;
19
20
  this.cf = props.cf;
20
- this.watchful.createAlarm(this, '5xxError', this.create5xxMonitor(props.errorsPerMinuteThreshold));
21
- this.watchful.createAlarm(this, 'cacheHitRate', this.createCacheHitMonitor(props.cacheHitPercent));
21
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.HTTP_CODE5XX, this.create5xxMonitor(props.errorsPerMinuteThreshold));
22
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.CACHE_HIT_RATE, this.createCacheHitMonitor(props.cacheHitPercent));
22
23
  }
23
24
  create5xxMonitor(errorsPerMinuteThreshold = 0) {
24
25
  const errorMetrics5xx = new cw.Metric({
@@ -62,4 +63,4 @@ class WatchCloudfrontDistribution extends constructs_1.Construct {
62
63
  exports.WatchCloudfrontDistribution = WatchCloudfrontDistribution;
63
64
  _a = JSII_RTTI_SYMBOL_1;
64
65
  WatchCloudfrontDistribution[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchCloudfrontDistribution", version: "0.0.0" };
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmcm9udC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy93YXRjaGZ1bC9jbG91ZGZyb250LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsNkNBQXVDO0FBRXZDLGlEQUFpRDtBQUNqRCwyQ0FBdUM7QUEwQ3ZDOzs7OztHQUtHO0FBQ0gsTUFBYSwyQkFBNEIsU0FBUSxzQkFBUztJQUl4RCxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQXVDO1FBQy9FLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxFQUFFLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDO1FBQ25HLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxjQUFjLEVBQUUsSUFBSSxDQUFDLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDO0lBQ3JHLENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyx3QkFBd0IsR0FBRyxDQUFDO1FBQ25ELE1BQU0sZUFBZSxHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUNwQyxVQUFVLEVBQUUsY0FBYztZQUMxQixTQUFTLEVBQUUsZ0JBQWdCO1lBQzNCLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUM7WUFDN0IsU0FBUyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTztZQUMvQixhQUFhLEVBQUU7Z0JBQ2IsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLGNBQWMsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGNBQWM7YUFDdkM7U0FDRixDQUFDLENBQUM7UUFDSCxPQUFPO1lBQ0wsTUFBTSxFQUFFLGVBQWU7WUFDdkIsZ0JBQWdCLEVBQUUsUUFBUSx3QkFBd0Isd0JBQXdCO1lBQzFFLFNBQVMsRUFBRSx3QkFBd0I7WUFDbkMsa0JBQWtCLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLHNCQUFzQjtZQUNoRSxpQkFBaUIsRUFBRSxDQUFDO1NBQ3JCLENBQUM7SUFDSixDQUFDO0lBRU8scUJBQXFCLENBQUMscUJBQXFCLEdBQUcsRUFBRTtRQUN0RCxNQUFNLGtCQUFrQixHQUFHLElBQUksRUFBRSxDQUFDLE1BQU0sQ0FBQztZQUN2QyxVQUFVLEVBQUUsY0FBYztZQUMxQixTQUFTLEVBQUUsZ0JBQWdCO1lBQzNCLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUM7WUFDN0IsU0FBUyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTztZQUMvQixhQUFhLEVBQUU7Z0JBQ2IsTUFBTSxFQUFFLFFBQVE7Z0JBQ2hCLGNBQWMsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGNBQWM7YUFDdkM7U0FDRixDQUFDLENBQUM7UUFDSCxPQUFPO1lBQ0wsTUFBTSxFQUFFLGtCQUFrQjtZQUMxQixnQkFBZ0IsRUFBRSw0QkFBNEIscUJBQXFCLEVBQUU7WUFDckUsU0FBUyxFQUFFLHFCQUFxQjtZQUNoQyxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsbUJBQW1CO1lBQzdELGlCQUFpQixFQUFFLENBQUM7U0FDckIsQ0FBQztJQUNKLENBQUM7O0FBbkRILGtFQW9EQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0ICogYXMgY2xvdWRmcm9udCBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWRmcm9udCc7XG5pbXBvcnQgKiBhcyBjdyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IE1ldHJpY0FsYXJtUHJvcHMgfSBmcm9tICcuL21ldHJpYy1hbGFybSc7XG5pbXBvcnQgeyBJV2F0Y2hmdWwgfSBmcm9tICcuL3dhdGNoZnVsJztcblxuLyoqXG4gKiBPcHRpb25zIGZvciBkZWZpbmluZyBhbGFybXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgV2F0Y2hDbG91ZGZyb250RGlzdHJpYnV0aW9uT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIE51bWJlciBvZiBhbGxvd2VkIGVycm9ycyBwZXIgbWludXRlLiBJZiB0aGVyZSBhcmUgbW9yZSBlcnJvcnMgdGhhbiB0aGF0LCBhbiBhbGFybSB3aWxsIHRyaWdnZXIuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDBcbiAgICAgKi9cbiAgcmVhZG9ubHkgZXJyb3JzUGVyTWludXRlVGhyZXNob2xkPzogbnVtYmVyO1xuXG4gIC8qKlxuICAgICAqIFRocmVzaG9sZCBmb3IgdGhlIGNhY2hlIGhpdCBhbGFybSBhcyBwZXJjZW50YWdlIG9mIHRoZSBDbG91ZGZyb250IERpc3RyaWJ1dGlvblxuICAgICAqXG4gICAgICogSWYgdGhpcyBpcyBzZXQgdG8gNDAlLCB0aGUgYWxhcm0gd2lsbCBiZSBzZXQgd2hlbiB0aGUgY2FjaGUgaGl0IHBlcmVudGFnZSBpc1xuICAgICAqIGxvd2VyIHRoYW4gdGhlIHRocmVzaG9sZCBzZXR0aW5nXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDQwXG4gICAgICovXG4gIHJlYWRvbmx5IGNhY2hlSGl0UGVyY2VudD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvblByb3BzIGV4dGVuZHMgV2F0Y2hDbG91ZGZyb250RGlzdHJpYnV0aW9uT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIFRoZSByZWZlcmVuY2UgdG8gSVdhdGNoZnVsIGNsYXNzLiBVc2VkIGludGVybmFsbHkuXG4gICAgICovXG4gIHJlYWRvbmx5IHdhdGNoZnVsOiBJV2F0Y2hmdWw7XG5cbiAgLyoqXG4gICAgICogVGhlIGNsb3VkZnJvbnQgZGlzdHJpYnV0aW9uIHRoYXQgc2hvdWxkIGJlIHdhdGNoZWQuXG4gICAgICogW2Rpc2FibGUtYXdzbGludDpyZWYtdmlhLWludGVyZmFjZV1cbiAgICAgKi9cbiAgcmVhZG9ubHkgY2Y6IGNsb3VkZnJvbnQuRGlzdHJpYnV0aW9uO1xufVxuXG4vKipcbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgdGhlIGZvbGxvd2luZyBhbGFybXMgZm9yIGNsb3VkZnJvbnQgZGlzdHJpYnV0aW9uczpcbiAqXG4gKiAtIGh0dHAtY29kZSA1eHhcbiAqIC0gbG93IGNhY2hlIGhpdHNcbiAqL1xuZXhwb3J0IGNsYXNzIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvbiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgd2F0Y2hmdWw6IElXYXRjaGZ1bDtcbiAgcHJpdmF0ZSByZWFkb25seSBjZjogY2xvdWRmcm9udC5EaXN0cmlidXRpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMud2F0Y2hmdWwgPSBwcm9wcy53YXRjaGZ1bDtcbiAgICB0aGlzLmNmID0gcHJvcHMuY2Y7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybSh0aGlzLCAnNXh4RXJyb3InLCB0aGlzLmNyZWF0ZTV4eE1vbml0b3IocHJvcHMuZXJyb3JzUGVyTWludXRlVGhyZXNob2xkKSk7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybSh0aGlzLCAnY2FjaGVIaXRSYXRlJywgdGhpcy5jcmVhdGVDYWNoZUhpdE1vbml0b3IocHJvcHMuY2FjaGVIaXRQZXJjZW50KSk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZTV4eE1vbml0b3IoZXJyb3JzUGVyTWludXRlVGhyZXNob2xkID0gMCk6IE1ldHJpY0FsYXJtUHJvcHMge1xuICAgIGNvbnN0IGVycm9yTWV0cmljczV4eCA9IG5ldyBjdy5NZXRyaWMoe1xuICAgICAgbWV0cmljTmFtZTogJzV4eEVycm9yUmF0ZScsXG4gICAgICBuYW1lc3BhY2U6ICdBV1MvQ2xvdWRGcm9udCcsXG4gICAgICBwZXJpb2Q6IER1cmF0aW9uLnNlY29uZHMoNjAwKSxcbiAgICAgIHN0YXRpc3RpYzogY3cuU3RhdGlzdGljLkFWRVJBR0UsXG4gICAgICBkaW1lbnNpb25zTWFwOiB7XG4gICAgICAgIFJlZ2lvbjogJ0dsb2JhbCcsXG4gICAgICAgIERpc3RyaWJ1dGlvbklkOiB0aGlzLmNmLmRpc3RyaWJ1dGlvbklkLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICByZXR1cm4ge1xuICAgICAgbWV0cmljOiBlcnJvck1ldHJpY3M1eHgsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgT3ZlciAke2Vycm9yc1Blck1pbnV0ZVRocmVzaG9sZH0gNXh4IGVycm9ycyBwZXIgbWludXRlYCxcbiAgICAgIHRocmVzaG9sZDogZXJyb3JzUGVyTWludXRlVGhyZXNob2xkLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX1RIUkVTSE9MRCxcbiAgICAgIGV2YWx1YXRpb25QZXJpb2RzOiAzLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUNhY2hlSGl0TW9uaXRvcihjYWNoZUhpdFJhdGVUaHJlc2hvbGQgPSA0MCk6IE1ldHJpY0FsYXJtUHJvcHMge1xuICAgIGNvbnN0IGNhY2hlSGl0UmF0ZU1ldHJpYyA9IG5ldyBjdy5NZXRyaWMoe1xuICAgICAgbWV0cmljTmFtZTogJ0NhY2hlSGl0UmF0ZScsXG4gICAgICBuYW1lc3BhY2U6ICdBV1MvQ2xvdWRGcm9udCcsXG4gICAgICBwZXJpb2Q6IER1cmF0aW9uLnNlY29uZHMoNjAwKSxcbiAgICAgIHN0YXRpc3RpYzogY3cuU3RhdGlzdGljLkFWRVJBR0UsXG4gICAgICBkaW1lbnNpb25zTWFwOiB7XG4gICAgICAgIFJlZ2lvbjogJ0dsb2JhbCcsXG4gICAgICAgIERpc3RyaWJ1dGlvbklkOiB0aGlzLmNmLmRpc3RyaWJ1dGlvbklkLFxuICAgICAgfSxcbiAgICB9KTtcbiAgICByZXR1cm4ge1xuICAgICAgbWV0cmljOiBjYWNoZUhpdFJhdGVNZXRyaWMsXG4gICAgICBhbGFybURlc2NyaXB0aW9uOiBgQ2FjaGUgaGl0IHJhdGUgbGVzcyB0aGFuICR7Y2FjaGVIaXRSYXRlVGhyZXNob2xkfWAsXG4gICAgICB0aHJlc2hvbGQ6IGNhY2hlSGl0UmF0ZVRocmVzaG9sZCxcbiAgICAgIGNvbXBhcmlzb25PcGVyYXRvcjogY3cuQ29tcGFyaXNvbk9wZXJhdG9yLkxFU1NfVEhBTl9USFJFU0hPTEQsXG4gICAgICBldmFsdWF0aW9uUGVyaW9kczogMyxcbiAgICB9O1xuICB9XG59XG4iXX0=
66
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xvdWRmcm9udC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy93YXRjaGZ1bC9jbG91ZGZyb250LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBQUEsNkNBQXVDO0FBRXZDLGlEQUFpRDtBQUNqRCwyQ0FBdUM7QUFFdkMsaURBQTZDO0FBMEM3Qzs7Ozs7R0FLRztBQUNILE1BQWEsMkJBQTRCLFNBQVEsc0JBQVM7SUFJeEQsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUF1QztRQUMvRSxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsRUFBRSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLDBCQUFXLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDO1FBQ2pILElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSwwQkFBVyxDQUFDLGNBQWMsRUFBRSxJQUFJLENBQUMscUJBQXFCLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUM7SUFDakgsQ0FBQztJQUVPLGdCQUFnQixDQUFDLHdCQUF3QixHQUFHLENBQUM7UUFDbkQsTUFBTSxlQUFlLEdBQUcsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ3BDLFVBQVUsRUFBRSxjQUFjO1lBQzFCLFNBQVMsRUFBRSxnQkFBZ0I7WUFDM0IsTUFBTSxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQztZQUM3QixTQUFTLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxPQUFPO1lBQy9CLGFBQWEsRUFBRTtnQkFDYixNQUFNLEVBQUUsUUFBUTtnQkFDaEIsY0FBYyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsY0FBYzthQUN2QztTQUNGLENBQUMsQ0FBQztRQUNILE9BQU87WUFDTCxNQUFNLEVBQUUsZUFBZTtZQUN2QixnQkFBZ0IsRUFBRSxRQUFRLHdCQUF3Qix3QkFBd0I7WUFDMUUsU0FBUyxFQUFFLHdCQUF3QjtZQUNuQyxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsc0JBQXNCO1lBQ2hFLGlCQUFpQixFQUFFLENBQUM7U0FDckIsQ0FBQztJQUNKLENBQUM7SUFFTyxxQkFBcUIsQ0FBQyxxQkFBcUIsR0FBRyxFQUFFO1FBQ3RELE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxFQUFFLENBQUMsTUFBTSxDQUFDO1lBQ3ZDLFVBQVUsRUFBRSxjQUFjO1lBQzFCLFNBQVMsRUFBRSxnQkFBZ0I7WUFDM0IsTUFBTSxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQztZQUM3QixTQUFTLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxPQUFPO1lBQy9CLGFBQWEsRUFBRTtnQkFDYixNQUFNLEVBQUUsUUFBUTtnQkFDaEIsY0FBYyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsY0FBYzthQUN2QztTQUNGLENBQUMsQ0FBQztRQUNILE9BQU87WUFDTCxNQUFNLEVBQUUsa0JBQWtCO1lBQzFCLGdCQUFnQixFQUFFLDRCQUE0QixxQkFBcUIsRUFBRTtZQUNyRSxTQUFTLEVBQUUscUJBQXFCO1lBQ2hDLGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxtQkFBbUI7WUFDN0QsaUJBQWlCLEVBQUUsQ0FBQztTQUNyQixDQUFDO0lBQ0osQ0FBQzs7QUFuREgsa0VBb0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBjbG91ZGZyb250IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZGZyb250JztcbmltcG9ydCAqIGFzIGN3IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgTWV0cmljQWxhcm1Qcm9wcyB9IGZyb20gJy4vbWV0cmljLWFsYXJtJztcbmltcG9ydCB7IE1vbml0b3JUeXBlIH0gZnJvbSAnLi9tb25pdG9yLXR5cGUnO1xuaW1wb3J0IHsgSVdhdGNoZnVsIH0gZnJvbSAnLi93YXRjaGZ1bCc7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgZGVmaW5pbmcgYWxhcm1zLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvbk9wdGlvbnMge1xuICAvKipcbiAgICAgKiBOdW1iZXIgb2YgYWxsb3dlZCBlcnJvcnMgcGVyIG1pbnV0ZS4gSWYgdGhlcmUgYXJlIG1vcmUgZXJyb3JzIHRoYW4gdGhhdCwgYW4gYWxhcm0gd2lsbCB0cmlnZ2VyLlxuICAgICAqXG4gICAgICogQGRlZmF1bHRWYWx1ZSAwXG4gICAgICovXG4gIHJlYWRvbmx5IGVycm9yc1Blck1pbnV0ZVRocmVzaG9sZD86IG51bWJlcjtcblxuICAvKipcbiAgICAgKiBUaHJlc2hvbGQgZm9yIHRoZSBjYWNoZSBoaXQgYWxhcm0gYXMgcGVyY2VudGFnZSBvZiB0aGUgQ2xvdWRmcm9udCBEaXN0cmlidXRpb25cbiAgICAgKlxuICAgICAqIElmIHRoaXMgaXMgc2V0IHRvIDQwJSwgdGhlIGFsYXJtIHdpbGwgYmUgc2V0IHdoZW4gdGhlIGNhY2hlIGhpdCBwZXJlbnRhZ2UgaXNcbiAgICAgKiBsb3dlciB0aGFuIHRoZSB0aHJlc2hvbGQgc2V0dGluZ1xuICAgICAqXG4gICAgICogQGRlZmF1bHRWYWx1ZSA0MFxuICAgICAqL1xuICByZWFkb25seSBjYWNoZUhpdFBlcmNlbnQ/OiBudW1iZXI7XG59XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgZGVmaW5pbmcgYSBXYXRjaENsb3VkZnJvbnREaXN0cmlidXRpb25cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaENsb3VkZnJvbnREaXN0cmlidXRpb25Qcm9wcyBleHRlbmRzIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvbk9wdGlvbnMge1xuICAvKipcbiAgICAgKiBUaGUgcmVmZXJlbmNlIHRvIElXYXRjaGZ1bCBjbGFzcy4gVXNlZCBpbnRlcm5hbGx5LlxuICAgICAqL1xuICByZWFkb25seSB3YXRjaGZ1bDogSVdhdGNoZnVsO1xuXG4gIC8qKlxuICAgICAqIFRoZSBjbG91ZGZyb250IGRpc3RyaWJ1dGlvbiB0aGF0IHNob3VsZCBiZSB3YXRjaGVkLlxuICAgICAqIFtkaXNhYmxlLWF3c2xpbnQ6cmVmLXZpYS1pbnRlcmZhY2VdXG4gICAgICovXG4gIHJlYWRvbmx5IGNmOiBjbG91ZGZyb250LkRpc3RyaWJ1dGlvbjtcbn1cblxuXG4vKipcbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgdGhlIGZvbGxvd2luZyBhbGFybXMgZm9yIGNsb3VkZnJvbnQgZGlzdHJpYnV0aW9uczpcbiAqXG4gKiAtIGh0dHAtY29kZSA1eHhcbiAqIC0gbG93IGNhY2hlIGhpdHNcbiAqL1xuZXhwb3J0IGNsYXNzIFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvbiBleHRlbmRzIENvbnN0cnVjdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgd2F0Y2hmdWw6IElXYXRjaGZ1bDtcbiAgcHJpdmF0ZSByZWFkb25seSBjZjogY2xvdWRmcm9udC5EaXN0cmlidXRpb247XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IFdhdGNoQ2xvdWRmcm9udERpc3RyaWJ1dGlvblByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMud2F0Y2hmdWwgPSBwcm9wcy53YXRjaGZ1bDtcbiAgICB0aGlzLmNmID0gcHJvcHMuY2Y7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVBbGFybSh0aGlzLCBNb25pdG9yVHlwZS5IVFRQX0NPREU1WFgsIHRoaXMuY3JlYXRlNXh4TW9uaXRvcihwcm9wcy5lcnJvcnNQZXJNaW51dGVUaHJlc2hvbGQpKTtcbiAgICB0aGlzLndhdGNoZnVsLmNyZWF0ZUFsYXJtKHRoaXMsIE1vbml0b3JUeXBlLkNBQ0hFX0hJVF9SQVRFLCB0aGlzLmNyZWF0ZUNhY2hlSGl0TW9uaXRvcihwcm9wcy5jYWNoZUhpdFBlcmNlbnQpKTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlNXh4TW9uaXRvcihlcnJvcnNQZXJNaW51dGVUaHJlc2hvbGQgPSAwKTogTWV0cmljQWxhcm1Qcm9wcyB7XG4gICAgY29uc3QgZXJyb3JNZXRyaWNzNXh4ID0gbmV3IGN3Lk1ldHJpYyh7XG4gICAgICBtZXRyaWNOYW1lOiAnNXh4RXJyb3JSYXRlJyxcbiAgICAgIG5hbWVzcGFjZTogJ0FXUy9DbG91ZEZyb250JyxcbiAgICAgIHBlcmlvZDogRHVyYXRpb24uc2Vjb25kcyg2MDApLFxuICAgICAgc3RhdGlzdGljOiBjdy5TdGF0aXN0aWMuQVZFUkFHRSxcbiAgICAgIGRpbWVuc2lvbnNNYXA6IHtcbiAgICAgICAgUmVnaW9uOiAnR2xvYmFsJyxcbiAgICAgICAgRGlzdHJpYnV0aW9uSWQ6IHRoaXMuY2YuZGlzdHJpYnV0aW9uSWQsXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGVycm9yTWV0cmljczV4eCxcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246IGBPdmVyICR7ZXJyb3JzUGVyTWludXRlVGhyZXNob2xkfSA1eHggZXJyb3JzIHBlciBtaW51dGVgLFxuICAgICAgdGhyZXNob2xkOiBlcnJvcnNQZXJNaW51dGVUaHJlc2hvbGQsXG4gICAgICBjb21wYXJpc29uT3BlcmF0b3I6IGN3LkNvbXBhcmlzb25PcGVyYXRvci5HUkVBVEVSX1RIQU5fVEhSRVNIT0xELFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDMsXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlQ2FjaGVIaXRNb25pdG9yKGNhY2hlSGl0UmF0ZVRocmVzaG9sZCA9IDQwKTogTWV0cmljQWxhcm1Qcm9wcyB7XG4gICAgY29uc3QgY2FjaGVIaXRSYXRlTWV0cmljID0gbmV3IGN3Lk1ldHJpYyh7XG4gICAgICBtZXRyaWNOYW1lOiAnQ2FjaGVIaXRSYXRlJyxcbiAgICAgIG5hbWVzcGFjZTogJ0FXUy9DbG91ZEZyb250JyxcbiAgICAgIHBlcmlvZDogRHVyYXRpb24uc2Vjb25kcyg2MDApLFxuICAgICAgc3RhdGlzdGljOiBjdy5TdGF0aXN0aWMuQVZFUkFHRSxcbiAgICAgIGRpbWVuc2lvbnNNYXA6IHtcbiAgICAgICAgUmVnaW9uOiAnR2xvYmFsJyxcbiAgICAgICAgRGlzdHJpYnV0aW9uSWQ6IHRoaXMuY2YuZGlzdHJpYnV0aW9uSWQsXG4gICAgICB9LFxuICAgIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGNhY2hlSGl0UmF0ZU1ldHJpYyxcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246IGBDYWNoZSBoaXQgcmF0ZSBsZXNzIHRoYW4gJHtjYWNoZUhpdFJhdGVUaHJlc2hvbGR9YCxcbiAgICAgIHRocmVzaG9sZDogY2FjaGVIaXRSYXRlVGhyZXNob2xkLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuTEVTU19USEFOX1RIUkVTSE9MRCxcbiAgICAgIGV2YWx1YXRpb25QZXJpb2RzOiAzLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
@@ -6,6 +6,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const cw = require("aws-cdk-lib/aws-cloudwatch");
8
8
  const constructs_1 = require("constructs");
9
+ const monitor_type_1 = require("./monitor-type");
9
10
  /**
10
11
  * A Construct which creates the following alarms for DocumentDb clusters:
11
12
  *
@@ -18,10 +19,10 @@ class WatchDocDbCluster extends constructs_1.Construct {
18
19
  super(scope, id);
19
20
  this.watchful = props.watchful;
20
21
  this.docDb = props.docDb;
21
- this.watchful.createAlarm(this, 'CpuUtilization', this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold));
22
- this.watchful.createAlarm(this, 'FreeableMemoryTooLow', this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte));
23
- this.watchful.createAlarm(this, 'SwapUsageTooHigh', this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte));
24
- this.watchful.createAlarm(this, 'FreeLocalStorageTooLow', this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte));
22
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.CPU_UTILIZATION, this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold));
23
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.FREEABLE_MEMORY, this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte));
24
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.SWAP_USAGE, this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte));
25
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.FREE_LOCAL_STORAGE, this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte));
25
26
  }
26
27
  createCpuUtilizationTooHighAlarm(cpuUtilizationThreshold = 80) {
27
28
  const docDbMetric = new cw.Metric({
@@ -99,4 +100,4 @@ class WatchDocDbCluster extends constructs_1.Construct {
99
100
  exports.WatchDocDbCluster = WatchDocDbCluster;
100
101
  _a = JSII_RTTI_SYMBOL_1;
101
102
  WatchDocDbCluster[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchDocDbCluster", version: "0.0.0" };
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docdb.js","sourceRoot":"","sources":["../../src/watchful/docdb.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as docdb from 'aws-cdk-lib/aws-docdb';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDocDbClusterOptions {\n  /**\n     * Threshold of database cpu utilization.\n     *\n     * @defaultValue 80\n     */\n  readonly cpuUtilizationThreshold?: number;\n  /**\n     * Minimum database freeable memory in bytes.\n     *\n     * @defaultValue 64000000 (64 Megabyte)\n     */\n  readonly freeableMemoryThresholdInByte?: number;\n  /**\n     * Threshold of database swap usage\n     *\n     * @defaultValue 256000000 (256 Megabyte)\n     */\n  readonly swapUsageThresholdInByte?: number;\n  /**\n     * Minimum database free local storage space\n     *\n     * @defaultValue 2000000000 (2 Gigabyte)\n     */\n  readonly freeLocalStorageInByte?: number;\n}\n\n/**\n * Properties for defining a WatchDocDbCluster\n */\nexport interface WatchDocDbClusterProps extends WatchDocDbClusterOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DocDB cluster that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly docDb: docdb.DatabaseCluster;\n}\n\n/**\n * A Construct which creates the following alarms for DocumentDb clusters:\n *\n * - freeable memory\n * - swap usage\n * - free local storage\n */\nexport class WatchDocDbCluster extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly docDb: docdb.DatabaseCluster;\n\n  constructor(scope: Construct, id: string, props: WatchDocDbClusterProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.docDb = props.docDb;\n\n    this.watchful.createAlarm(this,\n      'CpuUtilization',\n      this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'FreeableMemoryTooLow',\n      this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      'SwapUsageTooHigh',\n      this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      'FreeLocalStorageTooLow',\n      this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte),\n    );\n  }\n\n  private createCpuUtilizationTooHighAlarm(cpuUtilizationThreshold = 80): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'CPUUtilization',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database CPU utilization over last 10 minutes too high.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: cpuUtilizationThreshold,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeableMemoryTooLowAlarm(freeableMemoryThresholdInByte = 64000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeableMemory',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database freeable memory over last 10 minutes too low, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeableMemoryThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createSwapUsageTooHighAlarm(swapUsageThresholdInByte = 256000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'SwapUsage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database swap usage over last 10 minutes too high, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: swapUsageThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeLocalStorageTooLowAlarm(freeLocalStorageInByte = 2000000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeLocalStorage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database free local storage space over last 10 minutes too low.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeLocalStorageInByte,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docdb.js","sourceRoot":"","sources":["../../src/watchful/docdb.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as docdb from 'aws-cdk-lib/aws-docdb';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { MonitorType } from './monitor-type';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDocDbClusterOptions {\n  /**\n     * Threshold of database cpu utilization.\n     *\n     * @defaultValue 80\n     */\n  readonly cpuUtilizationThreshold?: number;\n  /**\n     * Minimum database freeable memory in bytes.\n     *\n     * @defaultValue 64000000 (64 Megabyte)\n     */\n  readonly freeableMemoryThresholdInByte?: number;\n  /**\n     * Threshold of database swap usage\n     *\n     * @defaultValue 256000000 (256 Megabyte)\n     */\n  readonly swapUsageThresholdInByte?: number;\n  /**\n     * Minimum database free local storage space\n     *\n     * @defaultValue 2000000000 (2 Gigabyte)\n     */\n  readonly freeLocalStorageInByte?: number;\n}\n\n/**\n * Properties for defining a WatchDocDbCluster\n */\nexport interface WatchDocDbClusterProps extends WatchDocDbClusterOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DocDB cluster that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly docDb: docdb.DatabaseCluster;\n}\n\n/**\n * A Construct which creates the following alarms for DocumentDb clusters:\n *\n * - freeable memory\n * - swap usage\n * - free local storage\n */\nexport class WatchDocDbCluster extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly docDb: docdb.DatabaseCluster;\n\n  constructor(scope: Construct, id: string, props: WatchDocDbClusterProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.docDb = props.docDb;\n\n    this.watchful.createAlarm(this,\n      MonitorType.CPU_UTILIZATION,\n      this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.FREEABLE_MEMORY,\n      this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.SWAP_USAGE,\n      this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.FREE_LOCAL_STORAGE,\n      this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte),\n    );\n  }\n\n  private createCpuUtilizationTooHighAlarm(cpuUtilizationThreshold = 80): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'CPUUtilization',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database CPU utilization over last 10 minutes too high.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: cpuUtilizationThreshold,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeableMemoryTooLowAlarm(freeableMemoryThresholdInByte = 64000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeableMemory',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database freeable memory over last 10 minutes too low, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeableMemoryThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createSwapUsageTooHighAlarm(swapUsageThresholdInByte = 256000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'SwapUsage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database swap usage over last 10 minutes too high, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: swapUsageThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeLocalStorageTooLowAlarm(freeLocalStorageInByte = 2000000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeLocalStorage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database free local storage space over last 10 minutes too low.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeLocalStorageInByte,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
@@ -5,6 +5,7 @@ exports.WatchDynamoDbTable = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const constructs_1 = require("constructs");
8
+ const monitor_type_1 = require("./monitor-type");
8
9
  /**
9
10
  * A Construct which creates the following alarms for DynamoDb tables:
10
11
  *
@@ -19,9 +20,9 @@ class WatchDynamoDbTable extends constructs_1.Construct {
19
20
  super(scope, id);
20
21
  this.watchful = props.watchful;
21
22
  this.dynamoDb = props.dynamoDbTable;
22
- this.watchful.createAlarm(this, 'ReadThrottleEvents', this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold));
23
- this.watchful.createAlarm(this, 'WriteThrottleEvents', this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold));
24
- this.watchful.createAlarm(this, 'ThrottledRequestsEvents', this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold));
23
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.READ_THROTTLE_EVENTS, this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold));
24
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.WRITE_THROTTLE_EVENTS, this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold));
25
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.THROTTLED_REQUESTS_EVENTS, this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold));
25
26
  }
26
27
  createReadThrottleEventsAlarm(readThrottleEventsThreshold = 1) {
27
28
  const dynamoDbMetric = new aws_cdk_lib_1.aws_cloudwatch.Metric({
@@ -84,4 +85,4 @@ class WatchDynamoDbTable extends constructs_1.Construct {
84
85
  exports.WatchDynamoDbTable = WatchDynamoDbTable;
85
86
  _a = JSII_RTTI_SYMBOL_1;
86
87
  WatchDynamoDbTable[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchDynamoDbTable", version: "0.0.0" };
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamodb.js","sourceRoot":"","sources":["../../src/watchful/dynamodb.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_cloudwatch as cw, aws_dynamodb as dynamodb, Duration } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDynamoDbTableOptions {\n  /**\n     * Threshold of read throttle events.\n     *\n     * @defaultValue 1\n     */\n  readonly readThrottleEventsThreshold?: number;\n  /**\n     * Threshold of write throttle events.\n     *\n     * @defaultValue 1\n     */\n  readonly writeThrottleEventsThreshold?: number;\n  /**\n     * Threshold of throttled requests events.\n     *\n     * @defaultValue 1\n     */\n  readonly throttledRequestsEventsThreshold?: number;\n  /**\n     * Threshold of user errors.\n     *\n     * @defaultValue 1\n     */\n  readonly userErrorsThreshold?: number;\n\n  /**\n     * Threshold of system errors.\n     *\n     * @defaultValue 1\n     */\n  readonly systemErrorsThreshold?: number;\n}\n\n/**\n * Properties for defining a WatchDynamoDbTable\n */\nexport interface WatchDynamoDbTableProps extends WatchDynamoDbTableOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DynamoDb table that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly dynamoDbTable: dynamodb.Table;\n}\n\n/**\n * A Construct which creates the following alarms for DynamoDb tables:\n *\n * - read throttles\n * - write throttles\n * - throttled requests\n * - user errors\n * - system errors\n */\nexport class WatchDynamoDbTable extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly dynamoDb: dynamodb.Table;\n\n  constructor(scope: Construct, id: string, props: WatchDynamoDbTableProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.dynamoDb = props.dynamoDbTable;\n\n    this.watchful.createAlarm(this,\n      'ReadThrottleEvents',\n      this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'WriteThrottleEvents',\n      this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'ThrottledRequestsEvents',\n      this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold),\n    );\n  }\n\n  private createReadThrottleEventsAlarm(readThrottleEventsThreshold = 1): MetricAlarmProps {\n\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ReadThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Reads are throttled. Lower ReadCapacityUnitsUtilizationTarget or increase MaxReadCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: readThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createWriteThrottleEventsAlarm(writeThrottleEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'WriteThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Writes are throttled. Lower WriteCapacityUnitsUtilizationTarget or increase MaxWriteCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: writeThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createThrottledRequestsEventsAlarm(throttledRequestsEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ThrottledRequests',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Batch requests are throttled. Lower {Read/Write}CapacityUnitsUtilizationTarget or increase Max{Read/Write}CapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: throttledRequestsEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamodb.js","sourceRoot":"","sources":["../../src/watchful/dynamodb.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_cloudwatch as cw, aws_dynamodb as dynamodb, Duration } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { MonitorType } from './monitor-type';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDynamoDbTableOptions {\n  /**\n     * Threshold of read throttle events.\n     *\n     * @defaultValue 1\n     */\n  readonly readThrottleEventsThreshold?: number;\n  /**\n     * Threshold of write throttle events.\n     *\n     * @defaultValue 1\n     */\n  readonly writeThrottleEventsThreshold?: number;\n  /**\n     * Threshold of throttled requests events.\n     *\n     * @defaultValue 1\n     */\n  readonly throttledRequestsEventsThreshold?: number;\n  /**\n     * Threshold of user errors.\n     *\n     * @defaultValue 1\n     */\n  readonly userErrorsThreshold?: number;\n\n  /**\n     * Threshold of system errors.\n     *\n     * @defaultValue 1\n     */\n  readonly systemErrorsThreshold?: number;\n}\n\n/**\n * Properties for defining a WatchDynamoDbTable\n */\nexport interface WatchDynamoDbTableProps extends WatchDynamoDbTableOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DynamoDb table that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly dynamoDbTable: dynamodb.Table;\n}\n\n/**\n * A Construct which creates the following alarms for DynamoDb tables:\n *\n * - read throttles\n * - write throttles\n * - throttled requests\n * - user errors\n * - system errors\n */\nexport class WatchDynamoDbTable extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly dynamoDb: dynamodb.Table;\n\n  constructor(scope: Construct, id: string, props: WatchDynamoDbTableProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.dynamoDb = props.dynamoDbTable;\n\n    this.watchful.createAlarm(this,\n      MonitorType.READ_THROTTLE_EVENTS,\n      this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.WRITE_THROTTLE_EVENTS,\n      this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.THROTTLED_REQUESTS_EVENTS,\n      this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold),\n    );\n  }\n\n  private createReadThrottleEventsAlarm(readThrottleEventsThreshold = 1): MetricAlarmProps {\n\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ReadThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Reads are throttled. Lower ReadCapacityUnitsUtilizationTarget or increase MaxReadCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: readThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createWriteThrottleEventsAlarm(writeThrottleEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'WriteThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Writes are throttled. Lower WriteCapacityUnitsUtilizationTarget or increase MaxWriteCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: writeThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createThrottledRequestsEventsAlarm(throttledRequestsEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ThrottledRequests',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Batch requests are throttled. Lower {Read/Write}CapacityUnitsUtilizationTarget or increase Max{Read/Write}CapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: throttledRequestsEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
@@ -22,9 +22,9 @@ class WatchEcsService extends constructs_1.Construct {
22
22
  super(scope, id);
23
23
  this.watchful = props.watchful;
24
24
  this.service = props.service;
25
- this.watchful.createAlarm(this, 'CpuUtilization', this.createCpuUtilizationMonitor(props.cpuUtilizationThresholdPercent));
26
- this.watchful.createAlarm(this, 'MemoryUtilization', this.createMemoryUtilizationMonitor(props.memoryUtilizationThresholdPercent));
27
- this.watchful.createLogAlarm(this, 'LogErrorMonitor', this.createLogErrorMonitor());
25
+ this.watchful.createAlarm(this, __1.MonitorType.CPU_UTILIZATION, this.createCpuUtilizationMonitor(props.cpuUtilizationThresholdPercent));
26
+ this.watchful.createAlarm(this, __1.MonitorType.MEMORY_UTILIZATION, this.createMemoryUtilizationMonitor(props.memoryUtilizationThresholdPercent));
27
+ this.watchful.createLogAlarm(this, __1.MonitorType.LOG_ERROR_MONITOR, this.createLogErrorMonitor());
28
28
  }
29
29
  createLogErrorMonitor() {
30
30
  return {
@@ -66,4 +66,4 @@ class WatchEcsService extends constructs_1.Construct {
66
66
  exports.WatchEcsService = WatchEcsService;
67
67
  _a = JSII_RTTI_SYMBOL_1;
68
68
  WatchEcsService[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchEcsService", version: "0.0.0" };
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dhdGNoZnVsL2Vjcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUF1QztBQUN2QyxpREFBaUQ7QUFFakQsMkNBQXVDO0FBQ3ZDLDBCQUF1RjtBQUd2RixNQUFNLHlDQUF5QyxHQUFHLEVBQUUsQ0FBQztBQUNyRCxNQUFNLDRDQUE0QyxHQUFHLEVBQUUsQ0FBQztBQXFDeEQ7Ozs7Ozs7R0FPRztBQUNILE1BQWEsZUFBZ0IsU0FBUSxzQkFBUztJQUk1QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTJCO1FBQ25FLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUU3QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQzVCLGdCQUFnQixFQUNoQixJQUFJLENBQUMsMkJBQTJCLENBQUMsS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQ3ZFLENBQUM7UUFDRixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQzVCLG1CQUFtQixFQUNuQixJQUFJLENBQUMsOEJBQThCLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQzdFLENBQUM7UUFDRixJQUFJLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQy9CLGlCQUFpQixFQUNqQixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FDN0IsQ0FBQztJQUNKLENBQUM7SUFFTyxxQkFBcUI7UUFDM0IsT0FBTztZQUNMLHVCQUF1QixFQUFFLElBQUk7WUFDN0IsTUFBTSxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztZQUMzQixZQUFZLEVBQUUsZ0JBQVksQ0FBQyxPQUFPO1lBQ2xDLGNBQWMsRUFBRSxzQkFBa0IsQ0FBQyxrQ0FBa0M7WUFDckUsU0FBUyxFQUFFLE9BQU87WUFDbEIsWUFBWSxFQUFFLE9BQU87WUFDckIsZ0JBQWdCLEVBQUUscUNBQXFDO1lBQ3ZELFNBQVMsRUFBRSxDQUFDO1lBQ1osUUFBUSxFQUFFLENBQUM7WUFDWCxLQUFLLEVBQUUsR0FBRztTQUNYLENBQUM7SUFDSixDQUFDO0lBRU8sMkJBQTJCLENBQ2pDLGlDQUF5Qyx5Q0FBeUM7UUFFbEYsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLG9CQUFvQixFQUFFLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLHNCQUFRLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUN4RyxPQUFPO1lBQ0wsTUFBTSxFQUFFLG9CQUFvQjtZQUM1QixnQkFBZ0IsRUFBRSw0REFBNEQsOEJBQThCLEdBQUc7WUFDL0csa0JBQWtCLEVBQUUsRUFBRSxDQUFDLGtCQUFrQixDQUFDLHNCQUFzQjtZQUNoRSxTQUFTLEVBQUUsOEJBQThCO1lBQ3pDLGlCQUFpQixFQUFFLENBQUM7U0FDckIsQ0FBQztJQUNKLENBQUM7SUFFTyw4QkFBOEIsQ0FDcEMsb0NBQTRDLDRDQUE0QztRQUV4RixNQUFNLHVCQUF1QixHQUFHLElBQUksQ0FBQyxPQUFPO2FBQ3pDLHVCQUF1QixFQUFFO2FBQ3pCLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDMUMsT0FBTztZQUNMLE1BQU0sRUFBRSx1QkFBdUI7WUFDL0IsZ0JBQWdCLEVBQUUsK0RBQStELGlDQUFpQyxHQUFHO1lBQ3JILGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDaEUsU0FBUyxFQUFFLGlDQUFpQztZQUM1QyxpQkFBaUIsRUFBRSxDQUFDO1NBQ3JCLENBQUM7SUFDSixDQUFDOztBQWpFSCwwQ0FtRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEdXJhdGlvbiB9IGZyb20gJ2F3cy1jZGstbGliJztcbmltcG9ydCAqIGFzIGN3IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcbmltcG9ydCAqIGFzIGVjcyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtZWNzJztcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gJ2NvbnN0cnVjdHMnO1xuaW1wb3J0IHsgQ29tcGFyaXNvbk9wZXJhdG9yLCBMb2dBbGFybVByb3BzLCBNZXRyaWNBbGFybVByb3BzLCBVbml0T2ZQZXJpb2QgfSBmcm9tICcuLic7XG5pbXBvcnQgeyBJV2F0Y2hmdWwgfSBmcm9tICcuL3dhdGNoZnVsJztcblxuY29uc3QgREVGQVVMVF9DUFVfVVRJTElaQVRJT05fVEhSRVNIT0xEX1BFUkNFTlQgPSA4MDtcbmNvbnN0IERFRkFVTFRfTUVNT1JZX1VUSUxJWkFUSU9OX1RIUkVTSE9MRF9QRVJDRU5UID0gOTU7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgZGVmaW5pbmcgYWxhcm1zLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdhdGNoRWNzU2VydmljZU9wdGlvbnMge1xuICAvKipcbiAgICAgKiBUaHJlc2hvbGQgZm9yIHRoZSBjcHUgdXRpbGl6YXRpb24gYWxhcm0gYXMgcGVyY2VudGFnZS5cbiAgICAgKlxuICAgICAqIEBkZWZhdWx0VmFsdWUgODBcbiAgICAgKi9cbiAgcmVhZG9ubHkgY3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50PzogbnVtYmVyO1xuXG4gIC8qKlxuICAgICAqIFRocmVzaG9sZCBmb3IgdGhlIG1lbW9yeSB1dGlsaXphdGlvbiBhbGFybSBhcyBwZXJjZW50YWdlLlxuICAgICAqXG4gICAgICogQGRlZmF1bHRWYWx1ZSA5NVxuICAgICAqL1xuICByZWFkb25seSBtZW1vcnlVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQ/OiBudW1iZXI7XG59XG5cbi8qKlxuICogUHJvcGVydGllcyBmb3IgZGVmaW5pbmcgYSBXYXRjaEVjc1NlcnZpY2VcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXYXRjaEVjc1NlcnZpY2VQcm9wcyBleHRlbmRzIFdhdGNoRWNzU2VydmljZU9wdGlvbnMge1xuICAvKipcbiAgICAgKiBUaGUgcmVmZXJlbmNlIHRvIElXYXRjaGZ1bCBjbGFzcy4gVXNlZCBpbnRlcm5hbGx5LlxuICAgICAqL1xuICByZWFkb25seSB3YXRjaGZ1bDogSVdhdGNoZnVsO1xuXG4gIC8qKlxuICAgICAqIFRoZSBFQ1Mgc2VydmljZSB0aGF0IHNob3VsZCBiZSB3YXRjaGVkLlxuICAgICAqIFtkaXNhYmxlLWF3c2xpbnQ6cmVmLXZpYS1pbnRlcmZhY2VdXG4gICAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2U6IGVjcy5CYXNlU2VydmljZTtcbn1cblxuLyoqXG4gKiBBIENvbnN0cnVjdCB3aGljaCBjcmVhdGVzIGRlZmF1bHQgYWxhcm1zIGZvciBFQ1Mgc2VydmljZXMuXG4gKiBBIENvbnN0cnVjdCB3aGljaCBjcmVhdGVzIHRoZSBmb2xsb3dpbmcgYWxhcm1zIGZvciBFQ1Mgc2VydmljZXM6XG4gKlxuICogLSBjcHUgdXRpbGl6YXRpb25cbiAqIC0gbWVtb3J5IHV0aWxpemF0aW9uXG4gKiAtIGVycm9yIGxvZyBhbGVydFxuICovXG5leHBvcnQgY2xhc3MgV2F0Y2hFY3NTZXJ2aWNlIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgcHJpdmF0ZSByZWFkb25seSB3YXRjaGZ1bDogSVdhdGNoZnVsO1xuICBwcml2YXRlIHJlYWRvbmx5IHNlcnZpY2U6IGVjcy5CYXNlU2VydmljZTtcblxuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogV2F0Y2hFY3NTZXJ2aWNlUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgdGhpcy53YXRjaGZ1bCA9IHByb3BzLndhdGNoZnVsO1xuICAgIHRoaXMuc2VydmljZSA9IHByb3BzLnNlcnZpY2U7XG5cbiAgICB0aGlzLndhdGNoZnVsLmNyZWF0ZUFsYXJtKHRoaXMsXG4gICAgICAnQ3B1VXRpbGl6YXRpb24nLFxuICAgICAgdGhpcy5jcmVhdGVDcHVVdGlsaXphdGlvbk1vbml0b3IocHJvcHMuY3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50KSxcbiAgICApO1xuICAgIHRoaXMud2F0Y2hmdWwuY3JlYXRlQWxhcm0odGhpcyxcbiAgICAgICdNZW1vcnlVdGlsaXphdGlvbicsXG4gICAgICB0aGlzLmNyZWF0ZU1lbW9yeVV0aWxpemF0aW9uTW9uaXRvcihwcm9wcy5tZW1vcnlVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQpLFxuICAgICk7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVMb2dBbGFybSh0aGlzLFxuICAgICAgJ0xvZ0Vycm9yTW9uaXRvcicsXG4gICAgICB0aGlzLmNyZWF0ZUxvZ0Vycm9yTW9uaXRvcigpLFxuICAgICk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUxvZ0Vycm9yTW9uaXRvcigpOiBMb2dBbGFybVByb3BzIHtcbiAgICByZXR1cm4ge1xuICAgICAgYXV0b0Nsb3NlT3BzR2VuaWVBbGVydHM6IHRydWUsXG4gICAgICBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoNSksXG4gICAgICB1bml0T2ZQZXJpb2Q6IFVuaXRPZlBlcmlvZC5NSU5VVEVTLCAvLyB0b0RvOiBtb3ZlIHRoYXQgc29tZXdoZXJlIGVsc2UgYW5kIHNldCBkZWZhdWx0cyB0aGVyZT9cbiAgICAgIHBlcmlvZE9wZXJhdG9yOiBDb21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX09SX0VRVUFMX1RPX1RIUkVTSE9MRCxcbiAgICAgIHN0YXRpc3RpYzogJ2NvdW50JyxcbiAgICAgIHF1ZXJ5RmlsdGVyczogJ2Vycm9yJyxcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246ICdBdXRvLWdlbmVyYXRlZCBhbGVydCBmb3IgZXJyb3IgbG9ncycsXG4gICAgICB0aHJlc2hvbGQ6IDEsXG4gICAgICBwcmlvcml0eTogMyxcbiAgICAgIGluZGV4OiAnKicsIC8vIHRvRG86IHdlIHNob3VsZCB0YWtlIGhlcmUgdGhlIHRlYW0gbmFtZSBidXQgZm9yIG9sZGVyIHNldHVwcyB0byB3b3JrIHdlIGtlZXAgdGhhdCBmb3IgY29tcGF0aWJpbGl0eVxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUNwdVV0aWxpemF0aW9uTW9uaXRvcihcbiAgICBjcHVVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQ6IG51bWJlciA9IERFRkFVTFRfQ1BVX1VUSUxJWkFUSU9OX1RIUkVTSE9MRF9QRVJDRU5ULFxuICApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCBjcHVVdGlsaXphdGlvbk1ldHJpYyA9IHRoaXMuc2VydmljZS5tZXRyaWNDcHVVdGlsaXphdGlvbigpLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoMTApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGNwdVV0aWxpemF0aW9uTWV0cmljLFxuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYEF2ZXJhZ2UgQ1BVIHV0aWxpemF0aW9uIG92ZXIgbGFzdCAxMCBtaW51dGVzIGhpZ2hlciB0aGFuICR7Y3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50fSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX1RIUkVTSE9MRCxcbiAgICAgIHRocmVzaG9sZDogY3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50LFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlTWVtb3J5VXRpbGl6YXRpb25Nb25pdG9yKFxuICAgIG1lbW9yeVV0aWxpemF0aW9uVGhyZXNob2xkUGVyY2VudDogbnVtYmVyID0gREVGQVVMVF9NRU1PUllfVVRJTElaQVRJT05fVEhSRVNIT0xEX1BFUkNFTlQsXG4gICk6IE1ldHJpY0FsYXJtUHJvcHMge1xuICAgIGNvbnN0IG1lbW9yeVV0aWxpemF0aW9uTWV0cmljID0gdGhpcy5zZXJ2aWNlXG4gICAgICAubWV0cmljTWVtb3J5VXRpbGl6YXRpb24oKVxuICAgICAgLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoMTApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IG1lbW9yeVV0aWxpemF0aW9uTWV0cmljLFxuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYEF2ZXJhZ2UgbWVtb3J5IHV0aWxpemF0aW9uIG92ZXIgbGFzdCAxMCBtaW51dGVzIGhpZ2hlciB0aGFuICR7bWVtb3J5VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50fSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX1RIUkVTSE9MRCxcbiAgICAgIHRocmVzaG9sZDogbWVtb3J5VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50LFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgfTtcbiAgfVxuXG59XG4iXX0=
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dhdGNoZnVsL2Vjcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLDZDQUF1QztBQUN2QyxpREFBaUQ7QUFFakQsMkNBQXVDO0FBQ3ZDLDBCQUFvRztBQUdwRyxNQUFNLHlDQUF5QyxHQUFHLEVBQUUsQ0FBQztBQUNyRCxNQUFNLDRDQUE0QyxHQUFHLEVBQUUsQ0FBQztBQXFDeEQ7Ozs7Ozs7R0FPRztBQUNILE1BQWEsZUFBZ0IsU0FBUSxzQkFBUztJQUk1QyxZQUFZLEtBQWdCLEVBQUUsRUFBVSxFQUFFLEtBQTJCO1FBQ25FLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUU3QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQzVCLGVBQVcsQ0FBQyxlQUFlLEVBQzNCLElBQUksQ0FBQywyQkFBMkIsQ0FBQyxLQUFLLENBQUMsOEJBQThCLENBQUMsQ0FDdkUsQ0FBQztRQUNGLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksRUFDNUIsZUFBVyxDQUFDLGtCQUFrQixFQUM5QixJQUFJLENBQUMsOEJBQThCLENBQUMsS0FBSyxDQUFDLGlDQUFpQyxDQUFDLENBQzdFLENBQUM7UUFDRixJQUFJLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQy9CLGVBQVcsQ0FBQyxpQkFBaUIsRUFDN0IsSUFBSSxDQUFDLHFCQUFxQixFQUFFLENBQzdCLENBQUM7SUFDSixDQUFDO0lBRU8scUJBQXFCO1FBQzNCLE9BQU87WUFDTCx1QkFBdUIsRUFBRSxJQUFJO1lBQzdCLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7WUFDM0IsWUFBWSxFQUFFLGdCQUFZLENBQUMsT0FBTztZQUNsQyxjQUFjLEVBQUUsc0JBQWtCLENBQUMsa0NBQWtDO1lBQ3JFLFNBQVMsRUFBRSxPQUFPO1lBQ2xCLFlBQVksRUFBRSxPQUFPO1lBQ3JCLGdCQUFnQixFQUFFLHFDQUFxQztZQUN2RCxTQUFTLEVBQUUsQ0FBQztZQUNaLFFBQVEsRUFBRSxDQUFDO1lBQ1gsS0FBSyxFQUFFLEdBQUc7U0FDWCxDQUFDO0lBQ0osQ0FBQztJQUVPLDJCQUEyQixDQUNqQyxpQ0FBeUMseUNBQXlDO1FBRWxGLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLElBQUksQ0FBQyxFQUFFLE1BQU0sRUFBRSxzQkFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDeEcsT0FBTztZQUNMLE1BQU0sRUFBRSxvQkFBb0I7WUFDNUIsZ0JBQWdCLEVBQUUsNERBQTRELDhCQUE4QixHQUFHO1lBQy9HLGtCQUFrQixFQUFFLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxzQkFBc0I7WUFDaEUsU0FBUyxFQUFFLDhCQUE4QjtZQUN6QyxpQkFBaUIsRUFBRSxDQUFDO1NBQ3JCLENBQUM7SUFDSixDQUFDO0lBRU8sOEJBQThCLENBQ3BDLG9DQUE0Qyw0Q0FBNEM7UUFFeEYsTUFBTSx1QkFBdUIsR0FBRyxJQUFJLENBQUMsT0FBTzthQUN6Qyx1QkFBdUIsRUFBRTthQUN6QixJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsc0JBQVEsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQzFDLE9BQU87WUFDTCxNQUFNLEVBQUUsdUJBQXVCO1lBQy9CLGdCQUFnQixFQUFFLCtEQUErRCxpQ0FBaUMsR0FBRztZQUNySCxrQkFBa0IsRUFBRSxFQUFFLENBQUMsa0JBQWtCLENBQUMsc0JBQXNCO1lBQ2hFLFNBQVMsRUFBRSxpQ0FBaUM7WUFDNUMsaUJBQWlCLEVBQUUsQ0FBQztTQUNyQixDQUFDO0lBQ0osQ0FBQzs7QUFqRUgsMENBbUVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgKiBhcyBjdyBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgKiBhcyBlY3MgZnJvbSAnYXdzLWNkay1saWIvYXdzLWVjcyc7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tICdjb25zdHJ1Y3RzJztcbmltcG9ydCB7IENvbXBhcmlzb25PcGVyYXRvciwgTG9nQWxhcm1Qcm9wcywgTWV0cmljQWxhcm1Qcm9wcywgTW9uaXRvclR5cGUsIFVuaXRPZlBlcmlvZCB9IGZyb20gJy4uJztcbmltcG9ydCB7IElXYXRjaGZ1bCB9IGZyb20gJy4vd2F0Y2hmdWwnO1xuXG5jb25zdCBERUZBVUxUX0NQVV9VVElMSVpBVElPTl9USFJFU0hPTERfUEVSQ0VOVCA9IDgwO1xuY29uc3QgREVGQVVMVF9NRU1PUllfVVRJTElaQVRJT05fVEhSRVNIT0xEX1BFUkNFTlQgPSA5NTtcblxuLyoqXG4gKiBPcHRpb25zIGZvciBkZWZpbmluZyBhbGFybXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgV2F0Y2hFY3NTZXJ2aWNlT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIFRocmVzaG9sZCBmb3IgdGhlIGNwdSB1dGlsaXphdGlvbiBhbGFybSBhcyBwZXJjZW50YWdlLlxuICAgICAqXG4gICAgICogQGRlZmF1bHRWYWx1ZSA4MFxuICAgICAqL1xuICByZWFkb25seSBjcHVVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQ/OiBudW1iZXI7XG5cbiAgLyoqXG4gICAgICogVGhyZXNob2xkIGZvciB0aGUgbWVtb3J5IHV0aWxpemF0aW9uIGFsYXJtIGFzIHBlcmNlbnRhZ2UuXG4gICAgICpcbiAgICAgKiBAZGVmYXVsdFZhbHVlIDk1XG4gICAgICovXG4gIHJlYWRvbmx5IG1lbW9yeVV0aWxpemF0aW9uVGhyZXNob2xkUGVyY2VudD86IG51bWJlcjtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIFdhdGNoRWNzU2VydmljZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdhdGNoRWNzU2VydmljZVByb3BzIGV4dGVuZHMgV2F0Y2hFY3NTZXJ2aWNlT3B0aW9ucyB7XG4gIC8qKlxuICAgICAqIFRoZSByZWZlcmVuY2UgdG8gSVdhdGNoZnVsIGNsYXNzLiBVc2VkIGludGVybmFsbHkuXG4gICAgICovXG4gIHJlYWRvbmx5IHdhdGNoZnVsOiBJV2F0Y2hmdWw7XG5cbiAgLyoqXG4gICAgICogVGhlIEVDUyBzZXJ2aWNlIHRoYXQgc2hvdWxkIGJlIHdhdGNoZWQuXG4gICAgICogW2Rpc2FibGUtYXdzbGludDpyZWYtdmlhLWludGVyZmFjZV1cbiAgICAgKi9cbiAgcmVhZG9ubHkgc2VydmljZTogZWNzLkJhc2VTZXJ2aWNlO1xufVxuXG4vKipcbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgZGVmYXVsdCBhbGFybXMgZm9yIEVDUyBzZXJ2aWNlcy5cbiAqIEEgQ29uc3RydWN0IHdoaWNoIGNyZWF0ZXMgdGhlIGZvbGxvd2luZyBhbGFybXMgZm9yIEVDUyBzZXJ2aWNlczpcbiAqXG4gKiAtIGNwdSB1dGlsaXphdGlvblxuICogLSBtZW1vcnkgdXRpbGl6YXRpb25cbiAqIC0gZXJyb3IgbG9nIGFsZXJ0XG4gKi9cbmV4cG9ydCBjbGFzcyBXYXRjaEVjc1NlcnZpY2UgZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwcml2YXRlIHJlYWRvbmx5IHdhdGNoZnVsOiBJV2F0Y2hmdWw7XG4gIHByaXZhdGUgcmVhZG9ubHkgc2VydmljZTogZWNzLkJhc2VTZXJ2aWNlO1xuXG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcsIHByb3BzOiBXYXRjaEVjc1NlcnZpY2VQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB0aGlzLndhdGNoZnVsID0gcHJvcHMud2F0Y2hmdWw7XG4gICAgdGhpcy5zZXJ2aWNlID0gcHJvcHMuc2VydmljZTtcblxuICAgIHRoaXMud2F0Y2hmdWwuY3JlYXRlQWxhcm0odGhpcyxcbiAgICAgIE1vbml0b3JUeXBlLkNQVV9VVElMSVpBVElPTixcbiAgICAgIHRoaXMuY3JlYXRlQ3B1VXRpbGl6YXRpb25Nb25pdG9yKHByb3BzLmNwdVV0aWxpemF0aW9uVGhyZXNob2xkUGVyY2VudCksXG4gICAgKTtcbiAgICB0aGlzLndhdGNoZnVsLmNyZWF0ZUFsYXJtKHRoaXMsXG4gICAgICBNb25pdG9yVHlwZS5NRU1PUllfVVRJTElaQVRJT04sXG4gICAgICB0aGlzLmNyZWF0ZU1lbW9yeVV0aWxpemF0aW9uTW9uaXRvcihwcm9wcy5tZW1vcnlVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQpLFxuICAgICk7XG4gICAgdGhpcy53YXRjaGZ1bC5jcmVhdGVMb2dBbGFybSh0aGlzLFxuICAgICAgTW9uaXRvclR5cGUuTE9HX0VSUk9SX01PTklUT1IsXG4gICAgICB0aGlzLmNyZWF0ZUxvZ0Vycm9yTW9uaXRvcigpLFxuICAgICk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUxvZ0Vycm9yTW9uaXRvcigpOiBMb2dBbGFybVByb3BzIHtcbiAgICByZXR1cm4ge1xuICAgICAgYXV0b0Nsb3NlT3BzR2VuaWVBbGVydHM6IHRydWUsXG4gICAgICBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoNSksXG4gICAgICB1bml0T2ZQZXJpb2Q6IFVuaXRPZlBlcmlvZC5NSU5VVEVTLCAvLyB0b0RvOiBtb3ZlIHRoYXQgc29tZXdoZXJlIGVsc2UgYW5kIHNldCBkZWZhdWx0cyB0aGVyZT9cbiAgICAgIHBlcmlvZE9wZXJhdG9yOiBDb21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX09SX0VRVUFMX1RPX1RIUkVTSE9MRCxcbiAgICAgIHN0YXRpc3RpYzogJ2NvdW50JyxcbiAgICAgIHF1ZXJ5RmlsdGVyczogJ2Vycm9yJyxcbiAgICAgIGFsYXJtRGVzY3JpcHRpb246ICdBdXRvLWdlbmVyYXRlZCBhbGVydCBmb3IgZXJyb3IgbG9ncycsXG4gICAgICB0aHJlc2hvbGQ6IDEsXG4gICAgICBwcmlvcml0eTogMyxcbiAgICAgIGluZGV4OiAnKicsIC8vIHRvRG86IHdlIHNob3VsZCB0YWtlIGhlcmUgdGhlIHRlYW0gbmFtZSBidXQgZm9yIG9sZGVyIHNldHVwcyB0byB3b3JrIHdlIGtlZXAgdGhhdCBmb3IgY29tcGF0aWJpbGl0eVxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZUNwdVV0aWxpemF0aW9uTW9uaXRvcihcbiAgICBjcHVVdGlsaXphdGlvblRocmVzaG9sZFBlcmNlbnQ6IG51bWJlciA9IERFRkFVTFRfQ1BVX1VUSUxJWkFUSU9OX1RIUkVTSE9MRF9QRVJDRU5ULFxuICApOiBNZXRyaWNBbGFybVByb3BzIHtcbiAgICBjb25zdCBjcHVVdGlsaXphdGlvbk1ldHJpYyA9IHRoaXMuc2VydmljZS5tZXRyaWNDcHVVdGlsaXphdGlvbigpLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoMTApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IGNwdVV0aWxpemF0aW9uTWV0cmljLFxuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYEF2ZXJhZ2UgQ1BVIHV0aWxpemF0aW9uIG92ZXIgbGFzdCAxMCBtaW51dGVzIGhpZ2hlciB0aGFuICR7Y3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50fSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX1RIUkVTSE9MRCxcbiAgICAgIHRocmVzaG9sZDogY3B1VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50LFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgfTtcbiAgfVxuXG4gIHByaXZhdGUgY3JlYXRlTWVtb3J5VXRpbGl6YXRpb25Nb25pdG9yKFxuICAgIG1lbW9yeVV0aWxpemF0aW9uVGhyZXNob2xkUGVyY2VudDogbnVtYmVyID0gREVGQVVMVF9NRU1PUllfVVRJTElaQVRJT05fVEhSRVNIT0xEX1BFUkNFTlQsXG4gICk6IE1ldHJpY0FsYXJtUHJvcHMge1xuICAgIGNvbnN0IG1lbW9yeVV0aWxpemF0aW9uTWV0cmljID0gdGhpcy5zZXJ2aWNlXG4gICAgICAubWV0cmljTWVtb3J5VXRpbGl6YXRpb24oKVxuICAgICAgLndpdGgoeyBwZXJpb2Q6IER1cmF0aW9uLm1pbnV0ZXMoMTApIH0pO1xuICAgIHJldHVybiB7XG4gICAgICBtZXRyaWM6IG1lbW9yeVV0aWxpemF0aW9uTWV0cmljLFxuICAgICAgYWxhcm1EZXNjcmlwdGlvbjogYEF2ZXJhZ2UgbWVtb3J5IHV0aWxpemF0aW9uIG92ZXIgbGFzdCAxMCBtaW51dGVzIGhpZ2hlciB0aGFuICR7bWVtb3J5VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50fSVgLFxuICAgICAgY29tcGFyaXNvbk9wZXJhdG9yOiBjdy5Db21wYXJpc29uT3BlcmF0b3IuR1JFQVRFUl9USEFOX1RIUkVTSE9MRCxcbiAgICAgIHRocmVzaG9sZDogbWVtb3J5VXRpbGl6YXRpb25UaHJlc2hvbGRQZXJjZW50LFxuICAgICAgZXZhbHVhdGlvblBlcmlvZHM6IDEsXG4gICAgfTtcbiAgfVxuXG59XG4iXX0=
@@ -12,3 +12,4 @@ export * from './metric-alarm';
12
12
  export * from './rds';
13
13
  export * from './cloudfront';
14
14
  export * from './upperToLower';
15
+ export * from './monitor-type';
@@ -24,4 +24,5 @@ __exportStar(require("./metric-alarm"), exports);
24
24
  __exportStar(require("./rds"), exports);
25
25
  __exportStar(require("./cloudfront"), exports);
26
26
  __exportStar(require("./upperToLower"), exports);
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd2F0Y2hmdWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsd0NBQXNCO0FBQ3RCLDJDQUF5QjtBQUN6Qix3Q0FBc0I7QUFDdEIsMENBQXdCO0FBQ3hCLDZDQUEyQjtBQUMzQiwyQ0FBeUI7QUFDekIsZ0RBQThCO0FBQzlCLHlEQUF1QztBQUN2QyxzREFBb0M7QUFDcEMsNkNBQTJCO0FBQzNCLGlEQUErQjtBQUMvQix3Q0FBc0I7QUFDdEIsK0NBQTZCO0FBQzdCLGlEQUErQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWxiJztcbmV4cG9ydCAqIGZyb20gJy4vYXNwZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vZWNzJztcbmV4cG9ydCAqIGZyb20gJy4vZG9jZGInO1xuZXhwb3J0ICogZnJvbSAnLi9keW5hbW9kYic7XG5leHBvcnQgKiBmcm9tICcuL2xhbWJkYSc7XG5leHBvcnQgKiBmcm9tICcuL3RhcmdldGdyb3VwJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YWRvZy1tZXRyaWMtYWxhcm0nO1xuZXhwb3J0ICogZnJvbSAnLi9kYXRhZG9nLWxvZy1hbGFybSc7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoZnVsJztcbmV4cG9ydCAqIGZyb20gJy4vbWV0cmljLWFsYXJtJztcbmV4cG9ydCAqIGZyb20gJy4vcmRzJztcbmV4cG9ydCAqIGZyb20gJy4vY2xvdWRmcm9udCc7XG5leHBvcnQgKiBmcm9tICcuL3VwcGVyVG9Mb3dlcic7Il19
27
+ __exportStar(require("./monitor-type"), exports);
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvd2F0Y2hmdWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBQUEsd0NBQXNCO0FBQ3RCLDJDQUF5QjtBQUN6Qix3Q0FBc0I7QUFDdEIsMENBQXdCO0FBQ3hCLDZDQUEyQjtBQUMzQiwyQ0FBeUI7QUFDekIsZ0RBQThCO0FBQzlCLHlEQUF1QztBQUN2QyxzREFBb0M7QUFDcEMsNkNBQTJCO0FBQzNCLGlEQUErQjtBQUMvQix3Q0FBc0I7QUFDdEIsK0NBQTZCO0FBQzdCLGlEQUErQjtBQUMvQixpREFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FsYic7XG5leHBvcnQgKiBmcm9tICcuL2FzcGVjdCc7XG5leHBvcnQgKiBmcm9tICcuL2Vjcyc7XG5leHBvcnQgKiBmcm9tICcuL2RvY2RiJztcbmV4cG9ydCAqIGZyb20gJy4vZHluYW1vZGInO1xuZXhwb3J0ICogZnJvbSAnLi9sYW1iZGEnO1xuZXhwb3J0ICogZnJvbSAnLi90YXJnZXRncm91cCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGFkb2ctbWV0cmljLWFsYXJtJztcbmV4cG9ydCAqIGZyb20gJy4vZGF0YWRvZy1sb2ctYWxhcm0nO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaGZ1bCc7XG5leHBvcnQgKiBmcm9tICcuL21ldHJpYy1hbGFybSc7XG5leHBvcnQgKiBmcm9tICcuL3Jkcyc7XG5leHBvcnQgKiBmcm9tICcuL2Nsb3VkZnJvbnQnO1xuZXhwb3J0ICogZnJvbSAnLi91cHBlclRvTG93ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9tb25pdG9yLXR5cGUnOyJdfQ==
@@ -7,6 +7,7 @@ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
7
  const cw = require("aws-cdk-lib/aws-cloudwatch");
8
8
  const constructs_1 = require("constructs");
9
9
  const datadog_log_alarm_1 = require("./datadog-log-alarm");
10
+ const monitor_type_1 = require("./monitor-type");
10
11
  const DEFAULT_DURATION_THRESHOLD_PERCENT = 80;
11
12
  /**
12
13
  * A Construct which creates the following alarms for lambda functions:
@@ -22,10 +23,10 @@ class WatchLambdaFunction extends constructs_1.Construct {
22
23
  const timeoutSec = cfnFunction.timeout || 3;
23
24
  this.watchful = props.watchful;
24
25
  this.fn = props.fn;
25
- this.watchful.createAlarm(this, 'Errors', this.createErrorsMonitor(props.errorsPerMinuteThreshold));
26
- this.watchful.createAlarm(this, 'Throttles', this.createThrottlesMonitor(props.throttlesPerMinuteThreshold));
27
- this.watchful.createAlarm(this, 'Duration', this.createDurationMonitor(timeoutSec, props.durationThresholdPercent));
28
- this.watchful.createLogAlarm(this, 'LogErrorMonitor', this.createLogErrorMonitor());
26
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.ERRORS, this.createErrorsMonitor(props.errorsPerMinuteThreshold));
27
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.THROTTLES, this.createThrottlesMonitor(props.throttlesPerMinuteThreshold));
28
+ this.watchful.createAlarm(this, monitor_type_1.MonitorType.DURATION, this.createDurationMonitor(timeoutSec, props.durationThresholdPercent));
29
+ this.watchful.createLogAlarm(this, monitor_type_1.MonitorType.LOG_ERROR_MONITOR, this.createLogErrorMonitor());
29
30
  }
30
31
  createLogErrorMonitor() {
31
32
  return {
@@ -80,4 +81,4 @@ class WatchLambdaFunction extends constructs_1.Construct {
80
81
  exports.WatchLambdaFunction = WatchLambdaFunction;
81
82
  _a = JSII_RTTI_SYMBOL_1;
82
83
  WatchLambdaFunction[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchLambdaFunction", version: "0.0.0" };
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["../../src/watchful/lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport { ComparisonOperator, LogAlarmProps, UnitOfPeriod } from './datadog-log-alarm';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { IWatchful } from './watchful';\n\nconst DEFAULT_DURATION_THRESHOLD_PERCENT = 80;\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchLambdaFunctionOptions {\n  /**\n     * Number of allowed errors per minute. If there are more errors than that, an alarm will trigger.\n     *\n     * @defaultValue 0\n     */\n  readonly errorsPerMinuteThreshold?: number;\n\n  /**\n     * Number of allowed throttles per minute.\n     *\n     * @defaultValue 0\n     */\n  readonly throttlesPerMinuteThreshold?: number;\n\n  /**\n     * Threshold for the duration alarm as percentage of the function's timeout\n     * value.\n     *\n     * If this is set to 50%, the alarm will be set when p99 latency of the\n     * function exceeds 50% of the function's timeout setting.\n     *\n     * @defaultValue 80\n     */\n  readonly durationThresholdPercent?: number;\n}\n\n/**\n * Properties for defining a WatchLambdaFunction\n */\nexport interface WatchLambdaFunctionProps extends WatchLambdaFunctionOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The lambda function that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly fn: lambda.Function;\n}\n\n/**\n * A Construct which creates the following alarms for lambda functions:\n *\n * - errors\n * - throttles\n * - duration\n */\nexport class WatchLambdaFunction extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly fn: lambda.Function;\n\n  constructor(scope: Construct, id: string, props: WatchLambdaFunctionProps) {\n    super(scope, id);\n\n    const cfnFunction = props.fn.node.defaultChild as lambda.CfnFunction;\n    const timeoutSec = cfnFunction.timeout || 3;\n\n    this.watchful = props.watchful;\n    this.fn = props.fn;\n\n    this.watchful.createAlarm(this, 'Errors', this.createErrorsMonitor(props.errorsPerMinuteThreshold));\n    this.watchful.createAlarm(this, 'Throttles', this.createThrottlesMonitor(props.throttlesPerMinuteThreshold));\n    this.watchful.createAlarm(this,\n      'Duration',\n      this.createDurationMonitor(timeoutSec, props.durationThresholdPercent),\n    );\n    this.watchful.createLogAlarm(\n      this,\n      'LogErrorMonitor',\n      this.createLogErrorMonitor(),\n    );\n  }\n\n  private createLogErrorMonitor(): LogAlarmProps {\n    return {\n      autoCloseOpsGenieAlerts: true,\n      period: Duration.minutes(5),\n      unitOfPeriod: UnitOfPeriod.MINUTES, // toDo: move that somewhere else and set defaults there?\n      periodOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      statistic: 'count',\n      queryFilters: 'error',\n      alarmDescription: 'Auto-generated alert for Lambda error logs',\n      threshold: 1,\n      priority: 3,\n      index: '*', // toDo: we should take here the team name but for older setups to work we keep that for compatibility\n      lambdaCloudwatchGroupName: this.fn.functionName,\n    };\n  }\n  private createErrorsMonitor(errorsPerMinuteThreshold = 0): MetricAlarmProps {\n    const fn = this.fn;\n    const errorsMetric = fn.metricErrors();\n    return {\n      metric: errorsMetric,\n      alarmDescription: `Over ${errorsPerMinuteThreshold} errors per minute`,\n      threshold: errorsPerMinuteThreshold,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: 3,\n    };\n  }\n\n  private createThrottlesMonitor(throttlesPerMinuteThreshold = 0): MetricAlarmProps {\n    const fn = this.fn;\n    const throttlesMetric = fn.metricThrottles();\n    return {\n      metric: throttlesMetric,\n      alarmDescription: `Over ${throttlesPerMinuteThreshold} throttles per minute`,\n      threshold: throttlesPerMinuteThreshold,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: 3,\n    };\n  }\n\n  private createDurationMonitor(\n    timeoutSec: number,\n    durationPercentThreshold: number = DEFAULT_DURATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const fn = this.fn;\n    const durationMetric = fn.metricDuration();\n    const durationThresholdSec = Math.floor((durationPercentThreshold / 100) * timeoutSec);\n    return {\n      metric: durationMetric,\n      alarmDescription: `p99 latency >= ${durationThresholdSec}s (${durationPercentThreshold}%)`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: durationThresholdSec * 1000, // milliseconds\n      evaluationPeriods: 3,\n    };\n  }\n}\n"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda.js","sourceRoot":"","sources":["../../src/watchful/lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport { Construct } from 'constructs';\nimport { ComparisonOperator, LogAlarmProps, UnitOfPeriod } from './datadog-log-alarm';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { MonitorType } from './monitor-type';\nimport { IWatchful } from './watchful';\n\nconst DEFAULT_DURATION_THRESHOLD_PERCENT = 80;\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchLambdaFunctionOptions {\n  /**\n     * Number of allowed errors per minute. If there are more errors than that, an alarm will trigger.\n     *\n     * @defaultValue 0\n     */\n  readonly errorsPerMinuteThreshold?: number;\n\n  /**\n     * Number of allowed throttles per minute.\n     *\n     * @defaultValue 0\n     */\n  readonly throttlesPerMinuteThreshold?: number;\n\n  /**\n     * Threshold for the duration alarm as percentage of the function's timeout\n     * value.\n     *\n     * If this is set to 50%, the alarm will be set when p99 latency of the\n     * function exceeds 50% of the function's timeout setting.\n     *\n     * @defaultValue 80\n     */\n  readonly durationThresholdPercent?: number;\n}\n\n/**\n * Properties for defining a WatchLambdaFunction\n */\nexport interface WatchLambdaFunctionProps extends WatchLambdaFunctionOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The lambda function that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly fn: lambda.Function;\n}\n\n/**\n * A Construct which creates the following alarms for lambda functions:\n *\n * - errors\n * - throttles\n * - duration\n */\nexport class WatchLambdaFunction extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly fn: lambda.Function;\n\n  constructor(scope: Construct, id: string, props: WatchLambdaFunctionProps) {\n    super(scope, id);\n\n    const cfnFunction = props.fn.node.defaultChild as lambda.CfnFunction;\n    const timeoutSec = cfnFunction.timeout || 3;\n\n    this.watchful = props.watchful;\n    this.fn = props.fn;\n\n    this.watchful.createAlarm(this, MonitorType.ERRORS, this.createErrorsMonitor(props.errorsPerMinuteThreshold));\n    this.watchful.createAlarm(this, MonitorType.THROTTLES, this.createThrottlesMonitor(props.throttlesPerMinuteThreshold));\n    this.watchful.createAlarm(this,\n      MonitorType.DURATION,\n      this.createDurationMonitor(timeoutSec, props.durationThresholdPercent),\n    );\n    this.watchful.createLogAlarm(\n      this,\n      MonitorType.LOG_ERROR_MONITOR,\n      this.createLogErrorMonitor(),\n    );\n  }\n\n  private createLogErrorMonitor(): LogAlarmProps {\n    return {\n      autoCloseOpsGenieAlerts: true,\n      period: Duration.minutes(5),\n      unitOfPeriod: UnitOfPeriod.MINUTES, // toDo: move that somewhere else and set defaults there?\n      periodOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      statistic: 'count',\n      queryFilters: 'error',\n      alarmDescription: 'Auto-generated alert for Lambda error logs',\n      threshold: 1,\n      priority: 3,\n      index: '*', // toDo: we should take here the team name but for older setups to work we keep that for compatibility\n      lambdaCloudwatchGroupName: this.fn.functionName,\n    };\n  }\n  private createErrorsMonitor(errorsPerMinuteThreshold = 0): MetricAlarmProps {\n    const fn = this.fn;\n    const errorsMetric = fn.metricErrors();\n    return {\n      metric: errorsMetric,\n      alarmDescription: `Over ${errorsPerMinuteThreshold} errors per minute`,\n      threshold: errorsPerMinuteThreshold,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: 3,\n    };\n  }\n\n  private createThrottlesMonitor(throttlesPerMinuteThreshold = 0): MetricAlarmProps {\n    const fn = this.fn;\n    const throttlesMetric = fn.metricThrottles();\n    return {\n      metric: throttlesMetric,\n      alarmDescription: `Over ${throttlesPerMinuteThreshold} throttles per minute`,\n      threshold: throttlesPerMinuteThreshold,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      evaluationPeriods: 3,\n    };\n  }\n\n  private createDurationMonitor(\n    timeoutSec: number,\n    durationPercentThreshold: number = DEFAULT_DURATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const fn = this.fn;\n    const durationMetric = fn.metricDuration();\n    const durationThresholdSec = Math.floor((durationPercentThreshold / 100) * timeoutSec);\n    return {\n      metric: durationMetric,\n      alarmDescription: `p99 latency >= ${durationThresholdSec}s (${durationPercentThreshold}%)`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: durationThresholdSec * 1000, // milliseconds\n      evaluationPeriods: 3,\n    };\n  }\n}\n"]}