@rio-cloud/cdk-v2-constructs 6.7.1 → 6.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +172 -81
- package/CHANGELOG.md +14 -0
- package/docs/API.md +159 -43
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.d.ts +12 -12
- package/lib/contributions/team-transport-two/pipeline/pipeline-stack.js +1 -1
- package/lib/datadog/datadog-monitor.d.ts +2 -2
- package/lib/datadog/datadog-monitor.js +1 -1
- package/lib/datadogv2/datadog-dashboard.d.ts +1 -1
- package/lib/datadogv2/datadog-dashboard.js +1 -1
- package/lib/datadogv2/datadog-monitor.js +1 -2
- package/lib/datadogv2/datadog-notification.d.ts +4 -4
- package/lib/datadogv2/datadog-notification.js +3 -3
- package/lib/fargate/rio-fargate-service.d.ts +6 -6
- package/lib/fargate/rio-fargate-service.js +1 -1
- package/lib/kafka/kafka-event-spec.d.ts +2 -2
- package/lib/kafka/kafka-event-spec.js +3 -3
- package/lib/kafka/kafka-topic.js +1 -1
- package/lib/kafka/rio-kafka-event-source.d.ts +4 -1
- package/lib/kafka/rio-kafka-event-source.js +1 -1
- package/lib/pipeline/rio-backup-secrets-restore-stage.js +1 -3
- package/lib/toggle.d.ts +7 -7
- package/lib/toggle.js +9 -12
- package/lib/watchful/ecs.d.ts +7 -0
- package/lib/watchful/ecs.js +21 -1
- package/lib/watchful/monitor-type.d.ts +5 -1
- package/lib/watchful/monitor-type.js +5 -1
- package/lib/watchful/watchful.d.ts +19 -3
- package/lib/watchful/watchful.js +15 -3
- package/lib/watchfulv2/watchful.d.ts +7 -3
- package/lib/watchfulv2/watchful.js +7 -3
- package/package.json +1 -1
- package/version.json +1 -1
package/lib/watchful/ecs.js
CHANGED
|
@@ -9,6 +9,7 @@ const constructs_1 = require("constructs");
|
|
|
9
9
|
const __1 = require("..");
|
|
10
10
|
const DEFAULT_CPU_UTILIZATION_THRESHOLD_PERCENT = 80;
|
|
11
11
|
const DEFAULT_MEMORY_UTILIZATION_THRESHOLD_PERCENT = 85;
|
|
12
|
+
const DEFAULT_MINIMUM_NUMBER_OF_TASKS = 1;
|
|
12
13
|
/**
|
|
13
14
|
* A Construct which creates default alarms for ECS services.
|
|
14
15
|
* A Construct which creates the following alarms for ECS services:
|
|
@@ -24,6 +25,7 @@ class WatchEcsService extends constructs_1.Construct {
|
|
|
24
25
|
this.service = props.service;
|
|
25
26
|
this.watchful.createAlarm(this, __1.MonitorType.CPU_UTILIZATION, this.createCpuUtilizationMonitor(props.cpuUtilizationThresholdPercent));
|
|
26
27
|
this.watchful.createAlarm(this, __1.MonitorType.MEMORY_UTILIZATION, this.createMemoryUtilizationMonitor(props.memoryUtilizationThresholdPercent));
|
|
28
|
+
this.watchful.createAlarm(this, __1.MonitorType.RUNNING_TASKS, this.createNumberOfTasksMonitor(props.minimumNumberOfTasks));
|
|
27
29
|
this.watchful.createLogAlarm(this, __1.MonitorType.LOG_ERROR_MONITOR, this.createLogErrorMonitor());
|
|
28
30
|
}
|
|
29
31
|
createLogErrorMonitor() {
|
|
@@ -68,8 +70,26 @@ class WatchEcsService extends constructs_1.Construct {
|
|
|
68
70
|
priority: 3,
|
|
69
71
|
};
|
|
70
72
|
}
|
|
73
|
+
createNumberOfTasksMonitor(minimumNumberOfTasks = DEFAULT_MINIMUM_NUMBER_OF_TASKS) {
|
|
74
|
+
return {
|
|
75
|
+
metric: this.service.metric('service.running', {
|
|
76
|
+
period: aws_cdk_lib_1.Duration.minutes(5),
|
|
77
|
+
statistic: 'min',
|
|
78
|
+
label: 'Number of running tasks',
|
|
79
|
+
dimensionsMap: {
|
|
80
|
+
account_id: aws_cdk_lib_1.Stack.of(this).account,
|
|
81
|
+
servicename: this.service.serviceName,
|
|
82
|
+
},
|
|
83
|
+
}),
|
|
84
|
+
alarmDescription: `Number of running tasks for ${this.service.serviceName} is less then ${minimumNumberOfTasks}`,
|
|
85
|
+
comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,
|
|
86
|
+
threshold: minimumNumberOfTasks,
|
|
87
|
+
evaluationPeriods: 1,
|
|
88
|
+
priority: 1,
|
|
89
|
+
};
|
|
90
|
+
}
|
|
71
91
|
}
|
|
72
92
|
exports.WatchEcsService = WatchEcsService;
|
|
73
93
|
_a = JSII_RTTI_SYMBOL_1;
|
|
74
94
|
WatchEcsService[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchEcsService", version: "0.0.0" };
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs.js","sourceRoot":"","sources":["../../src/watchful/ecs.ts"],"names":[],"mappings":";;;;;AAAA,6CAAuC;AACvC,iDAAiD;AAGjD,2CAAuC;AAEvC,0BAAoG;AAEpG,MAAM,yCAAyC,GAAG,EAAE,CAAC;AACrD,MAAM,4CAA4C,GAAG,EAAE,CAAC;AAqCxD;;;;;;;GAOG;AACH,MAAa,eAAgB,SAAQ,sBAAS;IAI5C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA2B;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAE7B,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAC5B,eAAW,CAAC,eAAe,EAC3B,IAAI,CAAC,2BAA2B,CAAC,KAAK,CAAC,8BAA8B,CAAC,CACvE,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,EAC5B,eAAW,CAAC,kBAAkB,EAC9B,IAAI,CAAC,8BAA8B,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAC7E,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,IAAI,EAC/B,eAAW,CAAC,iBAAiB,EAC7B,IAAI,CAAC,qBAAqB,EAAE,CAC7B,CAAC;IACJ,CAAC;IAEO,qBAAqB;QAC3B,OAAO;YACL,uBAAuB,EAAE,IAAI;YAC7B,MAAM,EAAE,sBAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;YAC3B,YAAY,EAAE,gBAAY,CAAC,OAAO,EAAE,yDAAyD;YAC7F,cAAc,EAAE,sBAAkB,CAAC,kCAAkC;YACrE,SAAS,EAAE,OAAO;YAClB,YAAY,EAAE,OAAO;YACrB,gBAAgB,EAAE,qCAAqC;YACvD,SAAS,EAAE,CAAC;YACZ,QAAQ,EAAE,CAAC;YACX,KAAK,EAAE,GAAG,EAAE,sGAAsG;SACnH,CAAC;IACJ,CAAC;IAEO,2BAA2B,CACjC,iCAAyC,yCAAyC;QAElF,MAAM,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,oBAAoB,EAAE,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QACxG,OAAO;YACL,MAAM,EAAE,oBAAoB;YAC5B,gBAAgB,EAAE,4DAA4D,8BAA8B,GAAG;YAC/G,kBAAkB,EAAE,EAAE,CAAC,kBAAkB,CAAC,sBAAsB;YAChE,SAAS,EAAE,8BAA8B;YACzC,iBAAiB,EAAE,CAAC;YACpB,QAAQ,EAAE,CAAC;SACZ,CAAC;IACJ,CAAC;IAEO,8BAA8B,CACpC,oCAA4C,4CAA4C;QAExF,MAAM,uBAAuB,GAAG,IAAI,CAAC,OAAO;aACzC,uBAAuB,EAAE;aACzB,IAAI,CAAC,EAAE,MAAM,EAAE,sBAAQ,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;QAE1C,MAAM,YAAY,GAAG,IAAI,EAAE,CAAC,MAAM,CAAC;YACjC,GAAG,uBAAsC;YACzC,UAAU,EAAE,GAAG,uBAAuB,CAAC,UAAU,UAAU;SAC5D,CAAC,CAAC;QACH,OAAO;YACL,MAAM,EAAE,YAAY;YACpB,gBAAgB,EAAE,+DAA+D,iCAAiC,GAAG;YACrH,kBAAkB,EAAE,EAAE,CAAC,kBAAkB,CAAC,sBAAsB;YAChE,SAAS,EAAE,iCAAiC;YAC5C,iBAAiB,EAAE,CAAC;YACpB,QAAQ,EAAE,CAAC;SACZ,CAAC;IACJ,CAAC;;AAxEH,0CA0EC","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport { MetricProps } from 'aws-cdk-lib/aws-cloudwatch';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Construct } from 'constructs';\nimport { IWatchful } from './watchful';\nimport { ComparisonOperator, LogAlarmProps, MetricAlarmProps, MonitorType, UnitOfPeriod } from '..';\n\nconst DEFAULT_CPU_UTILIZATION_THRESHOLD_PERCENT = 80;\nconst DEFAULT_MEMORY_UTILIZATION_THRESHOLD_PERCENT = 85;\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchEcsServiceOptions {\n  /**\n     * Threshold for the cpu utilization alarm as percentage.\n     *\n     * @defaultValue 80\n     */\n  readonly cpuUtilizationThresholdPercent?: number;\n\n  /**\n     * Threshold for the memory utilization alarm as percentage.\n     *\n     * @defaultValue 95\n     */\n  readonly memoryUtilizationThresholdPercent?: number;\n}\n\n/**\n * Properties for defining a WatchEcsService\n */\nexport interface WatchEcsServiceProps extends WatchEcsServiceOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The ECS service that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly service: ecs.BaseService;\n}\n\n/**\n * A Construct which creates default alarms for ECS services.\n * A Construct which creates the following alarms for ECS services:\n *\n * - cpu utilization\n * - memory utilization\n * - error log alert\n */\nexport class WatchEcsService extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly service: ecs.BaseService;\n\n  constructor(scope: Construct, id: string, props: WatchEcsServiceProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.service = props.service;\n\n    this.watchful.createAlarm(this,\n      MonitorType.CPU_UTILIZATION,\n      this.createCpuUtilizationMonitor(props.cpuUtilizationThresholdPercent),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.MEMORY_UTILIZATION,\n      this.createMemoryUtilizationMonitor(props.memoryUtilizationThresholdPercent),\n    );\n    this.watchful.createLogAlarm(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 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    };\n  }\n\n  private createCpuUtilizationMonitor(\n    cpuUtilizationThresholdPercent: number = DEFAULT_CPU_UTILIZATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const cpuUtilizationMetric = this.service.metricCpuUtilization().with({ period: Duration.minutes(10) });\n    return {\n      metric: cpuUtilizationMetric,\n      alarmDescription: `Average CPU utilization over last 10 minutes higher than ${cpuUtilizationThresholdPercent}%`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: cpuUtilizationThresholdPercent,\n      evaluationPeriods: 1,\n      priority: 3,\n    };\n  }\n\n  private createMemoryUtilizationMonitor(\n    memoryUtilizationThresholdPercent: number = DEFAULT_MEMORY_UTILIZATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const memoryUtilizationMetric = this.service\n      .metricMemoryUtilization()\n      .with({ period: Duration.minutes(10) });\n\n    const mappedMetric = new cw.Metric({\n      ...memoryUtilizationMetric as MetricProps,\n      metricName: `${memoryUtilizationMetric.metricName}.maximum`,\n    });\n    return {\n      metric: mappedMetric,\n      alarmDescription: `Maximum memory utilization over last 10 minutes higher than ${memoryUtilizationThresholdPercent}%`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: memoryUtilizationThresholdPercent,\n      evaluationPeriods: 1,\n      priority: 3,\n    };\n  }\n\n}\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecs.js","sourceRoot":"","sources":["../../src/watchful/ecs.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Stack } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport { MetricProps } from 'aws-cdk-lib/aws-cloudwatch';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport { Construct } from 'constructs';\nimport { IWatchful } from './watchful';\nimport { ComparisonOperator, LogAlarmProps, MetricAlarmProps, MonitorType, UnitOfPeriod } from '..';\n\nconst DEFAULT_CPU_UTILIZATION_THRESHOLD_PERCENT = 80;\nconst DEFAULT_MEMORY_UTILIZATION_THRESHOLD_PERCENT = 85;\nconst DEFAULT_MINIMUM_NUMBER_OF_TASKS = 1;\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchEcsServiceOptions {\n  /**\n     * Threshold for the cpu utilization alarm as percentage.\n     *\n     * @defaultValue 80\n     */\n  readonly cpuUtilizationThresholdPercent?: number;\n\n  /**\n     * Threshold for the memory utilization alarm as percentage.\n     *\n     * @defaultValue 95\n     */\n  readonly memoryUtilizationThresholdPercent?: number;\n\n  /**\n     * Minimum number of tasks that should be running.\n     *\n     * @defaultValue 1\n     */\n  readonly minimumNumberOfTasks?: number;\n}\n\n/**\n * Properties for defining a WatchEcsService\n */\nexport interface WatchEcsServiceProps extends WatchEcsServiceOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The ECS service that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly service: ecs.BaseService;\n}\n\n/**\n * A Construct which creates default alarms for ECS services.\n * A Construct which creates the following alarms for ECS services:\n *\n * - cpu utilization\n * - memory utilization\n * - error log alert\n */\nexport class WatchEcsService extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly service: ecs.BaseService;\n\n  constructor(scope: Construct, id: string, props: WatchEcsServiceProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.service = props.service;\n\n    this.watchful.createAlarm(this,\n      MonitorType.CPU_UTILIZATION,\n      this.createCpuUtilizationMonitor(props.cpuUtilizationThresholdPercent),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.MEMORY_UTILIZATION,\n      this.createMemoryUtilizationMonitor(props.memoryUtilizationThresholdPercent),\n    );\n    this.watchful.createAlarm(this,\n      MonitorType.RUNNING_TASKS,\n      this.createNumberOfTasksMonitor(props.minimumNumberOfTasks),\n    );\n    this.watchful.createLogAlarm(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 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    };\n  }\n\n  private createCpuUtilizationMonitor(\n    cpuUtilizationThresholdPercent: number = DEFAULT_CPU_UTILIZATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const cpuUtilizationMetric = this.service.metricCpuUtilization().with({ period: Duration.minutes(10) });\n    return {\n      metric: cpuUtilizationMetric,\n      alarmDescription: `Average CPU utilization over last 10 minutes higher than ${cpuUtilizationThresholdPercent}%`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: cpuUtilizationThresholdPercent,\n      evaluationPeriods: 1,\n      priority: 3,\n    };\n  }\n\n  private createMemoryUtilizationMonitor(\n    memoryUtilizationThresholdPercent: number = DEFAULT_MEMORY_UTILIZATION_THRESHOLD_PERCENT,\n  ): MetricAlarmProps {\n    const memoryUtilizationMetric = this.service\n      .metricMemoryUtilization()\n      .with({ period: Duration.minutes(10) });\n\n    const mappedMetric = new cw.Metric({\n      ...memoryUtilizationMetric as MetricProps,\n      metricName: `${memoryUtilizationMetric.metricName}.maximum`,\n    });\n    return {\n      metric: mappedMetric,\n      alarmDescription: `Maximum memory utilization over last 10 minutes higher than ${memoryUtilizationThresholdPercent}%`,\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: memoryUtilizationThresholdPercent,\n      evaluationPeriods: 1,\n      priority: 3,\n    };\n  }\n\n  private createNumberOfTasksMonitor(minimumNumberOfTasks: number = DEFAULT_MINIMUM_NUMBER_OF_TASKS): MetricAlarmProps {\n    return {\n      metric: this.service.metric('service.running', {\n        period: Duration.minutes(5),\n        statistic: 'min',\n        label: 'Number of running tasks',\n        dimensionsMap: {\n          account_id: Stack.of(this).account,\n          servicename: this.service.serviceName,\n        },\n      }),\n      alarmDescription: `Number of running tasks for ${this.service.serviceName} is less then ${minimumNumberOfTasks}`,\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: minimumNumberOfTasks,\n      evaluationPeriods: 1,\n      priority: 1,\n    };\n  }\n}\n"]}
|
|
@@ -62,5 +62,9 @@ export declare enum MonitorType {
|
|
|
62
62
|
/**
|
|
63
63
|
* Connection error metrics for Application load balancer target group
|
|
64
64
|
*/
|
|
65
|
-
CONNECTION_ERROR = "ConnectionError"
|
|
65
|
+
CONNECTION_ERROR = "ConnectionError",
|
|
66
|
+
/**
|
|
67
|
+
* Running fargate tasks monitor
|
|
68
|
+
*/
|
|
69
|
+
RUNNING_TASKS = "RunningTasks"
|
|
66
70
|
}
|
|
@@ -67,5 +67,9 @@ var MonitorType;
|
|
|
67
67
|
* Connection error metrics for Application load balancer target group
|
|
68
68
|
*/
|
|
69
69
|
MonitorType["CONNECTION_ERROR"] = "ConnectionError";
|
|
70
|
+
/**
|
|
71
|
+
* Running fargate tasks monitor
|
|
72
|
+
*/
|
|
73
|
+
MonitorType["RUNNING_TASKS"] = "RunningTasks";
|
|
70
74
|
})(MonitorType || (exports.MonitorType = MonitorType = {}));
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9uaXRvci10eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3dhdGNoZnVsL21vbml0b3ItdHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxJQUFZLFdBc0ZYO0FBdEZELFdBQVksV0FBVztJQUVyQjs7T0FFRztJQUNILHlEQUEwQyxDQUFBO0lBRTFDOztPQUVHO0lBQ0gsMkNBQTRCLENBQUE7SUFFNUI7O09BRUc7SUFDSCw4Q0FBK0IsQ0FBQTtJQUUvQjs7T0FFRztJQUNILGlEQUFrQyxDQUFBO0lBRWxDOztPQUVHO0lBQ0gsOENBQStCLENBQUE7SUFFL0I7O09BRUc7SUFDSCw0REFBNkMsQ0FBQTtJQUU3Qzs7T0FFRztJQUNILDBEQUEyQyxDQUFBO0lBRTNDOztPQUVHO0lBQ0gsNERBQTZDLENBQUE7SUFFN0M7O09BRUc7SUFDSCxvRUFBcUQsQ0FBQTtJQUVyRDs7T0FFRztJQUNILHVEQUF3QyxDQUFBO0lBRXhDOztPQUVHO0lBQ0gsb0RBQXFDLENBQUE7SUFFckM7O09BRUc7SUFDSCxnQ0FBaUIsQ0FBQTtJQUVqQjs7T0FFRztJQUNILHNDQUF1QixDQUFBO0lBRXZCOztPQUVHO0lBQ0gsb0NBQXFCLENBQUE7SUFFckI7O09BRUc7SUFDSCxpREFBa0MsQ0FBQTtJQUVsQzs7T0FFRztJQUNILG1EQUFvQyxDQUFBO0lBRXBDOztPQUVHO0lBQ0gsNkNBQThCLENBQUE7QUFDaEMsQ0FBQyxFQXRGVyxXQUFXLDJCQUFYLFdBQVcsUUFzRnRCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTW9uaXRvclR5cGUge1xuXG4gIC8qKlxuICAgKiBNb25pdG9yIGlkIGZvciBhcHBsaWNhdGlvbiBsb2FkIGJhbGFuY2VyIHJlamVjdGVkIGNvbm5lY3Rpb25zXG4gICAqL1xuICBSRUpFQ1RFRF9DT05ORUNUSU9OID0gJ1JlamVjdGVkQ29ubmVjdGlvbicsXG5cbiAgLyoqXG4gICAqIDV4eCBlcnJvciBjb2RlcyBmb3IgY2xvdWRmcm9udCBhbmQgYXBwbGljYXRpb24gbG9hZCBiYWxhbmNlclxuICAgKi9cbiAgSFRUUF9DT0RFNVhYID0gJ0h0dHBDb2RlNXh4JyxcblxuICAvKipcbiAgICogQ2FjaGUgaGl0IHJhdGUgZm9yIGRvY3VtZW50IGRiXG4gICAqL1xuICBDQUNIRV9ISVRfUkFURSA9ICdjYWNoZUhpdFJhdGUnLFxuXG4gIC8qKlxuICAgKiBDUFUgVXRpbGl6YXRpb24gZm9yIGRvY3VtZW50IGRiLCBFQ1MgYW5kIFJEU1xuICAgKi9cbiAgQ1BVX1VUSUxJWkFUSU9OID0gJ0NwdVV0aWxpemF0aW9uJyxcblxuICAvKipcbiAgICogU3dhcCB1c2FnZSBmb3IgZG9jdW1lbnQgREJcbiAgICovXG4gIFNXQVBfVVNBR0UgPSAnU3dhcFVzYWdlVG9vSGlnaCcsXG5cbiAgLyoqXG4gICAqIEZyZWUgbG9jYWwgc3RvcmFnZSBmb3IgZG9jdW1lbnQgREJcbiAgICovXG4gIEZSRUVfTE9DQUxfU1RPUkFHRSA9ICdGcmVlTG9jYWxTdG9yYWdlVG9vTG93JyxcblxuICAvKipcbiAgICogUmVhZCB0aHJvdHRsZSBldmVudHMgZm9yIGR5bmFtb2RiXG4gICAqL1xuICBSRUFEX1RIUk9UVExFX0VWRU5UUyA9ICdSZWFkVGhyb3R0bGVFdmVudHMnLFxuXG4gIC8qKlxuICAgKiBXcml0ZSB0aHJvdHRsZSBldmVudHMgZm9yIGR5bmFtb2RiXG4gICAqL1xuICBXUklURV9USFJPVFRMRV9FVkVOVFMgPSAnV3JpdGVUaHJvdHRsZUV2ZW50cycsXG5cbiAgLyoqXG4gICAqIFRocm90dGxlIHJlcXVlc3QgZXZlYnRzIGZvciBkeW5hbW9kYlxuICAgKi9cbiAgVEhST1RUTEVEX1JFUVVFU1RTX0VWRU5UUyA9ICdUaHJvdHRsZWRSZXF1ZXN0c0V2ZW50cycsXG5cbiAgLyoqXG4gICAqIE1lbW9yeSB1dGlsaXphdGlvbiBmb3IgRUNTXG4gICAqL1xuICBNRU1PUllfVVRJTElaQVRJT04gPSAnTWVtb3J5VXRpbGl6YXRpb24nLFxuXG4gIC8qKlxuICAgKiBMb2cgZXJyb3IgbW9uaXRvciBmb3IgRUNTIGFuZCBsYW1iZGFcbiAgICovXG4gIExPR19FUlJPUl9NT05JVE9SID0gJ0xvZ0Vycm9yTW9uaXRvcicsXG5cbiAgLyoqXG4gICAqIElub3ZhdGlvbiBlcnJvcnMgd2l0aCBsYW1iZGFcbiAgICovXG4gIEVSUk9SUyA9ICdFcnJvcnMnLFxuXG4gIC8qKlxuICAgKiBUaHJvdHRsZSBtZXRyaWNzIGZvciBsYW1iZGFcbiAgICovXG4gIFRIUk9UVExFUyA9ICdUaHJvdHRsZXMnLFxuXG4gIC8qKlxuICAgKiBSdW50aW1lIGR1cmF0aW9uIG1ldHJpY3MgZm9yIGxhbWJkYVxuICAgKi9cbiAgRFVSQVRJT04gPSAnRHVyYXRpb24nLFxuXG4gIC8qKlxuICAgKiBGcmVlIG1lbW9yeSBmb3IgRG9jdW1lbnQgREIgYW5kIFJEU1xuICAgKi9cbiAgRlJFRUFCTEVfTUVNT1JZID0gJ0ZyZWVhYmxlTWVtb3J5JyxcblxuICAvKipcbiAgICogQ29ubmVjdGlvbiBlcnJvciBtZXRyaWNzIGZvciBBcHBsaWNhdGlvbiBsb2FkIGJhbGFuY2VyIHRhcmdldCBncm91cFxuICAgKi9cbiAgQ09OTkVDVElPTl9FUlJPUiA9ICdDb25uZWN0aW9uRXJyb3InLFxuXG4gIC8qKlxuICAgKiBSdW5uaW5nIGZhcmdhdGUgdGFza3MgbW9uaXRvclxuICAgKi9cbiAgUlVOTklOR19UQVNLUyA9ICdSdW5uaW5nVGFza3MnLFxufSJdfQ==
|
|
@@ -14,12 +14,16 @@ import { WatchLambdaFunctionOptions, WatchCloudfrontDistributionOptions, WatchAp
|
|
|
14
14
|
export interface IWatchful extends IConstruct {
|
|
15
15
|
/**
|
|
16
16
|
* Adds and alert for error logs
|
|
17
|
+
* @param scope - The construct to add the alarm to
|
|
17
18
|
* @param id - The name of the service
|
|
19
|
+
* @param alarm - The alarm properties see {@link LogAlarmProps}
|
|
18
20
|
*/
|
|
19
21
|
createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void;
|
|
20
22
|
/**
|
|
21
23
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
22
|
-
* @param
|
|
24
|
+
* @param scope - The construct to add the alarm to
|
|
25
|
+
* @param id - The id of the alarm
|
|
26
|
+
* @param alarm - Additional options for the watch see {@link MetricAlarmProps}
|
|
23
27
|
*
|
|
24
28
|
*/
|
|
25
29
|
createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;
|
|
@@ -59,41 +63,49 @@ export declare abstract class AbstractWatchful extends Construct implements IWat
|
|
|
59
63
|
/**
|
|
60
64
|
* Adds alarms for the given lambda function.
|
|
61
65
|
* @param fn - A lambda function that should be watched [disable-awslint:ref-via-interface]
|
|
66
|
+
* @param options - Additional options for the watch see {@link WatchLambdaFunctionOptions}
|
|
62
67
|
*/
|
|
63
68
|
watchLambdaFunction(fn: lambda.Function, options?: WatchLambdaFunctionOptions): void;
|
|
64
69
|
/**
|
|
65
70
|
* Adds alarms for the given Cloudfront Distribution.
|
|
66
71
|
* @param cf - A Cloudfront Distribution that should be watched [disable-awslint:ref-via-interface]
|
|
72
|
+
* @param options - Additional options for the watch see {@link WatchCloudfrontDistributionOptions}
|
|
67
73
|
*/
|
|
68
74
|
watchCloudfrontDistribution(cf: cloudfront.Distribution, options?: WatchCloudfrontDistributionOptions): void;
|
|
69
75
|
/**
|
|
70
76
|
* Adds alarms for the given ECS service.
|
|
71
77
|
* @param service - An ECS service that should be watched [disable-awslint:ref-via-interface]
|
|
78
|
+
* @param options - Additional options for the watch see {@link WatchEcsServiceOptions}
|
|
72
79
|
*/
|
|
73
80
|
watchEcsService(service: ecs.BaseService, options?: WatchEcsServiceOptions): void;
|
|
74
81
|
/**
|
|
75
82
|
* Adds alarms for the given application load balancer.
|
|
76
83
|
* @param alb - An application load balancer that should be watched [disable-awslint:ref-via-interface]
|
|
84
|
+
* @param options - Additional options for the watch see {@link WatchApplicationLoadBalancerOptions}
|
|
77
85
|
*/
|
|
78
86
|
watchAlb(alb: elbv2.ApplicationLoadBalancer, options?: WatchApplicationLoadBalancerOptions): void;
|
|
79
87
|
/**
|
|
80
88
|
* Adds alarms for the given application target gorup.
|
|
81
89
|
* @param atg - An application target group that should be watched [disable-awslint:ref-via-interface]
|
|
90
|
+
* @param options - Additional options for the watch see {@link WatchApplicationTargetGroupOptions}
|
|
82
91
|
*/
|
|
83
92
|
watchApplicationTargetGroup(atg: elbv2.ApplicationTargetGroup, options?: WatchApplicationTargetGroupOptions): void;
|
|
84
93
|
/**
|
|
85
94
|
* Adds alarms for the given DocDb cluster.
|
|
86
95
|
* @param docDb - An DocDb cluster that should be watched [disable-awslint:ref-via-interface]
|
|
96
|
+
* @param options - Additional options for the watch see {@link WatchDocDbClusterOptions}
|
|
87
97
|
*/
|
|
88
98
|
watchDocDb(docDb: docdb.DatabaseCluster, options?: WatchDocDbClusterOptions): void;
|
|
89
99
|
/**
|
|
90
100
|
* Adds alarms for the given database cluster.
|
|
91
101
|
* @param databaseCluster - An database cluster that should be watched [disable-awslint:ref-via-interface]
|
|
102
|
+
* @param options - Additional options for the watch see {@link WatchDatabaseClusterOptions}
|
|
92
103
|
*/
|
|
93
104
|
watchDatabaseCluster(databaseCluster: rds.DatabaseCluster, options?: WatchDatabaseClusterOptions): void;
|
|
94
105
|
/**
|
|
95
106
|
* Adds alarms for the given DynamoDb table.
|
|
96
107
|
* @param dynamoDbTable - An database cluster that should be watched [disable-awslint:ref-via-interface]
|
|
108
|
+
* @param options - Additional options for the watch see {@link WatchDynamoDbTableOptions}
|
|
97
109
|
*/
|
|
98
110
|
watchDynamoDbTable(dynamoDbTable: dynamodb.Table, options?: WatchDynamoDbTableOptions): void;
|
|
99
111
|
}
|
|
@@ -138,12 +150,16 @@ export declare class Watchful extends AbstractWatchful {
|
|
|
138
150
|
constructor(scope: Construct, id: string, props?: WatchfulProps);
|
|
139
151
|
/**
|
|
140
152
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
141
|
-
* @param
|
|
153
|
+
* @param scope - The construct to add the alarm to
|
|
154
|
+
* @param id - The id of the alarm
|
|
155
|
+
* @param alarm - Additional options for the watch see {@link MetricAlarmProps}
|
|
142
156
|
*/
|
|
143
157
|
createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;
|
|
144
158
|
/**
|
|
145
159
|
* Adds an alert for error logs
|
|
146
|
-
* @param scope
|
|
160
|
+
* @param scope - The construct to add the alarm to
|
|
161
|
+
* @param id - The id of the alarm
|
|
162
|
+
* @param alarm - The alarm properties see {@link LogAlarmProps}
|
|
147
163
|
*/
|
|
148
164
|
createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void;
|
|
149
165
|
/**
|
package/lib/watchful/watchful.js
CHANGED
|
@@ -36,6 +36,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
36
36
|
/**
|
|
37
37
|
* Adds alarms for the given lambda function.
|
|
38
38
|
* @param fn - A lambda function that should be watched [disable-awslint:ref-via-interface]
|
|
39
|
+
* @param options - Additional options for the watch see {@link WatchLambdaFunctionOptions}
|
|
39
40
|
*/
|
|
40
41
|
watchLambdaFunction(fn, options = {}) {
|
|
41
42
|
new _1.WatchLambdaFunction(this, fn.node.id, {
|
|
@@ -47,6 +48,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
47
48
|
/**
|
|
48
49
|
* Adds alarms for the given Cloudfront Distribution.
|
|
49
50
|
* @param cf - A Cloudfront Distribution that should be watched [disable-awslint:ref-via-interface]
|
|
51
|
+
* @param options - Additional options for the watch see {@link WatchCloudfrontDistributionOptions}
|
|
50
52
|
*/
|
|
51
53
|
watchCloudfrontDistribution(cf, options = {}) {
|
|
52
54
|
new _1.WatchCloudfrontDistribution(this, cf.node.id, {
|
|
@@ -58,6 +60,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
58
60
|
/**
|
|
59
61
|
* Adds alarms for the given ECS service.
|
|
60
62
|
* @param service - An ECS service that should be watched [disable-awslint:ref-via-interface]
|
|
63
|
+
* @param options - Additional options for the watch see {@link WatchEcsServiceOptions}
|
|
61
64
|
*/
|
|
62
65
|
watchEcsService(service, options = {}) {
|
|
63
66
|
new _1.WatchEcsService(this, service.node.id, {
|
|
@@ -69,6 +72,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
69
72
|
/**
|
|
70
73
|
* Adds alarms for the given application load balancer.
|
|
71
74
|
* @param alb - An application load balancer that should be watched [disable-awslint:ref-via-interface]
|
|
75
|
+
* @param options - Additional options for the watch see {@link WatchApplicationLoadBalancerOptions}
|
|
72
76
|
*/
|
|
73
77
|
watchAlb(alb, options = {}) {
|
|
74
78
|
new _1.WatchApplicationLoadBalancer(this, alb.node.id, {
|
|
@@ -80,6 +84,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
80
84
|
/**
|
|
81
85
|
* Adds alarms for the given application target gorup.
|
|
82
86
|
* @param atg - An application target group that should be watched [disable-awslint:ref-via-interface]
|
|
87
|
+
* @param options - Additional options for the watch see {@link WatchApplicationTargetGroupOptions}
|
|
83
88
|
*/
|
|
84
89
|
watchApplicationTargetGroup(atg, options = {}) {
|
|
85
90
|
new _1.WatchApplicationTargetGroup(this, atg.node.id, {
|
|
@@ -91,6 +96,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
91
96
|
/**
|
|
92
97
|
* Adds alarms for the given DocDb cluster.
|
|
93
98
|
* @param docDb - An DocDb cluster that should be watched [disable-awslint:ref-via-interface]
|
|
99
|
+
* @param options - Additional options for the watch see {@link WatchDocDbClusterOptions}
|
|
94
100
|
*/
|
|
95
101
|
watchDocDb(docDb, options = {}) {
|
|
96
102
|
new _1.WatchDocDbCluster(this, docDb.node.id, {
|
|
@@ -102,6 +108,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
102
108
|
/**
|
|
103
109
|
* Adds alarms for the given database cluster.
|
|
104
110
|
* @param databaseCluster - An database cluster that should be watched [disable-awslint:ref-via-interface]
|
|
111
|
+
* @param options - Additional options for the watch see {@link WatchDatabaseClusterOptions}
|
|
105
112
|
*/
|
|
106
113
|
watchDatabaseCluster(databaseCluster, options = {}) {
|
|
107
114
|
new _1.WatchDatabaseCluster(this, databaseCluster.node.id, {
|
|
@@ -113,6 +120,7 @@ class AbstractWatchful extends constructs_1.Construct {
|
|
|
113
120
|
/**
|
|
114
121
|
* Adds alarms for the given DynamoDb table.
|
|
115
122
|
* @param dynamoDbTable - An database cluster that should be watched [disable-awslint:ref-via-interface]
|
|
123
|
+
* @param options - Additional options for the watch see {@link WatchDynamoDbTableOptions}
|
|
116
124
|
*/
|
|
117
125
|
watchDynamoDbTable(dynamoDbTable, options = {}) {
|
|
118
126
|
new _1.WatchDynamoDbTable(this, dynamoDbTable.node.id, {
|
|
@@ -145,7 +153,9 @@ class Watchful extends AbstractWatchful {
|
|
|
145
153
|
}
|
|
146
154
|
/**
|
|
147
155
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
148
|
-
* @param
|
|
156
|
+
* @param scope - The construct to add the alarm to
|
|
157
|
+
* @param id - The id of the alarm
|
|
158
|
+
* @param alarm - Additional options for the watch see {@link MetricAlarmProps}
|
|
149
159
|
*/
|
|
150
160
|
createAlarm(scope, id, alarm) {
|
|
151
161
|
const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });
|
|
@@ -178,7 +188,9 @@ class Watchful extends AbstractWatchful {
|
|
|
178
188
|
}
|
|
179
189
|
/**
|
|
180
190
|
* Adds an alert for error logs
|
|
181
|
-
* @param scope
|
|
191
|
+
* @param scope - The construct to add the alarm to
|
|
192
|
+
* @param id - The id of the alarm
|
|
193
|
+
* @param alarm - The alarm properties see {@link LogAlarmProps}
|
|
182
194
|
*/
|
|
183
195
|
createLogAlarm(scope, id, alarm) {
|
|
184
196
|
const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });
|
|
@@ -211,4 +223,4 @@ class Watchful extends AbstractWatchful {
|
|
|
211
223
|
exports.Watchful = Watchful;
|
|
212
224
|
_b = JSII_RTTI_SYMBOL_1;
|
|
213
225
|
Watchful[_b] = { fqn: "@rio-cloud/cdk-v2-constructs.Watchful", version: "0.0.0" };
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watchful.js","sourceRoot":"","sources":["../../src/watchful/watchful.ts"],"names":[],"mappings":"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","sourcesContent":["import { Annotations, Aspects, Stack } from 'aws-cdk-lib';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as cw_actions from 'aws-cdk-lib/aws-cloudwatch-actions';\nimport * as docdb from 'aws-cdk-lib/aws-docdb';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as rds from 'aws-cdk-lib/aws-rds';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct, IConstruct } from 'constructs';\nimport {\n  WatchfulAspect,\n  WatchLambdaFunction,\n  WatchLambdaFunctionOptions,\n  WatchCloudfrontDistribution,\n  WatchCloudfrontDistributionOptions,\n  WatchApplicationLoadBalancer,\n  WatchApplicationLoadBalancerOptions,\n  WatchEcsService,\n  WatchEcsServiceOptions,\n  WatchApplicationTargetGroup,\n  WatchApplicationTargetGroupOptions,\n  DataDogMetricAlarm,\n  DataDogLogAlarm,\n  MetricAlarmProps,\n  WatchDocDbCluster,\n  WatchDocDbClusterOptions,\n  WatchDatabaseCluster,\n  WatchDatabaseClusterOptions,\n  WatchDynamoDbTable,\n  WatchDynamoDbTableOptions,\n  LogAlarmProps,\n  MonitorType,\n} from './';\n\n/**\n * Interface for Watchful implementation.\n */\nexport interface IWatchful extends IConstruct {\n  /**\n   * Adds and alert for error logs\n   * @param id - The name of the service\n   */\n  createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void;\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\n   * @param alarm - The watchful to add those resources to\n   *\n   */\n  createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;\n}\n\nexport interface OverrideAlarmThresholdProps {\n  /**\n   * The scope of the resource for which the threshold needs to be overriden\n   */\n  readonly monitoredResourceScope: Construct;\n\n  /**\n   * Id of the monitor that needs to be overriden.\n   * Eg - Errors, Thresholds, LogErrorMonitor\n   */\n  readonly monitorType: MonitorType;\n\n  /**\n   * The threshold that needs to be set\n  */\n  readonly threshold: number;\n}\n\nexport interface ShouldOverrideThresholdProps {\n  readonly watchfulMonitorScope: Construct;\n  readonly watchfulNodeId: string;\n}\n\nexport interface ShouldOverrideThresholdReturnProps {\n  readonly shouldOverrideThreshold: boolean;\n  readonly threshold?: number;\n}\n\nexport abstract class AbstractWatchful extends Construct implements IWatchful {\n  protected readonly metricsAlarmOverrides: Array<OverrideAlarmThresholdProps> = [];\n  abstract createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void\n  abstract createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;\n\n  /**\n   * Override the default thresholds for the watchful monitors\n   */\n  public overrideAlarmThreshold(props: OverrideAlarmThresholdProps) {\n    this.metricsAlarmOverrides.push({\n      monitoredResourceScope: props.monitoredResourceScope,\n      monitorType: props.monitorType,\n      threshold: props.threshold,\n    });\n  }\n\n  protected shouldOverrideThreshold(props: ShouldOverrideThresholdProps): ShouldOverrideThresholdReturnProps {\n    for (const metricsAlarmOverride of this.metricsAlarmOverrides) {\n      if (\n        props.watchfulMonitorScope.node.id === metricsAlarmOverride.monitoredResourceScope.node.id &&\n        props.watchfulNodeId === metricsAlarmOverride.monitorType) {\n        return { shouldOverrideThreshold: true, threshold: metricsAlarmOverride.threshold };\n      }\n    }\n    return { shouldOverrideThreshold: false };\n  };\n\n  /**\n   * Adds alarms for the given lambda function.\n   * @param fn - A lambda function that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchLambdaFunction(fn: lambda.Function, options: WatchLambdaFunctionOptions = {}): void {\n\n    new WatchLambdaFunction(this, fn.node.id, {\n      watchful: this,\n      fn,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given Cloudfront Distribution.\n   * @param cf - A Cloudfront Distribution that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchCloudfrontDistribution(\n    cf: cloudfront.Distribution,\n    options: WatchCloudfrontDistributionOptions = {},\n  ): void {\n    new WatchCloudfrontDistribution(this, cf.node.id, {\n      watchful: this,\n      cf,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given ECS service.\n   * @param service - An ECS service that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchEcsService(service: ecs.BaseService, options: WatchEcsServiceOptions = {}): void {\n    new WatchEcsService(this, service.node.id, {\n      watchful: this,\n      service,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given application load balancer.\n   * @param alb - An application load balancer that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchAlb(alb: elbv2.ApplicationLoadBalancer, options: WatchApplicationLoadBalancerOptions = {}): void {\n    new WatchApplicationLoadBalancer(this, alb.node.id, {\n      watchful: this,\n      alb,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given application target gorup.\n   * @param atg - An application target group that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchApplicationTargetGroup(\n    atg: elbv2.ApplicationTargetGroup,\n    options: WatchApplicationTargetGroupOptions = {},\n  ): void {\n    new WatchApplicationTargetGroup(this, atg.node.id, {\n      watchful: this,\n      atg,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given DocDb cluster.\n   * @param docDb - An DocDb cluster that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchDocDb(docDb: docdb.DatabaseCluster, options: WatchDocDbClusterOptions = {}): void {\n    new WatchDocDbCluster(this, docDb.node.id, {\n      watchful: this,\n      docDb,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given database cluster.\n   * @param databaseCluster - An database cluster that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchDatabaseCluster(databaseCluster: rds.DatabaseCluster, options: WatchDatabaseClusterOptions = {}): void {\n    new WatchDatabaseCluster(this, databaseCluster.node.id, {\n      watchful: this,\n      databaseCluster,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given DynamoDb table.\n   * @param dynamoDbTable - An database cluster that should be watched [disable-awslint:ref-via-interface]\n   */\n  public watchDynamoDbTable(dynamoDbTable: dynamodb.Table, options: WatchDynamoDbTableOptions = {}): void {\n    new WatchDynamoDbTable(this, dynamoDbTable.node.id, {\n      watchful: this,\n      dynamoDbTable: dynamoDbTable,\n      ...options,\n    });\n  }\n}\n\n/**\n * Properties for defining Watchful\n */\nexport interface WatchfulProps {\n  /**\n   * An SNS topic as target for alarm actions.\n   *\n   * @defaultValue  The SNS topic provided by OpsGenie Integration account module.\n   */\n  readonly alarmSns?: sns.ITopic;\n\n  /**\n   * The service token for the DataDog Monitor custom resource.\n   *\n   * @defaultValue Empty.\n   */\n  readonly dataDogMonitorServiceToken?: string;\n\n  /**\n   * The service name.\n   *\n   * @defaultValue The stack name.\n   */\n  readonly dataDogMonitorServiceName?: string;\n\n  /**\n   * The OpsGenie handle used in DataDog to forward the DD monitor to OpsGenie.\n   *\n   * @defaultValue Empty if dataDogMonitorServiceToken is not set. Otherwise, team SSM parameter from LandingZone is used.\n   */\n  readonly dataDogOpsGenieIntegrationName?: string;\n}\n\n/**\n * A construct to watch given scope or resources. Opinionated DataDog alarms are automatically created for watched resources.\n * @deprecated Please use watchfulv2 instead\n */\nexport class Watchful extends AbstractWatchful {\n  private readonly alarmTopic?: sns.ITopic;\n  private readonly dataDogMonitorServiceToken?: string;\n  private readonly dataDogOpsGenieIntegrationName?: string;\n  private readonly dataDogMonitorServiceName: string;\n\n  constructor(scope: Construct, id: string, props: WatchfulProps = {}) {\n    super(scope, id);\n\n    // const opsGenieAlarmTopicArn = Fn.importValue('opsgenie-cloudwatch-alarm-sns-topic-arn');\n    // const opsGenieAlarmTopic = sns.Topic.fromTopicArn(this, 'OpsGenieTopic', opsGenieAlarmTopicArn);\n    this.alarmTopic = props.alarmSns;\n    this.dataDogMonitorServiceToken = props.dataDogMonitorServiceToken;\n\n    this.dataDogMonitorServiceName = props.dataDogMonitorServiceName ?? Stack.of(this).stackName;\n\n    if (props.dataDogMonitorServiceToken !== undefined) {\n\n      const teamNameParam = ssm.StringParameter.fromStringParameterName(\n        this,\n        'TeamNameParam',\n        '/config/team/name',\n      );\n      this.dataDogOpsGenieIntegrationName = props.dataDogOpsGenieIntegrationName ?? teamNameParam.stringValue;\n    }\n    Annotations.of(scope).addDeprecation('@rio-cloud/cdk-v2-constructs/watchful', 'watchful deprecated! Please use watchfulv2 instead');\n  }\n\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\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    if (this.alarmTopic !== undefined) {\n      const cwAlarm = alarm.metric.createAlarm(scope, id, {\n        alarmDescription: alarm.alarmDescription,\n        threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n        comparisonOperator: alarm.comparisonOperator,\n        evaluationPeriods: alarm.evaluationPeriods,\n      });\n      if (this.alarmTopic) {\n        cwAlarm.addAlarmAction(new cw_actions.SnsAction(this.alarmTopic));\n        cwAlarm.addOkAction(new cw_actions.SnsAction(this.alarmTopic));\n      }\n    }\n\n    if (this.dataDogMonitorServiceToken !== undefined) {\n      new DataDogMetricAlarm(scope, id, {\n        serviceToken: this.dataDogMonitorServiceToken ?? '',\n        serviceName: this.dataDogMonitorServiceName,\n        dataDogOpsGenieIntegrationName: this.dataDogOpsGenieIntegrationName ?? '',\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: 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    if (this.dataDogMonitorServiceToken !== undefined) {\n      new DataDogLogAlarm(scope, id, {\n        serviceToken: this.dataDogMonitorServiceToken ?? '',\n        serviceName: alarm.lambdaCloudwatchGroupName ?? this.dataDogMonitorServiceName,\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        lambdaCloudwatchGroupName: alarm.lambdaCloudwatchGroupName,\n      });\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}\n"]}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watchful.js","sourceRoot":"","sources":["../../src/watchful/watchful.ts"],"names":[],"mappings":";;;;;AAAA,6CAA0D;AAE1D,iEAAiE;AAQjE,2CAA2C;AAC3C,2CAAmD;AACnD,yBAuBY;AAmDZ,MAAsB,gBAAiB,SAAQ,sBAAS;IAAxD;;QACqB,0BAAqB,GAAuC,EAAE,CAAC;KAwInF;IApIC;;OAEG;IACI,sBAAsB,CAAC,KAAkC;QAC9D,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC9B,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;YACpD,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;SAC3B,CAAC,CAAC;IACL,CAAC;IAES,uBAAuB,CAAC,KAAmC;QACnE,KAAK,MAAM,oBAAoB,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC9D,IACE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,KAAK,oBAAoB,CAAC,sBAAsB,CAAC,IAAI,CAAC,EAAE;gBAC1F,KAAK,CAAC,cAAc,KAAK,oBAAoB,CAAC,WAAW,EAAE,CAAC;gBAC5D,OAAO,EAAE,uBAAuB,EAAE,IAAI,EAAE,SAAS,EAAE,oBAAoB,CAAC,SAAS,EAAE,CAAC;YACtF,CAAC;QACH,CAAC;QACD,OAAO,EAAE,uBAAuB,EAAE,KAAK,EAAE,CAAC;IAC5C,CAAC;IAAA,CAAC;IAEF;;;;OAIG;IACI,mBAAmB,CAAC,EAAmB,EAAE,UAAsC,EAAE;QAEtF,IAAI,sBAAmB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE;YACxC,QAAQ,EAAE,IAAI;YACd,EAAE;YACF,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,2BAA2B,CAChC,EAA2B,EAC3B,UAA8C,EAAE;QAEhD,IAAI,8BAA2B,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,EAAE;YAChD,QAAQ,EAAE,IAAI;YACd,EAAE;YACF,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,eAAe,CAAC,OAAwB,EAAE,UAAkC,EAAE;QACnF,IAAI,kBAAe,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE;YACzC,QAAQ,EAAE,IAAI;YACd,OAAO;YACP,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,GAAkC,EAAE,UAA+C,EAAE;QACnG,IAAI,+BAA4B,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YAClD,QAAQ,EAAE,IAAI;YACd,GAAG;YACH,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,2BAA2B,CAChC,GAAiC,EACjC,UAA8C,EAAE;QAEhD,IAAI,8BAA2B,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACjD,QAAQ,EAAE,IAAI;YACd,GAAG;YACH,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,UAAU,CAAC,KAA4B,EAAE,UAAoC,EAAE;QACpF,IAAI,oBAAiB,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE;YACzC,QAAQ,EAAE,IAAI;YACd,KAAK;YACL,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,oBAAoB,CAAC,eAAoC,EAAE,UAAuC,EAAE;QACzG,IAAI,uBAAoB,CAAC,IAAI,EAAE,eAAe,CAAC,IAAI,CAAC,EAAE,EAAE;YACtD,QAAQ,EAAE,IAAI;YACd,eAAe;YACf,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,kBAAkB,CAAC,aAA6B,EAAE,UAAqC,EAAE;QAC9F,IAAI,qBAAkB,CAAC,IAAI,EAAE,aAAa,CAAC,IAAI,CAAC,EAAE,EAAE;YAClD,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,aAAa;YAC5B,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;;AAxIH,4CAyIC;;;AAmCD;;;GAGG;AACH,MAAa,QAAS,SAAQ,gBAAgB;IAM5C,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAuB,EAAE;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,2FAA2F;QAC3F,mGAAmG;QACnG,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC,yBAAyB,IAAI,mBAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;QAE7F,IAAI,KAAK,CAAC,0BAA0B,KAAK,SAAS,EAAE,CAAC;YAEnD,MAAM,aAAa,GAAG,GAAG,CAAC,eAAe,CAAC,uBAAuB,CAC/D,IAAI,EACJ,eAAe,EACf,mBAAmB,CACpB,CAAC;YACF,IAAI,CAAC,8BAA8B,GAAG,KAAK,CAAC,8BAA8B,IAAI,aAAa,CAAC,WAAW,CAAC;QAC1G,CAAC;QACD,yBAAW,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uCAAuC,EAAE,oDAAoD,CAAC,CAAC;IACtI,CAAC;IAED;;;;;OAKG;IACI,WAAW,CAAC,KAAgB,EAAE,EAAe,EAAE,KAAuB;QAC3E,MAAM,EAAE,uBAAuB,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,uBAAuB,CAAC,EAAE,oBAAoB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC;QACjI,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE,CAAC;YAClC,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,EAAE,EAAE;gBAClD,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,SAAS,EAAE,uBAAuB,CAAC,CAAC,CAAC,SAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS;gBAC1E,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;gBAC5C,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;aAC3C,CAAC,CAAC;YACH,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBACpB,OAAO,CAAC,cAAc,CAAC,IAAI,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;gBAClE,OAAO,CAAC,WAAW,CAAC,IAAI,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACjE,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,0BAA0B,KAAK,SAAS,EAAE,CAAC;YAClD,IAAI,qBAAkB,CAAC,KAAK,EAAE,EAAE,EAAE;gBAChC,YAAY,EAAE,IAAI,CAAC,0BAA0B,IAAI,EAAE;gBACnD,WAAW,EAAE,IAAI,CAAC,yBAAyB;gBAC3C,8BAA8B,EAAE,IAAI,CAAC,8BAA8B,IAAI,EAAE;gBACzE,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;gBAC5C,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;gBAC1C,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,SAAS,EAAE,uBAAuB,CAAC,CAAC,CAAC,SAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS;gBAC1E,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,QAAQ,EAAE,KAAK,CAAC,QAAQ;aACzB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED;;;;;OAKG;IACI,cAAc,CAAC,KAAgB,EAAE,EAAe,EAAE,KAAoB;QAC3E,MAAM,EAAE,uBAAuB,EAAE,SAAS,EAAE,GAAG,IAAI,CAAC,uBAAuB,CAAC,EAAE,oBAAoB,EAAE,KAAK,EAAE,cAAc,EAAE,EAAE,EAAE,CAAC,CAAC;QACjI,IAAI,IAAI,CAAC,0BAA0B,KAAK,SAAS,EAAE,CAAC;YAClD,IAAI,kBAAe,CAAC,KAAK,EAAE,EAAE,EAAE;gBAC7B,YAAY,EAAE,IAAI,CAAC,0BAA0B,IAAI,EAAE;gBACnD,WAAW,EAAE,KAAK,CAAC,yBAAyB,IAAI,IAAI,CAAC,yBAAyB;gBAC9E,uBAAuB,EAAE,KAAK,CAAC,uBAAuB;gBACtD,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,YAAY,EAAE,KAAK,CAAC,YAAY,EAAE,yDAAyD;gBAC3F,cAAc,EAAE,KAAK,CAAC,cAAc;gBACpC,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,YAAY,EAAE,KAAK,CAAC,YAAY,EAAE,yDAAyD;gBAC3F,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;gBACxC,SAAS,EAAE,uBAAuB,CAAC,CAAC,CAAC,SAAmB,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS;gBAC1E,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,KAAK,EAAE,KAAK,CAAC,KAAK;gBAClB,yBAAyB,EAAE,KAAK,CAAC,yBAAyB;aAC3D,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED;;OAEG;IACI,UAAU,CAAC,KAAgB;QAChC,MAAM,MAAM,GAAG,IAAI,iBAAc,CAAC,IAAI,CAAC,CAAC;QACxC,qBAAO,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;;AAlGH,4BAoGC","sourcesContent":["import { Annotations, Aspects, Stack } from 'aws-cdk-lib';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as cw_actions from 'aws-cdk-lib/aws-cloudwatch-actions';\nimport * as docdb from 'aws-cdk-lib/aws-docdb';\nimport * as dynamodb from 'aws-cdk-lib/aws-dynamodb';\nimport * as ecs from 'aws-cdk-lib/aws-ecs';\nimport * as elbv2 from 'aws-cdk-lib/aws-elasticloadbalancingv2';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as rds from 'aws-cdk-lib/aws-rds';\nimport * as sns from 'aws-cdk-lib/aws-sns';\nimport * as ssm from 'aws-cdk-lib/aws-ssm';\nimport { Construct, IConstruct } from 'constructs';\nimport {\n  WatchfulAspect,\n  WatchLambdaFunction,\n  WatchLambdaFunctionOptions,\n  WatchCloudfrontDistribution,\n  WatchCloudfrontDistributionOptions,\n  WatchApplicationLoadBalancer,\n  WatchApplicationLoadBalancerOptions,\n  WatchEcsService,\n  WatchEcsServiceOptions,\n  WatchApplicationTargetGroup,\n  WatchApplicationTargetGroupOptions,\n  DataDogMetricAlarm,\n  DataDogLogAlarm,\n  MetricAlarmProps,\n  WatchDocDbCluster,\n  WatchDocDbClusterOptions,\n  WatchDatabaseCluster,\n  WatchDatabaseClusterOptions,\n  WatchDynamoDbTable,\n  WatchDynamoDbTableOptions,\n  LogAlarmProps,\n  MonitorType,\n} from './';\n\n/**\n * Interface for Watchful implementation.\n */\nexport interface IWatchful extends IConstruct {\n  /**\n   * Adds and alert for error logs\n   * @param scope - The construct to add the alarm to\n   * @param id - The name of the service\n   * @param alarm - The alarm properties see {@link LogAlarmProps}\n   */\n  createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void;\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\n   * @param scope - The construct to add the alarm to\n   * @param id - The id of the alarm\n   * @param alarm - Additional options for the watch see {@link MetricAlarmProps}\n   *\n   */\n  createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;\n}\n\nexport interface OverrideAlarmThresholdProps {\n  /**\n   * The scope of the resource for which the threshold needs to be overriden\n   */\n  readonly monitoredResourceScope: Construct;\n\n  /**\n   * Id of the monitor that needs to be overriden.\n   * Eg - Errors, Thresholds, LogErrorMonitor\n   */\n  readonly monitorType: MonitorType;\n\n  /**\n   * The threshold that needs to be set\n  */\n  readonly threshold: number;\n}\n\nexport interface ShouldOverrideThresholdProps {\n  readonly watchfulMonitorScope: Construct;\n  readonly watchfulNodeId: string;\n}\n\nexport interface ShouldOverrideThresholdReturnProps {\n  readonly shouldOverrideThreshold: boolean;\n  readonly threshold?: number;\n}\n\nexport abstract class AbstractWatchful extends Construct implements IWatchful {\n  protected readonly metricsAlarmOverrides: Array<OverrideAlarmThresholdProps> = [];\n  abstract createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void\n  abstract createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;\n\n  /**\n   * Override the default thresholds for the watchful monitors\n   */\n  public overrideAlarmThreshold(props: OverrideAlarmThresholdProps) {\n    this.metricsAlarmOverrides.push({\n      monitoredResourceScope: props.monitoredResourceScope,\n      monitorType: props.monitorType,\n      threshold: props.threshold,\n    });\n  }\n\n  protected shouldOverrideThreshold(props: ShouldOverrideThresholdProps): ShouldOverrideThresholdReturnProps {\n    for (const metricsAlarmOverride of this.metricsAlarmOverrides) {\n      if (\n        props.watchfulMonitorScope.node.id === metricsAlarmOverride.monitoredResourceScope.node.id &&\n        props.watchfulNodeId === metricsAlarmOverride.monitorType) {\n        return { shouldOverrideThreshold: true, threshold: metricsAlarmOverride.threshold };\n      }\n    }\n    return { shouldOverrideThreshold: false };\n  };\n\n  /**\n   * Adds alarms for the given lambda function.\n   * @param fn - A lambda function that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchLambdaFunctionOptions}\n   */\n  public watchLambdaFunction(fn: lambda.Function, options: WatchLambdaFunctionOptions = {}): void {\n\n    new WatchLambdaFunction(this, fn.node.id, {\n      watchful: this,\n      fn,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given Cloudfront Distribution.\n   * @param cf - A Cloudfront Distribution that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchCloudfrontDistributionOptions}\n   */\n  public watchCloudfrontDistribution(\n    cf: cloudfront.Distribution,\n    options: WatchCloudfrontDistributionOptions = {},\n  ): void {\n    new WatchCloudfrontDistribution(this, cf.node.id, {\n      watchful: this,\n      cf,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given ECS service.\n   * @param service - An ECS service that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchEcsServiceOptions}\n   */\n  public watchEcsService(service: ecs.BaseService, options: WatchEcsServiceOptions = {}): void {\n    new WatchEcsService(this, service.node.id, {\n      watchful: this,\n      service,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given application load balancer.\n   * @param alb - An application load balancer that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchApplicationLoadBalancerOptions}\n   */\n  public watchAlb(alb: elbv2.ApplicationLoadBalancer, options: WatchApplicationLoadBalancerOptions = {}): void {\n    new WatchApplicationLoadBalancer(this, alb.node.id, {\n      watchful: this,\n      alb,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given application target gorup.\n   * @param atg - An application target group that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchApplicationTargetGroupOptions}\n   */\n  public watchApplicationTargetGroup(\n    atg: elbv2.ApplicationTargetGroup,\n    options: WatchApplicationTargetGroupOptions = {},\n  ): void {\n    new WatchApplicationTargetGroup(this, atg.node.id, {\n      watchful: this,\n      atg,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given DocDb cluster.\n   * @param docDb - An DocDb cluster that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchDocDbClusterOptions}\n   */\n  public watchDocDb(docDb: docdb.DatabaseCluster, options: WatchDocDbClusterOptions = {}): void {\n    new WatchDocDbCluster(this, docDb.node.id, {\n      watchful: this,\n      docDb,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given database cluster.\n   * @param databaseCluster - An database cluster that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchDatabaseClusterOptions}\n   */\n  public watchDatabaseCluster(databaseCluster: rds.DatabaseCluster, options: WatchDatabaseClusterOptions = {}): void {\n    new WatchDatabaseCluster(this, databaseCluster.node.id, {\n      watchful: this,\n      databaseCluster,\n      ...options,\n    });\n  }\n\n  /**\n   * Adds alarms for the given DynamoDb table.\n   * @param dynamoDbTable - An database cluster that should be watched [disable-awslint:ref-via-interface]\n   * @param options - Additional options for the watch see {@link WatchDynamoDbTableOptions}\n   */\n  public watchDynamoDbTable(dynamoDbTable: dynamodb.Table, options: WatchDynamoDbTableOptions = {}): void {\n    new WatchDynamoDbTable(this, dynamoDbTable.node.id, {\n      watchful: this,\n      dynamoDbTable: dynamoDbTable,\n      ...options,\n    });\n  }\n}\n\n/**\n * Properties for defining Watchful\n */\nexport interface WatchfulProps {\n  /**\n   * An SNS topic as target for alarm actions.\n   *\n   * @defaultValue  The SNS topic provided by OpsGenie Integration account module.\n   */\n  readonly alarmSns?: sns.ITopic;\n\n  /**\n   * The service token for the DataDog Monitor custom resource.\n   *\n   * @defaultValue Empty.\n   */\n  readonly dataDogMonitorServiceToken?: string;\n\n  /**\n   * The service name.\n   *\n   * @defaultValue The stack name.\n   */\n  readonly dataDogMonitorServiceName?: string;\n\n  /**\n   * The OpsGenie handle used in DataDog to forward the DD monitor to OpsGenie.\n   *\n   * @defaultValue Empty if dataDogMonitorServiceToken is not set. Otherwise, team SSM parameter from LandingZone is used.\n   */\n  readonly dataDogOpsGenieIntegrationName?: string;\n}\n\n/**\n * A construct to watch given scope or resources. Opinionated DataDog alarms are automatically created for watched resources.\n * @deprecated Please use watchfulv2 instead\n */\nexport class Watchful extends AbstractWatchful {\n  private readonly alarmTopic?: sns.ITopic;\n  private readonly dataDogMonitorServiceToken?: string;\n  private readonly dataDogOpsGenieIntegrationName?: string;\n  private readonly dataDogMonitorServiceName: string;\n\n  constructor(scope: Construct, id: string, props: WatchfulProps = {}) {\n    super(scope, id);\n\n    // const opsGenieAlarmTopicArn = Fn.importValue('opsgenie-cloudwatch-alarm-sns-topic-arn');\n    // const opsGenieAlarmTopic = sns.Topic.fromTopicArn(this, 'OpsGenieTopic', opsGenieAlarmTopicArn);\n    this.alarmTopic = props.alarmSns;\n    this.dataDogMonitorServiceToken = props.dataDogMonitorServiceToken;\n\n    this.dataDogMonitorServiceName = props.dataDogMonitorServiceName ?? Stack.of(this).stackName;\n\n    if (props.dataDogMonitorServiceToken !== undefined) {\n\n      const teamNameParam = ssm.StringParameter.fromStringParameterName(\n        this,\n        'TeamNameParam',\n        '/config/team/name',\n      );\n      this.dataDogOpsGenieIntegrationName = props.dataDogOpsGenieIntegrationName ?? teamNameParam.stringValue;\n    }\n    Annotations.of(scope).addDeprecation('@rio-cloud/cdk-v2-constructs/watchful', 'watchful deprecated! Please use watchfulv2 instead');\n  }\n\n  /**\n   * Adds the alarmTopic as alarm action to the given alarm.\n   * @param scope - The construct to add the alarm to\n   * @param id - The id of the alarm\n   * @param alarm - Additional options for the watch see {@link MetricAlarmProps}\n   */\n  public createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    if (this.alarmTopic !== undefined) {\n      const cwAlarm = alarm.metric.createAlarm(scope, id, {\n        alarmDescription: alarm.alarmDescription,\n        threshold: shouldOverrideThreshold ? threshold as number : alarm.threshold,\n        comparisonOperator: alarm.comparisonOperator,\n        evaluationPeriods: alarm.evaluationPeriods,\n      });\n      if (this.alarmTopic) {\n        cwAlarm.addAlarmAction(new cw_actions.SnsAction(this.alarmTopic));\n        cwAlarm.addOkAction(new cw_actions.SnsAction(this.alarmTopic));\n      }\n    }\n\n    if (this.dataDogMonitorServiceToken !== undefined) {\n      new DataDogMetricAlarm(scope, id, {\n        serviceToken: this.dataDogMonitorServiceToken ?? '',\n        serviceName: this.dataDogMonitorServiceName,\n        dataDogOpsGenieIntegrationName: this.dataDogOpsGenieIntegrationName ?? '',\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: alarm.priority,\n      });\n    }\n  }\n\n  /**\n   * Adds an alert for error logs\n   * @param scope - The construct to add the alarm to\n   * @param id - The id of the alarm\n   * @param alarm - The alarm properties see {@link LogAlarmProps}\n   */\n  public createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps):void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });\n    if (this.dataDogMonitorServiceToken !== undefined) {\n      new DataDogLogAlarm(scope, id, {\n        serviceToken: this.dataDogMonitorServiceToken ?? '',\n        serviceName: alarm.lambdaCloudwatchGroupName ?? this.dataDogMonitorServiceName,\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        lambdaCloudwatchGroupName: alarm.lambdaCloudwatchGroupName,\n      });\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}\n"]}
|
|
@@ -21,7 +21,7 @@ export interface LogErrorMonitorProps {
|
|
|
21
21
|
* This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig.
|
|
22
22
|
* The functionality remains unchanged
|
|
23
23
|
*
|
|
24
|
-
* @defaultValue
|
|
24
|
+
* @defaultValue false
|
|
25
25
|
*/
|
|
26
26
|
readonly createCasesFromErrorLogMonitors?: boolean;
|
|
27
27
|
/**
|
|
@@ -59,7 +59,7 @@ export interface WatchfulProps {
|
|
|
59
59
|
* Enable error log monitors creating cases in Datadog.
|
|
60
60
|
*
|
|
61
61
|
* @deprecated This property has been deprecated. The propery has been instead nested into logErrorMonitorConfig. The functionality remains unchanged.
|
|
62
|
-
* @defaultValue
|
|
62
|
+
* @defaultValue false
|
|
63
63
|
*/
|
|
64
64
|
readonly createCasesFromErrorLogMonitors?: boolean;
|
|
65
65
|
/**
|
|
@@ -94,12 +94,16 @@ export declare class Watchful extends AbstractWatchful {
|
|
|
94
94
|
/**
|
|
95
95
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
96
96
|
*
|
|
97
|
+
* @param scope - The construct to add the alarm to
|
|
98
|
+
* @param id - The id of the alarm
|
|
97
99
|
* @param alarm - The watchful to add those resources to
|
|
98
100
|
*/
|
|
99
101
|
createAlarm(scope: Construct, id: MonitorType, alarm: MetricAlarmProps): void;
|
|
100
102
|
/**
|
|
101
103
|
* Adds an alert for error logs
|
|
102
|
-
* @param scope
|
|
104
|
+
* @param scope - The construct to add the alarm to
|
|
105
|
+
* @param id - The id of the alarm
|
|
106
|
+
* @param alarm - The alarm properties see {@link LogAlarmProps}
|
|
103
107
|
*/
|
|
104
108
|
createLogAlarm(scope: Construct, id: MonitorType, alarm: LogAlarmProps): void;
|
|
105
109
|
/**
|
|
@@ -31,7 +31,7 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
31
31
|
false;
|
|
32
32
|
if (props.createCasesFromErrorLogMonitors) {
|
|
33
33
|
const annotations = aws_cdk_lib_1.Annotations.of(aws_cdk_lib_1.Stack.of(this));
|
|
34
|
-
annotations.addWarningV2(scope.node.path, '\n ❌ This property has been deprecated. The
|
|
34
|
+
annotations.addWarningV2(scope.node.path, '\n ❌ This property has been deprecated. The property has been instead nested into logErrorMonitorConfig.\n');
|
|
35
35
|
}
|
|
36
36
|
this.queryErrorMonitorConfig = props.queryErrorMonitorConfig;
|
|
37
37
|
this.logErrorMonitorConfig = props.logErrorMonitorConfig;
|
|
@@ -39,6 +39,8 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
39
39
|
/**
|
|
40
40
|
* Adds the alarmTopic as alarm action to the given alarm.
|
|
41
41
|
*
|
|
42
|
+
* @param scope - The construct to add the alarm to
|
|
43
|
+
* @param id - The id of the alarm
|
|
42
44
|
* @param alarm - The watchful to add those resources to
|
|
43
45
|
*/
|
|
44
46
|
createAlarm(scope, id, alarm) {
|
|
@@ -60,7 +62,9 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
60
62
|
}
|
|
61
63
|
/**
|
|
62
64
|
* Adds an alert for error logs
|
|
63
|
-
* @param scope
|
|
65
|
+
* @param scope - The construct to add the alarm to
|
|
66
|
+
* @param id - The id of the alarm
|
|
67
|
+
* @param alarm - The alarm properties see {@link LogAlarmProps}
|
|
64
68
|
*/
|
|
65
69
|
createLogAlarm(scope, id, alarm) {
|
|
66
70
|
const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold({ watchfulMonitorScope: scope, watchfulNodeId: id });
|
|
@@ -100,4 +104,4 @@ class Watchful extends watchful_1.AbstractWatchful {
|
|
|
100
104
|
exports.Watchful = Watchful;
|
|
101
105
|
_a = JSII_RTTI_SYMBOL_1;
|
|
102
106
|
Watchful[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.watchfulv2.Watchful", version: "0.0.0" };
|
|
103
|
-
//# 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 {\n  DatadogCaseNotification,\n  DefaultSlackNotification,\n  NotificationAggregator,\n  INotification,\n} from '../datadogv2';\nimport {\n  WatchfulAspect,\n  MetricAlarmProps,\n  AbstractWatchful,\n  MonitorType,\n} 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   * Renotification interval for log error monitor in minutes\n   */\n  readonly renotifyInterval?: number;\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 =\n      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(\n    scope: Construct,\n    id: MonitorType,\n    alarm: MetricAlarmProps,\n  ): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold(\n      { watchfulMonitorScope: scope, watchfulNodeId: id },\n    );\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\n        ? (threshold as number)\n        : alarm.threshold,\n      treatMissingData: alarm.treatMissingData,\n      priority: this.queryErrorMonitorConfig?.priority ?? alarm.priority,\n      aggregateQueryAsCount: alarm.aggregateQueryAsCount,\n    });\n  }\n\n  /**\n   * Adds an alert for error logs\n   * @param scope\n   */\n  public createLogAlarm(\n    scope: Construct,\n    id: MonitorType,\n    alarm: LogAlarmProps,\n  ): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold(\n      { watchfulMonitorScope: scope, watchfulNodeId: id },\n    );\n    const notifications: INotification = this.createCasesFromErrorLogMonitors\n      ? new NotificationAggregator([\n        this.notification,\n        new DatadogCaseNotification(),\n      ])\n      : this.notification;\n\n    new DataDogLogAlarm(scope, id, {\n      serviceName: alarm.lambdaCloudwatchGroupName ?? this.serviceName,\n      lambdaFunctionName: alarm.lambdaCloudwatchGroupName,\n      notification: notifications,\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\n        ? (threshold as number)\n        : alarm.threshold,\n      priority: this.logErrorMonitorConfig?.priority ?? alarm.priority,\n      index: alarm.index,\n      disableAutoClose: this.logErrorMonitorConfig?.disableAutoClose,\n      renotifyInterval: this.logErrorMonitorConfig?.renotifyInterval,\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"]}
|
|
107
|
+
//# 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 {\n  DatadogCaseNotification,\n  DefaultSlackNotification,\n  NotificationAggregator,\n  INotification,\n} from '../datadogv2';\nimport {\n  WatchfulAspect,\n  MetricAlarmProps,\n  AbstractWatchful,\n  MonitorType,\n} 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 false\n   */\n  readonly createCasesFromErrorLogMonitors?: boolean;\n\n  /**\n   * Renotification interval for log error monitor in minutes\n   */\n  readonly renotifyInterval?: number;\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 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 =\n      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 property 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 scope - The construct to add the alarm to\n   * @param id - The id of the alarm\n   * @param alarm - The watchful to add those resources to\n   */\n  public createAlarm(\n    scope: Construct,\n    id: MonitorType,\n    alarm: MetricAlarmProps,\n  ): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold(\n      { watchfulMonitorScope: scope, watchfulNodeId: id },\n    );\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\n        ? (threshold as number)\n        : alarm.threshold,\n      treatMissingData: alarm.treatMissingData,\n      priority: this.queryErrorMonitorConfig?.priority ?? alarm.priority,\n      aggregateQueryAsCount: alarm.aggregateQueryAsCount,\n    });\n  }\n\n  /**\n   * Adds an alert for error logs\n   * @param scope - The construct to add the alarm to\n   * @param id - The id of the alarm\n   * @param alarm - The alarm properties see {@link LogAlarmProps}\n   */\n  public createLogAlarm(\n    scope: Construct,\n    id: MonitorType,\n    alarm: LogAlarmProps,\n  ): void {\n    const { shouldOverrideThreshold, threshold } = this.shouldOverrideThreshold(\n      { watchfulMonitorScope: scope, watchfulNodeId: id },\n    );\n    const notifications: INotification = this.createCasesFromErrorLogMonitors\n      ? new NotificationAggregator([\n        this.notification,\n        new DatadogCaseNotification(),\n      ])\n      : this.notification;\n\n    new DataDogLogAlarm(scope, id, {\n      serviceName: alarm.lambdaCloudwatchGroupName ?? this.serviceName,\n      lambdaFunctionName: alarm.lambdaCloudwatchGroupName,\n      notification: notifications,\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\n        ? (threshold as number)\n        : alarm.threshold,\n      priority: this.logErrorMonitorConfig?.priority ?? alarm.priority,\n      index: alarm.index,\n      disableAutoClose: this.logErrorMonitorConfig?.disableAutoClose,\n      renotifyInterval: this.logErrorMonitorConfig?.renotifyInterval,\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