@rio-cloud/cdk-v2-constructs 1.0.1-alpha.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.
Files changed (110) hide show
  1. package/.gitattributes +15 -0
  2. package/.jsii +7832 -0
  3. package/.versionrc.json +14 -0
  4. package/API.md +8136 -0
  5. package/CHANGELOG.md +5 -0
  6. package/LICENSE +202 -0
  7. package/README.md +56 -0
  8. package/lib/datadog/datadogLogIndexMonitoring.d.ts +49 -0
  9. package/lib/datadog/datadogLogIndexMonitoring.js +116 -0
  10. package/lib/datadog/datadogMonitor.d.ts +13 -0
  11. package/lib/datadog/datadogMonitor.js +19 -0
  12. package/lib/datadog/index.d.ts +1 -0
  13. package/lib/datadog/index.js +19 -0
  14. package/lib/fargate/datadog.d.ts +18 -0
  15. package/lib/fargate/datadog.js +225 -0
  16. package/lib/fargate/rio-fargate-service.d.ts +276 -0
  17. package/lib/fargate/rio-fargate-service.js +147 -0
  18. package/lib/fargate/spring.d.ts +6 -0
  19. package/lib/fargate/spring.js +39 -0
  20. package/lib/index.d.ts +21 -0
  21. package/lib/index.js +34 -0
  22. package/lib/kafka/index.d.ts +2 -0
  23. package/lib/kafka/index.js +15 -0
  24. package/lib/kafka/kafka-event-spec.d.ts +43 -0
  25. package/lib/kafka/kafka-event-spec.js +106 -0
  26. package/lib/kafka/kafka-topic.d.ts +102 -0
  27. package/lib/kafka/kafka-topic.js +70 -0
  28. package/lib/pipeline/rio-backup-secrets-restore-stage.d.ts +40 -0
  29. package/lib/pipeline/rio-backup-secrets-restore-stage.js +104 -0
  30. package/lib/pipeline/rio-bitbucket-source-action.d.ts +25 -0
  31. package/lib/pipeline/rio-bitbucket-source-action.js +36 -0
  32. package/lib/rio-claidometer.d.ts +21 -0
  33. package/lib/rio-claidometer.js +39 -0
  34. package/lib/rio-landing-zone.d.ts +16 -0
  35. package/lib/rio-landing-zone.js +57 -0
  36. package/lib/rio-load-balancer.d.ts +26 -0
  37. package/lib/rio-load-balancer.js +42 -0
  38. package/lib/toggle.d.ts +21 -0
  39. package/lib/toggle.js +44 -0
  40. package/lib/watchful/alb.d.ts +47 -0
  41. package/lib/watchful/alb.js +52 -0
  42. package/lib/watchful/aspect.d.ts +16 -0
  43. package/lib/watchful/aspect.js +55 -0
  44. package/lib/watchful/cloudfront.d.ts +50 -0
  45. package/lib/watchful/cloudfront.js +65 -0
  46. package/lib/watchful/datadog-log-alarm.d.ts +37 -0
  47. package/lib/watchful/datadog-log-alarm.js +88 -0
  48. package/lib/watchful/datadog-metric-alarm.d.ts +32 -0
  49. package/lib/watchful/datadog-metric-alarm.js +158 -0
  50. package/lib/watchful/docdb.d.ts +62 -0
  51. package/lib/watchful/docdb.js +102 -0
  52. package/lib/watchful/dynamodb.d.ts +69 -0
  53. package/lib/watchful/dynamodb.js +87 -0
  54. package/lib/watchful/ecs.d.ts +50 -0
  55. package/lib/watchful/ecs.js +69 -0
  56. package/lib/watchful/lambda.d.ts +59 -0
  57. package/lib/watchful/lambda.js +65 -0
  58. package/lib/watchful/metric-alarm.d.ts +34 -0
  59. package/lib/watchful/metric-alarm.js +3 -0
  60. package/lib/watchful/rds.d.ts +47 -0
  61. package/lib/watchful/rds.js +47 -0
  62. package/lib/watchful/targetgroup.d.ts +47 -0
  63. package/lib/watchful/targetgroup.js +54 -0
  64. package/lib/watchful/upperToLower.d.ts +7 -0
  65. package/lib/watchful/upperToLower.js +35 -0
  66. package/lib/watchful/watchful.d.ts +119 -0
  67. package/lib/watchful/watchful.js +182 -0
  68. package/node_modules/argparse/CHANGELOG.md +216 -0
  69. package/node_modules/argparse/LICENSE +254 -0
  70. package/node_modules/argparse/README.md +84 -0
  71. package/node_modules/argparse/argparse.js +3707 -0
  72. package/node_modules/argparse/lib/sub.js +67 -0
  73. package/node_modules/argparse/lib/textwrap.js +440 -0
  74. package/node_modules/argparse/package.json +31 -0
  75. package/node_modules/js-yaml/CHANGELOG.md +616 -0
  76. package/node_modules/js-yaml/LICENSE +21 -0
  77. package/node_modules/js-yaml/README.md +246 -0
  78. package/node_modules/js-yaml/bin/js-yaml.js +126 -0
  79. package/node_modules/js-yaml/dist/js-yaml.js +3874 -0
  80. package/node_modules/js-yaml/dist/js-yaml.min.js +2 -0
  81. package/node_modules/js-yaml/dist/js-yaml.mjs +3851 -0
  82. package/node_modules/js-yaml/index.js +47 -0
  83. package/node_modules/js-yaml/lib/common.js +59 -0
  84. package/node_modules/js-yaml/lib/dumper.js +965 -0
  85. package/node_modules/js-yaml/lib/exception.js +55 -0
  86. package/node_modules/js-yaml/lib/loader.js +1727 -0
  87. package/node_modules/js-yaml/lib/schema/core.js +11 -0
  88. package/node_modules/js-yaml/lib/schema/default.js +22 -0
  89. package/node_modules/js-yaml/lib/schema/failsafe.js +17 -0
  90. package/node_modules/js-yaml/lib/schema/json.js +19 -0
  91. package/node_modules/js-yaml/lib/schema.js +121 -0
  92. package/node_modules/js-yaml/lib/snippet.js +101 -0
  93. package/node_modules/js-yaml/lib/type/binary.js +125 -0
  94. package/node_modules/js-yaml/lib/type/bool.js +35 -0
  95. package/node_modules/js-yaml/lib/type/float.js +97 -0
  96. package/node_modules/js-yaml/lib/type/int.js +156 -0
  97. package/node_modules/js-yaml/lib/type/map.js +8 -0
  98. package/node_modules/js-yaml/lib/type/merge.js +12 -0
  99. package/node_modules/js-yaml/lib/type/null.js +35 -0
  100. package/node_modules/js-yaml/lib/type/omap.js +44 -0
  101. package/node_modules/js-yaml/lib/type/pairs.js +53 -0
  102. package/node_modules/js-yaml/lib/type/seq.js +8 -0
  103. package/node_modules/js-yaml/lib/type/set.js +29 -0
  104. package/node_modules/js-yaml/lib/type/str.js +8 -0
  105. package/node_modules/js-yaml/lib/type/timestamp.js +88 -0
  106. package/node_modules/js-yaml/lib/type.js +66 -0
  107. package/node_modules/js-yaml/package.json +66 -0
  108. package/package.json +126 -0
  109. package/release-commit-check.js +6 -0
  110. package/version.json +3 -0
