@cdklabs/multi-az-observability 0.0.0-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 (212) hide show
  1. package/.jsii +10177 -0
  2. package/API.md +5119 -0
  3. package/LICENSE +202 -0
  4. package/README.md +175 -0
  5. package/cdk.json +68 -0
  6. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +214 -0
  7. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +763 -0
  8. package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.d.ts +22 -0
  9. package/lib/alarmsandrules/BaseOperationRegionalAlarmsAndRules.js +21 -0
  10. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +34 -0
  11. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +39 -0
  12. package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.d.ts +7 -0
  13. package/lib/alarmsandrules/CanaryOperationRegionalAlarmsAndRules.js +11 -0
  14. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.d.ts +16 -0
  15. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +17 -0
  16. package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.d.ts +18 -0
  17. package/lib/alarmsandrules/IBaseOperationRegionalAlarmsAndRules.js +3 -0
  18. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +30 -0
  19. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +3 -0
  20. package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.d.ts +6 -0
  21. package/lib/alarmsandrules/ICanaryOperationRegionalAlarmsAndRules.js +3 -0
  22. package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.d.ts +12 -0
  23. package/lib/alarmsandrules/ICanaryOperationZonalAlarmsAndRules.js +3 -0
  24. package/lib/alarmsandrules/IOperationAlarmsAndRules.d.ts +55 -0
  25. package/lib/alarmsandrules/IOperationAlarmsAndRules.js +3 -0
  26. package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.d.ts +15 -0
  27. package/lib/alarmsandrules/IServerSideOperationRegionalAlarmsAndRules.js +3 -0
  28. package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.d.ts +36 -0
  29. package/lib/alarmsandrules/IServerSideOperationZonalAlarmsAndRules.js +3 -0
  30. package/lib/alarmsandrules/IServiceAlarmsAndRules.d.ts +44 -0
  31. package/lib/alarmsandrules/IServiceAlarmsAndRules.js +3 -0
  32. package/lib/alarmsandrules/InsightRuleBody.d.ts +67 -0
  33. package/lib/alarmsandrules/InsightRuleBody.js +46 -0
  34. package/lib/alarmsandrules/OperationAlarmsAndRules.d.ts +59 -0
  35. package/lib/alarmsandrules/OperationAlarmsAndRules.js +135 -0
  36. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.d.ts +19 -0
  37. package/lib/alarmsandrules/ServerSideOperationRegionalAlarmsAndRules.js +22 -0
  38. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.d.ts +40 -0
  39. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +46 -0
  40. package/lib/alarmsandrules/ServiceAlarmsAndRules.d.ts +48 -0
  41. package/lib/alarmsandrules/ServiceAlarmsAndRules.js +166 -0
  42. package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.d.ts +24 -0
  43. package/lib/alarmsandrules/props/BaseOperationRegionalAlarmsAndRulesProps.js +3 -0
  44. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +62 -0
  45. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +3 -0
  46. package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
  47. package/lib/alarmsandrules/props/CanaryOperationRegionalAlarmsAndRulesProps.js +3 -0
  48. package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.d.ts +6 -0
  49. package/lib/alarmsandrules/props/CanaryOperationZonalAlarmsAndRulesProps.js +3 -0
  50. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.d.ts +45 -0
  51. package/lib/alarmsandrules/props/OperationAlarmsAndRulesProps.js +3 -0
  52. package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.d.ts +6 -0
  53. package/lib/alarmsandrules/props/ServerSideOperationRegionalAlarmsAndRulesProps.js +3 -0
  54. package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.d.ts +6 -0
  55. package/lib/alarmsandrules/props/ServerSideOperationZonalAlarmsAndRulesProps.js +3 -0
  56. package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.d.ts +13 -0
  57. package/lib/alarmsandrules/props/ServiceAlarmsAndRulesProps.js +3 -0
  58. package/lib/azmapper/AvailabilityZoneMapper.d.ts +86 -0
  59. package/lib/azmapper/AvailabilityZoneMapper.js +200 -0
  60. package/lib/azmapper/IAvailabilityZoneMapper.d.ts +86 -0
  61. package/lib/azmapper/IAvailabilityZoneMapper.js +3 -0
  62. package/lib/azmapper/props/AvailabilityZoneMapperProps.d.ts +13 -0
  63. package/lib/azmapper/props/AvailabilityZoneMapperProps.js +3 -0
  64. package/lib/azmapper/src/index.py +107 -0
  65. package/lib/canaries/CanaryFunction.d.ts +16 -0
  66. package/lib/canaries/CanaryFunction.js +152 -0
  67. package/lib/canaries/CanaryTest.d.ts +10 -0
  68. package/lib/canaries/CanaryTest.js +84 -0
  69. package/lib/canaries/ICanaryFunction.d.ts +6 -0
  70. package/lib/canaries/ICanaryFunction.js +3 -0
  71. package/lib/canaries/props/AddCanaryTestProps.d.ts +66 -0
  72. package/lib/canaries/props/AddCanaryTestProps.js +3 -0
  73. package/lib/canaries/props/CanaryFunctionProps.d.ts +29 -0
  74. package/lib/canaries/props/CanaryFunctionProps.js +3 -0
  75. package/lib/canaries/props/CanaryTestProps.d.ts +21 -0
  76. package/lib/canaries/props/CanaryTestProps.js +3 -0
  77. package/lib/canaries/props/NetworkConfigurationProps.d.ts +16 -0
  78. package/lib/canaries/props/NetworkConfigurationProps.js +3 -0
  79. package/lib/canaries/src/canary.zip +0 -0
  80. package/lib/dashboards/BasicServiceDashboard.d.ts +10 -0
  81. package/lib/dashboards/BasicServiceDashboard.js +130 -0
  82. package/lib/dashboards/ContributorInsightsWidget.d.ts +22 -0
  83. package/lib/dashboards/ContributorInsightsWidget.js +55 -0
  84. package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.d.ts +10 -0
  85. package/lib/dashboards/IOperationAvailabilityAndLatencyDashboard.js +3 -0
  86. package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.d.ts +10 -0
  87. package/lib/dashboards/IServiceAvailabilityAndLatencyDashboard.js +3 -0
  88. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +20 -0
  89. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +588 -0
  90. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +24 -0
  91. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +475 -0
  92. package/lib/dashboards/props/BasicServiceDashboardProps.d.ts +23 -0
  93. package/lib/dashboards/props/BasicServiceDashboardProps.js +3 -0
  94. package/lib/dashboards/props/ContributorInsightWidgetProps.d.ts +31 -0
  95. package/lib/dashboards/props/ContributorInsightWidgetProps.js +3 -0
  96. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +84 -0
  97. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +3 -0
  98. package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +37 -0
  99. package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +3 -0
  100. package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +37 -0
  101. package/lib/dashboards/props/OperationLatencyWidgetProps.js +3 -0
  102. package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.d.ts +30 -0
  103. package/lib/dashboards/props/ServiceAvailabilityAndLatencyDashboardProps.js +3 -0
  104. package/lib/index.d.ts +35 -0
  105. package/lib/index.js +30 -0
  106. package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +36 -0
  107. package/lib/metrics/ApplicationLoadBalancerMetrics.js +150 -0
  108. package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +61 -0
  109. package/lib/metrics/AvailabilityAndLatencyMetrics.js +212 -0
  110. package/lib/metrics/NetworkLoadBalancerMetrics.d.ts +19 -0
  111. package/lib/metrics/NetworkLoadBalancerMetrics.js +48 -0
  112. package/lib/metrics/RegionalAvailabilityMetrics.d.ts +19 -0
  113. package/lib/metrics/RegionalAvailabilityMetrics.js +71 -0
  114. package/lib/metrics/RegionalLatencyMetrics.d.ts +33 -0
  115. package/lib/metrics/RegionalLatencyMetrics.js +69 -0
  116. package/lib/metrics/ZonalAvailabilityMetrics.d.ts +19 -0
  117. package/lib/metrics/ZonalAvailabilityMetrics.js +71 -0
  118. package/lib/metrics/ZonalLatencyMetrics.d.ts +29 -0
  119. package/lib/metrics/ZonalLatencyMetrics.js +65 -0
  120. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +23 -0
  121. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +3 -0
  122. package/lib/metrics/props/AvailabilityMetricProps.d.ts +11 -0
  123. package/lib/metrics/props/AvailabilityMetricProps.js +3 -0
  124. package/lib/metrics/props/LatencyMetricProps.d.ts +15 -0
  125. package/lib/metrics/props/LatencyMetricProps.js +3 -0
  126. package/lib/metrics/props/RegionalAvailabilityMetricProps.d.ts +6 -0
  127. package/lib/metrics/props/RegionalAvailabilityMetricProps.js +3 -0
  128. package/lib/metrics/props/RegionalLatencyMetricProps.d.ts +6 -0
  129. package/lib/metrics/props/RegionalLatencyMetricProps.js +3 -0
  130. package/lib/metrics/props/ServiceAvailabilityMetricProps.d.ts +23 -0
  131. package/lib/metrics/props/ServiceAvailabilityMetricProps.js +3 -0
  132. package/lib/metrics/props/ServiceLatencyMericProps.d.ts +23 -0
  133. package/lib/metrics/props/ServiceLatencyMericProps.js +3 -0
  134. package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +10 -0
  135. package/lib/metrics/props/ZonalAvailabilityMetricProps.js +3 -0
  136. package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +10 -0
  137. package/lib/metrics/props/ZonalLatencyMetricProps.js +3 -0
  138. package/lib/monitoring/src/monitoring-layer.zip +0 -0
  139. package/lib/outlier-detection/IOutlierDetectionFunction.d.ts +12 -0
  140. package/lib/outlier-detection/IOutlierDetectionFunction.js +3 -0
  141. package/lib/outlier-detection/OutlierDetectionFunction.d.ts +16 -0
  142. package/lib/outlier-detection/OutlierDetectionFunction.js +126 -0
  143. package/lib/outlier-detection/props/OutlierDetectionFunctionProps.d.ts +12 -0
  144. package/lib/outlier-detection/props/OutlierDetectionFunctionProps.js +3 -0
  145. package/lib/outlier-detection/src/outlier-detection.zip +0 -0
  146. package/lib/outlier-detection/src/scipy-layer.zip +0 -0
  147. package/lib/services/BasicServiceMultiAZObservability.d.ts +64 -0
  148. package/lib/services/BasicServiceMultiAZObservability.js +504 -0
  149. package/lib/services/CanaryMetrics.d.ts +17 -0
  150. package/lib/services/CanaryMetrics.js +19 -0
  151. package/lib/services/CanaryTestMetricsOverride.d.ts +39 -0
  152. package/lib/services/CanaryTestMetricsOverride.js +23 -0
  153. package/lib/services/ContributorInsightRuleDetails.d.ts +42 -0
  154. package/lib/services/ContributorInsightRuleDetails.js +23 -0
  155. package/lib/services/IBasicServiceMultiAZObservability.d.ts +45 -0
  156. package/lib/services/IBasicServiceMultiAZObservability.js +3 -0
  157. package/lib/services/ICanaryMetrics.d.ts +14 -0
  158. package/lib/services/ICanaryMetrics.js +3 -0
  159. package/lib/services/ICanaryTestMetricsOverride.d.ts +36 -0
  160. package/lib/services/ICanaryTestMetricsOverride.js +3 -0
  161. package/lib/services/IContributorInsightRuleDetails.d.ts +38 -0
  162. package/lib/services/IContributorInsightRuleDetails.js +3 -0
  163. package/lib/services/IInstrumentedServiceMultiAZObservability.d.ts +39 -0
  164. package/lib/services/IInstrumentedServiceMultiAZObservability.js +3 -0
  165. package/lib/services/IOperation.d.ts +75 -0
  166. package/lib/services/IOperation.js +3 -0
  167. package/lib/services/IOperationMetricDetails.d.ts +78 -0
  168. package/lib/services/IOperationMetricDetails.js +3 -0
  169. package/lib/services/IService.d.ts +76 -0
  170. package/lib/services/IService.js +3 -0
  171. package/lib/services/IServiceMetricDetails.d.ts +68 -0
  172. package/lib/services/IServiceMetricDetails.js +3 -0
  173. package/lib/services/InstrumentedServiceMultiAZObservability.d.ts +55 -0
  174. package/lib/services/InstrumentedServiceMultiAZObservability.js +310 -0
  175. package/lib/services/Operation.d.ts +78 -0
  176. package/lib/services/Operation.js +34 -0
  177. package/lib/services/OperationMetricDetails.d.ts +82 -0
  178. package/lib/services/OperationMetricDetails.js +50 -0
  179. package/lib/services/Service.d.ts +80 -0
  180. package/lib/services/Service.js +36 -0
  181. package/lib/services/ServiceMetricDetails.d.ts +71 -0
  182. package/lib/services/ServiceMetricDetails.js +28 -0
  183. package/lib/services/props/BasicServiceMultiAZObservabilityProps.d.ts +126 -0
  184. package/lib/services/props/BasicServiceMultiAZObservabilityProps.js +3 -0
  185. package/lib/services/props/CanaryMetricProps.d.ts +14 -0
  186. package/lib/services/props/CanaryMetricProps.js +3 -0
  187. package/lib/services/props/CanaryTestMetricsOverrideProps.d.ts +47 -0
  188. package/lib/services/props/CanaryTestMetricsOverrideProps.js +3 -0
  189. package/lib/services/props/ContributorInsightRuleDetailsProps.d.ts +38 -0
  190. package/lib/services/props/ContributorInsightRuleDetailsProps.js +3 -0
  191. package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.d.ts +88 -0
  192. package/lib/services/props/InstrumentedServiceMultiAZObservabilityProps.js +3 -0
  193. package/lib/services/props/MetricDimensions.d.ts +61 -0
  194. package/lib/services/props/MetricDimensions.js +63 -0
  195. package/lib/services/props/OperationMetricDetailsProps.d.ts +97 -0
  196. package/lib/services/props/OperationMetricDetailsProps.js +3 -0
  197. package/lib/services/props/OperationProps.d.ts +93 -0
  198. package/lib/services/props/OperationProps.js +3 -0
  199. package/lib/services/props/ServiceMetricDetailsProps.d.ts +68 -0
  200. package/lib/services/props/ServiceMetricDetailsProps.js +3 -0
  201. package/lib/services/props/ServiceProps.d.ts +69 -0
  202. package/lib/services/props/ServiceProps.js +3 -0
  203. package/lib/utilities/AvailabilityMetricType.d.ts +26 -0
  204. package/lib/utilities/AvailabilityMetricType.js +33 -0
  205. package/lib/utilities/LatencyMetricType.d.ts +13 -0
  206. package/lib/utilities/LatencyMetricType.js +20 -0
  207. package/lib/utilities/OutlierDetectionAlgorithm.d.ts +42 -0
  208. package/lib/utilities/OutlierDetectionAlgorithm.js +49 -0
  209. package/lib/utilities/StackWithDynamicSource.d.ts +14 -0
  210. package/lib/utilities/StackWithDynamicSource.js +82 -0
  211. package/package.json +176 -0
  212. package/rosetta/default.ts-fixture +13 -0
