@rio-cloud/cdk-v2-constructs 4.32.0 → 4.33.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +228 -40
- package/API.md +208 -23
- package/CHANGELOG.md +20 -0
- package/README.md +3 -3
- package/lib/contributions/team-oubout-order-book/aws-ecs-abruptly-stopped-monitor/aws-ecs-abruptly-stopped-monitor.d.ts +36 -12
- package/lib/contributions/team-oubout-order-book/aws-ecs-abruptly-stopped-monitor/aws-ecs-abruptly-stopped-monitor.js +17 -11
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.d.ts +3 -0
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +46 -25
- package/lib/index.js +1 -1
- package/lib/kafka/kafka-event-spec.js +4 -3
- package/lib/watchful/alb.js +3 -1
- package/lib/watchful/cloudfront.js +3 -1
- package/lib/watchful/docdb.js +5 -1
- package/lib/watchful/dynamodb.js +4 -1
- package/lib/watchful/ecs.js +3 -1
- package/lib/watchful/lambda.js +4 -1
- package/lib/watchful/metric-alarm.d.ts +4 -0
- package/lib/watchful/metric-alarm.js +1 -1
- package/lib/watchful/rds.js +3 -1
- package/lib/watchful/targetgroup.js +3 -1
- package/lib/watchful/watchful.js +2 -1
- package/lib/watchfulv2/datadog-log-alarm.d.ts +1 -0
- package/lib/watchfulv2/datadog-log-alarm.js +4 -1
- package/lib/watchfulv2/datadog-metric-alarm.js +2 -1
- package/lib/watchfulv2/watchful.d.ts +45 -0
- package/lib/watchfulv2/watchful.js +13 -3
- package/package.json +1 -1
- package/version.json +1 -1
|
@@ -2,6 +2,39 @@ import { Construct } from 'constructs';
|
|
|
2
2
|
import { LogAlarmProps } from './datadog-log-alarm';
|
|
3
3
|
import { INotification } from '../datadogv2';
|
|
4
4
|
import { MetricAlarmProps, AbstractWatchful, MonitorType } from '../watchful';
|
|
5
|
+
/**
|
|
6
|
+
* Log error monitor props
|
|
7
|
+
*/
|
|
8
|
+
export interface LogErrorMonitorProps {
|
|
9
|
+
/**
|
|
10
|
+
* Configure if monitor needs to be resolved manually every time. This option also sets the renotify interval to 2 hours
|
|
11
|
+
* @defaultValue false
|
|
12
|
+
*/
|
|
13
|
+
readonly disableAutoClose?: boolean;
|
|
14
|
+
/**
|
|
15
|
+
* Set the priority of the log error monitor
|
|
16
|
+
* @defaultValue 3
|
|
17
|
+
*/
|
|
18
|
+
readonly priority?: number;
|
|
19
|
+
/**
|
|
20
|
+
* Enable error log monitors creating cases in Datadog.
|
|
21
|
+
* This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig.
|
|
22
|
+
* The functionality remains unchanged
|
|
23
|
+
*
|
|
24
|
+
* @defaultValue {@link false}
|
|
25
|
+
*/
|
|
26
|
+
readonly createCasesFromErrorLogMonitors?: boolean;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Query error monitor props
|
|
30
|
+
*/
|
|
31
|
+
export interface QueryErrorMonitorProps {
|
|
32
|
+
/**
|
|
33
|
+
* Set the priority of the log error monitor
|
|
34
|
+
* @defaultValue 3
|
|
35
|
+
*/
|
|
36
|
+
readonly priority?: number;
|
|
37
|
+
}
|
|
5
38
|
/**
|
|
6
39
|
* Properties for defining Watchful
|
|
7
40
|
*/
|
|
@@ -21,9 +54,19 @@ export interface WatchfulProps {
|
|
|
21
54
|
/**
|
|
22
55
|
* Enable error log monitors creating cases in Datadog.
|
|
23
56
|
*
|
|
57
|
+
* @deprecated This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig. The functionality remains unchanged.
|
|
24
58
|
* @defaultValue {@link false}
|
|
25
59
|
*/
|
|
26
60
|
readonly createCasesFromErrorLogMonitors?: boolean;
|
|
61
|
+
/**
|
|
62
|
+
* Configure log error monitor properties
|
|
63
|
+
*/
|
|
64
|
+
readonly logErrorMonitorConfig?: LogErrorMonitorProps;
|
|
65
|
+
/**
|
|
66
|
+
* Configure query alert monitors. All monitors created by watchful except for Log error monitor.
|
|
67
|
+
* Configure property *logErrorMonitor* for Log error monitor.
|
|
68
|
+
*/
|
|
69
|
+
readonly queryErrorMonitorConfig?: QueryErrorMonitorProps;
|
|
27
70
|
}
|
|
28
71
|
/**
|
|
29
72
|
* A construct to watch given scope or resources. Opinionated DataDog alarms are automatically created for watched resources.
|
|
@@ -41,6 +84,8 @@ export declare class Watchful extends AbstractWatchful {
|
|
|
41
84
|
private readonly notification;
|
|
42
85
|
private readonly createCasesFromErrorLogMonitors;
|
|
43
86
|
private readonly serviceName;
|
|
87
|
+
private readonly logErrorMonitorConfig?;
|
|
88
|
+
private readonly queryErrorMonitorConfig?;
|
|
44
89
|
constructor(scope: Construct, id: string, props?: WatchfulProps);
|
|
45
90
|
/**
|
|
46
91
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
@@ -25,7 +25,15 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
25
25
|
super(scope, id);
|
|
26
26
|
this.serviceName = props.serviceName ?? aws_cdk_lib_1.Stack.of(this).stackName;
|
|
27
27
|
this.notification = props.notification ?? new datadogv2_1.DefaultSlackNotification();
|
|
28
|
-
this.createCasesFromErrorLogMonitors = props.createCasesFromErrorLogMonitors
|
|
28
|
+
this.createCasesFromErrorLogMonitors = props.logErrorMonitorConfig?.createCasesFromErrorLogMonitors
|
|
29
|
+
?? props.createCasesFromErrorLogMonitors
|
|
30
|
+
?? false;
|
|
31
|
+
if (props.createCasesFromErrorLogMonitors) {
|
|
32
|
+
const annotations = aws_cdk_lib_1.Annotations.of(aws_cdk_lib_1.Stack.of(this));
|
|
33
|
+
annotations.addWarningV2(scope.node.path, '\n ❌ This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig.\n');
|
|
34
|
+
}
|
|
35
|
+
this.queryErrorMonitorConfig = props.queryErrorMonitorConfig;
|
|
36
|
+
this.logErrorMonitorConfig = props.logErrorMonitorConfig;
|
|
29
37
|
}
|
|
30
38
|
/**
|
|
31
39
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
@@ -43,6 +51,7 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
43
51
|
metric: alarm.metric,
|
|
44
52
|
threshold: shouldOverrideThreshold ? threshold : alarm.threshold,
|
|
45
53
|
treatMissingData: alarm.treatMissingData,
|
|
54
|
+
priority: this.queryErrorMonitorConfig?.priority ?? alarm.priority,
|
|
46
55
|
});
|
|
47
56
|
}
|
|
48
57
|
/**
|
|
@@ -65,8 +74,9 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
65
74
|
queryFilters: alarm.queryFilters,
|
|
66
75
|
alarmDescription: alarm.alarmDescription,
|
|
67
76
|
threshold: shouldOverrideThreshold ? threshold : alarm.threshold,
|
|
68
|
-
priority: alarm.priority,
|
|
77
|
+
priority: this.logErrorMonitorConfig?.priority ?? alarm.priority,
|
|
69
78
|
index: alarm.index,
|
|
79
|
+
disableAutoClose: this.logErrorMonitorConfig?.disableAutoClose,
|
|
70
80
|
});
|
|
71
81
|
}
|
|
72
82
|
/**
|
|
@@ -80,4 +90,4 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
80
90
|
exports.Watchful = Watchful;
|
|
81
91
|
_a = JSII_RTTI_SYMBOL_1;
|
|
82
92
|
Watchful[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.watchfulv2.Watchful", version: "0.0.0" };
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watchful.js","sourceRoot":"","sources":["../../src/watchfulv2/watchful.ts"],"names":[],"mappings":"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","sourcesContent":["import { Aspects, Stack } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DataDogLogAlarm, LogAlarmProps } from './datadog-log-alarm';\nimport { DataDogMetricAlarm } from './datadog-metric-alarm';\nimport { DatadogCaseNotification, DefaultSlackNotification, NotificationAggregator, INotification } from '../datadogv2';\nimport { WatchfulAspect, MetricAlarmProps, AbstractWatchful, MonitorType } from '../watchful';\n\n/**\n * Properties for defining Watchful\n */\nexport interface WatchfulProps {\n  /**\n   * The service name.\n   *\n   * @defaultValue The stack name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * Set the way how monitors should notify in case of an alert.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   */\n  readonly notification?: INotification;\n\n  /**\n   * Enable error log monitors creating cases in Datadog.\n   *\n   * @defaultValue {@link false}\n   */\n  readonly createCasesFromErrorLogMonitors?: boolean;\n}\n\n/**\n * A construct to watch given scope or resources. Opinionated DataDog alarms are automatically created for watched resources.\n *\n * Usage with non-default notification:\n * ```ts\n * const dw = new watchfulv2.Watchful(this, 'Watchful', {\n *   serviceName: props.serviceName,\n *   notification: new datadogv2.SlackNotification({channel: 'team-alert-channel'})\n * });\n * dw.watchScope(this);\n *```\n */\nexport class Watchful extends AbstractWatchful {\n  private readonly notification: INotification;\n  private readonly createCasesFromErrorLogMonitors: boolean;\n  private readonly serviceName: string;\n\n  constructor(scope: Construct, id: string, props: WatchfulProps = {}) {\n    super(scope, id);\n    this.serviceName = props.serviceName ?? Stack.of(this).stackName;\n\n    this.notification = props.notification ?? new DefaultSlackNotification();\n    this.createCasesFromErrorLogMonitors = props.createCasesFromErrorLogMonitors ?? false;\n  }\n\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\n   *\n   * @param alarm - The watchful to add those resources to\n   */\n  public createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    new DataDogMetricAlarm(scope, id, {\n      serviceName: this.serviceName,\n      notification: this.notification,\n      alarmDescription: alarm.alarmDescription,\n      comparisonOperator: alarm.comparisonOperator,\n      evaluationPeriods: alarm.evaluationPeriods,\n      metric: alarm.metric,\n      threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n      treatMissingData: alarm.treatMissingData,\n    });\n\n  }\n\n  /**\n   * Adds an alert for error logs\n   * @param scope\n   */\n  public createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps):void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    const notfications: INotification = this.createCasesFromErrorLogMonitors\n      ? new NotificationAggregator([this.notification, new DatadogCaseNotification()])\n      : this.notification;\n\n    new DataDogLogAlarm(scope, id, {\n      serviceName: alarm.lambdaCloudwatchGroupName ?? this.serviceName,\n      notification: notfications,\n      autoCloseOpsGenieAlerts: alarm.autoCloseOpsGenieAlerts,\n      period: alarm.period,\n      unitOfPeriod: alarm.unitOfPeriod, // toDo: move that somewhere else and set defaults there?\n      periodOperator: alarm.periodOperator,\n      statistic: alarm.statistic,\n      queryFilters: alarm.queryFilters, // toDo: move that somewhere else and set defaults there?\n      alarmDescription: alarm.alarmDescription,\n      threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n      priority: alarm.priority,\n      index: alarm.index,\n    });\n  }\n\n  /**\n   * Watches the given scope and adds alarms for known resources.\n   */\n  public watchScope(scope: Construct): void {\n    const aspect = new WatchfulAspect(this);\n    Aspects.of(scope).add(aspect);\n  }\n}\n"]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watchful.js","sourceRoot":"","sources":["../../src/watchfulv2/watchful.ts"],"names":[],"mappings":"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","sourcesContent":["import { Aspects, Stack, Annotations } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { DataDogLogAlarm, LogAlarmProps } from './datadog-log-alarm';\nimport { DataDogMetricAlarm } from './datadog-metric-alarm';\nimport { DatadogCaseNotification, DefaultSlackNotification, NotificationAggregator, INotification } from '../datadogv2';\nimport { WatchfulAspect, MetricAlarmProps, AbstractWatchful, MonitorType } from '../watchful';\n\n/**\n * Log error monitor props\n */\nexport interface LogErrorMonitorProps {\n  /**\n   * Configure if monitor needs to be resolved manually every time. This option also sets the renotify interval to 2 hours\n   * @defaultValue false\n   */\n  readonly disableAutoClose?: boolean;\n\n  /**\n   * Set the priority of the log error monitor\n   * @defaultValue 3\n   */\n  readonly priority?: number;\n\n  /**\n   * Enable error log monitors creating cases in Datadog.\n   * This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig.\n   * The functionality remains unchanged\n   *\n   * @defaultValue {@link false}\n   */\n  readonly createCasesFromErrorLogMonitors?: boolean;\n}\n\n/**\n * Query error monitor props\n */\nexport interface QueryErrorMonitorProps {\n  /**\n   * Set the priority of the log error monitor\n   * @defaultValue 3\n   */\n  readonly priority?: number;\n}\n\n/**\n * Properties for defining Watchful\n */\nexport interface WatchfulProps {\n  /**\n   * The service name.\n   *\n   * @defaultValue The stack name.\n   */\n  readonly serviceName?: string;\n\n  /**\n   * Set the way how monitors should notify in case of an alert.\n   *\n   * @defaultValue {@link DefaultSlackNotification}\n   */\n  readonly notification?: INotification;\n\n  /**\n   * Enable error log monitors creating cases in Datadog.\n   *\n   * @deprecated This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig. The functionality remains unchanged.\n   * @defaultValue {@link false}\n   */\n  readonly createCasesFromErrorLogMonitors?: boolean;\n\n  /**\n   * Configure log error monitor properties\n   */\n  readonly logErrorMonitorConfig?: LogErrorMonitorProps;\n\n  /**\n   * Configure query alert monitors. All monitors created by watchful except for Log error monitor.\n   * Configure property *logErrorMonitor* for Log error monitor.\n   */\n  readonly queryErrorMonitorConfig?: QueryErrorMonitorProps;\n}\n\n/**\n * A construct to watch given scope or resources. Opinionated DataDog alarms are automatically created for watched resources.\n *\n * Usage with non-default notification:\n * ```ts\n * const dw = new watchfulv2.Watchful(this, 'Watchful', {\n *   serviceName: props.serviceName,\n *   notification: new datadogv2.SlackNotification({channel: 'team-alert-channel'})\n * });\n * dw.watchScope(this);\n *```\n */\nexport class Watchful extends AbstractWatchful {\n  private readonly notification: INotification;\n  private readonly createCasesFromErrorLogMonitors: boolean;\n  private readonly serviceName: string;\n  private readonly logErrorMonitorConfig?: LogErrorMonitorProps;\n  private readonly queryErrorMonitorConfig?: QueryErrorMonitorProps;\n\n  constructor(scope: Construct, id: string, props: WatchfulProps = {}) {\n    super(scope, id);\n    this.serviceName = props.serviceName ?? Stack.of(this).stackName;\n\n    this.notification = props.notification ?? new DefaultSlackNotification();\n    this.createCasesFromErrorLogMonitors = props.logErrorMonitorConfig?.createCasesFromErrorLogMonitors\n      ?? props.createCasesFromErrorLogMonitors\n      ?? false;\n    if (props.createCasesFromErrorLogMonitors) {\n      const annotations = Annotations.of(Stack.of(this));\n      annotations.addWarningV2(\n        scope.node.path,\n        '\\n ❌ This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig.\\n',\n      );\n    }\n    this.queryErrorMonitorConfig = props.queryErrorMonitorConfig;\n    this.logErrorMonitorConfig = props.logErrorMonitorConfig;\n  }\n\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\n   *\n   * @param alarm - The watchful to add those resources to\n   */\n  public createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    new DataDogMetricAlarm(scope, id, {\n      serviceName: this.serviceName,\n      notification: this.notification,\n      alarmDescription: alarm.alarmDescription,\n      comparisonOperator: alarm.comparisonOperator,\n      evaluationPeriods: alarm.evaluationPeriods,\n      metric: alarm.metric,\n      threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n      treatMissingData: alarm.treatMissingData,\n      priority: this.queryErrorMonitorConfig?.priority ?? alarm.priority,\n    });\n\n  }\n\n  /**\n   * Adds an alert for error logs\n   * @param scope\n   */\n  public createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps):void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    const notfications: INotification = this.createCasesFromErrorLogMonitors\n      ? new NotificationAggregator([this.notification, new DatadogCaseNotification()])\n      : this.notification;\n\n    new DataDogLogAlarm(scope, id, {\n      serviceName: alarm.lambdaCloudwatchGroupName ?? this.serviceName,\n      notification: notfications,\n      autoCloseOpsGenieAlerts: alarm.autoCloseOpsGenieAlerts,\n      period: alarm.period,\n      unitOfPeriod: alarm.unitOfPeriod, // toDo: move that somewhere else and set defaults there?\n      periodOperator: alarm.periodOperator,\n      statistic: alarm.statistic,\n      queryFilters: alarm.queryFilters, // toDo: move that somewhere else and set defaults there?\n      alarmDescription: alarm.alarmDescription,\n      threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n      priority: this.logErrorMonitorConfig?.priority ?? alarm.priority,\n      index: alarm.index,\n      disableAutoClose: this.logErrorMonitorConfig?.disableAutoClose,\n    });\n  }\n\n  /**\n   * Watches the given scope and adds alarms for known resources.\n   */\n  public watchScope(scope: Construct): void {\n    const aspect = new WatchfulAspect(this);\n    Aspects.of(scope).add(aspect);\n  }\n}\n"]}
|
package/package.json
CHANGED
package/version.json
CHANGED