@@ -0,0 +1,158 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DataDogMetricAlarm = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const cw = require("aws-cdk-lib/aws-cloudwatch");
8
+ const constructs_1 = require("constructs");
9
+ const upperToLower_1 = require("./upperToLower");
10
+ /**
11
+ * A wrapper for a custom resource that creates a DataDog Monitor.
12
+ *
13
+ * To use this construct, the DataDog integration needs to be installed.
14
+ */
15
+ class DataDogMetricAlarm extends constructs_1.Construct {
16
+ constructor(scope, id, props) {
17
+ var _b;
18
+ super(scope, id);
19
+ this.serviceToken = upperToLower_1.UpperToLower.getOrCreate(this).provider.serviceToken;
20
+ new aws_cdk_lib_1.CustomResource(this, 'DDMonitor', {
21
+ serviceToken: props.serviceToken,
22
+ pascalCaseProperties: true,
23
+ resourceType: 'Custom::DataDogMonitor',
24
+ properties: {
25
+ ServiceName: props.serviceName,
26
+ version: '1.0.0',
27
+ monitor: {
28
+ type: 'query alert',
29
+ query: this.alarmToDataDogQuery(props),
30
+ name: `${(_b = this.node.scope) === null || _b === void 0 ? void 0 : _b.node.id} ${id}`,
31
+ // TeamName
32
+ message: `
33
+ {{#is_alert}}
34
+ ${props.alarmDescription}
35
+ {{/is_alert}}
36
+
37
+ {{#is_alert_recovery}}
38
+ ${props.alarmDescription} is back to normal.
39
+ {{/is_alert_recovery}}
40
+
41
+ @opsgenie-${props.dataDogOpsGenieIntegrationName}`,
42
+ options: {
43
+ notify_audit: false,
44
+ locked: false,
45
+ timeout_h: 0,
46
+ silenced: {},
47
+ include_tags: false,
48
+ new_host_delay: 300,
49
+ require_full_window: false,
50
+ notify_no_data: props.treatMissingData === cw.TreatMissingData.BREACHING,
51
+ renotify_interval: 0,
52
+ escalation_message: '',
53
+ evaluation_delay: 900,
54
+ },
55
+ },
56
+ },
57
+ });
58
+ }
59
+ /**
60
+ * Helper function to convert a generic alarm into a DataDog query string.
61
+ */
62
+ alarmToDataDogQuery(alarm) {
63
+ let unit = 'not supported';
64
+ let totalPeriod = 0;
65
+ if (alarm.metric.period.toSeconds() < 60) {
66
+ totalPeriod = alarm.metric.period.toSeconds() * alarm.evaluationPeriods;
67
+ unit = 's';
68
+ }
69
+ if (alarm.metric.period.toMinutes() < 1440) {
70
+ totalPeriod = alarm.metric.period.toMinutes() * alarm.evaluationPeriods;
71
+ unit = 'm';
72
+ }
73
+ else {
74
+ totalPeriod = alarm.metric.period.toDays() * alarm.evaluationPeriods;
75
+ unit = 'd';
76
+ }
77
+ // avg(last_15m):max:aws.fargate.cpu.percent{ecs_container_name:$ServiceName$} > 95
78
+ const namespace = alarm.metric.namespace.toLocaleLowerCase().replace('/', '.');
79
+ let metricName = alarm.metric.metricName;
80
+ // Special case for ALB / TargetGroup metrics
81
+ switch (metricName) {
82
+ case 'HTTPCode_ELB_5XX_Count':
83
+ metricName = 'HTTPCode_ELB_5XX';
84
+ break;
85
+ case 'HTTPCode_Target_5XX_Count':
86
+ metricName = 'HTTPCode_Target_5XX';
87
+ break;
88
+ }
89
+ if (!metricName.includes('_')) {
90
+ metricName = metricName.replace(/([a-z])([A-Z])/g, '$1_$2');
91
+ }
92
+ metricName = metricName.toLocaleLowerCase();
93
+ const metric = `${namespace}.${metricName}`;
94
+ // statistics must be lowerCase and probably also converted (see allowed values in cw.Metric)
95
+ let comparisonOperator = 'not supported';
96
+ switch (alarm.comparisonOperator) {
97
+ case cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD:
98
+ comparisonOperator = '>=';
99
+ break;
100
+ case cw.ComparisonOperator.GREATER_THAN_THRESHOLD:
101
+ comparisonOperator = '>';
102
+ break;
103
+ case cw.ComparisonOperator.LESS_THAN_OR_EQUAL_TO_THRESHOLD:
104
+ comparisonOperator = '<=';
105
+ break;
106
+ case cw.ComparisonOperator.LESS_THAN_THRESHOLD:
107
+ comparisonOperator = '<';
108
+ break;
109
+ }
110
+ //const timeStatistic = 'sum'; // For count it should be `sum`, for gauges maybe `avg`
111
+ let alarmStatistic = 'not supported';
112
+ switch (alarm.metric.statistic) {
113
+ case cw.Statistic.AVERAGE:
114
+ alarmStatistic = 'avg';
115
+ break;
116
+ case cw.Statistic.MAXIMUM:
117
+ alarmStatistic = 'max';
118
+ break;
119
+ case cw.Statistic.MINIMUM:
120
+ alarmStatistic = 'min';
121
+ break;
122
+ case cw.Statistic.SAMPLE_COUNT:
123
+ break;
124
+ case cw.Statistic.SUM:
125
+ alarmStatistic = 'sum';
126
+ break;
127
+ default:
128
+ alarmStatistic = 'avg';
129
+ break;
130
+ }
131
+ let dimensions = `account_id:${aws_cdk_lib_1.Stack.of(this).account}`;
132
+ if (alarm.metric.dimensions) {
133
+ for (const key in alarm.metric.dimensions) {
134
+ const upperToLowerCr = new aws_cdk_lib_1.CustomResource(this, `${key}UpperToLower`, {
135
+ resourceType: 'Custom::UpperToLower',
136
+ serviceToken: this.serviceToken,
137
+ properties: {
138
+ Upper: alarm.metric.dimensions[key],
139
+ },
140
+ });
141
+ const value = upperToLowerCr.getAtt('Lower');
142
+ dimensions += `,${key.toLocaleLowerCase()}:${value}`;
143
+ }
144
+ }
145
+ switch (alarm.treatMissingData) {
146
+ case cw.TreatMissingData.NOT_BREACHING:
147
+ return `${alarmStatistic}(last_${totalPeriod}${unit}):default_zero(${alarmStatistic}:${metric}{${dimensions}}) ${comparisonOperator} ${alarm.threshold}`;
148
+ case cw.TreatMissingData.BREACHING:
149
+ case cw.TreatMissingData.IGNORE:
150
+ default:
151
+ return `${alarmStatistic}(last_${totalPeriod}${unit}):${alarmStatistic}:${metric}{${dimensions}} ${comparisonOperator} ${alarm.threshold}`;
152
+ }
153
+ }
154
+ }
155
+ exports.DataDogMetricAlarm = DataDogMetricAlarm;
156
+ _a = JSII_RTTI_SYMBOL_1;
157
+ DataDogMetricAlarm[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.DataDogMetricAlarm", version: "0.0.0" };
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datadog-metric-alarm.js","sourceRoot":"","sources":["../../src/watchful/datadog-metric-alarm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, CustomResource } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { UpperToLower } from './upperToLower';\n\n/**\n * Interface for DataDogMonitor implementation.\n */\nexport interface DataDogMetricAlarmProps extends MetricAlarmProps {\n  /**\n     * Service token which points to the DataDog Monitor custom resource lambda or sns topic.\n     */\n  readonly serviceToken: string;\n\n  /**\n   * The service name used to name the montors (in datadog-integration).\n   */\n  readonly serviceName: string;\n\n  /**\n   * The name of DataDog's OpsGenie integration. Used to automatically create OpsGenie alarms for the created DataDog Monitor.\n   */\n  readonly dataDogOpsGenieIntegrationName: string;\n}\n\n/**\n * A wrapper for a custom resource that creates a DataDog Monitor.\n *\n * To use this construct, the DataDog integration needs to be installed.\n */\nexport class DataDogMetricAlarm extends Construct {\n  private serviceToken: string;\n  constructor(scope: Construct, id: string, props: DataDogMetricAlarmProps) {\n    super(scope, id);\n\n    this.serviceToken = UpperToLower.getOrCreate(this).provider.serviceToken;\n\n    new CustomResource(this, 'DDMonitor', {\n      serviceToken: props.serviceToken,\n      pascalCaseProperties: true,\n      resourceType: 'Custom::DataDogMonitor',\n      properties: {\n        ServiceName: props.serviceName,\n        version: '1.0.0',\n        monitor: {\n          type: 'query alert',\n          query: this.alarmToDataDogQuery(props),\n          name: `${this.node.scope?.node.id} ${id}`, // datadog-integration custom resource prepend it with Team and ServiceName\n          // TeamName\n          message: `\n{{#is_alert}}\n${props.alarmDescription}\n{{/is_alert}} \n\n{{#is_alert_recovery}}\n${props.alarmDescription} is back to normal.\n{{/is_alert_recovery}} \n\n@opsgenie-${props.dataDogOpsGenieIntegrationName}`,\n          options: {\n            notify_audit: false,\n            locked: false, // double-check!\n            timeout_h: 0,\n            silenced: {},\n            include_tags: false,\n            new_host_delay: 300,\n            require_full_window: false,\n            notify_no_data: props.treatMissingData === cw.TreatMissingData.BREACHING,\n            renotify_interval: 0,\n            escalation_message: '',\n            evaluation_delay: 900,\n          },\n        },\n      },\n    });\n  }\n\n  /**\n     * Helper function to convert a generic alarm into a DataDog query string.\n     */\n  alarmToDataDogQuery(alarm: MetricAlarmProps): string {\n    let unit = 'not supported';\n    let totalPeriod = 0;\n    if (alarm.metric.period.toSeconds() < 60) {\n      totalPeriod = alarm.metric.period.toSeconds() * alarm.evaluationPeriods;\n      unit = 's';\n    }\n    if (alarm.metric.period.toMinutes() < 1440) {\n      totalPeriod = alarm.metric.period.toMinutes() * alarm.evaluationPeriods;\n      unit = 'm';\n    } else {\n      totalPeriod = alarm.metric.period.toDays() * alarm.evaluationPeriods;\n      unit = 'd';\n    }\n\n    // avg(last_15m):max:aws.fargate.cpu.percent{ecs_container_name:$ServiceName$} > 95\n    const namespace = alarm.metric.namespace.toLocaleLowerCase().replace('/', '.');\n\n    let metricName = alarm.metric.metricName;\n\n    // Special case for ALB / TargetGroup metrics\n    switch (metricName) {\n      case 'HTTPCode_ELB_5XX_Count':\n        metricName = 'HTTPCode_ELB_5XX';\n        break;\n      case 'HTTPCode_Target_5XX_Count':\n        metricName = 'HTTPCode_Target_5XX';\n        break;\n    }\n    if (!metricName.includes('_')) {\n      metricName = metricName.replace(/([a-z])([A-Z])/g, '$1_$2');\n    }\n    metricName = metricName.toLocaleLowerCase();\n\n    const metric = `${namespace}.${metricName}`;\n\n    // statistics must be lowerCase and probably also converted (see allowed values in cw.Metric)\n    let comparisonOperator = 'not supported';\n    switch (alarm.comparisonOperator) {\n      case cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD:\n        comparisonOperator = '>=';\n        break;\n      case cw.ComparisonOperator.GREATER_THAN_THRESHOLD:\n        comparisonOperator = '>';\n        break;\n      case cw.ComparisonOperator.LESS_THAN_OR_EQUAL_TO_THRESHOLD:\n        comparisonOperator = '<=';\n        break;\n      case cw.ComparisonOperator.LESS_THAN_THRESHOLD:\n        comparisonOperator = '<';\n        break;\n    }\n\n    //const timeStatistic = 'sum'; // For count it should be `sum`, for gauges maybe `avg`\n\n    let alarmStatistic = 'not supported';\n    switch (alarm.metric.statistic) {\n      case cw.Statistic.AVERAGE:\n        alarmStatistic = 'avg';\n        break;\n      case cw.Statistic.MAXIMUM:\n        alarmStatistic = 'max';\n        break;\n      case cw.Statistic.MINIMUM:\n        alarmStatistic = 'min';\n        break;\n      case cw.Statistic.SAMPLE_COUNT:\n        break;\n      case cw.Statistic.SUM:\n        alarmStatistic = 'sum';\n        break;\n      default:\n        alarmStatistic = 'avg';\n        break;\n    }\n\n    let dimensions = `account_id:${Stack.of(this).account}`;\n\n    if (alarm.metric.dimensions) {\n      for (const key in alarm.metric.dimensions) {\n        const upperToLowerCr = new CustomResource(this, `${key}UpperToLower`, {\n          resourceType: 'Custom::UpperToLower',\n          serviceToken: this.serviceToken,\n          properties: {\n            Upper: alarm.metric.dimensions[key],\n          },\n        });\n        const value = upperToLowerCr.getAtt('Lower');\n        dimensions += `,${key.toLocaleLowerCase()}:${value}`;\n      }\n    }\n\n    switch (alarm.treatMissingData) {\n      case cw.TreatMissingData.NOT_BREACHING:\n        return `${alarmStatistic}(last_${totalPeriod}${unit}):default_zero(${alarmStatistic}:${metric}{${dimensions}}) ${comparisonOperator} ${alarm.threshold}`;\n      case cw.TreatMissingData.BREACHING:\n      case cw.TreatMissingData.IGNORE:\n      default:\n        return `${alarmStatistic}(last_${totalPeriod}${unit}):${alarmStatistic}:${metric}{${dimensions}} ${comparisonOperator} ${alarm.threshold}`;\n    }\n  }\n}\n"]}
@@ -0,0 +1,62 @@
1
+ import * as docdb from 'aws-cdk-lib/aws-docdb';
2
+ import { Construct } from 'constructs';
3
+ import { IWatchful } from './watchful';
4
+ /**
5
+ * Options for defining alarms.
6
+ */
7
+ export interface WatchDocDbClusterOptions {
8
+ /**
9
+ * Threshold of database cpu utilization.
10
+ *
11
+ * @default 80
12
+ */
13
+ readonly cpuUtilizationThreshold?: number;
14
+ /**
15
+ * Minimum database freeable memory in bytes.
16
+ *
17
+ * @default 64000000 (64 Megabyte)
18
+ */
19
+ readonly freeableMemoryThresholdInByte?: number;
20
+ /**
21
+ * Threshold of database swap usage
22
+ *
23
+ * @default 256000000 (256 Megabyte)
24
+ */
25
+ readonly swapUsageThresholdInByte?: number;
26
+ /**
27
+ * Minimum database free local storage space
28
+ *
29
+ * @default 2000000000 (2 Gigabyte)
30
+ */
31
+ readonly freeLocalStorageInByte?: number;
32
+ }
33
+ /**
34
+ * Properties for defining a WatchDocDbCluster
35
+ */
36
+ export interface WatchDocDbClusterProps extends WatchDocDbClusterOptions {
37
+ /**
38
+ * The reference to IWatchful class. Used internally.
39
+ */
40
+ readonly watchful: IWatchful;
41
+ /**
42
+ * The DocDB cluster that should be watched.
43
+ * [disable-awslint:ref-via-interface]
44
+ */
45
+ readonly docDb: docdb.DatabaseCluster;
46
+ }
47
+ /**
48
+ * A Construct which creates the following alarms for DocumentDb clusters:
49
+ *
50
+ * - freeable memory
51
+ * - swap usage
52
+ * - free local storage
53
+ */
54
+ export declare class WatchDocDbCluster extends Construct {
55
+ private readonly watchful;
56
+ private readonly docDb;
57
+ constructor(scope: Construct, id: string, props: WatchDocDbClusterProps);
58
+ private createCpuUtilizationTooHighAlarm;
59
+ private createFreeableMemoryTooLowAlarm;
60
+ private createSwapUsageTooHighAlarm;
61
+ private createFreeLocalStorageTooLowAlarm;
62
+ }
@@ -0,0 +1,102 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.WatchDocDbCluster = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const cw = require("aws-cdk-lib/aws-cloudwatch");
8
+ const constructs_1 = require("constructs");
9
+ /**
10
+ * A Construct which creates the following alarms for DocumentDb clusters:
11
+ *
12
+ * - freeable memory
13
+ * - swap usage
14
+ * - free local storage
15
+ */
16
+ class WatchDocDbCluster extends constructs_1.Construct {
17
+ constructor(scope, id, props) {
18
+ super(scope, id);
19
+ this.watchful = props.watchful;
20
+ this.docDb = props.docDb;
21
+ this.watchful.createAlarm(this, 'CpuUtilization', this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold));
22
+ this.watchful.createAlarm(this, 'FreeableMemoryTooLow', this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte));
23
+ this.watchful.createAlarm(this, 'SwapUsageTooHigh', this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte));
24
+ this.watchful.createAlarm(this, 'FreeLocalStorageTooLow', this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte));
25
+ }
26
+ createCpuUtilizationTooHighAlarm(cpuUtilizationThreshold = 80) {
27
+ const docDbMetric = new cw.Metric({
28
+ metricName: 'CPUUtilization',
29
+ namespace: 'AWS/DocDB',
30
+ period: aws_cdk_lib_1.Duration.seconds(600),
31
+ statistic: cw.Statistic.AVERAGE,
32
+ dimensionsMap: {
33
+ DBClusterIdentifier: this.docDb.clusterIdentifier,
34
+ },
35
+ });
36
+ return {
37
+ metric: docDbMetric,
38
+ alarmDescription: 'Average database CPU utilization over last 10 minutes too high.',
39
+ comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,
40
+ threshold: cpuUtilizationThreshold,
41
+ evaluationPeriods: 1,
42
+ };
43
+ }
44
+ createFreeableMemoryTooLowAlarm(freeableMemoryThresholdInByte = 64000000) {
45
+ const docDbMetric = new cw.Metric({
46
+ metricName: 'FreeableMemory',
47
+ namespace: 'AWS/DocDB',
48
+ period: aws_cdk_lib_1.Duration.seconds(600),
49
+ statistic: cw.Statistic.AVERAGE,
50
+ dimensionsMap: {
51
+ DBClusterIdentifier: this.docDb.clusterIdentifier,
52
+ },
53
+ });
54
+ return {
55
+ metric: docDbMetric,
56
+ alarmDescription: 'Average database freeable memory over last 10 minutes too low, performance may suffer.',
57
+ comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,
58
+ threshold: freeableMemoryThresholdInByte,
59
+ evaluationPeriods: 1,
60
+ };
61
+ }
62
+ createSwapUsageTooHighAlarm(swapUsageThresholdInByte = 256000000) {
63
+ const docDbMetric = new cw.Metric({
64
+ metricName: 'SwapUsage',
65
+ namespace: 'AWS/DocDB',
66
+ period: aws_cdk_lib_1.Duration.seconds(600),
67
+ statistic: cw.Statistic.AVERAGE,
68
+ dimensionsMap: {
69
+ DBClusterIdentifier: this.docDb.clusterIdentifier,
70
+ },
71
+ });
72
+ return {
73
+ metric: docDbMetric,
74
+ alarmDescription: 'Average database swap usage over last 10 minutes too high, performance may suffer.',
75
+ comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,
76
+ threshold: swapUsageThresholdInByte,
77
+ evaluationPeriods: 1,
78
+ };
79
+ }
80
+ createFreeLocalStorageTooLowAlarm(freeLocalStorageInByte = 2000000000) {
81
+ const docDbMetric = new cw.Metric({
82
+ metricName: 'FreeLocalStorage',
83
+ namespace: 'AWS/DocDB',
84
+ period: aws_cdk_lib_1.Duration.seconds(600),
85
+ statistic: cw.Statistic.AVERAGE,
86
+ dimensionsMap: {
87
+ DBClusterIdentifier: this.docDb.clusterIdentifier,
88
+ },
89
+ });
90
+ return {
91
+ metric: docDbMetric,
92
+ alarmDescription: 'Average database free local storage space over last 10 minutes too low.',
93
+ comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,
94
+ threshold: freeLocalStorageInByte,
95
+ evaluationPeriods: 1,
96
+ };
97
+ }
98
+ }
99
+ exports.WatchDocDbCluster = WatchDocDbCluster;
100
+ _a = JSII_RTTI_SYMBOL_1;
101
+ WatchDocDbCluster[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchDocDbCluster", version: "0.0.0" };
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docdb.js","sourceRoot":"","sources":["../../src/watchful/docdb.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from 'aws-cdk-lib';\nimport * as cw from 'aws-cdk-lib/aws-cloudwatch';\nimport * as docdb from 'aws-cdk-lib/aws-docdb';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDocDbClusterOptions {\n  /**\n     * Threshold of database cpu utilization.\n     *\n     * @default 80\n     */\n  readonly cpuUtilizationThreshold?: number;\n  /**\n     * Minimum database freeable memory in bytes.\n     *\n     * @default 64000000 (64 Megabyte)\n     */\n  readonly freeableMemoryThresholdInByte?: number;\n  /**\n     * Threshold of database swap usage\n     *\n     * @default 256000000 (256 Megabyte)\n     */\n  readonly swapUsageThresholdInByte?: number;\n  /**\n     * Minimum database free local storage space\n     *\n     * @default 2000000000 (2 Gigabyte)\n     */\n  readonly freeLocalStorageInByte?: number;\n}\n\n/**\n * Properties for defining a WatchDocDbCluster\n */\nexport interface WatchDocDbClusterProps extends WatchDocDbClusterOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DocDB cluster that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly docDb: docdb.DatabaseCluster;\n}\n\n/**\n * A Construct which creates the following alarms for DocumentDb clusters:\n *\n * - freeable memory\n * - swap usage\n * - free local storage\n */\nexport class WatchDocDbCluster extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly docDb: docdb.DatabaseCluster;\n\n  constructor(scope: Construct, id: string, props: WatchDocDbClusterProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.docDb = props.docDb;\n\n    this.watchful.createAlarm(this,\n      'CpuUtilization',\n      this.createCpuUtilizationTooHighAlarm(props.cpuUtilizationThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'FreeableMemoryTooLow',\n      this.createFreeableMemoryTooLowAlarm(props.freeableMemoryThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      'SwapUsageTooHigh',\n      this.createSwapUsageTooHighAlarm(props.swapUsageThresholdInByte),\n    );\n    this.watchful.createAlarm(this,\n      'FreeLocalStorageTooLow',\n      this.createFreeLocalStorageTooLowAlarm(props.freeLocalStorageInByte),\n    );\n  }\n\n  private createCpuUtilizationTooHighAlarm(cpuUtilizationThreshold = 80): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'CPUUtilization',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database CPU utilization over last 10 minutes too high.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: cpuUtilizationThreshold,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeableMemoryTooLowAlarm(freeableMemoryThresholdInByte = 64000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeableMemory',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database freeable memory over last 10 minutes too low, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeableMemoryThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createSwapUsageTooHighAlarm(swapUsageThresholdInByte = 256000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'SwapUsage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database swap usage over last 10 minutes too high, performance may suffer.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_THRESHOLD,\n      threshold: swapUsageThresholdInByte,\n      evaluationPeriods: 1,\n    };\n  }\n\n  private createFreeLocalStorageTooLowAlarm(freeLocalStorageInByte = 2000000000): MetricAlarmProps {\n    const docDbMetric = new cw.Metric({\n      metricName: 'FreeLocalStorage',\n      namespace: 'AWS/DocDB',\n      period: Duration.seconds(600),\n      statistic: cw.Statistic.AVERAGE,\n      dimensionsMap: {\n        DBClusterIdentifier: this.docDb.clusterIdentifier,\n      },\n    });\n    return {\n      metric: docDbMetric,\n      alarmDescription: 'Average database free local storage space over last 10 minutes too low.',\n      comparisonOperator: cw.ComparisonOperator.LESS_THAN_THRESHOLD,\n      threshold: freeLocalStorageInByte,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
@@ -0,0 +1,69 @@
1
+ import { aws_dynamodb as dynamodb } from 'aws-cdk-lib';
2
+ import { Construct } from 'constructs';
3
+ import { IWatchful } from './watchful';
4
+ /**
5
+ * Options for defining alarms.
6
+ */
7
+ export interface WatchDynamoDbTableOptions {
8
+ /**
9
+ * Threshold of read throttle events.
10
+ *
11
+ * @default 1
12
+ */
13
+ readonly readThrottleEventsThreshold?: number;
14
+ /**
15
+ * Threshold of write throttle events.
16
+ *
17
+ * @default 1
18
+ */
19
+ readonly writeThrottleEventsThreshold?: number;
20
+ /**
21
+ * Threshold of throttled requests events.
22
+ *
23
+ * @default 1
24
+ */
25
+ readonly throttledRequestsEventsThreshold?: number;
26
+ /**
27
+ * Threshold of user errors.
28
+ *
29
+ * @default 1
30
+ */
31
+ readonly userErrorsThreshold?: number;
32
+ /**
33
+ * Threshold of system errors.
34
+ *
35
+ * @default 1
36
+ */
37
+ readonly systemErrorsThreshold?: number;
38
+ }
39
+ /**
40
+ * Properties for defining a WatchDynamoDbTable
41
+ */
42
+ export interface WatchDynamoDbTableProps extends WatchDynamoDbTableOptions {
43
+ /**
44
+ * The reference to IWatchful class. Used internally.
45
+ */
46
+ readonly watchful: IWatchful;
47
+ /**
48
+ * The DynamoDb table that should be watched.
49
+ * [disable-awslint:ref-via-interface]
50
+ */
51
+ readonly dynamoDbTable: dynamodb.Table;
52
+ }
53
+ /**
54
+ * A Construct which creates the following alarms for DynamoDb tables:
55
+ *
56
+ * - read throttles
57
+ * - write throttles
58
+ * - throttled requests
59
+ * - user errors
60
+ * - system errors
61
+ */
62
+ export declare class WatchDynamoDbTable extends Construct {
63
+ private readonly watchful;
64
+ private readonly dynamoDb;
65
+ constructor(scope: Construct, id: string, props: WatchDynamoDbTableProps);
66
+ private createReadThrottleEventsAlarm;
67
+ private createWriteThrottleEventsAlarm;
68
+ private createThrottledRequestsEventsAlarm;
69
+ }
@@ -0,0 +1,87 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.WatchDynamoDbTable = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ const aws_cdk_lib_1 = require("aws-cdk-lib");
7
+ const constructs_1 = require("constructs");
8
+ /**
9
+ * A Construct which creates the following alarms for DynamoDb tables:
10
+ *
11
+ * - read throttles
12
+ * - write throttles
13
+ * - throttled requests
14
+ * - user errors
15
+ * - system errors
16
+ */
17
+ class WatchDynamoDbTable extends constructs_1.Construct {
18
+ constructor(scope, id, props) {
19
+ super(scope, id);
20
+ this.watchful = props.watchful;
21
+ this.dynamoDb = props.dynamoDbTable;
22
+ this.watchful.createAlarm(this, 'ReadThrottleEvents', this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold));
23
+ this.watchful.createAlarm(this, 'WriteThrottleEvents', this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold));
24
+ this.watchful.createAlarm(this, 'ThrottledRequestsEvents', this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold));
25
+ }
26
+ createReadThrottleEventsAlarm(readThrottleEventsThreshold = 1) {
27
+ const dynamoDbMetric = new aws_cdk_lib_1.aws_cloudwatch.Metric({
28
+ metricName: 'ReadThrottleEvents',
29
+ namespace: 'AWS/DynamoDB',
30
+ period: aws_cdk_lib_1.Duration.seconds(60),
31
+ statistic: aws_cdk_lib_1.aws_cloudwatch.Statistic.SUM,
32
+ dimensionsMap: {
33
+ TableName: this.dynamoDb.tableName,
34
+ },
35
+ });
36
+ return {
37
+ metric: dynamoDbMetric,
38
+ alarmDescription: 'Reads are throttled. Lower ReadCapacityUnitsUtilizationTarget or increase MaxReadCapacityUnits.',
39
+ comparisonOperator: aws_cdk_lib_1.aws_cloudwatch.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
40
+ threshold: readThrottleEventsThreshold,
41
+ treatMissingData: aws_cdk_lib_1.aws_cloudwatch.TreatMissingData.NOT_BREACHING,
42
+ evaluationPeriods: 1,
43
+ };
44
+ }
45
+ createWriteThrottleEventsAlarm(writeThrottleEventsThreshold = 1) {
46
+ const dynamoDbMetric = new aws_cdk_lib_1.aws_cloudwatch.Metric({
47
+ metricName: 'WriteThrottleEvents',
48
+ namespace: 'AWS/DynamoDB',
49
+ period: aws_cdk_lib_1.Duration.seconds(60),
50
+ statistic: aws_cdk_lib_1.aws_cloudwatch.Statistic.SUM,
51
+ dimensionsMap: {
52
+ TableName: this.dynamoDb.tableName,
53
+ },
54
+ });
55
+ return {
56
+ metric: dynamoDbMetric,
57
+ alarmDescription: 'Writes are throttled. Lower WriteCapacityUnitsUtilizationTarget or increase MaxWriteCapacityUnits.',
58
+ comparisonOperator: aws_cdk_lib_1.aws_cloudwatch.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
59
+ threshold: writeThrottleEventsThreshold,
60
+ treatMissingData: aws_cdk_lib_1.aws_cloudwatch.TreatMissingData.NOT_BREACHING,
61
+ evaluationPeriods: 1,
62
+ };
63
+ }
64
+ createThrottledRequestsEventsAlarm(throttledRequestsEventsThreshold = 1) {
65
+ const dynamoDbMetric = new aws_cdk_lib_1.aws_cloudwatch.Metric({
66
+ metricName: 'ThrottledRequests',
67
+ namespace: 'AWS/DynamoDB',
68
+ period: aws_cdk_lib_1.Duration.seconds(60),
69
+ statistic: aws_cdk_lib_1.aws_cloudwatch.Statistic.SUM,
70
+ dimensionsMap: {
71
+ TableName: this.dynamoDb.tableName,
72
+ },
73
+ });
74
+ return {
75
+ metric: dynamoDbMetric,
76
+ alarmDescription: 'Batch requests are throttled. Lower {Read/Write}CapacityUnitsUtilizationTarget or increase Max{Read/Write}CapacityUnits.',
77
+ comparisonOperator: aws_cdk_lib_1.aws_cloudwatch.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
78
+ threshold: throttledRequestsEventsThreshold,
79
+ treatMissingData: aws_cdk_lib_1.aws_cloudwatch.TreatMissingData.NOT_BREACHING,
80
+ evaluationPeriods: 1,
81
+ };
82
+ }
83
+ }
84
+ exports.WatchDynamoDbTable = WatchDynamoDbTable;
85
+ _a = JSII_RTTI_SYMBOL_1;
86
+ WatchDynamoDbTable[_a] = { fqn: "@rio-cloud/cdk-v2-constructs.WatchDynamoDbTable", version: "0.0.0" };
87
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamodb.js","sourceRoot":"","sources":["../../src/watchful/dynamodb.ts"],"names":[],"mappings":"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","sourcesContent":["import { aws_cloudwatch as cw, aws_dynamodb as dynamodb, Duration } from 'aws-cdk-lib';\nimport { Construct } from 'constructs';\nimport { MetricAlarmProps } from './metric-alarm';\nimport { IWatchful } from './watchful';\n\n/**\n * Options for defining alarms.\n */\nexport interface WatchDynamoDbTableOptions {\n  /**\n     * Threshold of read throttle events.\n     *\n     * @default 1\n     */\n  readonly readThrottleEventsThreshold?: number;\n  /**\n     * Threshold of write throttle events.\n     *\n     * @default 1\n     */\n  readonly writeThrottleEventsThreshold?: number;\n  /**\n     * Threshold of throttled requests events.\n     *\n     * @default 1\n     */\n  readonly throttledRequestsEventsThreshold?: number;\n  /**\n     * Threshold of user errors.\n     *\n     * @default 1\n     */\n  readonly userErrorsThreshold?: number;\n\n  /**\n     * Threshold of system errors.\n     *\n     * @default 1\n     */\n  readonly systemErrorsThreshold?: number;\n}\n\n/**\n * Properties for defining a WatchDynamoDbTable\n */\nexport interface WatchDynamoDbTableProps extends WatchDynamoDbTableOptions {\n  /**\n     * The reference to IWatchful class. Used internally.\n     */\n  readonly watchful: IWatchful;\n\n  /**\n     * The DynamoDb table that should be watched.\n     * [disable-awslint:ref-via-interface]\n     */\n  readonly dynamoDbTable: dynamodb.Table;\n}\n\n/**\n * A Construct which creates the following alarms for DynamoDb tables:\n *\n * - read throttles\n * - write throttles\n * - throttled requests\n * - user errors\n * - system errors\n */\nexport class WatchDynamoDbTable extends Construct {\n  private readonly watchful: IWatchful;\n  private readonly dynamoDb: dynamodb.Table;\n\n  constructor(scope: Construct, id: string, props: WatchDynamoDbTableProps) {\n    super(scope, id);\n\n    this.watchful = props.watchful;\n    this.dynamoDb = props.dynamoDbTable;\n\n    this.watchful.createAlarm(this,\n      'ReadThrottleEvents',\n      this.createReadThrottleEventsAlarm(props.readThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'WriteThrottleEvents',\n      this.createWriteThrottleEventsAlarm(props.writeThrottleEventsThreshold),\n    );\n    this.watchful.createAlarm(this,\n      'ThrottledRequestsEvents',\n      this.createThrottledRequestsEventsAlarm(props.throttledRequestsEventsThreshold),\n    );\n  }\n\n  private createReadThrottleEventsAlarm(readThrottleEventsThreshold = 1): MetricAlarmProps {\n\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ReadThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Reads are throttled. Lower ReadCapacityUnitsUtilizationTarget or increase MaxReadCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: readThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createWriteThrottleEventsAlarm(writeThrottleEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'WriteThrottleEvents',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Writes are throttled. Lower WriteCapacityUnitsUtilizationTarget or increase MaxWriteCapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: writeThrottleEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n  private createThrottledRequestsEventsAlarm(throttledRequestsEventsThreshold = 1): MetricAlarmProps {\n    const dynamoDbMetric = new cw.Metric({\n      metricName: 'ThrottledRequests',\n      namespace: 'AWS/DynamoDB',\n      period: Duration.seconds(60),\n      statistic: cw.Statistic.SUM,\n      dimensionsMap: {\n        TableName: this.dynamoDb.tableName,\n      },\n    });\n    return {\n      metric: dynamoDbMetric,\n      alarmDescription:\n        'Batch requests are throttled. Lower {Read/Write}CapacityUnitsUtilizationTarget or increase Max{Read/Write}CapacityUnits.',\n      comparisonOperator: cw.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n      threshold: throttledRequestsEventsThreshold,\n      treatMissingData: cw.TreatMissingData.NOT_BREACHING,\n      evaluationPeriods: 1,\n    };\n  }\n}\n"]}
@@ -0,0 +1,50 @@
1
+ import * as ecs from 'aws-cdk-lib/aws-ecs';
2
+ import { Construct } from 'constructs';
3
+ import { IWatchful } from './watchful';
4
+ /**
5
+ * Options for defining alarms.
6
+ */
7
+ export interface WatchEcsServiceOptions {
8
+ /**
9
+ * Threshold for the cpu utilization alarm as percentage.
10
+ *
11
+ * @default 80
12
+ */
13
+ readonly cpuUtilizationThresholdPercent?: number;
14
+ /**
15
+ * Threshold for the memory utilization alarm as percentage.
16
+ *
17
+ * @default 95
18
+ */
19
+ readonly memoryUtilizationThresholdPercent?: number;
20
+ }
21
+ /**
22
+ * Properties for defining a WatchEcsService
23
+ */
24
+ export interface WatchEcsServiceProps extends WatchEcsServiceOptions {
25
+ /**
26
+ * The reference to IWatchful class. Used internally.
27
+ */
28
+ readonly watchful: IWatchful;
29
+ /**
30
+ * The ECS service that should be watched.
31
+ * [disable-awslint:ref-via-interface]
32
+ */
33
+ readonly service: ecs.BaseService;
34
+ }
35
+ /**
36
+ * A Construct which creates default alarms for ECS services.
37
+ * A Construct which creates the following alarms for ECS services:
38
+ *
39
+ * - cpu utilization
40
+ * - memory utilization
41
+ * - error log alert
42
+ */
43
+ export declare class WatchEcsService extends Construct {
44
+ private readonly watchful;
45
+ private readonly service;
46
+ constructor(scope: Construct, id: string, props: WatchEcsServiceProps);
47
+ private createLogErrorMonitor;
48
+ private createCpuUtilizationMonitor;
49
+ private createMemoryUtilizationMonitor;
50
+ }