@@ -0,0 +1,78 @@
1
+ import { ICanaryMetrics } from './ICanaryMetrics';
2
+ import { ICanaryTestMetricsOverride } from './ICanaryTestMetricsOverride';
3
+ import { IContributorInsightRuleDetails } from './IContributorInsightRuleDetails';
4
+ import { IOperation } from './IOperation';
5
+ import { IOperationMetricDetails } from './IOperationMetricDetails';
6
+ import { IService } from './IService';
7
+ import { OperationProps } from './props/OperationProps';
8
+ import { AddCanaryTestProps } from '../canaries/props/AddCanaryTestProps';
9
+ /**
10
+ * A single operation that is part of a service
11
+ */
12
+ export declare class Operation implements IOperation {
13
+ /**
14
+ * The service the operation is associated with
15
+ */
16
+ readonly service: IService;
17
+ /**
18
+ * The name of the operation
19
+ */
20
+ readonly operationName: string;
21
+ /**
22
+ * The HTTP path for the operation for canaries
23
+ * to run against, something like "/products/list"
24
+ */
25
+ readonly path: string;
26
+ /**
27
+ * The server side availability metric details
28
+ */
29
+ readonly serverSideAvailabilityMetricDetails: IOperationMetricDetails;
30
+ /**
31
+ * The server side latency metric details
32
+ */
33
+ readonly serverSideLatencyMetricDetails: IOperationMetricDetails;
34
+ /**
35
+ * Optional metric details if the service has a canary
36
+ */
37
+ readonly canaryMetricDetails?: ICanaryMetrics;
38
+ /**
39
+ * The override values for automatically created canary tests so you can
40
+ * use values other than the service defaults to define the thresholds for
41
+ * availability.
42
+ */
43
+ readonly canaryTestAvailabilityMetricsOverride?: ICanaryTestMetricsOverride;
44
+ /**
45
+ * The override values for automatically created canary tests so you can
46
+ * use values other than the service defaults to define the thresholds for
47
+ * latency.
48
+ */
49
+ readonly canaryTestLatencyMetricsOverride?: ICanaryTestMetricsOverride;
50
+ /**
51
+ * The server side details for contributor insights rules
52
+ */
53
+ readonly serverSideContributorInsightRuleDetails?: IContributorInsightRuleDetails;
54
+ /**
55
+ * Indicates this is a critical operation for the service
56
+ * and will be included in service level metrics and
57
+ * dashboards
58
+ */
59
+ readonly critical: boolean;
60
+ /**
61
+ * The http methods supported by the operation
62
+ */
63
+ readonly httpMethods: string[];
64
+ /**
65
+ * If they have been added, the properties for
66
+ * creating new canary tests on this operation
67
+ */
68
+ readonly canaryTestProps?: AddCanaryTestProps;
69
+ /**
70
+ * Set to true if you have defined CanaryTestProps for your
71
+ * service, which applies to all operations, but you want to
72
+ * opt out of creating the canary test for this operation.
73
+ *
74
+ * @default - The operation is not opted out
75
+ */
76
+ readonly optOutOfServiceCreatedCanary?: boolean;
77
+ constructor(props: OperationProps);
78
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Operation = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * A single operation that is part of a service
8
+ */
9
+ class Operation {
10
+ constructor(props) {
11
+ this.canaryMetricDetails = props.canaryMetricDetails;
12
+ this.httpMethods = props.httpMethods;
13
+ this.critical = props.critical;
14
+ this.operationName = props.operationName;
15
+ this.path = props.path;
16
+ this.serverSideAvailabilityMetricDetails =
17
+ props.serverSideAvailabilityMetricDetails;
18
+ this.serverSideLatencyMetricDetails = props.serverSideLatencyMetricDetails;
19
+ this.serverSideContributorInsightRuleDetails =
20
+ props.serverSideContributorInsightRuleDetails;
21
+ this.service = props.service;
22
+ this.canaryTestProps = props.canaryTestProps;
23
+ this.optOutOfServiceCreatedCanary = props.optOutOfServiceCreatedCanary;
24
+ this.canaryTestAvailabilityMetricsOverride =
25
+ props.canaryTestAvailabilityMetricsOverride;
26
+ this.canaryTestLatencyMetricsOverride =
27
+ props.canaryTestLatencyMetricsOverride;
28
+ this.optOutOfServiceCreatedCanary = props.optOutOfServiceCreatedCanary;
29
+ }
30
+ }
31
+ exports.Operation = Operation;
32
+ _a = JSII_RTTI_SYMBOL_1;
33
+ Operation[_a] = { fqn: "@cdklabs/multi-az-observability.Operation", version: "0.0.0-alpha.0" };
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiT3BlcmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlcnZpY2VzL09wZXJhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQVdBOztHQUVHO0FBQ0gsTUFBYSxTQUFTO0lBOEVwQixZQUFZLEtBQXFCO1FBQy9CLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsbUJBQW1CLENBQUM7UUFDckQsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQztRQUMvQixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUM7UUFDekMsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxtQ0FBbUM7WUFDdEMsS0FBSyxDQUFDLG1DQUFtQyxDQUFDO1FBQzVDLElBQUksQ0FBQyw4QkFBOEIsR0FBRyxLQUFLLENBQUMsOEJBQThCLENBQUM7UUFDM0UsSUFBSSxDQUFDLHVDQUF1QztZQUMxQyxLQUFLLENBQUMsdUNBQXVDLENBQUM7UUFDaEQsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzdCLElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDLGVBQWUsQ0FBQztRQUM3QyxJQUFJLENBQUMsNEJBQTRCLEdBQUcsS0FBSyxDQUFDLDRCQUE0QixDQUFDO1FBQ3ZFLElBQUksQ0FBQyxxQ0FBcUM7WUFDeEMsS0FBSyxDQUFDLHFDQUFxQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxnQ0FBZ0M7WUFDbkMsS0FBSyxDQUFDLGdDQUFnQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyw0QkFBNEIsR0FBRyxLQUFLLENBQUMsNEJBQTRCLENBQUM7SUFDekUsQ0FBQzs7QUFqR0gsOEJBa0dDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuaW1wb3J0IHsgSUNhbmFyeU1ldHJpY3MgfSBmcm9tICcuL0lDYW5hcnlNZXRyaWNzJztcbmltcG9ydCB7IElDYW5hcnlUZXN0TWV0cmljc092ZXJyaWRlIH0gZnJvbSAnLi9JQ2FuYXJ5VGVzdE1ldHJpY3NPdmVycmlkZSc7XG5pbXBvcnQgeyBJQ29udHJpYnV0b3JJbnNpZ2h0UnVsZURldGFpbHMgfSBmcm9tICcuL0lDb250cmlidXRvckluc2lnaHRSdWxlRGV0YWlscyc7XG5pbXBvcnQgeyBJT3BlcmF0aW9uIH0gZnJvbSAnLi9JT3BlcmF0aW9uJztcbmltcG9ydCB7IElPcGVyYXRpb25NZXRyaWNEZXRhaWxzIH0gZnJvbSAnLi9JT3BlcmF0aW9uTWV0cmljRGV0YWlscyc7XG5pbXBvcnQgeyBJU2VydmljZSB9IGZyb20gJy4vSVNlcnZpY2UnO1xuaW1wb3J0IHsgT3BlcmF0aW9uUHJvcHMgfSBmcm9tICcuL3Byb3BzL09wZXJhdGlvblByb3BzJztcbmltcG9ydCB7IEFkZENhbmFyeVRlc3RQcm9wcyB9IGZyb20gJy4uL2NhbmFyaWVzL3Byb3BzL0FkZENhbmFyeVRlc3RQcm9wcyc7XG5cbi8qKlxuICogQSBzaW5nbGUgb3BlcmF0aW9uIHRoYXQgaXMgcGFydCBvZiBhIHNlcnZpY2VcbiAqL1xuZXhwb3J0IGNsYXNzIE9wZXJhdGlvbiBpbXBsZW1lbnRzIElPcGVyYXRpb24ge1xuICAvKipcbiAgICogVGhlIHNlcnZpY2UgdGhlIG9wZXJhdGlvbiBpcyBhc3NvY2lhdGVkIHdpdGhcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2U6IElTZXJ2aWNlO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgb3BlcmF0aW9uXG4gICAqL1xuICByZWFkb25seSBvcGVyYXRpb25OYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqICBUaGUgSFRUUCBwYXRoIGZvciB0aGUgb3BlcmF0aW9uIGZvciBjYW5hcmllc1xuICAgKiAgdG8gcnVuIGFnYWluc3QsIHNvbWV0aGluZyBsaWtlIFwiL3Byb2R1Y3RzL2xpc3RcIlxuICAgKi9cbiAgcmVhZG9ubHkgcGF0aDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgc2VydmVyIHNpZGUgYXZhaWxhYmlsaXR5IG1ldHJpYyBkZXRhaWxzXG4gICAqL1xuICByZWFkb25seSBzZXJ2ZXJTaWRlQXZhaWxhYmlsaXR5TWV0cmljRGV0YWlsczogSU9wZXJhdGlvbk1ldHJpY0RldGFpbHM7XG5cbiAgLyoqXG4gICAqIFRoZSBzZXJ2ZXIgc2lkZSBsYXRlbmN5IG1ldHJpYyBkZXRhaWxzXG4gICAqL1xuICByZWFkb25seSBzZXJ2ZXJTaWRlTGF0ZW5jeU1ldHJpY0RldGFpbHM6IElPcGVyYXRpb25NZXRyaWNEZXRhaWxzO1xuXG4gIC8qKlxuICAgKiBPcHRpb25hbCBtZXRyaWMgZGV0YWlscyBpZiB0aGUgc2VydmljZSBoYXMgYSBjYW5hcnlcbiAgICovXG4gIHJlYWRvbmx5IGNhbmFyeU1ldHJpY0RldGFpbHM/OiBJQ2FuYXJ5TWV0cmljcztcblxuICAvKipcbiAgICogVGhlIG92ZXJyaWRlIHZhbHVlcyBmb3IgYXV0b21hdGljYWxseSBjcmVhdGVkIGNhbmFyeSB0ZXN0cyBzbyB5b3UgY2FuXG4gICAqIHVzZSB2YWx1ZXMgb3RoZXIgdGhhbiB0aGUgc2VydmljZSBkZWZhdWx0cyB0byBkZWZpbmUgdGhlIHRocmVzaG9sZHMgZm9yXG4gICAqIGF2YWlsYWJpbGl0eS5cbiAgICovXG4gIHJlYWRvbmx5IGNhbmFyeVRlc3RBdmFpbGFiaWxpdHlNZXRyaWNzT3ZlcnJpZGU/OiBJQ2FuYXJ5VGVzdE1ldHJpY3NPdmVycmlkZTtcblxuICAvKipcbiAgICogVGhlIG92ZXJyaWRlIHZhbHVlcyBmb3IgYXV0b21hdGljYWxseSBjcmVhdGVkIGNhbmFyeSB0ZXN0cyBzbyB5b3UgY2FuXG4gICAqIHVzZSB2YWx1ZXMgb3RoZXIgdGhhbiB0aGUgc2VydmljZSBkZWZhdWx0cyB0byBkZWZpbmUgdGhlIHRocmVzaG9sZHMgZm9yXG4gICAqIGxhdGVuY3kuXG4gICAqL1xuICByZWFkb25seSBjYW5hcnlUZXN0TGF0ZW5jeU1ldHJpY3NPdmVycmlkZT86IElDYW5hcnlUZXN0TWV0cmljc092ZXJyaWRlO1xuXG4gIC8qKlxuICAgKiBUaGUgc2VydmVyIHNpZGUgZGV0YWlscyBmb3IgY29udHJpYnV0b3IgaW5zaWdodHMgcnVsZXNcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZlclNpZGVDb250cmlidXRvckluc2lnaHRSdWxlRGV0YWlscz86IElDb250cmlidXRvckluc2lnaHRSdWxlRGV0YWlscztcblxuICAvKipcbiAgICogSW5kaWNhdGVzIHRoaXMgaXMgYSBjcml0aWNhbCBvcGVyYXRpb24gZm9yIHRoZSBzZXJ2aWNlXG4gICAqIGFuZCB3aWxsIGJlIGluY2x1ZGVkIGluIHNlcnZpY2UgbGV2ZWwgbWV0cmljcyBhbmRcbiAgICogZGFzaGJvYXJkc1xuICAgKi9cbiAgcmVhZG9ubHkgY3JpdGljYWw6IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFRoZSBodHRwIG1ldGhvZHMgc3VwcG9ydGVkIGJ5IHRoZSBvcGVyYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGh0dHBNZXRob2RzOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogSWYgdGhleSBoYXZlIGJlZW4gYWRkZWQsIHRoZSBwcm9wZXJ0aWVzIGZvclxuICAgKiBjcmVhdGluZyBuZXcgY2FuYXJ5IHRlc3RzIG9uIHRoaXMgb3BlcmF0aW9uXG4gICAqL1xuICByZWFkb25seSBjYW5hcnlUZXN0UHJvcHM/OiBBZGRDYW5hcnlUZXN0UHJvcHM7XG5cbiAgLyoqXG4gICAqIFNldCB0byB0cnVlIGlmIHlvdSBoYXZlIGRlZmluZWQgQ2FuYXJ5VGVzdFByb3BzIGZvciB5b3VyXG4gICAqIHNlcnZpY2UsIHdoaWNoIGFwcGxpZXMgdG8gYWxsIG9wZXJhdGlvbnMsIGJ1dCB5b3Ugd2FudCB0b1xuICAgKiBvcHQgb3V0IG9mIGNyZWF0aW5nIHRoZSBjYW5hcnkgdGVzdCBmb3IgdGhpcyBvcGVyYXRpb24uXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gVGhlIG9wZXJhdGlvbiBpcyBub3Qgb3B0ZWQgb3V0XG4gICAqL1xuICByZWFkb25seSBvcHRPdXRPZlNlcnZpY2VDcmVhdGVkQ2FuYXJ5PzogYm9vbGVhbjtcblxuICBjb25zdHJ1Y3Rvcihwcm9wczogT3BlcmF0aW9uUHJvcHMpIHtcbiAgICB0aGlzLmNhbmFyeU1ldHJpY0RldGFpbHMgPSBwcm9wcy5jYW5hcnlNZXRyaWNEZXRhaWxzO1xuICAgIHRoaXMuaHR0cE1ldGhvZHMgPSBwcm9wcy5odHRwTWV0aG9kcztcbiAgICB0aGlzLmNyaXRpY2FsID0gcHJvcHMuY3JpdGljYWw7XG4gICAgdGhpcy5vcGVyYXRpb25OYW1lID0gcHJvcHMub3BlcmF0aW9uTmFtZTtcbiAgICB0aGlzLnBhdGggPSBwcm9wcy5wYXRoO1xuICAgIHRoaXMuc2VydmVyU2lkZUF2YWlsYWJpbGl0eU1ldHJpY0RldGFpbHMgPVxuICAgICAgcHJvcHMuc2VydmVyU2lkZUF2YWlsYWJpbGl0eU1ldHJpY0RldGFpbHM7XG4gICAgdGhpcy5zZXJ2ZXJTaWRlTGF0ZW5jeU1ldHJpY0RldGFpbHMgPSBwcm9wcy5zZXJ2ZXJTaWRlTGF0ZW5jeU1ldHJpY0RldGFpbHM7XG4gICAgdGhpcy5zZXJ2ZXJTaWRlQ29udHJpYnV0b3JJbnNpZ2h0UnVsZURldGFpbHMgPVxuICAgICAgcHJvcHMuc2VydmVyU2lkZUNvbnRyaWJ1dG9ySW5zaWdodFJ1bGVEZXRhaWxzO1xuICAgIHRoaXMuc2VydmljZSA9IHByb3BzLnNlcnZpY2U7XG4gICAgdGhpcy5jYW5hcnlUZXN0UHJvcHMgPSBwcm9wcy5jYW5hcnlUZXN0UHJvcHM7XG4gICAgdGhpcy5vcHRPdXRPZlNlcnZpY2VDcmVhdGVkQ2FuYXJ5ID0gcHJvcHMub3B0T3V0T2ZTZXJ2aWNlQ3JlYXRlZENhbmFyeTtcbiAgICB0aGlzLmNhbmFyeVRlc3RBdmFpbGFiaWxpdHlNZXRyaWNzT3ZlcnJpZGUgPVxuICAgICAgcHJvcHMuY2FuYXJ5VGVzdEF2YWlsYWJpbGl0eU1ldHJpY3NPdmVycmlkZTtcbiAgICB0aGlzLmNhbmFyeVRlc3RMYXRlbmN5TWV0cmljc092ZXJyaWRlID1cbiAgICAgIHByb3BzLmNhbmFyeVRlc3RMYXRlbmN5TWV0cmljc092ZXJyaWRlO1xuICAgIHRoaXMub3B0T3V0T2ZTZXJ2aWNlQ3JlYXRlZENhbmFyeSA9IHByb3BzLm9wdE91dE9mU2VydmljZUNyZWF0ZWRDYW5hcnk7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,82 @@
1
+ import { Duration } from 'aws-cdk-lib';
2
+ import { Unit } from 'aws-cdk-lib/aws-cloudwatch';
3
+ import { IOperationMetricDetails } from './IOperationMetricDetails';
4
+ import { IServiceMetricDetails } from './IServiceMetricDetails';
5
+ import { MetricDimensions } from './props/MetricDimensions';
6
+ import { OperationMetricDetailsProps } from './props/OperationMetricDetailsProps';
7
+ /**
8
+ * Generic metric details for an operation
9
+ */
10
+ export declare class OperationMetricDetails implements IOperationMetricDetails {
11
+ /**
12
+ * The operation these metric details are for
13
+ */
14
+ readonly operationName: string;
15
+ /**
16
+ * The CloudWatch metric namespace for these metrics
17
+ */
18
+ readonly metricNamespace: string;
19
+ /**
20
+ * The names of success indicating metrics
21
+ */
22
+ readonly successMetricNames: string[];
23
+ /**
24
+ * The names of fault indicating metrics
25
+ */
26
+ readonly faultMetricNames: string[];
27
+ /**
28
+ * The statistic used for alarms, for availability metrics this should
29
+ * be "Sum", for latency metrics it could something like "p99" or "p99.9"
30
+ */
31
+ readonly alarmStatistic: string;
32
+ /**
33
+ * The statistics for successes you want to appear on dashboards, for example, with
34
+ * latency metrics, you might want p50, p99, and tm99. For availability
35
+ * metrics this will typically just be "Sum".
36
+ *
37
+ * @default - For availability metrics, this will be "Sum", for latency metrics it will be just "p99"
38
+ */
39
+ readonly graphedSuccessStatistics?: string[];
40
+ /**
41
+ * The statistics for faults you want to appear on dashboards, for example, with
42
+ * latency metrics, you might want p50, p99, and tm99. For availability
43
+ * metrics this will typically just be "Sum".
44
+ *
45
+ * @default - For availability metrics, this will be "Sum", for latency metrics it will be just "p99"
46
+ */
47
+ readonly graphedFaultStatistics?: string[];
48
+ /**
49
+ * The unit used for these metrics
50
+ */
51
+ readonly unit: Unit;
52
+ /**
53
+ * The period for the metrics
54
+ */
55
+ readonly period: Duration;
56
+ /**
57
+ * The number of evaluation periods for latency and availabiltiy alarms
58
+ */
59
+ readonly evaluationPeriods: number;
60
+ /**
61
+ * The number of datapoints to alarm on for latency and availability alarms
62
+ */
63
+ readonly datapointsToAlarm: number;
64
+ /**
65
+ * The threshold for alarms associated with success metrics, for example if measuring
66
+ * success rate, the threshold may be 99, meaning you would want an alarm that triggers
67
+ * if success drops below 99%.
68
+ */
69
+ readonly successAlarmThreshold: number;
70
+ /**
71
+ * The threshold for alarms associated with fault metrics, for example if measuring
72
+ * fault rate, the threshold may be 1, meaning you would want an alarm that triggers
73
+ * if the fault rate goes above 1%.
74
+ */
75
+ readonly faultAlarmThreshold: number;
76
+ /**
77
+ * The metric dimensions for this operation, must be implemented
78
+ * as a concrete class by the user
79
+ */
80
+ readonly metricDimensions: MetricDimensions;
81
+ constructor(props: OperationMetricDetailsProps, defaultProps: IServiceMetricDetails);
82
+ }
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.OperationMetricDetails = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Generic metric details for an operation
8
+ */
9
+ class OperationMetricDetails {
10
+ constructor(props, defaultProps) {
11
+ this.alarmStatistic = props.alarmStatistic
12
+ ? props.alarmStatistic
13
+ : defaultProps.alarmStatistic;
14
+ this.datapointsToAlarm = props.datapointsToAlarm
15
+ ? props.datapointsToAlarm
16
+ : defaultProps.datapointsToAlarm;
17
+ this.evaluationPeriods = props.evaluationPeriods
18
+ ? props.evaluationPeriods
19
+ : defaultProps.evaluationPeriods;
20
+ this.faultAlarmThreshold = props.faultAlarmThreshold
21
+ ? props.faultAlarmThreshold
22
+ : defaultProps.faultAlarmThreshold;
23
+ this.faultMetricNames = props.faultMetricNames
24
+ ? props.faultMetricNames
25
+ : defaultProps.faultMetricNames;
26
+ this.graphedFaultStatistics = props.graphedFaultStatistics
27
+ ? props.graphedFaultStatistics
28
+ : defaultProps.graphedFaultStatistics;
29
+ this.graphedSuccessStatistics = props.graphedSuccessStatistics
30
+ ? props.graphedSuccessStatistics
31
+ : defaultProps.graphedSuccessStatistics;
32
+ this.metricNamespace = props.metricNamespace
33
+ ? props.metricNamespace
34
+ : defaultProps.metricNamespace;
35
+ this.operationName = props.operationName;
36
+ this.period = props.period ? props.period : defaultProps.period;
37
+ this.successAlarmThreshold = props.successAlarmThreshold
38
+ ? props.successAlarmThreshold
39
+ : defaultProps.successAlarmThreshold;
40
+ this.successMetricNames = props.successMetricNames
41
+ ? props.successMetricNames
42
+ : defaultProps.successMetricNames;
43
+ this.unit = props.unit ? props.unit : defaultProps.unit;
44
+ this.metricDimensions = props.metricDimensions;
45
+ }
46
+ }
47
+ exports.OperationMetricDetails = OperationMetricDetails;
48
+ _a = JSII_RTTI_SYMBOL_1;
49
+ OperationMetricDetails[_a] = { fqn: "@cdklabs/multi-az-observability.OperationMetricDetails", version: "0.0.0-alpha.0" };
50
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"OperationMetricDetails.js","sourceRoot":"","sources":["../../src/services/OperationMetricDetails.ts"],"names":[],"mappings":";;;;;AASA;;GAEG;AACH,MAAa,sBAAsB;IAqFjC,YACE,KAAkC,EAClC,YAAmC;QAEnC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC,cAAc;YACxC,CAAC,CAAC,KAAK,CAAC,cAAc;YACtB,CAAC,CAAC,YAAY,CAAC,cAAc,CAAC;QAChC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB;YAC9C,CAAC,CAAC,KAAK,CAAC,iBAAiB;YACzB,CAAC,CAAC,YAAY,CAAC,iBAAiB,CAAC;QACnC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,iBAAiB;YAC9C,CAAC,CAAC,KAAK,CAAC,iBAAiB;YACzB,CAAC,CAAC,YAAY,CAAC,iBAAiB,CAAC;QACnC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC,mBAAmB;YAClD,CAAC,CAAC,KAAK,CAAC,mBAAmB;YAC3B,CAAC,CAAC,YAAY,CAAC,mBAAmB,CAAC;QACrC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,gBAAgB;YAC5C,CAAC,CAAC,KAAK,CAAC,gBAAgB;YACxB,CAAC,CAAC,YAAY,CAAC,gBAAgB,CAAC;QAClC,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC,sBAAsB;YACxD,CAAC,CAAC,KAAK,CAAC,sBAAsB;YAC9B,CAAC,CAAC,YAAY,CAAC,sBAAsB,CAAC;QACxC,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC,wBAAwB;YAC5D,CAAC,CAAC,KAAK,CAAC,wBAAwB;YAChC,CAAC,CAAC,YAAY,CAAC,wBAAwB,CAAC;QAC1C,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC,eAAe;YAC1C,CAAC,CAAC,KAAK,CAAC,eAAe;YACvB,CAAC,CAAC,YAAY,CAAC,eAAe,CAAC;QACjC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QACzC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;QAChE,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC,qBAAqB;YACtD,CAAC,CAAC,KAAK,CAAC,qBAAqB;YAC7B,CAAC,CAAC,YAAY,CAAC,qBAAqB,CAAC;QACvC,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC,kBAAkB;YAChD,CAAC,CAAC,KAAK,CAAC,kBAAkB;YAC1B,CAAC,CAAC,YAAY,CAAC,kBAAkB,CAAC;QACpC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC;QACxD,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,gBAAgB,CAAC;IACjD,CAAC;;AA3HH,wDA4HC","sourcesContent":["// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n// SPDX-License-Identifier: Apache-2.0\nimport { Duration } from 'aws-cdk-lib';\nimport { Unit } from 'aws-cdk-lib/aws-cloudwatch';\nimport { IOperationMetricDetails } from './IOperationMetricDetails';\nimport { IServiceMetricDetails } from './IServiceMetricDetails';\nimport { MetricDimensions } from './props/MetricDimensions';\nimport { OperationMetricDetailsProps } from './props/OperationMetricDetailsProps';\n\n/**\n * Generic metric details for an operation\n */\nexport class OperationMetricDetails implements IOperationMetricDetails {\n  /**\n   * The operation these metric details are for\n   */\n  readonly operationName: string;\n\n  /**\n   * The CloudWatch metric namespace for these metrics\n   */\n  readonly metricNamespace: string;\n\n  /**\n   * The names of success indicating metrics\n   */\n  readonly successMetricNames: string[];\n\n  /**\n   * The names of fault indicating metrics\n   */\n  readonly faultMetricNames: string[];\n\n  /**\n   * The statistic used for alarms, for availability metrics this should\n   * be \"Sum\", for latency metrics it could something like \"p99\" or \"p99.9\"\n   */\n  readonly alarmStatistic: string;\n\n  /**\n   * The statistics for successes you want to appear on dashboards, for example, with\n   * latency metrics, you might want p50, p99, and tm99. For availability\n   * metrics this will typically just be \"Sum\".\n   *\n   * @default - For availability metrics, this will be \"Sum\", for latency metrics it will be just \"p99\"\n   */\n  readonly graphedSuccessStatistics?: string[];\n\n  /**\n   * The statistics for faults you want to appear on dashboards, for example, with\n   * latency metrics, you might want p50, p99, and tm99. For availability\n   * metrics this will typically just be \"Sum\".\n   *\n   * @default - For availability metrics, this will be \"Sum\", for latency metrics it will be just \"p99\"\n   */\n  readonly graphedFaultStatistics?: string[];\n\n  /**\n   * The unit used for these metrics\n   */\n  readonly unit: Unit;\n\n  /**\n   * The period for the metrics\n   */\n  readonly period: Duration;\n\n  /**\n   * The number of evaluation periods for latency and availabiltiy alarms\n   */\n  readonly evaluationPeriods: number;\n\n  /**\n   * The number of datapoints to alarm on for latency and availability alarms\n   */\n  readonly datapointsToAlarm: number;\n\n  /**\n   * The threshold for alarms associated with success metrics, for example if measuring\n   * success rate, the threshold may be 99, meaning you would want an alarm that triggers\n   * if success drops below 99%.\n   */\n  readonly successAlarmThreshold: number;\n\n  /**\n   * The threshold for alarms associated with fault metrics, for example if measuring\n   * fault rate, the threshold may be 1, meaning you would want an alarm that triggers\n   * if the fault rate goes above 1%.\n   */\n  readonly faultAlarmThreshold: number;\n\n  /**\n   * The metric dimensions for this operation, must be implemented\n   * as a concrete class by the user\n   */\n  readonly metricDimensions: MetricDimensions;\n\n  constructor(\n    props: OperationMetricDetailsProps,\n    defaultProps: IServiceMetricDetails,\n  ) {\n    this.alarmStatistic = props.alarmStatistic\n      ? props.alarmStatistic\n      : defaultProps.alarmStatistic;\n    this.datapointsToAlarm = props.datapointsToAlarm\n      ? props.datapointsToAlarm\n      : defaultProps.datapointsToAlarm;\n    this.evaluationPeriods = props.evaluationPeriods\n      ? props.evaluationPeriods\n      : defaultProps.evaluationPeriods;\n    this.faultAlarmThreshold = props.faultAlarmThreshold\n      ? props.faultAlarmThreshold\n      : defaultProps.faultAlarmThreshold;\n    this.faultMetricNames = props.faultMetricNames\n      ? props.faultMetricNames\n      : defaultProps.faultMetricNames;\n    this.graphedFaultStatistics = props.graphedFaultStatistics\n      ? props.graphedFaultStatistics\n      : defaultProps.graphedFaultStatistics;\n    this.graphedSuccessStatistics = props.graphedSuccessStatistics\n      ? props.graphedSuccessStatistics\n      : defaultProps.graphedSuccessStatistics;\n    this.metricNamespace = props.metricNamespace\n      ? props.metricNamespace\n      : defaultProps.metricNamespace;\n    this.operationName = props.operationName;\n    this.period = props.period ? props.period : defaultProps.period;\n    this.successAlarmThreshold = props.successAlarmThreshold\n      ? props.successAlarmThreshold\n      : defaultProps.successAlarmThreshold;\n    this.successMetricNames = props.successMetricNames\n      ? props.successMetricNames\n      : defaultProps.successMetricNames;\n    this.unit = props.unit ? props.unit : defaultProps.unit;\n    this.metricDimensions = props.metricDimensions;\n  }\n}\n"]}
@@ -0,0 +1,80 @@
1
+ import { Duration } from 'aws-cdk-lib';
2
+ import { ILoadBalancerV2 } from 'aws-cdk-lib/aws-elasticloadbalancingv2';
3
+ import { IContributorInsightRuleDetails } from './IContributorInsightRuleDetails';
4
+ import { IOperation } from './IOperation';
5
+ import { IService } from './IService';
6
+ import { IServiceMetricDetails } from './IServiceMetricDetails';
7
+ import { ServiceProps } from './props/ServiceProps';
8
+ import { AddCanaryTestProps } from '../canaries/props/AddCanaryTestProps';
9
+ /**
10
+ * The representation of a service composed of multiple operations
11
+ */
12
+ export declare class Service implements IService {
13
+ /**
14
+ * The name of your service
15
+ */
16
+ readonly serviceName: string;
17
+ /**
18
+ * The base endpoint for this service, like "https://www.example.com". Operation paths will be appended to this endpoint for canary testing the service.
19
+ */
20
+ readonly baseUrl: string;
21
+ /**
22
+ * The fault count threshold that indicates the service is unhealthy. This is an absolute value of faults
23
+ * being produced by all critical operations in aggregate.
24
+ */
25
+ readonly faultCountThreshold: number;
26
+ /**
27
+ * A list of the Availability Zone names used by this application
28
+ */
29
+ readonly availabilityZoneNames: string[];
30
+ /**
31
+ * The period for which metrics for the service should be aggregated
32
+ */
33
+ readonly period: Duration;
34
+ /**
35
+ * The operations that are part of this service
36
+ */
37
+ readonly operations: IOperation[];
38
+ /**
39
+ * The load balancer this service sits behind
40
+ *
41
+ * @default - No load balancer metrics will be included in
42
+ * dashboards and its ARN will not be added to top level AZ
43
+ * alarm descriptions.
44
+ */
45
+ readonly loadBalancer?: ILoadBalancerV2;
46
+ /**
47
+ * Define these settings if you want to automatically add canary
48
+ * tests to your operations. Operations can individually opt out
49
+ * of canary test creation if you define this setting.
50
+ *
51
+ * @default - Automatic canary tests will not be created for
52
+ * operations in this service.
53
+ */
54
+ readonly canaryTestProps?: AddCanaryTestProps;
55
+ /**
56
+ * The default settings that are used for availability metrics
57
+ * for all operations unless specifically overridden in an
58
+ * operation definition.
59
+ */
60
+ readonly defaultAvailabilityMetricDetails: IServiceMetricDetails;
61
+ /**
62
+ * The default settings that are used for availability metrics
63
+ * for all operations unless specifically overridden in an
64
+ * operation definition.
65
+ */
66
+ readonly defaultLatencyMetricDetails: IServiceMetricDetails;
67
+ /**
68
+ * The default settings that are used for contributor insight
69
+ * rules.
70
+ *
71
+ * @default - No defaults are provided and must be specified per operation
72
+ */
73
+ readonly defaultContributorInsightRuleDetails?: IContributorInsightRuleDetails;
74
+ constructor(props: ServiceProps);
75
+ /**
76
+ * Adds an operation to this service and sets the operation's
77
+ * service property
78
+ */
79
+ addOperation(operation: IOperation): void;
80
+ }
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.Service = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * The representation of a service composed of multiple operations
8
+ */
9
+ class Service {
10
+ constructor(props) {
11
+ this.serviceName = props.serviceName;
12
+ this.availabilityZoneNames = props.availabilityZoneNames;
13
+ this.baseUrl = props.baseUrl;
14
+ this.faultCountThreshold = props.faultCountThreshold;
15
+ this.operations = [];
16
+ this.period = props.period;
17
+ this.loadBalancer = props.loadBalancer;
18
+ this.canaryTestProps = props.canaryTestProps;
19
+ this.defaultAvailabilityMetricDetails =
20
+ props.defaultAvailabilityMetricDetails;
21
+ this.defaultLatencyMetricDetails = props.defaultLatencyMetricDetails;
22
+ this.defaultContributorInsightRuleDetails =
23
+ props.defaultContributorInsightRuleDetails;
24
+ }
25
+ /**
26
+ * Adds an operation to this service and sets the operation's
27
+ * service property
28
+ */
29
+ addOperation(operation) {
30
+ this.operations.push(operation);
31
+ }
32
+ }
33
+ exports.Service = Service;
34
+ _a = JSII_RTTI_SYMBOL_1;
35
+ Service[_a] = { fqn: "@cdklabs/multi-az-observability.Service", version: "0.0.0-alpha.0" };
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zZXJ2aWNlcy9TZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBV0E7O0dBRUc7QUFDSCxNQUFhLE9BQU87SUF5RWxCLFlBQVksS0FBbUI7UUFDN0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUMsV0FBVyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxLQUFLLENBQUMscUJBQXFCLENBQUM7UUFDekQsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQzdCLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsbUJBQW1CLENBQUM7UUFDckQsSUFBSSxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7UUFDckIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO1FBQzNCLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDLFlBQVksQ0FBQztRQUN2QyxJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQyxlQUFlLENBQUM7UUFDN0MsSUFBSSxDQUFDLGdDQUFnQztZQUNuQyxLQUFLLENBQUMsZ0NBQWdDLENBQUM7UUFDekMsSUFBSSxDQUFDLDJCQUEyQixHQUFHLEtBQUssQ0FBQywyQkFBMkIsQ0FBQztRQUNyRSxJQUFJLENBQUMsb0NBQW9DO1lBQ3ZDLEtBQUssQ0FBQyxvQ0FBb0MsQ0FBQztJQUMvQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsWUFBWSxDQUFDLFNBQXFCO1FBQ2hDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7O0FBL0ZILDBCQWdHQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbmltcG9ydCB7IER1cmF0aW9uIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgSUxvYWRCYWxhbmNlclYyIH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWVsYXN0aWNsb2FkYmFsYW5jaW5ndjInO1xuaW1wb3J0IHsgSUNvbnRyaWJ1dG9ySW5zaWdodFJ1bGVEZXRhaWxzIH0gZnJvbSAnLi9JQ29udHJpYnV0b3JJbnNpZ2h0UnVsZURldGFpbHMnO1xuaW1wb3J0IHsgSU9wZXJhdGlvbiB9IGZyb20gJy4vSU9wZXJhdGlvbic7XG5pbXBvcnQgeyBJU2VydmljZSB9IGZyb20gJy4vSVNlcnZpY2UnO1xuaW1wb3J0IHsgSVNlcnZpY2VNZXRyaWNEZXRhaWxzIH0gZnJvbSAnLi9JU2VydmljZU1ldHJpY0RldGFpbHMnO1xuaW1wb3J0IHsgU2VydmljZVByb3BzIH0gZnJvbSAnLi9wcm9wcy9TZXJ2aWNlUHJvcHMnO1xuaW1wb3J0IHsgQWRkQ2FuYXJ5VGVzdFByb3BzIH0gZnJvbSAnLi4vY2FuYXJpZXMvcHJvcHMvQWRkQ2FuYXJ5VGVzdFByb3BzJztcblxuLyoqXG4gKiBUaGUgcmVwcmVzZW50YXRpb24gb2YgYSBzZXJ2aWNlIGNvbXBvc2VkIG9mIG11bHRpcGxlIG9wZXJhdGlvbnNcbiAqL1xuZXhwb3J0IGNsYXNzIFNlcnZpY2UgaW1wbGVtZW50cyBJU2VydmljZSB7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB5b3VyIHNlcnZpY2VcbiAgICovXG4gIHJlYWRvbmx5IHNlcnZpY2VOYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBiYXNlIGVuZHBvaW50IGZvciB0aGlzIHNlcnZpY2UsIGxpa2UgXCJodHRwczovL3d3dy5leGFtcGxlLmNvbVwiLiBPcGVyYXRpb24gcGF0aHMgd2lsbCBiZSBhcHBlbmRlZCB0byB0aGlzIGVuZHBvaW50IGZvciBjYW5hcnkgdGVzdGluZyB0aGUgc2VydmljZS5cbiAgICovXG4gIHJlYWRvbmx5IGJhc2VVcmw6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIGZhdWx0IGNvdW50IHRocmVzaG9sZCB0aGF0IGluZGljYXRlcyB0aGUgc2VydmljZSBpcyB1bmhlYWx0aHkuIFRoaXMgaXMgYW4gYWJzb2x1dGUgdmFsdWUgb2YgZmF1bHRzXG4gICAqIGJlaW5nIHByb2R1Y2VkIGJ5IGFsbCBjcml0aWNhbCBvcGVyYXRpb25zIGluIGFnZ3JlZ2F0ZS5cbiAgICovXG4gIHJlYWRvbmx5IGZhdWx0Q291bnRUaHJlc2hvbGQ6IG51bWJlcjtcblxuICAvKipcbiAgICogQSBsaXN0IG9mIHRoZSBBdmFpbGFiaWxpdHkgWm9uZSBuYW1lcyB1c2VkIGJ5IHRoaXMgYXBwbGljYXRpb25cbiAgICovXG4gIHJlYWRvbmx5IGF2YWlsYWJpbGl0eVpvbmVOYW1lczogc3RyaW5nW107XG5cbiAgLyoqXG4gICAqIFRoZSBwZXJpb2QgZm9yIHdoaWNoIG1ldHJpY3MgZm9yIHRoZSBzZXJ2aWNlIHNob3VsZCBiZSBhZ2dyZWdhdGVkXG4gICAqL1xuICByZWFkb25seSBwZXJpb2Q6IER1cmF0aW9uO1xuXG4gIC8qKlxuICAgKiBUaGUgb3BlcmF0aW9ucyB0aGF0IGFyZSBwYXJ0IG9mIHRoaXMgc2VydmljZVxuICAgKi9cbiAgcmVhZG9ubHkgb3BlcmF0aW9uczogSU9wZXJhdGlvbltdO1xuXG4gIC8qKlxuICAgKiBUaGUgbG9hZCBiYWxhbmNlciB0aGlzIHNlcnZpY2Ugc2l0cyBiZWhpbmRcbiAgICpcbiAgICogQGRlZmF1bHQgLSBObyBsb2FkIGJhbGFuY2VyIG1ldHJpY3Mgd2lsbCBiZSBpbmNsdWRlZCBpblxuICAgKiBkYXNoYm9hcmRzIGFuZCBpdHMgQVJOIHdpbGwgbm90IGJlIGFkZGVkIHRvIHRvcCBsZXZlbCBBWlxuICAgKiBhbGFybSBkZXNjcmlwdGlvbnMuXG4gICAqL1xuICByZWFkb25seSBsb2FkQmFsYW5jZXI/OiBJTG9hZEJhbGFuY2VyVjI7XG5cbiAgLyoqXG4gICAqIERlZmluZSB0aGVzZSBzZXR0aW5ncyBpZiB5b3Ugd2FudCB0byBhdXRvbWF0aWNhbGx5IGFkZCBjYW5hcnlcbiAgICogdGVzdHMgdG8geW91ciBvcGVyYXRpb25zLiBPcGVyYXRpb25zIGNhbiBpbmRpdmlkdWFsbHkgb3B0IG91dFxuICAgKiBvZiBjYW5hcnkgdGVzdCBjcmVhdGlvbiBpZiB5b3UgZGVmaW5lIHRoaXMgc2V0dGluZy5cbiAgICpcbiAgICogQGRlZmF1bHQgLSBBdXRvbWF0aWMgY2FuYXJ5IHRlc3RzIHdpbGwgbm90IGJlIGNyZWF0ZWQgZm9yXG4gICAqIG9wZXJhdGlvbnMgaW4gdGhpcyBzZXJ2aWNlLlxuICAgKi9cbiAgcmVhZG9ubHkgY2FuYXJ5VGVzdFByb3BzPzogQWRkQ2FuYXJ5VGVzdFByb3BzO1xuXG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBzZXR0aW5ncyB0aGF0IGFyZSB1c2VkIGZvciBhdmFpbGFiaWxpdHkgbWV0cmljc1xuICAgKiBmb3IgYWxsIG9wZXJhdGlvbnMgdW5sZXNzIHNwZWNpZmljYWxseSBvdmVycmlkZGVuIGluIGFuXG4gICAqIG9wZXJhdGlvbiBkZWZpbml0aW9uLlxuICAgKi9cbiAgcmVhZG9ubHkgZGVmYXVsdEF2YWlsYWJpbGl0eU1ldHJpY0RldGFpbHM6IElTZXJ2aWNlTWV0cmljRGV0YWlscztcblxuICAvKipcbiAgICogVGhlIGRlZmF1bHQgc2V0dGluZ3MgdGhhdCBhcmUgdXNlZCBmb3IgYXZhaWxhYmlsaXR5IG1ldHJpY3NcbiAgICogZm9yIGFsbCBvcGVyYXRpb25zIHVubGVzcyBzcGVjaWZpY2FsbHkgb3ZlcnJpZGRlbiBpbiBhblxuICAgKiBvcGVyYXRpb24gZGVmaW5pdGlvbi5cbiAgICovXG4gIHJlYWRvbmx5IGRlZmF1bHRMYXRlbmN5TWV0cmljRGV0YWlsczogSVNlcnZpY2VNZXRyaWNEZXRhaWxzO1xuXG4gIC8qKlxuICAgKiBUaGUgZGVmYXVsdCBzZXR0aW5ncyB0aGF0IGFyZSB1c2VkIGZvciBjb250cmlidXRvciBpbnNpZ2h0XG4gICAqIHJ1bGVzLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIE5vIGRlZmF1bHRzIGFyZSBwcm92aWRlZCBhbmQgbXVzdCBiZSBzcGVjaWZpZWQgcGVyIG9wZXJhdGlvblxuICAgKi9cbiAgcmVhZG9ubHkgZGVmYXVsdENvbnRyaWJ1dG9ySW5zaWdodFJ1bGVEZXRhaWxzPzogSUNvbnRyaWJ1dG9ySW5zaWdodFJ1bGVEZXRhaWxzO1xuXG4gIGNvbnN0cnVjdG9yKHByb3BzOiBTZXJ2aWNlUHJvcHMpIHtcbiAgICB0aGlzLnNlcnZpY2VOYW1lID0gcHJvcHMuc2VydmljZU5hbWU7XG4gICAgdGhpcy5hdmFpbGFiaWxpdHlab25lTmFtZXMgPSBwcm9wcy5hdmFpbGFiaWxpdHlab25lTmFtZXM7XG4gICAgdGhpcy5iYXNlVXJsID0gcHJvcHMuYmFzZVVybDtcbiAgICB0aGlzLmZhdWx0Q291bnRUaHJlc2hvbGQgPSBwcm9wcy5mYXVsdENvdW50VGhyZXNob2xkO1xuICAgIHRoaXMub3BlcmF0aW9ucyA9IFtdO1xuICAgIHRoaXMucGVyaW9kID0gcHJvcHMucGVyaW9kO1xuICAgIHRoaXMubG9hZEJhbGFuY2VyID0gcHJvcHMubG9hZEJhbGFuY2VyO1xuICAgIHRoaXMuY2FuYXJ5VGVzdFByb3BzID0gcHJvcHMuY2FuYXJ5VGVzdFByb3BzO1xuICAgIHRoaXMuZGVmYXVsdEF2YWlsYWJpbGl0eU1ldHJpY0RldGFpbHMgPVxuICAgICAgcHJvcHMuZGVmYXVsdEF2YWlsYWJpbGl0eU1ldHJpY0RldGFpbHM7XG4gICAgdGhpcy5kZWZhdWx0TGF0ZW5jeU1ldHJpY0RldGFpbHMgPSBwcm9wcy5kZWZhdWx0TGF0ZW5jeU1ldHJpY0RldGFpbHM7XG4gICAgdGhpcy5kZWZhdWx0Q29udHJpYnV0b3JJbnNpZ2h0UnVsZURldGFpbHMgPVxuICAgICAgcHJvcHMuZGVmYXVsdENvbnRyaWJ1dG9ySW5zaWdodFJ1bGVEZXRhaWxzO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYW4gb3BlcmF0aW9uIHRvIHRoaXMgc2VydmljZSBhbmQgc2V0cyB0aGUgb3BlcmF0aW9uJ3NcbiAgICogc2VydmljZSBwcm9wZXJ0eVxuICAgKi9cbiAgYWRkT3BlcmF0aW9uKG9wZXJhdGlvbjogSU9wZXJhdGlvbik6IHZvaWQge1xuICAgIHRoaXMub3BlcmF0aW9ucy5wdXNoKG9wZXJhdGlvbik7XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,71 @@
1
+ import { Duration } from 'aws-cdk-lib';
2
+ import { Unit } from 'aws-cdk-lib/aws-cloudwatch';
3
+ import { IServiceMetricDetails } from './IServiceMetricDetails';
4
+ import { ServiceMetricDetailsProps } from './props/ServiceMetricDetailsProps';
5
+ /**
6
+ * Default metric details for a service
7
+ */
8
+ export declare class ServiceMetricDetails implements IServiceMetricDetails {
9
+ /**
10
+ * The CloudWatch metric namespace for these metrics
11
+ */
12
+ readonly metricNamespace: string;
13
+ /**
14
+ * The names of success indicating metrics
15
+ */
16
+ readonly successMetricNames: string[];
17
+ /**
18
+ * The names of fault indicating metrics
19
+ */
20
+ readonly faultMetricNames: string[];
21
+ /**
22
+ * The statistic used for alarms, for availability metrics this should
23
+ * be "Sum", for latency metrics it could something like "p99" or "p99.9"
24
+ */
25
+ readonly alarmStatistic: string;
26
+ /**
27
+ * The statistics for successes you want to appear on dashboards, for example, with
28
+ * latency metrics, you might want p50, p99, and tm99. For availability
29
+ * metrics this will typically just be "Sum".
30
+ *
31
+ * @default - For availability metrics, this will be "Sum", for latency metrics it will be just "p99"
32
+ */
33
+ readonly graphedSuccessStatistics?: string[];
34
+ /**
35
+ * The statistics for faults you want to appear on dashboards, for example, with
36
+ * latency metrics, you might want p50, p99, and tm99. For availability
37
+ * metrics this will typically just be "Sum".
38
+ *
39
+ * @default - For availability metrics, this will be "Sum", for latency metrics it will be just "p99"
40
+ */
41
+ readonly graphedFaultStatistics?: string[];
42
+ /**
43
+ * The unit used for these metrics
44
+ */
45
+ readonly unit: Unit;
46
+ /**
47
+ * The period for the metrics
48
+ */
49
+ readonly period: Duration;
50
+ /**
51
+ * The number of evaluation periods for latency and availabiltiy alarms
52
+ */
53
+ readonly evaluationPeriods: number;
54
+ /**
55
+ * The number of datapoints to alarm on for latency and availability alarms
56
+ */
57
+ readonly datapointsToAlarm: number;
58
+ /**
59
+ * The threshold for alarms associated with success metrics, for example if measuring
60
+ * success rate, the threshold may be 99, meaning you would want an alarm that triggers
61
+ * if success drops below 99%.
62
+ */
63
+ readonly successAlarmThreshold: number;
64
+ /**
65
+ * The threshold for alarms associated with fault metrics, for example if measuring
66
+ * fault rate, the threshold may be 1, meaning you would want an alarm that triggers
67
+ * if the fault rate goes above 1%.
68
+ */
69
+ readonly faultAlarmThreshold: number;
70
+ constructor(props: ServiceMetricDetailsProps);
71
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ServiceMetricDetails = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Default metric details for a service
8
+ */
9
+ class ServiceMetricDetails {
10
+ constructor(props) {
11
+ this.alarmStatistic = props.alarmStatistic;
12
+ this.datapointsToAlarm = props.datapointsToAlarm;
13
+ this.evaluationPeriods = props.evaluationPeriods;
14
+ this.faultAlarmThreshold = props.faultAlarmThreshold;
15
+ this.faultMetricNames = props.faultMetricNames;
16
+ this.graphedFaultStatistics = props.graphedFaultStatistics;
17
+ this.graphedSuccessStatistics = props.graphedSuccessStatistics;
18
+ this.metricNamespace = props.metricNamespace;
19
+ this.period = props.period;
20
+ this.successAlarmThreshold = props.successAlarmThreshold;
21
+ this.successMetricNames = props.successMetricNames;
22
+ this.unit = props.unit;
23
+ }
24
+ }
25
+ exports.ServiceMetricDetails = ServiceMetricDetails;
26
+ _a = JSII_RTTI_SYMBOL_1;
27
+ ServiceMetricDetails[_a] = { fqn: "@cdklabs/multi-az-observability.ServiceMetricDetails", version: "0.0.0-alpha.0" };
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2VydmljZU1ldHJpY0RldGFpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvU2VydmljZU1ldHJpY0RldGFpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFPQTs7R0FFRztBQUNILE1BQWEsb0JBQW9CO0lBMEUvQixZQUFZLEtBQWdDO1FBQzFDLElBQUksQ0FBQyxjQUFjLEdBQUcsS0FBSyxDQUFDLGNBQWMsQ0FBQztRQUMzQyxJQUFJLENBQUMsaUJBQWlCLEdBQUcsS0FBSyxDQUFDLGlCQUFpQixDQUFDO1FBQ2pELElBQUksQ0FBQyxpQkFBaUIsR0FBRyxLQUFLLENBQUMsaUJBQWlCLENBQUM7UUFDakQsSUFBSSxDQUFDLG1CQUFtQixHQUFHLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQztRQUNyRCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsS0FBSyxDQUFDLGdCQUFnQixDQUFDO1FBQy9DLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxLQUFLLENBQUMsc0JBQXNCLENBQUM7UUFDM0QsSUFBSSxDQUFDLHdCQUF3QixHQUFHLEtBQUssQ0FBQyx3QkFBd0IsQ0FBQztRQUMvRCxJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQyxlQUFlLENBQUM7UUFDN0MsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDO1FBQzNCLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxLQUFLLENBQUMscUJBQXFCLENBQUM7UUFDekQsSUFBSSxDQUFDLGtCQUFrQixHQUFHLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQztRQUNuRCxJQUFJLENBQUMsSUFBSSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUM7SUFDekIsQ0FBQzs7QUF2Rkgsb0RBd0ZDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuaW1wb3J0IHsgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBVbml0IH0gZnJvbSAnYXdzLWNkay1saWIvYXdzLWNsb3Vkd2F0Y2gnO1xuaW1wb3J0IHsgSVNlcnZpY2VNZXRyaWNEZXRhaWxzIH0gZnJvbSAnLi9JU2VydmljZU1ldHJpY0RldGFpbHMnO1xuaW1wb3J0IHsgU2VydmljZU1ldHJpY0RldGFpbHNQcm9wcyB9IGZyb20gJy4vcHJvcHMvU2VydmljZU1ldHJpY0RldGFpbHNQcm9wcyc7XG5cbi8qKlxuICogRGVmYXVsdCBtZXRyaWMgZGV0YWlscyBmb3IgYSBzZXJ2aWNlXG4gKi9cbmV4cG9ydCBjbGFzcyBTZXJ2aWNlTWV0cmljRGV0YWlscyBpbXBsZW1lbnRzIElTZXJ2aWNlTWV0cmljRGV0YWlscyB7XG4gIC8qKlxuICAgKiBUaGUgQ2xvdWRXYXRjaCBtZXRyaWMgbmFtZXNwYWNlIGZvciB0aGVzZSBtZXRyaWNzXG4gICAqL1xuICByZWFkb25seSBtZXRyaWNOYW1lc3BhY2U6IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIG5hbWVzIG9mIHN1Y2Nlc3MgaW5kaWNhdGluZyBtZXRyaWNzXG4gICAqL1xuICByZWFkb25seSBzdWNjZXNzTWV0cmljTmFtZXM6IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBUaGUgbmFtZXMgb2YgZmF1bHQgaW5kaWNhdGluZyBtZXRyaWNzXG4gICAqL1xuICByZWFkb25seSBmYXVsdE1ldHJpY05hbWVzOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogVGhlIHN0YXRpc3RpYyB1c2VkIGZvciBhbGFybXMsIGZvciBhdmFpbGFiaWxpdHkgbWV0cmljcyB0aGlzIHNob3VsZFxuICAgKiBiZSBcIlN1bVwiLCBmb3IgbGF0ZW5jeSBtZXRyaWNzIGl0IGNvdWxkIHNvbWV0aGluZyBsaWtlIFwicDk5XCIgb3IgXCJwOTkuOVwiXG4gICAqL1xuICByZWFkb25seSBhbGFybVN0YXRpc3RpYzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgc3RhdGlzdGljcyBmb3Igc3VjY2Vzc2VzIHlvdSB3YW50IHRvIGFwcGVhciBvbiBkYXNoYm9hcmRzLCBmb3IgZXhhbXBsZSwgd2l0aFxuICAgKiBsYXRlbmN5IG1ldHJpY3MsIHlvdSBtaWdodCB3YW50IHA1MCwgcDk5LCBhbmQgdG05OS4gRm9yIGF2YWlsYWJpbGl0eVxuICAgKiBtZXRyaWNzIHRoaXMgd2lsbCB0eXBpY2FsbHkganVzdCBiZSBcIlN1bVwiLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIEZvciBhdmFpbGFiaWxpdHkgbWV0cmljcywgdGhpcyB3aWxsIGJlIFwiU3VtXCIsIGZvciBsYXRlbmN5IG1ldHJpY3MgaXQgd2lsbCBiZSBqdXN0IFwicDk5XCJcbiAgICovXG4gIHJlYWRvbmx5IGdyYXBoZWRTdWNjZXNzU3RhdGlzdGljcz86IHN0cmluZ1tdO1xuXG4gIC8qKlxuICAgKiBUaGUgc3RhdGlzdGljcyBmb3IgZmF1bHRzIHlvdSB3YW50IHRvIGFwcGVhciBvbiBkYXNoYm9hcmRzLCBmb3IgZXhhbXBsZSwgd2l0aFxuICAgKiBsYXRlbmN5IG1ldHJpY3MsIHlvdSBtaWdodCB3YW50IHA1MCwgcDk5LCBhbmQgdG05OS4gRm9yIGF2YWlsYWJpbGl0eVxuICAgKiBtZXRyaWNzIHRoaXMgd2lsbCB0eXBpY2FsbHkganVzdCBiZSBcIlN1bVwiLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIEZvciBhdmFpbGFiaWxpdHkgbWV0cmljcywgdGhpcyB3aWxsIGJlIFwiU3VtXCIsIGZvciBsYXRlbmN5IG1ldHJpY3MgaXQgd2lsbCBiZSBqdXN0IFwicDk5XCJcbiAgICovXG4gIHJlYWRvbmx5IGdyYXBoZWRGYXVsdFN0YXRpc3RpY3M/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogVGhlIHVuaXQgdXNlZCBmb3IgdGhlc2UgbWV0cmljc1xuICAgKi9cbiAgcmVhZG9ubHkgdW5pdDogVW5pdDtcblxuICAvKipcbiAgICogVGhlIHBlcmlvZCBmb3IgdGhlIG1ldHJpY3NcbiAgICovXG4gIHJlYWRvbmx5IHBlcmlvZDogRHVyYXRpb247XG5cbiAgLyoqXG4gICAqIFRoZSBudW1iZXIgb2YgZXZhbHVhdGlvbiBwZXJpb2RzIGZvciBsYXRlbmN5IGFuZCBhdmFpbGFiaWx0aXkgYWxhcm1zXG4gICAqL1xuICByZWFkb25seSBldmFsdWF0aW9uUGVyaW9kczogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiBUaGUgbnVtYmVyIG9mIGRhdGFwb2ludHMgdG8gYWxhcm0gb24gZm9yIGxhdGVuY3kgYW5kIGF2YWlsYWJpbGl0eSBhbGFybXNcbiAgICovXG4gIHJlYWRvbmx5IGRhdGFwb2ludHNUb0FsYXJtOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFRoZSB0aHJlc2hvbGQgZm9yIGFsYXJtcyBhc3NvY2lhdGVkIHdpdGggc3VjY2VzcyBtZXRyaWNzLCBmb3IgZXhhbXBsZSBpZiBtZWFzdXJpbmdcbiAgICogc3VjY2VzcyByYXRlLCB0aGUgdGhyZXNob2xkIG1heSBiZSA5OSwgbWVhbmluZyB5b3Ugd291bGQgd2FudCBhbiBhbGFybSB0aGF0IHRyaWdnZXJzXG4gICAqIGlmIHN1Y2Nlc3MgZHJvcHMgYmVsb3cgOTklLlxuICAgKi9cbiAgcmVhZG9ubHkgc3VjY2Vzc0FsYXJtVGhyZXNob2xkOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIFRoZSB0aHJlc2hvbGQgZm9yIGFsYXJtcyBhc3NvY2lhdGVkIHdpdGggZmF1bHQgbWV0cmljcywgZm9yIGV4YW1wbGUgaWYgbWVhc3VyaW5nXG4gICAqIGZhdWx0IHJhdGUsIHRoZSB0aHJlc2hvbGQgbWF5IGJlIDEsIG1lYW5pbmcgeW91IHdvdWxkIHdhbnQgYW4gYWxhcm0gdGhhdCB0cmlnZ2Vyc1xuICAgKiBpZiB0aGUgZmF1bHQgcmF0ZSBnb2VzIGFib3ZlIDElLlxuICAgKi9cbiAgcmVhZG9ubHkgZmF1bHRBbGFybVRocmVzaG9sZDogbnVtYmVyO1xuXG4gIGNvbnN0cnVjdG9yKHByb3BzOiBTZXJ2aWNlTWV0cmljRGV0YWlsc1Byb3BzKSB7XG4gICAgdGhpcy5hbGFybVN0YXRpc3RpYyA9IHByb3BzLmFsYXJtU3RhdGlzdGljO1xuICAgIHRoaXMuZGF0YXBvaW50c1RvQWxhcm0gPSBwcm9wcy5kYXRhcG9pbnRzVG9BbGFybTtcbiAgICB0aGlzLmV2YWx1YXRpb25QZXJpb2RzID0gcHJvcHMuZXZhbHVhdGlvblBlcmlvZHM7XG4gICAgdGhpcy5mYXVsdEFsYXJtVGhyZXNob2xkID0gcHJvcHMuZmF1bHRBbGFybVRocmVzaG9sZDtcbiAgICB0aGlzLmZhdWx0TWV0cmljTmFtZXMgPSBwcm9wcy5mYXVsdE1ldHJpY05hbWVzO1xuICAgIHRoaXMuZ3JhcGhlZEZhdWx0U3RhdGlzdGljcyA9IHByb3BzLmdyYXBoZWRGYXVsdFN0YXRpc3RpY3M7XG4gICAgdGhpcy5ncmFwaGVkU3VjY2Vzc1N0YXRpc3RpY3MgPSBwcm9wcy5ncmFwaGVkU3VjY2Vzc1N0YXRpc3RpY3M7XG4gICAgdGhpcy5tZXRyaWNOYW1lc3BhY2UgPSBwcm9wcy5tZXRyaWNOYW1lc3BhY2U7XG4gICAgdGhpcy5wZXJpb2QgPSBwcm9wcy5wZXJpb2Q7XG4gICAgdGhpcy5zdWNjZXNzQWxhcm1UaHJlc2hvbGQgPSBwcm9wcy5zdWNjZXNzQWxhcm1UaHJlc2hvbGQ7XG4gICAgdGhpcy5zdWNjZXNzTWV0cmljTmFtZXMgPSBwcm9wcy5zdWNjZXNzTWV0cmljTmFtZXM7XG4gICAgdGhpcy51bml0ID0gcHJvcHMudW5pdDtcbiAgfVxufVxuIl19
@@ -0,0 +1,126 @@
1
+ import { Duration } from 'aws-cdk-lib';
2
+ import { CfnNatGateway } from 'aws-cdk-lib/aws-ec2';
3
+ import { IApplicationLoadBalancer } from 'aws-cdk-lib/aws-elasticloadbalancingv2';
4
+ import { OutlierDetectionAlgorithm } from '../../utilities/OutlierDetectionAlgorithm';
5
+ /**
6
+ * Properties for creating a basic service
7
+ */
8
+ export interface BasicServiceMultiAZObservabilityProps {
9
+ /**
10
+ * (Optional) A map of Availability Zone name to the NAT Gateways
11
+ * in that AZ
12
+ *
13
+ * @default - No alarms for NAT Gateways will be created
14
+ */
15
+ readonly natGateways?: {
16
+ [key: string]: CfnNatGateway[];
17
+ };
18
+ /**
19
+ * The application load balancers being used by the service
20
+ *
21
+ * @default - No alarms for ALBs will be created
22
+ */
23
+ readonly applicationLoadBalancers?: IApplicationLoadBalancer[];
24
+ /**
25
+ * The service's name
26
+ */
27
+ readonly serviceName: string;
28
+ /**
29
+ * The outlier threshold for determining if an AZ is an
30
+ * outlier for latency or faults. This number is interpreted
31
+ * differently for different outlier algorithms. When used with
32
+ * STATIC, the number should be between 0 and 1 to represent the
33
+ * percentage of errors (like .7) that an AZ must be responsible
34
+ * for to be considered an outlier. When used with CHI_SQUARED, it
35
+ * represents the p value that indicates statistical significance, like
36
+ * 0.05 which means the skew has less than or equal to a 5% chance of
37
+ * occuring. When used with Z_SCORE it indicates how many standard
38
+ * deviations to evaluate for an AZ being an outlier, typically 3 is
39
+ * standard for Z_SCORE.
40
+ *
41
+ * Standard defaults based on the outlier detection algorithm:
42
+ * STATIC: 0.7
43
+ * CHI_SQUARED: 0.05
44
+ * Z_SCORE: 2
45
+ * IQR: 1.5
46
+ * MAD: 3
47
+ *
48
+ * @default - Depends on the outlier detection algorithm selected
49
+ */
50
+ readonly outlierThreshold?: number;
51
+ /**
52
+ * The amount of packet loss in a NAT GW to determine if an AZ
53
+ * is actually impacted, recommendation is 0.01%
54
+ *
55
+ * @default - 0.01 (as in 0.01%)
56
+ */
57
+ readonly packetLossImpactPercentageThreshold?: number;
58
+ /**
59
+ * The percentage of faults for a single ALB to consider an AZ
60
+ * to be unhealthy, this should align with your availability goal. For example
61
+ * 1% or 5%.
62
+ *
63
+ * @default - 5 (as in 5%)
64
+ */
65
+ readonly faultCountPercentageThreshold?: number;
66
+ /**
67
+ * The algorithm to use for performing outlier detection
68
+ */
69
+ readonly outlierDetectionAlgorithm: OutlierDetectionAlgorithm;
70
+ /**
71
+ * The period to evaluate metrics
72
+ */
73
+ readonly period: Duration;
74
+ /**
75
+ * Whether to create a dashboard displaying the metrics and alarms
76
+ */
77
+ readonly createDashboard: boolean;
78
+ /**
79
+ * Dashboard interval
80
+ *
81
+ * @default - 1 hour
82
+ */
83
+ readonly interval?: Duration;
84
+ /**
85
+ * If you are not using a static bucket to deploy assets, for example
86
+ * you are synthing this and it gets uploaded to a bucket whose name
87
+ * is unknown to you (maybe used as part of a central CI/CD system)
88
+ * and is provided as a parameter to your stack, specify that parameter
89
+ * name here. It will override the bucket location CDK provides by
90
+ * default for bundled assets. The stack containing this contruct needs
91
+ * to have a parameter defined that uses this name. The underlying
92
+ * stacks in this construct that deploy assets will copy the parent stack's
93
+ * value for this property.
94
+ *
95
+ * @default - The assets will be uploaded to the default defined
96
+ * asset location.
97
+ */
98
+ readonly assetsBucketParameterName?: string;
99
+ /**
100
+ * If you are not using a static bucket to deploy assets, for example
101
+ * you are synthing this and it gets uploaded to a bucket that uses a prefix
102
+ * that is unknown to you (maybe used as part of a central CI/CD system)
103
+ * and is provided as a parameter to your stack, specify that parameter
104
+ * name here. It will override the bucket prefix CDK provides by
105
+ * default for bundled assets. This property only takes effect if you
106
+ * defined the assetsBucketParameterName. The stack containing this contruct needs
107
+ * to have a parameter defined that uses this name. The underlying
108
+ * stacks in this construct that deploy assets will copy the parent stack's
109
+ * value for this property.
110
+ *
111
+ * @default - No object prefix will be added to your custom assets location.
112
+ * However, if you have overridden something like the 'BucketPrefix' property
113
+ * in your stack synthesizer with a variable like "${AssetsBucketPrefix",
114
+ * you will need to define this property so it doesn't cause a reference error
115
+ * even if the prefix value is blank.
116
+ */
117
+ readonly assetsBucketPrefixParameterName?: string;
118
+ /**
119
+ * The number of evaluation periods for latency and availabiltiy alarms
120
+ */
121
+ readonly evaluationPeriods: number;
122
+ /**
123
+ * The number of datapoints to alarm on for latency and availability alarms
124
+ */
125
+ readonly datapointsToAlarm: number;
126
+ }