@cdklabs/multi-az-observability 0.0.1-alpha.2 → 0.0.1-alpha.21

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 (84) hide show
  1. package/.jsii +372 -115
  2. package/API.md +292 -74
  3. package/README.md +21 -14
  4. package/cdk.json +1 -1
  5. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.d.ts +6 -6
  6. package/lib/alarmsandrules/AvailabilityAndLatencyAlarmsAndRules.js +31 -28
  7. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.d.ts +0 -4
  8. package/lib/alarmsandrules/BaseOperationZonalAlarmsAndRules.js +6 -5
  9. package/lib/alarmsandrules/CanaryOperationZonalAlarmsAndRules.js +8 -6
  10. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.d.ts +0 -4
  11. package/lib/alarmsandrules/IBaseOperationZonalAlarmsAndRules.js +1 -1
  12. package/lib/alarmsandrules/OperationAlarmsAndRules.js +10 -12
  13. package/lib/alarmsandrules/ServerSideOperationZonalAlarmsAndRules.js +14 -12
  14. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.d.ts +2 -2
  15. package/lib/alarmsandrules/props/BaseOperationZonalAlarmsAndRulesProps.js +1 -1
  16. package/lib/azmapper/AvailabilityZoneMapper.js +4 -3
  17. package/lib/basic_observability/BasicServiceDashboard.d.ts +1 -2
  18. package/lib/basic_observability/BasicServiceDashboard.js +58 -78
  19. package/lib/basic_observability/BasicServiceMultiAZObservability.d.ts +8 -9
  20. package/lib/basic_observability/BasicServiceMultiAZObservability.js +100 -312
  21. package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.d.ts +50 -0
  22. package/lib/basic_observability/props/ApplicationLoadBalancerDetectionProps.js +3 -0
  23. package/lib/basic_observability/props/BasicServiceDashboardProps.d.ts +27 -13
  24. package/lib/basic_observability/props/BasicServiceDashboardProps.js +1 -1
  25. package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.d.ts +10 -38
  26. package/lib/basic_observability/props/BasicServiceMultiAZObservabilityProps.js +1 -1
  27. package/lib/basic_observability/props/NatGatewayDetectionProps.d.ts +31 -0
  28. package/lib/basic_observability/props/NatGatewayDetectionProps.js +3 -0
  29. package/lib/canaries/CanaryFunction.js +7 -6
  30. package/lib/canaries/src/canary.zip +0 -0
  31. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.d.ts +3 -6
  32. package/lib/dashboards/OperationAvailabilityAndLatencyDashboard.js +359 -498
  33. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.d.ts +0 -1
  34. package/lib/dashboards/ServiceAvailabilityAndLatencyDashboard.js +56 -113
  35. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.d.ts +4 -8
  36. package/lib/dashboards/props/OperationAvailabilityAndLatencyDashboardProps.js +1 -1
  37. package/lib/dashboards/props/OperationAvailabilityWidgetProps.d.ts +7 -2
  38. package/lib/dashboards/props/OperationAvailabilityWidgetProps.js +1 -1
  39. package/lib/dashboards/props/OperationLatencyWidgetProps.d.ts +7 -2
  40. package/lib/dashboards/props/OperationLatencyWidgetProps.js +1 -1
  41. package/lib/index.d.ts +5 -0
  42. package/lib/index.js +8 -2
  43. package/lib/metrics/ApplicationLoadBalancerMetrics.d.ts +65 -4
  44. package/lib/metrics/ApplicationLoadBalancerMetrics.js +629 -40
  45. package/lib/metrics/AvailabilityAndLatencyMetrics.d.ts +23 -0
  46. package/lib/metrics/AvailabilityAndLatencyMetrics.js +115 -24
  47. package/lib/metrics/NatGatewayMetrics.d.ts +110 -0
  48. package/lib/metrics/NatGatewayMetrics.js +300 -0
  49. package/lib/metrics/RegionalLatencyMetrics.d.ts +1 -1
  50. package/lib/metrics/RegionalLatencyMetrics.js +27 -20
  51. package/lib/metrics/ZonalAvailabilityMetrics.d.ts +2 -8
  52. package/lib/metrics/ZonalAvailabilityMetrics.js +10 -25
  53. package/lib/metrics/ZonalLatencyMetrics.d.ts +2 -1
  54. package/lib/metrics/ZonalLatencyMetrics.js +33 -23
  55. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.d.ts +4 -0
  56. package/lib/metrics/props/AvailabilityAndLatencyMetricProps.js +1 -1
  57. package/lib/metrics/props/LatencyMetricProps.d.ts +6 -0
  58. package/lib/metrics/props/LatencyMetricProps.js +1 -1
  59. package/lib/metrics/props/ZonalAvailabilityMetricProps.d.ts +4 -0
  60. package/lib/metrics/props/ZonalAvailabilityMetricProps.js +1 -1
  61. package/lib/metrics/props/ZonalLatencyMetricProps.d.ts +4 -0
  62. package/lib/metrics/props/ZonalLatencyMetricProps.js +1 -1
  63. package/lib/monitoring/src/monitoring-layer.zip +0 -0
  64. package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.d.ts +10 -0
  65. package/lib/outlier-detection/ApplicationLoadBalancerAvailabilityOutlierAlgorithm.js +15 -0
  66. package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.d.ts +18 -0
  67. package/lib/outlier-detection/ApplicationLoadBalancerLatencyOutlierAlgorithm.js +23 -0
  68. package/lib/outlier-detection/OutlierDetectionFunction.js +6 -5
  69. package/lib/outlier-detection/PacketLossOutlierAlgorithm.d.ts +10 -0
  70. package/lib/outlier-detection/PacketLossOutlierAlgorithm.js +15 -0
  71. package/lib/outlier-detection/src/outlier-detection.zip +0 -0
  72. package/lib/outlier-detection/src/scipy-layer.zip +0 -0
  73. package/lib/services/CanaryMetrics.js +1 -1
  74. package/lib/services/CanaryTestMetricsOverride.js +1 -1
  75. package/lib/services/ContributorInsightRuleDetails.js +1 -1
  76. package/lib/services/InstrumentedServiceMultiAZObservability.js +3 -3
  77. package/lib/services/Operation.js +1 -1
  78. package/lib/services/OperationMetricDetails.js +1 -1
  79. package/lib/services/Service.js +1 -1
  80. package/lib/services/ServiceMetricDetails.js +1 -1
  81. package/lib/services/props/MetricDimensions.js +1 -1
  82. package/lib/utilities/MetricsHelper.d.ts +14 -10
  83. package/lib/utilities/MetricsHelper.js +18 -11
  84. package/package.json +8 -8
@@ -0,0 +1,300 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.NatGatewayMetrics = void 0;
4
+ const MetricsHelper_1 = require("../utilities/MetricsHelper");
5
+ const aws_cloudwatch_1 = require("aws-cdk-lib/aws-cloudwatch");
6
+ const PacketLossOutlierAlgorithm_1 = require("../outlier-detection/PacketLossOutlierAlgorithm");
7
+ /**
8
+ * Provides functions for getting CloudWatch metrics and alarms for NAT Gateways.
9
+ */
10
+ class NatGatewayMetrics {
11
+ /**
12
+ * Gets the count of packet drops for all NAT Gateways that belong to the provided AZ
13
+ * @param natgws
14
+ * @param availabilityZoneId
15
+ * @param period
16
+ * @returns
17
+ */
18
+ static getDroppedPacketCountMetricForAZ(natgws, availabilityZoneId, period, prefix, color) {
19
+ let keyprefix = prefix ? prefix : MetricsHelper_1.MetricsHelper.nextChar();
20
+ let packetDropCountMetrics = {};
21
+ natgws.forEach((natgw, index) => {
22
+ packetDropCountMetrics[`${keyprefix}${index}`] = new aws_cloudwatch_1.Metric({
23
+ metricName: 'PacketsDropCount',
24
+ namespace: 'AWS/NATGateway',
25
+ statistic: aws_cloudwatch_1.Stats.SUM,
26
+ unit: aws_cloudwatch_1.Unit.COUNT,
27
+ label: availabilityZoneId,
28
+ dimensionsMap: {
29
+ NatGatewayId: natgw.attrNatGatewayId,
30
+ },
31
+ period: period,
32
+ });
33
+ });
34
+ return new aws_cloudwatch_1.MathExpression({
35
+ expression: Object.keys(packetDropCountMetrics).join("+"),
36
+ usingMetrics: packetDropCountMetrics,
37
+ period: period,
38
+ label: availabilityZoneId,
39
+ color: color
40
+ });
41
+ }
42
+ /**
43
+ * Get the packet drop rate for all NAT Gateways that belong to the provided AZ
44
+ * @param natgws
45
+ * @param availabilityZoneId
46
+ * @param period
47
+ * @returns Percent of packet drops like 52%
48
+ */
49
+ static getDroppedPacketRateMetricForAZ(natgws, availabilityZoneId, period, prefix, color) {
50
+ let keyprefix = prefix ? prefix : MetricsHelper_1.MetricsHelper.nextChar();
51
+ let packetDropCountMetrics = {};
52
+ let packetsInFromSourceMetrics = {};
53
+ let packetsInFromDestinationMetrics = {};
54
+ natgws.forEach((natgw, index) => {
55
+ packetDropCountMetrics[`${keyprefix}${index}1`] = new aws_cloudwatch_1.Metric({
56
+ metricName: 'PacketsDropCount',
57
+ namespace: 'AWS/NATGateway',
58
+ statistic: aws_cloudwatch_1.Stats.SUM,
59
+ unit: aws_cloudwatch_1.Unit.COUNT,
60
+ label: availabilityZoneId + ' packet drops',
61
+ dimensionsMap: {
62
+ NatGatewayId: natgw.attrNatGatewayId,
63
+ },
64
+ period: period,
65
+ });
66
+ // Calculate packets in from source
67
+ packetsInFromSourceMetrics[`${keyprefix}${index}2`] = new aws_cloudwatch_1.Metric({
68
+ metricName: 'PacketsInFromSource',
69
+ namespace: 'AWS/NATGateway',
70
+ statistic: aws_cloudwatch_1.Stats.SUM,
71
+ unit: aws_cloudwatch_1.Unit.COUNT,
72
+ label: availabilityZoneId + ' packets in from source',
73
+ dimensionsMap: {
74
+ NatGatewayId: natgw.attrNatGatewayId,
75
+ },
76
+ period: period,
77
+ });
78
+ // Calculate packets in from destination
79
+ packetsInFromDestinationMetrics[`${keyprefix}${index}3`] = new aws_cloudwatch_1.Metric({
80
+ metricName: 'PacketsInFromDestination',
81
+ namespace: 'AWS/NATGateway',
82
+ statistic: aws_cloudwatch_1.Stats.SUM,
83
+ unit: aws_cloudwatch_1.Unit.COUNT,
84
+ label: availabilityZoneId + ' packets in from destination',
85
+ dimensionsMap: {
86
+ NatGatewayId: natgw.attrNatGatewayId,
87
+ },
88
+ period: period,
89
+ });
90
+ });
91
+ keyprefix = MetricsHelper_1.MetricsHelper.nextChar(keyprefix);
92
+ let packetDropTotal = new aws_cloudwatch_1.MathExpression({
93
+ expression: Object.keys(packetDropCountMetrics).join("+"),
94
+ usingMetrics: packetDropCountMetrics,
95
+ period: period
96
+ });
97
+ let packetsInFromSourceTotal = new aws_cloudwatch_1.MathExpression({
98
+ expression: Object.keys(packetsInFromSourceMetrics).join("+"),
99
+ usingMetrics: packetsInFromSourceMetrics,
100
+ period: period
101
+ });
102
+ let packetsInFromDestinationTotal = new aws_cloudwatch_1.MathExpression({
103
+ expression: Object.keys(packetsInFromDestinationMetrics).join("+"),
104
+ usingMetrics: packetsInFromDestinationMetrics,
105
+ period: period
106
+ });
107
+ let usingMetrics = {};
108
+ usingMetrics[`${keyprefix}1`] = packetDropTotal;
109
+ usingMetrics[`${keyprefix}2`] = packetsInFromSourceTotal;
110
+ usingMetrics[`${keyprefix}3`] = packetsInFromDestinationTotal;
111
+ // Calculate a percentage of dropped packets for the NAT GW
112
+ return new aws_cloudwatch_1.MathExpression({
113
+ expression: `(${keyprefix}1 / (${keyprefix}2 + ${keyprefix}3)) * 100`,
114
+ usingMetrics: usingMetrics,
115
+ label: availabilityZoneId,
116
+ period: period,
117
+ color: color
118
+ });
119
+ }
120
+ /**
121
+ * Get the packet count for all NAT Gateways that belong to the provided AZ
122
+ * @param natgws
123
+ * @param availabilityZoneId
124
+ * @param period
125
+ * @returns
126
+ */
127
+ static getTotalPacketCountMetricForAZ(natgws, availabilityZoneId, period, prefix, color) {
128
+ let keyprefix = prefix ? prefix : MetricsHelper_1.MetricsHelper.nextChar();
129
+ let usingMetrics = {};
130
+ natgws.forEach((natgw, index) => {
131
+ // Calculate packets in from source
132
+ usingMetrics[`${keyprefix}${index}1`] = new aws_cloudwatch_1.Metric({
133
+ metricName: 'PacketsInFromSource',
134
+ namespace: 'AWS/NATGateway',
135
+ statistic: aws_cloudwatch_1.Stats.SUM,
136
+ unit: aws_cloudwatch_1.Unit.COUNT,
137
+ label: availabilityZoneId + ' packets in from source',
138
+ dimensionsMap: {
139
+ NatGatewayId: natgw.attrNatGatewayId,
140
+ },
141
+ period: period,
142
+ });
143
+ // Calculate packets in from destination
144
+ usingMetrics[`${keyprefix}${index}2`] = new aws_cloudwatch_1.Metric({
145
+ metricName: 'PacketsInFromDestination',
146
+ namespace: 'AWS/NATGateway',
147
+ statistic: aws_cloudwatch_1.Stats.SUM,
148
+ unit: aws_cloudwatch_1.Unit.COUNT,
149
+ label: availabilityZoneId + ' packets in from destination',
150
+ dimensionsMap: {
151
+ NatGatewayId: natgw.attrNatGatewayId,
152
+ },
153
+ period: period,
154
+ });
155
+ });
156
+ // Calculate total packets in from sources and destinations
157
+ return new aws_cloudwatch_1.MathExpression({
158
+ expression: Object.keys(usingMetrics).join("+"),
159
+ usingMetrics: usingMetrics,
160
+ label: availabilityZoneId,
161
+ period: period,
162
+ color: color
163
+ });
164
+ }
165
+ /**
166
+ * Returns an alarm indicating if the quantity of packet drops in a single AZ across all NAT Gateways in that
167
+ * AZ exceeds a threshold compared to all packet loss across all AZs.
168
+ *
169
+ * For example:
170
+ *
171
+ * A = 150 packets
172
+ * B = 175 packets
173
+ * C = 160 packets
174
+ *
175
+ * And the selected AZ is "A", then the calculation is 150 / (150 + 175 + 160).
176
+ *
177
+ * @param scope
178
+ * @param natgws
179
+ * @param availabilityZoneId
180
+ * @param availabilityZone
181
+ * @param threshold
182
+ * @param period
183
+ * @param evaluationPeriods
184
+ * @param datapointsToAlarm
185
+ * @returns
186
+ */
187
+ static isAZAnOutlierForPacketLossNATGW(scope, natgws, algorithm, availabilityZone, azMapper, threshold, period, evaluationPeriods, datapointsToAlarm) {
188
+ let azPacketDropCountMetrics = {};
189
+ let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(availabilityZone.substring(availabilityZone.length - 1));
190
+ let keyprefix = MetricsHelper_1.MetricsHelper.nextChar();
191
+ Object.keys(natgws).forEach((az) => {
192
+ let azLetter = az.substring(az.length - 1);
193
+ let azId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);
194
+ azPacketDropCountMetrics[azLetter] = NatGatewayMetrics.getDroppedPacketCountMetricForAZ(natgws[az], azId, period, keyprefix);
195
+ keyprefix = MetricsHelper_1.MetricsHelper.nextChar(keyprefix);
196
+ });
197
+ switch (algorithm) {
198
+ case PacketLossOutlierAlgorithm_1.PacketLossOutlierAlgorithm.STATIC:
199
+ default:
200
+ return new aws_cloudwatch_1.Alarm(scope, availabilityZone.substring(availabilityZone.length - 1) + "-packet-loss-outlier", {
201
+ metric: new aws_cloudwatch_1.MathExpression({
202
+ expression: `(${availabilityZone.substring(availabilityZone.length - 1)} / (${Object.keys(azPacketDropCountMetrics).join("+")})) * 100`,
203
+ usingMetrics: azPacketDropCountMetrics,
204
+ period: period,
205
+ label: availabilityZoneId + "-packet-loss-percentage-of-total"
206
+ }),
207
+ threshold: threshold,
208
+ evaluationPeriods: evaluationPeriods,
209
+ datapointsToAlarm: datapointsToAlarm,
210
+ comparisonOperator: aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,
211
+ treatMissingData: aws_cloudwatch_1.TreatMissingData.IGNORE
212
+ });
213
+ }
214
+ }
215
+ /**
216
+ * Creates an alarm to determine is the packet loss rate in a single AZ across all NAT Gateways provided
217
+ * for that AZ exceed the provided threshold.
218
+ * @param scope
219
+ * @param natgws
220
+ * @param availabilityZoneId
221
+ * @param availabilityZone
222
+ * @param threshold
223
+ * @param period
224
+ * @param evaluationPeriods
225
+ * @param datapointsToAlarm
226
+ * @returns
227
+ */
228
+ static isThereAnAZPacketLossImpactNATGW(scope, natgws, availabilityZoneId, availabilityZone, threshold, period, evaluationPeriods, datapointsToAlarm) {
229
+ // Calculate a percentage of dropped packets for the NAT GW
230
+ let packetDropPercentage = NatGatewayMetrics.getDroppedPacketRateMetricForAZ(natgws, availabilityZoneId, period);
231
+ // Create an alarm for this NAT GW if packet drops exceed the specified threshold
232
+ return new aws_cloudwatch_1.Alarm(scope, availabilityZone.substring(availabilityZone.length - 1) + "-packet-drop-impact-alarm", {
233
+ alarmName: availabilityZoneId +
234
+ '-packet-drop-impact',
235
+ actionsEnabled: false,
236
+ metric: packetDropPercentage,
237
+ threshold: threshold,
238
+ comparisonOperator: aws_cloudwatch_1.ComparisonOperator.GREATER_THAN_THRESHOLD,
239
+ evaluationPeriods: evaluationPeriods,
240
+ datapointsToAlarm: datapointsToAlarm,
241
+ treatMissingData: aws_cloudwatch_1.TreatMissingData.IGNORE
242
+ });
243
+ }
244
+ /**
245
+ * Gets the count of all packets from all NAT Gateways in each provided Availability Zone.
246
+ * @param natgws
247
+ * @param azMapper
248
+ * @param period
249
+ * @returns
250
+ */
251
+ static getTotalPacketCountForEveryAZ(natgws, azMapper, period) {
252
+ let usingMetrics = {};
253
+ let keyprefix = MetricsHelper_1.MetricsHelper.nextChar();
254
+ Object.keys(natgws).forEach((availabilityZone, index) => {
255
+ let azLetter = availabilityZone.substring(availabilityZone.length - 1);
256
+ let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);
257
+ usingMetrics[azLetter] = this.getTotalPacketCountMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper_1.MetricsHelper.colors[index]);
258
+ keyprefix = MetricsHelper_1.MetricsHelper.nextChar(keyprefix);
259
+ });
260
+ return usingMetrics;
261
+ }
262
+ /**
263
+ * Gets the count of packet drops from all NAT Gateways in each provided Availability Zone.
264
+ * @param natgws
265
+ * @param azMapper
266
+ * @param period
267
+ * @returns
268
+ */
269
+ static getTotalPacketDropsForEveryAZ(natgws, azMapper, period) {
270
+ let usingMetrics = {};
271
+ let keyprefix = MetricsHelper_1.MetricsHelper.nextChar();
272
+ Object.keys(natgws).forEach((availabilityZone, index) => {
273
+ let azLetter = availabilityZone.substring(availabilityZone.length - 1);
274
+ let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);
275
+ usingMetrics[azLetter] = this.getDroppedPacketCountMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper_1.MetricsHelper.colors[index]);
276
+ keyprefix = MetricsHelper_1.MetricsHelper.nextChar(keyprefix);
277
+ });
278
+ return usingMetrics;
279
+ }
280
+ /**
281
+ * Gets the packet drop rate from all NAT Gateways in each provided Availability Zone.
282
+ * @param natgws
283
+ * @param azMapper
284
+ * @param period
285
+ * @returns
286
+ */
287
+ static getTotalPacketDropRateForEveryAZ(natgws, azMapper, period) {
288
+ let usingMetrics = {};
289
+ let keyprefix = MetricsHelper_1.MetricsHelper.nextChar();
290
+ Object.keys(natgws).forEach((availabilityZone, index) => {
291
+ let azLetter = availabilityZone.substring(availabilityZone.length - 1);
292
+ let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);
293
+ usingMetrics[azLetter] = this.getDroppedPacketRateMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper_1.MetricsHelper.colors[index]);
294
+ keyprefix = MetricsHelper_1.MetricsHelper.nextChar(keyprefix);
295
+ });
296
+ return usingMetrics;
297
+ }
298
+ }
299
+ exports.NatGatewayMetrics = NatGatewayMetrics;
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NatGatewayMetrics.js","sourceRoot":"","sources":["../../src/metrics/NatGatewayMetrics.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnNatGateway } from \"aws-cdk-lib/aws-ec2\";\nimport { MetricsHelper } from \"../utilities/MetricsHelper\";\nimport { Alarm, ComparisonOperator, IAlarm, IMetric, MathExpression, Metric, Stats, TreatMissingData, Unit } from \"aws-cdk-lib/aws-cloudwatch\";\nimport { Duration } from \"aws-cdk-lib\";\nimport { IConstruct } from \"constructs\";\nimport { IAvailabilityZoneMapper } from \"../azmapper/IAvailabilityZoneMapper\";\nimport { PacketLossOutlierAlgorithm } from \"../outlier-detection/PacketLossOutlierAlgorithm\";\n\n/**\n * Provides functions for getting CloudWatch metrics and alarms for NAT Gateways.\n */\nexport class NatGatewayMetrics {\n\n    /**\n     * Gets the count of packet drops for all NAT Gateways that belong to the provided AZ\n     * @param natgws \n     * @param availabilityZoneId \n     * @param period \n     * @returns \n     */\n    static getDroppedPacketCountMetricForAZ(\n        natgws: CfnNatGateway[],\n        availabilityZoneId: string,\n        period: Duration,\n        prefix?: string,\n        color?: string\n    ) : IMetric \n    {\n        let keyprefix: string = prefix ? prefix : MetricsHelper.nextChar();\n        let packetDropCountMetrics: {[key: string]: IMetric} = {};\n\n        natgws.forEach((natgw: CfnNatGateway, index: number)=> {\n        \n            packetDropCountMetrics[`${keyprefix}${index}`] = new Metric({\n              metricName: 'PacketsDropCount',\n              namespace: 'AWS/NATGateway',\n              statistic: Stats.SUM,\n              unit: Unit.COUNT,\n              label: availabilityZoneId,\n              dimensionsMap: {\n                NatGatewayId: natgw.attrNatGatewayId,\n              },\n              period: period,\n            });\n        });\n\n        return new MathExpression({\n          expression: Object.keys(packetDropCountMetrics).join(\"+\"),\n          usingMetrics: packetDropCountMetrics,\n          period: period,\n          label: availabilityZoneId, \n          color: color\n        });\n    }\n\n    /**\n     * Get the packet drop rate for all NAT Gateways that belong to the provided AZ\n     * @param natgws \n     * @param availabilityZoneId \n     * @param period \n     * @returns Percent of packet drops like 52%\n     */\n    static getDroppedPacketRateMetricForAZ(\n        natgws: CfnNatGateway[],\n        availabilityZoneId: string,\n        period: Duration,\n        prefix?: string,\n        color?: string\n    ) : IMetric \n    {\n        \n        let keyprefix = prefix ? prefix : MetricsHelper.nextChar();\n\n        let packetDropCountMetrics: {[key: string]: IMetric} = {};\n        let packetsInFromSourceMetrics: {[key: string]: IMetric} = {};\n        let packetsInFromDestinationMetrics: {[key: string]: IMetric} = {};\n        \n        natgws.forEach((natgw: CfnNatGateway, index: number)=> {\n\n          packetDropCountMetrics[`${keyprefix}${index}1`] = new Metric({\n            metricName: 'PacketsDropCount',\n            namespace: 'AWS/NATGateway',\n            statistic: Stats.SUM,\n            unit: Unit.COUNT,\n            label: availabilityZoneId + ' packet drops',\n            dimensionsMap: {\n              NatGatewayId: natgw.attrNatGatewayId,\n            },\n            period: period,\n          });\n      \n          // Calculate packets in from source\n          packetsInFromSourceMetrics[`${keyprefix}${index}2`] = new Metric({\n            metricName: 'PacketsInFromSource',\n            namespace: 'AWS/NATGateway',\n            statistic: Stats.SUM,\n            unit: Unit.COUNT,\n            label: availabilityZoneId + ' packets in from source',\n            dimensionsMap: {\n              NatGatewayId: natgw.attrNatGatewayId,\n            },\n            period: period,\n          });\n      \n          // Calculate packets in from destination\n          packetsInFromDestinationMetrics[`${keyprefix}${index}3`] = new Metric({\n            metricName: 'PacketsInFromDestination',\n            namespace: 'AWS/NATGateway',\n            statistic: Stats.SUM,\n            unit: Unit.COUNT,\n            label: availabilityZoneId + ' packets in from destination',\n            dimensionsMap: {\n              NatGatewayId: natgw.attrNatGatewayId,\n            },\n            period: period,\n          });\n        });\n\n        keyprefix = MetricsHelper.nextChar(keyprefix);\n\n        let packetDropTotal: IMetric = new MathExpression({\n          expression: Object.keys(packetDropCountMetrics).join(\"+\"),\n          usingMetrics: packetDropCountMetrics,\n          period: period\n        });\n\n        let packetsInFromSourceTotal: IMetric = new MathExpression({\n          expression: Object.keys(packetsInFromSourceMetrics).join(\"+\"),\n          usingMetrics: packetsInFromSourceMetrics,\n          period: period\n        });\n\n        let packetsInFromDestinationTotal: IMetric = new MathExpression({\n          expression: Object.keys(packetsInFromDestinationMetrics).join(\"+\"),\n          usingMetrics: packetsInFromDestinationMetrics,\n          period: period\n        });\n\n        let usingMetrics: { [key: string]: IMetric } = {};\n        usingMetrics[`${keyprefix}1`] = packetDropTotal;\n        usingMetrics[`${keyprefix}2`] = packetsInFromSourceTotal;\n        usingMetrics[`${keyprefix}3`] = packetsInFromDestinationTotal;\n\n        // Calculate a percentage of dropped packets for the NAT GW\n        return new MathExpression({\n          expression: `(${keyprefix}1 / (${keyprefix}2 + ${keyprefix}3)) * 100`,\n          usingMetrics: usingMetrics,\n          label: availabilityZoneId,\n          period: period,\n          color: color\n        });\n    }\n\n    /**\n     * Get the packet count for all NAT Gateways that belong to the provided AZ\n     * @param natgws \n     * @param availabilityZoneId \n     * @param period \n     * @returns \n     */\n    static getTotalPacketCountMetricForAZ(\n        natgws: CfnNatGateway[],\n        availabilityZoneId: string,\n        period: Duration,\n        prefix?: string,\n        color?: string\n    ) : IMetric \n    {\n        let keyprefix = prefix ? prefix : MetricsHelper.nextChar();\n        let usingMetrics: {[key: string]: IMetric} = {};\n        \n        natgws.forEach((natgw: CfnNatGateway, index: number)=> {\n      \n          // Calculate packets in from source\n          usingMetrics[`${keyprefix}${index}1`] = new Metric({\n            metricName: 'PacketsInFromSource',\n            namespace: 'AWS/NATGateway',\n            statistic: Stats.SUM,\n            unit: Unit.COUNT,\n            label: availabilityZoneId + ' packets in from source',\n            dimensionsMap: {\n              NatGatewayId: natgw.attrNatGatewayId,\n            },\n            period: period,\n          });\n      \n          // Calculate packets in from destination\n          usingMetrics[`${keyprefix}${index}2`] = new Metric({\n            metricName: 'PacketsInFromDestination',\n            namespace: 'AWS/NATGateway',\n            statistic: Stats.SUM,\n            unit: Unit.COUNT,\n            label: availabilityZoneId + ' packets in from destination',\n            dimensionsMap: {\n              NatGatewayId: natgw.attrNatGatewayId,\n            },\n            period: period,\n          });\n        });\n\n        // Calculate total packets in from sources and destinations\n        return new MathExpression({\n          expression: Object.keys(usingMetrics).join(\"+\"),\n          usingMetrics: usingMetrics,\n          label: availabilityZoneId,\n          period: period,\n          color: color\n        });\n    }\n\n    /**\n       * Returns an alarm indicating if the quantity of packet drops in a single AZ across all NAT Gateways in that\n       * AZ exceeds a threshold compared to all packet loss across all AZs.\n       * \n       * For example:\n       * \n       * A = 150 packets\n       * B = 175 packets\n       * C = 160 packets\n       * \n       * And the selected AZ is \"A\", then the calculation is 150 / (150 + 175 + 160).\n       * \n       * @param scope \n       * @param natgws \n       * @param availabilityZoneId \n       * @param availabilityZone \n       * @param threshold \n       * @param period \n       * @param evaluationPeriods \n       * @param datapointsToAlarm \n       * @returns \n       */\n    static isAZAnOutlierForPacketLossNATGW(\n        scope: IConstruct,\n        natgws: {[key: string]: CfnNatGateway[]}, \n        algorithm: PacketLossOutlierAlgorithm,\n        availabilityZone: string,\n        azMapper: IAvailabilityZoneMapper,\n        threshold: number,\n        period: Duration,\n        evaluationPeriods: number,\n        datapointsToAlarm: number\n    ) : IAlarm {\n        let azPacketDropCountMetrics: {[key: string]: IMetric} = {};\n        let availabilityZoneId: string = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(availabilityZone.substring(availabilityZone.length - 1));\n        let keyprefix: string = MetricsHelper.nextChar();\n\n        Object.keys(natgws).forEach((az: string) => {\n          let azLetter = az.substring(az.length - 1);\n          let azId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);\n          azPacketDropCountMetrics[azLetter] = NatGatewayMetrics.getDroppedPacketCountMetricForAZ(natgws[az], azId, period, keyprefix);\n\n          keyprefix = MetricsHelper.nextChar(keyprefix);\n        });\n\n        switch (algorithm) {\n          case PacketLossOutlierAlgorithm.STATIC:\n          default:\n            return new Alarm(\n              scope, \n              availabilityZone.substring(availabilityZone.length - 1) + \"-packet-loss-outlier\", \n              {\n                 metric: new MathExpression({\n                    expression: `(${availabilityZone.substring(availabilityZone.length - 1)} / (${Object.keys(azPacketDropCountMetrics).join(\"+\")})) * 100`,\n                    usingMetrics: azPacketDropCountMetrics,\n                    period: period,\n                    label: availabilityZoneId + \"-packet-loss-percentage-of-total\"\n                 }),\n                 threshold: threshold,\n                 evaluationPeriods: evaluationPeriods,\n                 datapointsToAlarm: datapointsToAlarm,\n                 comparisonOperator: ComparisonOperator.GREATER_THAN_OR_EQUAL_TO_THRESHOLD,\n                 treatMissingData: TreatMissingData.IGNORE\n              }\n            );\n        }     \n    }\n\n    /**\n     * Creates an alarm to determine is the packet loss rate in a single AZ across all NAT Gateways provided\n     * for that AZ exceed the provided threshold.\n     * @param scope \n     * @param natgws \n     * @param availabilityZoneId \n     * @param availabilityZone \n     * @param threshold \n     * @param period \n     * @param evaluationPeriods \n     * @param datapointsToAlarm \n     * @returns \n     */\n    static isThereAnAZPacketLossImpactNATGW(\n        scope: IConstruct,\n        natgws: CfnNatGateway[], \n        availabilityZoneId: string,\n        availabilityZone: string,\n        threshold: number,\n        period: Duration,\n        evaluationPeriods: number,\n        datapointsToAlarm: number\n      ) : IAlarm {\n        // Calculate a percentage of dropped packets for the NAT GW\n        let packetDropPercentage: IMetric = NatGatewayMetrics.getDroppedPacketRateMetricForAZ(natgws, availabilityZoneId, period);\n    \n        // Create an alarm for this NAT GW if packet drops exceed the specified threshold\n        return new Alarm(\n          scope,\n          availabilityZone.substring(availabilityZone.length - 1) + \"-packet-drop-impact-alarm\",\n          {\n            alarmName:\n              availabilityZoneId +\n              '-packet-drop-impact',\n            actionsEnabled: false,\n            metric: packetDropPercentage,\n            threshold: threshold,\n            comparisonOperator: ComparisonOperator.GREATER_THAN_THRESHOLD,\n            evaluationPeriods: evaluationPeriods,\n            datapointsToAlarm: datapointsToAlarm,\n            treatMissingData: TreatMissingData.IGNORE\n          }\n        );\n    }\n\n    /**\n     * Gets the count of all packets from all NAT Gateways in each provided Availability Zone.\n     * @param natgws \n     * @param azMapper \n     * @param period \n     * @returns \n     */\n    static getTotalPacketCountForEveryAZ(\n        natgws: {[key: string]: CfnNatGateway[]},\n        azMapper: IAvailabilityZoneMapper,\n        period: Duration\n    ) : {[key: string]: IMetric}\n    {\n        let usingMetrics: {[key: string]: IMetric} = {};\n        let keyprefix: string = MetricsHelper.nextChar();\n\n        Object.keys(natgws).forEach((availabilityZone: string, index: number) => {\n            let azLetter: string = availabilityZone.substring(availabilityZone.length - 1);\n            let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);\n\n            usingMetrics[azLetter] = this.getTotalPacketCountMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper.colors[index]);\n\n            keyprefix = MetricsHelper.nextChar(keyprefix);\n        });\n\n        return usingMetrics;\n    }\n\n    /**\n     * Gets the count of packet drops from all NAT Gateways in each provided Availability Zone.\n     * @param natgws \n     * @param azMapper \n     * @param period \n     * @returns \n     */\n    static getTotalPacketDropsForEveryAZ(\n        natgws: {[key: string]: CfnNatGateway[]},\n        azMapper: IAvailabilityZoneMapper,\n        period: Duration\n    ) : {[key: string]: IMetric}\n    {\n        let usingMetrics: {[key: string]: IMetric} = {};\n        let keyprefix: string = MetricsHelper.nextChar();\n\n        Object.keys(natgws).forEach((availabilityZone: string, index: number) => {\n            let azLetter: string = availabilityZone.substring(availabilityZone.length - 1);\n            let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);\n\n            usingMetrics[azLetter] = this.getDroppedPacketCountMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper.colors[index]);\n\n            keyprefix = MetricsHelper.nextChar(keyprefix);\n        });\n\n        return usingMetrics;\n    }\n\n    /**\n     * Gets the packet drop rate from all NAT Gateways in each provided Availability Zone.\n     * @param natgws \n     * @param azMapper \n     * @param period \n     * @returns \n     */\n    static getTotalPacketDropRateForEveryAZ(\n        natgws: {[key: string]: CfnNatGateway[]},\n        azMapper: IAvailabilityZoneMapper,\n        period: Duration\n    ) : {[key: string]: IMetric}\n    {\n        let usingMetrics: {[key: string]: IMetric} = {};\n        let keyprefix: string = MetricsHelper.nextChar();\n\n        Object.keys(natgws).forEach((availabilityZone: string, index: number) => {\n            let azLetter: string = availabilityZone.substring(availabilityZone.length - 1);\n            let availabilityZoneId = azMapper.availabilityZoneIdFromAvailabilityZoneLetter(azLetter);\n\n            usingMetrics[azLetter] = this.getDroppedPacketRateMetricForAZ(natgws[availabilityZone], availabilityZoneId, period, keyprefix, MetricsHelper.colors[index]);\n\n            keyprefix = MetricsHelper.nextChar(keyprefix);\n        });\n\n        return usingMetrics;\n    }\n}"]}
@@ -29,5 +29,5 @@ export declare class RegionalLatencyMetrics {
29
29
  * @param props
30
30
  * @returns
31
31
  */
32
- static createRegionalServiceLatencyCountMetrics(props: ServiceLatencyMetricProps): IMetric[];
32
+ static createRegionalServiceLatencyCountMetrics(props: ServiceLatencyMetricProps, includeRegionCountAggregate?: boolean): IMetric[];
33
33
  }
@@ -41,30 +41,37 @@ class RegionalLatencyMetrics {
41
41
  * @param props
42
42
  * @returns
43
43
  */
44
- static createRegionalServiceLatencyCountMetrics(props) {
45
- let usingMetrics = {};
46
- let operationMetrics = [];
47
- let keyPrefix = MetricsHelper_1.MetricsHelper.nextChar('');
48
- props.latencyMetricProps.forEach((prop, index) => {
49
- let operationRegionalMetric = this.createRegionalLatencyCountMetric(prop);
50
- operationMetrics.push(operationRegionalMetric);
51
- usingMetrics[`${keyPrefix}${index}`] = operationRegionalMetric;
52
- keyPrefix = MetricsHelper_1.MetricsHelper.nextChar(keyPrefix);
53
- });
54
- if (Object.keys(usingMetrics).length == 1) {
55
- operationMetrics.push(Object.values(usingMetrics)[0]);
44
+ static createRegionalServiceLatencyCountMetrics(props, includeRegionCountAggregate) {
45
+ if (includeRegionCountAggregate) {
46
+ let usingMetrics = {};
47
+ let operationMetrics = [];
48
+ let keyPrefix = MetricsHelper_1.MetricsHelper.nextChar();
49
+ props.latencyMetricProps.forEach((prop, index) => {
50
+ let operationRegionalMetric = this.createRegionalLatencyCountMetric(prop);
51
+ operationMetrics.push(operationRegionalMetric);
52
+ usingMetrics[`${keyPrefix}${index}`] = operationRegionalMetric;
53
+ keyPrefix = MetricsHelper_1.MetricsHelper.nextChar(keyPrefix);
54
+ });
55
+ if (Object.keys(usingMetrics).length == 1) {
56
+ operationMetrics.push(Object.values(usingMetrics)[0]);
57
+ }
58
+ else {
59
+ let math = new aws_cloudwatch_1.MathExpression({
60
+ usingMetrics: usingMetrics,
61
+ period: props.period,
62
+ label: props.label,
63
+ expression: Object.keys(usingMetrics).join('+'),
64
+ });
65
+ operationMetrics.splice(0, 0, math);
66
+ }
67
+ return operationMetrics;
56
68
  }
57
69
  else {
58
- let math = new aws_cloudwatch_1.MathExpression({
59
- usingMetrics: usingMetrics,
60
- period: props.period,
61
- label: props.label,
62
- expression: Object.keys(usingMetrics).join('+'),
70
+ return props.latencyMetricProps.map((prop) => {
71
+ return this.createRegionalLatencyCountMetric(prop);
63
72
  });
64
- operationMetrics.splice(0, 0, math);
65
73
  }
66
- return operationMetrics;
67
74
  }
68
75
  }
69
76
  exports.RegionalLatencyMetrics = RegionalLatencyMetrics;
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVnaW9uYWxMYXRlbmN5TWV0cmljcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tZXRyaWNzL1JlZ2lvbmFsTGF0ZW5jeU1ldHJpY3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXFFO0FBQ3JFLHNDQUFzQztBQUN0Qyw2Q0FBa0M7QUFDbEMsK0RBQXFFO0FBQ3JFLG1GQUFnRjtBQUloRiw4REFBMkQ7QUFFM0QsTUFBYSxzQkFBc0I7SUFDakM7Ozs7Ozs7T0FPRztJQUNILE1BQU0sQ0FBQyw0QkFBNEIsQ0FDakMsS0FBaUM7UUFFakMsT0FBTyw2REFBNkIsQ0FBQyxvQkFBb0IsQ0FDdkQsS0FBSyxFQUNMLEtBQUssQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQ3JELGlCQUFHLENBQUMsTUFBTSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILE1BQU0sQ0FBQyxrQ0FBa0MsQ0FDdkMsS0FBaUM7UUFFakMsT0FBTyw2REFBNkIsQ0FBQywwQkFBMEIsQ0FDN0QsS0FBSyxFQUNMLEtBQUssQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQ3JELGlCQUFHLENBQUMsTUFBTSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsTUFBTSxDQUFDLGdDQUFnQyxDQUNyQyxLQUFpQztRQUVqQyxPQUFPLDZEQUE2QixDQUFDLHdCQUF3QixDQUMzRCxLQUFLLEVBQ0wsS0FBSyxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsQ0FDckQsaUJBQUcsQ0FBQyxNQUFNLENBQ1gsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsd0NBQXdDLENBQzdDLEtBQWdDO1FBRWhDLElBQUksWUFBWSxHQUErQixFQUFFLENBQUM7UUFDbEQsSUFBSSxnQkFBZ0IsR0FBYyxFQUFFLENBQUM7UUFDckMsSUFBSSxTQUFTLEdBQVcsNkJBQWEsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFbkQsS0FBSyxDQUFDLGtCQUFrQixDQUFDLE9BQU8sQ0FDOUIsQ0FBQyxJQUF3QixFQUFFLEtBQWEsRUFBRSxFQUFFO1lBQzFDLElBQUksdUJBQXVCLEdBQ3pCLElBQUksQ0FBQyxnQ0FBZ0MsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUU5QyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsQ0FBQztZQUMvQyxZQUFZLENBQUMsR0FBRyxTQUFTLEdBQUcsS0FBSyxFQUFFLENBQUMsR0FBRyx1QkFBdUIsQ0FBQztZQUMvRCxTQUFTLEdBQUcsNkJBQWEsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDaEQsQ0FBQyxDQUNGLENBQUM7UUFFRixJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQzFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDeEQsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLElBQUksR0FBWSxJQUFJLCtCQUFjLENBQUM7Z0JBQ3JDLFlBQVksRUFBRSxZQUFZO2dCQUMxQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07Z0JBQ3BCLEtBQUssRUFBRSxLQUFLLENBQUMsS0FBSztnQkFDbEIsVUFBVSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQzthQUNoRCxDQUFDLENBQUM7WUFFSCxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN0QyxDQUFDO1FBRUQsT0FBTyxnQkFBZ0IsQ0FBQztJQUMxQixDQUFDO0NBQ0Y7QUEzRkQsd0RBMkZDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuaW1wb3J0IHsgQXdzIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgSU1ldHJpYywgTWF0aEV4cHJlc3Npb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgeyBBdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcyB9IGZyb20gJy4vQXZhaWxhYmlsaXR5QW5kTGF0ZW5jeU1ldHJpY3MnO1xuaW1wb3J0IHsgTGF0ZW5jeU1ldHJpY1Byb3BzIH0gZnJvbSAnLi9wcm9wcy9MYXRlbmN5TWV0cmljUHJvcHMnO1xuaW1wb3J0IHsgUmVnaW9uYWxMYXRlbmN5TWV0cmljUHJvcHMgfSBmcm9tICcuL3Byb3BzL1JlZ2lvbmFsTGF0ZW5jeU1ldHJpY1Byb3BzJztcbmltcG9ydCB7IFNlcnZpY2VMYXRlbmN5TWV0cmljUHJvcHMgfSBmcm9tICcuL3Byb3BzL1NlcnZpY2VMYXRlbmN5TWVyaWNQcm9wcyc7XG5pbXBvcnQgeyBNZXRyaWNzSGVscGVyIH0gZnJvbSAnLi4vdXRpbGl0aWVzL01ldHJpY3NIZWxwZXInO1xuXG5leHBvcnQgY2xhc3MgUmVnaW9uYWxMYXRlbmN5TWV0cmljcyB7XG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbWV0cmljcyBmb3IgcmVnaW9uYWwgbGF0ZW5jeSwgb25lIG1ldHJpYyBwZXIgbWV0cmljIG5hbWUgZm9yIHRoZVxuICAgKiBzcGVjaWZpZWQgdHlwZSBvZiBsYXRlbmN5IG1ldHJpYy4gWW91IHdpbGwgbmVlZCB0byBwZXJmb3JtIHNvbWUgYWdncmVnYXRpb25cbiAgICogb2YgdGhlc2UgbWV0cmljcyBpZiB0aGVyZSBpcyBtb3JlIHRoYW4gMSBtZXRyaWMgbmFtZSB0aGF0IGNvcnJlcG9uZHMgdG9cbiAgICogU3VjY2Vzc0xhdGVuY3kgb3IgRmF1bHRMYXRlbmN5LCBsaWtlIGRvaW5nIGFuIGF2ZXJhZ2UuXG4gICAqIEBwYXJhbSBwcm9wc1xuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgc3RhdGljIGNyZWF0ZVJlZ2lvbmFsTGF0ZW5jeU1ldHJpY3MoXG4gICAgcHJvcHM6IFJlZ2lvbmFsTGF0ZW5jeU1ldHJpY1Byb3BzLFxuICApOiBJTWV0cmljW10ge1xuICAgIHJldHVybiBBdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcy5jcmVhdGVMYXRlbmN5TWV0cmljcyhcbiAgICAgIHByb3BzLFxuICAgICAgcHJvcHMubWV0cmljRGV0YWlscy5tZXRyaWNEaW1lbnNpb25zLnJlZ2lvbmFsRGltZW5zaW9ucyhcbiAgICAgICAgQXdzLlJFR0lPTixcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgcmVnaW9uYWwgYXZlcmFnZSBsYXRlbmN5IG1ldHJpYywgYXZlcmFnZXMgdGhlIHZhbHVlcyBmcm9tIGFsbCBvZiB0aGVcbiAgICogbWV0cmljIG5hbWVzIHRoYXQgcmVwcmVzZW50IGVpdGhlciBTdWNjZXNzTGF0ZW5jeSBvciBGYXVsdExhdGVuY3lcbiAgICogQHBhcmFtIHByb3BzXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBzdGF0aWMgY3JlYXRlUmVnaW9uYWxBdmVyYWdlTGF0ZW5jeU1ldHJpYyhcbiAgICBwcm9wczogUmVnaW9uYWxMYXRlbmN5TWV0cmljUHJvcHMsXG4gICk6IElNZXRyaWMge1xuICAgIHJldHVybiBBdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcy5jcmVhdGVBdmVyYWdlTGF0ZW5jeU1ldHJpYyhcbiAgICAgIHByb3BzLFxuICAgICAgcHJvcHMubWV0cmljRGV0YWlscy5tZXRyaWNEaW1lbnNpb25zLnJlZ2lvbmFsRGltZW5zaW9ucyhcbiAgICAgICAgQXdzLlJFR0lPTixcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgY291bnQgb2YgaGlnaCBsYXRlbmN5IG1ldHJpY3MgZm9yIGVpdGhlciBTdWNjZXNzTGF0ZW5jeSBvciBGYXVsdExhdGVuY3lcbiAgICogQHBhcmFtIHByb3BzXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBzdGF0aWMgY3JlYXRlUmVnaW9uYWxMYXRlbmN5Q291bnRNZXRyaWMoXG4gICAgcHJvcHM6IFJlZ2lvbmFsTGF0ZW5jeU1ldHJpY1Byb3BzLFxuICApOiBJTWV0cmljIHtcbiAgICByZXR1cm4gQXZhaWxhYmlsaXR5QW5kTGF0ZW5jeU1ldHJpY3MuY3JlYXRlTGF0ZW5jeUNvdW50TWV0cmljKFxuICAgICAgcHJvcHMsXG4gICAgICBwcm9wcy5tZXRyaWNEZXRhaWxzLm1ldHJpY0RpbWVuc2lvbnMucmVnaW9uYWxEaW1lbnNpb25zKFxuICAgICAgICBBd3MuUkVHSU9OLFxuICAgICAgKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBjb3VudCBvZiBoaWdoIGxhdGVuY3kgcmVzcG9uc2VzIGZvciBhbGwgY3JpdGljYWwgb3BlcmF0aW9uc1xuICAgKiBAcGFyYW0gcHJvcHNcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBjcmVhdGVSZWdpb25hbFNlcnZpY2VMYXRlbmN5Q291bnRNZXRyaWNzKFxuICAgIHByb3BzOiBTZXJ2aWNlTGF0ZW5jeU1ldHJpY1Byb3BzLFxuICApOiBJTWV0cmljW10ge1xuICAgIGxldCB1c2luZ01ldHJpY3M6IHsgW2tleTogc3RyaW5nXTogSU1ldHJpYyB9ID0ge307XG4gICAgbGV0IG9wZXJhdGlvbk1ldHJpY3M6IElNZXRyaWNbXSA9IFtdO1xuICAgIGxldCBrZXlQcmVmaXg6IHN0cmluZyA9IE1ldHJpY3NIZWxwZXIubmV4dENoYXIoJycpO1xuXG4gICAgcHJvcHMubGF0ZW5jeU1ldHJpY1Byb3BzLmZvckVhY2goXG4gICAgICAocHJvcDogTGF0ZW5jeU1ldHJpY1Byb3BzLCBpbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgIGxldCBvcGVyYXRpb25SZWdpb25hbE1ldHJpYzogSU1ldHJpYyA9XG4gICAgICAgICAgdGhpcy5jcmVhdGVSZWdpb25hbExhdGVuY3lDb3VudE1ldHJpYyhwcm9wKTtcblxuICAgICAgICBvcGVyYXRpb25NZXRyaWNzLnB1c2gob3BlcmF0aW9uUmVnaW9uYWxNZXRyaWMpO1xuICAgICAgICB1c2luZ01ldHJpY3NbYCR7a2V5UHJlZml4fSR7aW5kZXh9YF0gPSBvcGVyYXRpb25SZWdpb25hbE1ldHJpYztcbiAgICAgICAga2V5UHJlZml4ID0gTWV0cmljc0hlbHBlci5uZXh0Q2hhcihrZXlQcmVmaXgpO1xuICAgICAgfSxcbiAgICApO1xuXG4gICAgaWYgKE9iamVjdC5rZXlzKHVzaW5nTWV0cmljcykubGVuZ3RoID09IDEpIHtcbiAgICAgIG9wZXJhdGlvbk1ldHJpY3MucHVzaChPYmplY3QudmFsdWVzKHVzaW5nTWV0cmljcylbMF0pO1xuICAgIH0gZWxzZSB7XG4gICAgICBsZXQgbWF0aDogSU1ldHJpYyA9IG5ldyBNYXRoRXhwcmVzc2lvbih7XG4gICAgICAgIHVzaW5nTWV0cmljczogdXNpbmdNZXRyaWNzLFxuICAgICAgICBwZXJpb2Q6IHByb3BzLnBlcmlvZCxcbiAgICAgICAgbGFiZWw6IHByb3BzLmxhYmVsLFxuICAgICAgICBleHByZXNzaW9uOiBPYmplY3Qua2V5cyh1c2luZ01ldHJpY3MpLmpvaW4oJysnKSxcbiAgICAgIH0pO1xuXG4gICAgICBvcGVyYXRpb25NZXRyaWNzLnNwbGljZSgwLCAwLCBtYXRoKTtcbiAgICB9XG5cbiAgICByZXR1cm4gb3BlcmF0aW9uTWV0cmljcztcbiAgfVxufVxuIl19
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiUmVnaW9uYWxMYXRlbmN5TWV0cmljcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9tZXRyaWNzL1JlZ2lvbmFsTGF0ZW5jeU1ldHJpY3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXFFO0FBQ3JFLHNDQUFzQztBQUN0Qyw2Q0FBa0M7QUFDbEMsK0RBQXFFO0FBQ3JFLG1GQUFnRjtBQUloRiw4REFBMkQ7QUFFM0QsTUFBYSxzQkFBc0I7SUFDakM7Ozs7Ozs7T0FPRztJQUNILE1BQU0sQ0FBQyw0QkFBNEIsQ0FDakMsS0FBaUM7UUFFakMsT0FBTyw2REFBNkIsQ0FBQyxvQkFBb0IsQ0FDdkQsS0FBSyxFQUNMLEtBQUssQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQ3JELGlCQUFHLENBQUMsTUFBTSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILE1BQU0sQ0FBQyxrQ0FBa0MsQ0FDdkMsS0FBaUM7UUFFakMsT0FBTyw2REFBNkIsQ0FBQywwQkFBMEIsQ0FDN0QsS0FBSyxFQUNMLEtBQUssQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLENBQ3JELGlCQUFHLENBQUMsTUFBTSxDQUNYLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsTUFBTSxDQUFDLGdDQUFnQyxDQUNyQyxLQUFpQztRQUVqQyxPQUFPLDZEQUE2QixDQUFDLHdCQUF3QixDQUMzRCxLQUFLLEVBQ0wsS0FBSyxDQUFDLGFBQWEsQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsQ0FDckQsaUJBQUcsQ0FBQyxNQUFNLENBQ1gsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsd0NBQXdDLENBQzdDLEtBQWdDLEVBQ2hDLDJCQUFxQztRQUdyQyxJQUFJLDJCQUEyQixFQUFFLENBQUM7WUFDaEMsSUFBSSxZQUFZLEdBQStCLEVBQUUsQ0FBQztZQUNsRCxJQUFJLGdCQUFnQixHQUFjLEVBQUUsQ0FBQztZQUNyQyxJQUFJLFNBQVMsR0FBVyw2QkFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBRWpELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQzlCLENBQUMsSUFBd0IsRUFBRSxLQUFhLEVBQUUsRUFBRTtnQkFDMUMsSUFBSSx1QkFBdUIsR0FDekIsSUFBSSxDQUFDLGdDQUFnQyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUU5QyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsQ0FBQztnQkFDL0MsWUFBWSxDQUFDLEdBQUcsU0FBUyxHQUFHLEtBQUssRUFBRSxDQUFDLEdBQUcsdUJBQXVCLENBQUM7Z0JBQy9ELFNBQVMsR0FBRyw2QkFBYSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNoRCxDQUFDLENBQ0YsQ0FBQztZQUVGLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyxFQUFFLENBQUM7Z0JBQzFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLElBQUksSUFBSSxHQUFZLElBQUksK0JBQWMsQ0FBQztvQkFDckMsWUFBWSxFQUFFLFlBQVk7b0JBQzFCLE1BQU0sRUFBRSxLQUFLLENBQUMsTUFBTTtvQkFDcEIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO29CQUNsQixVQUFVLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDO2lCQUNoRCxDQUFDLENBQUM7Z0JBRUgsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDdEMsQ0FBQztZQUVELE9BQU8sZ0JBQWdCLENBQUM7UUFDMUIsQ0FBQzthQUNJLENBQUM7WUFDSixPQUFPLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUF3QixFQUFFLEVBQUU7Z0JBQy9ELE9BQU8sSUFBSSxDQUFDLGdDQUFnQyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ3JELENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7Q0FDRjtBQXBHRCx3REFvR0MiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb3B5cmlnaHQgQW1hem9uLmNvbSwgSW5jLiBvciBpdHMgYWZmaWxpYXRlcy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbi8vIFNQRFgtTGljZW5zZS1JZGVudGlmaWVyOiBBcGFjaGUtMi4wXG5pbXBvcnQgeyBBd3MgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBJTWV0cmljLCBNYXRoRXhwcmVzc2lvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcbmltcG9ydCB7IEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzIH0gZnJvbSAnLi9BdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcyc7XG5pbXBvcnQgeyBMYXRlbmN5TWV0cmljUHJvcHMgfSBmcm9tICcuL3Byb3BzL0xhdGVuY3lNZXRyaWNQcm9wcyc7XG5pbXBvcnQgeyBSZWdpb25hbExhdGVuY3lNZXRyaWNQcm9wcyB9IGZyb20gJy4vcHJvcHMvUmVnaW9uYWxMYXRlbmN5TWV0cmljUHJvcHMnO1xuaW1wb3J0IHsgU2VydmljZUxhdGVuY3lNZXRyaWNQcm9wcyB9IGZyb20gJy4vcHJvcHMvU2VydmljZUxhdGVuY3lNZXJpY1Byb3BzJztcbmltcG9ydCB7IE1ldHJpY3NIZWxwZXIgfSBmcm9tICcuLi91dGlsaXRpZXMvTWV0cmljc0hlbHBlcic7XG5cbmV4cG9ydCBjbGFzcyBSZWdpb25hbExhdGVuY3lNZXRyaWNzIHtcbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBtZXRyaWNzIGZvciByZWdpb25hbCBsYXRlbmN5LCBvbmUgbWV0cmljIHBlciBtZXRyaWMgbmFtZSBmb3IgdGhlXG4gICAqIHNwZWNpZmllZCB0eXBlIG9mIGxhdGVuY3kgbWV0cmljLiBZb3Ugd2lsbCBuZWVkIHRvIHBlcmZvcm0gc29tZSBhZ2dyZWdhdGlvblxuICAgKiBvZiB0aGVzZSBtZXRyaWNzIGlmIHRoZXJlIGlzIG1vcmUgdGhhbiAxIG1ldHJpYyBuYW1lIHRoYXQgY29ycmVwb25kcyB0b1xuICAgKiBTdWNjZXNzTGF0ZW5jeSBvciBGYXVsdExhdGVuY3ksIGxpa2UgZG9pbmcgYW4gYXZlcmFnZS5cbiAgICogQHBhcmFtIHByb3BzXG4gICAqIEByZXR1cm5zXG4gICAqL1xuICBzdGF0aWMgY3JlYXRlUmVnaW9uYWxMYXRlbmN5TWV0cmljcyhcbiAgICBwcm9wczogUmVnaW9uYWxMYXRlbmN5TWV0cmljUHJvcHMsXG4gICk6IElNZXRyaWNbXSB7XG4gICAgcmV0dXJuIEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzLmNyZWF0ZUxhdGVuY3lNZXRyaWNzKFxuICAgICAgcHJvcHMsXG4gICAgICBwcm9wcy5tZXRyaWNEZXRhaWxzLm1ldHJpY0RpbWVuc2lvbnMucmVnaW9uYWxEaW1lbnNpb25zKFxuICAgICAgICBBd3MuUkVHSU9OLFxuICAgICAgKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSByZWdpb25hbCBhdmVyYWdlIGxhdGVuY3kgbWV0cmljLCBhdmVyYWdlcyB0aGUgdmFsdWVzIGZyb20gYWxsIG9mIHRoZVxuICAgKiBtZXRyaWMgbmFtZXMgdGhhdCByZXByZXNlbnQgZWl0aGVyIFN1Y2Nlc3NMYXRlbmN5IG9yIEZhdWx0TGF0ZW5jeVxuICAgKiBAcGFyYW0gcHJvcHNcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBjcmVhdGVSZWdpb25hbEF2ZXJhZ2VMYXRlbmN5TWV0cmljKFxuICAgIHByb3BzOiBSZWdpb25hbExhdGVuY3lNZXRyaWNQcm9wcyxcbiAgKTogSU1ldHJpYyB7XG4gICAgcmV0dXJuIEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzLmNyZWF0ZUF2ZXJhZ2VMYXRlbmN5TWV0cmljKFxuICAgICAgcHJvcHMsXG4gICAgICBwcm9wcy5tZXRyaWNEZXRhaWxzLm1ldHJpY0RpbWVuc2lvbnMucmVnaW9uYWxEaW1lbnNpb25zKFxuICAgICAgICBBd3MuUkVHSU9OLFxuICAgICAgKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIENyZWF0ZXMgYSBjb3VudCBvZiBoaWdoIGxhdGVuY3kgbWV0cmljcyBmb3IgZWl0aGVyIFN1Y2Nlc3NMYXRlbmN5IG9yIEZhdWx0TGF0ZW5jeVxuICAgKiBAcGFyYW0gcHJvcHNcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBjcmVhdGVSZWdpb25hbExhdGVuY3lDb3VudE1ldHJpYyhcbiAgICBwcm9wczogUmVnaW9uYWxMYXRlbmN5TWV0cmljUHJvcHMsXG4gICk6IElNZXRyaWMge1xuICAgIHJldHVybiBBdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcy5jcmVhdGVMYXRlbmN5Q291bnRNZXRyaWMoXG4gICAgICBwcm9wcyxcbiAgICAgIHByb3BzLm1ldHJpY0RldGFpbHMubWV0cmljRGltZW5zaW9ucy5yZWdpb25hbERpbWVuc2lvbnMoXG4gICAgICAgIEF3cy5SRUdJT04sXG4gICAgICApLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogQ3JlYXRlcyBhIGNvdW50IG9mIGhpZ2ggbGF0ZW5jeSByZXNwb25zZXMgZm9yIGFsbCBjcml0aWNhbCBvcGVyYXRpb25zXG4gICAqIEBwYXJhbSBwcm9wc1xuICAgKiBAcmV0dXJuc1xuICAgKi9cbiAgc3RhdGljIGNyZWF0ZVJlZ2lvbmFsU2VydmljZUxhdGVuY3lDb3VudE1ldHJpY3MoXG4gICAgcHJvcHM6IFNlcnZpY2VMYXRlbmN5TWV0cmljUHJvcHMsXG4gICAgaW5jbHVkZVJlZ2lvbkNvdW50QWdncmVnYXRlPzogYm9vbGVhblxuICApOiBJTWV0cmljW10ge1xuICAgIFxuICAgIGlmIChpbmNsdWRlUmVnaW9uQ291bnRBZ2dyZWdhdGUpIHtcbiAgICAgIGxldCB1c2luZ01ldHJpY3M6IHsgW2tleTogc3RyaW5nXTogSU1ldHJpYyB9ID0ge307XG4gICAgICBsZXQgb3BlcmF0aW9uTWV0cmljczogSU1ldHJpY1tdID0gW107XG4gICAgICBsZXQga2V5UHJlZml4OiBzdHJpbmcgPSBNZXRyaWNzSGVscGVyLm5leHRDaGFyKCk7XG5cbiAgICAgIHByb3BzLmxhdGVuY3lNZXRyaWNQcm9wcy5mb3JFYWNoKFxuICAgICAgICAocHJvcDogTGF0ZW5jeU1ldHJpY1Byb3BzLCBpbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgICAgbGV0IG9wZXJhdGlvblJlZ2lvbmFsTWV0cmljOiBJTWV0cmljID1cbiAgICAgICAgICAgIHRoaXMuY3JlYXRlUmVnaW9uYWxMYXRlbmN5Q291bnRNZXRyaWMocHJvcCk7XG4gIFxuICAgICAgICAgIG9wZXJhdGlvbk1ldHJpY3MucHVzaChvcGVyYXRpb25SZWdpb25hbE1ldHJpYyk7XG4gICAgICAgICAgdXNpbmdNZXRyaWNzW2Ake2tleVByZWZpeH0ke2luZGV4fWBdID0gb3BlcmF0aW9uUmVnaW9uYWxNZXRyaWM7XG4gICAgICAgICAga2V5UHJlZml4ID0gTWV0cmljc0hlbHBlci5uZXh0Q2hhcihrZXlQcmVmaXgpO1xuICAgICAgICB9LFxuICAgICAgKTtcbiAgXG4gICAgICBpZiAoT2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5sZW5ndGggPT0gMSkge1xuICAgICAgICBvcGVyYXRpb25NZXRyaWNzLnB1c2goT2JqZWN0LnZhbHVlcyh1c2luZ01ldHJpY3MpWzBdKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGxldCBtYXRoOiBJTWV0cmljID0gbmV3IE1hdGhFeHByZXNzaW9uKHtcbiAgICAgICAgICB1c2luZ01ldHJpY3M6IHVzaW5nTWV0cmljcyxcbiAgICAgICAgICBwZXJpb2Q6IHByb3BzLnBlcmlvZCxcbiAgICAgICAgICBsYWJlbDogcHJvcHMubGFiZWwsXG4gICAgICAgICAgZXhwcmVzc2lvbjogT2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyksXG4gICAgICAgIH0pO1xuICBcbiAgICAgICAgb3BlcmF0aW9uTWV0cmljcy5zcGxpY2UoMCwgMCwgbWF0aCk7XG4gICAgICB9XG4gIFxuICAgICAgcmV0dXJuIG9wZXJhdGlvbk1ldHJpY3M7XG4gICAgfVxuICAgIGVsc2Uge1xuICAgICAgcmV0dXJuIHByb3BzLmxhdGVuY3lNZXRyaWNQcm9wcy5tYXAoKHByb3A6IExhdGVuY3lNZXRyaWNQcm9wcykgPT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5jcmVhdGVSZWdpb25hbExhdGVuY3lDb3VudE1ldHJpYyhwcm9wKTtcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -1,5 +1,5 @@
1
+ import { Duration } from 'aws-cdk-lib';
1
2
  import { IMetric } from 'aws-cdk-lib/aws-cloudwatch';
2
- import { ServiceAvailabilityMetricProps } from './props/ServiceAvailabilityMetricProps';
3
3
  import { ZonalAvailabilityMetricProps } from './props/ZonalAvailabilityMetricProps';
4
4
  export declare class ZonalAvailabilityMetrics {
5
5
  /**
@@ -9,11 +9,5 @@ export declare class ZonalAvailabilityMetrics {
9
9
  * @returns The metric at index 0 is the metric math expression for the whole service. The following metrics
10
10
  * are the metrics for each operation included in the request availability metric props.
11
11
  */
12
- static createZonalServiceAvailabilityMetrics(props: ServiceAvailabilityMetricProps): IMetric[];
13
- /**
14
- * Creates a zonal availability metric
15
- * @param props
16
- * @returns
17
- */
18
- static createZonalAvailabilityMetric(props: ZonalAvailabilityMetricProps): IMetric;
12
+ static createZonalServiceAvailabilityMetrics(metrics: ZonalAvailabilityMetricProps[], period: Duration, label: string): IMetric[];
19
13
  }
@@ -15,26 +15,19 @@ class ZonalAvailabilityMetrics {
15
15
  * @returns The metric at index 0 is the metric math expression for the whole service. The following metrics
16
16
  * are the metrics for each operation included in the request availability metric props.
17
17
  */
18
- static createZonalServiceAvailabilityMetrics(props) {
18
+ static createZonalServiceAvailabilityMetrics(metrics, period, label) {
19
19
  let usingMetrics = {};
20
20
  let operationMetrics = [];
21
- let counter = 0;
22
- props.availabilityMetricProps.forEach((prop) => {
23
- let keyPrefix = (prop.keyPrefix === undefined || prop.keyPrefix == ''
24
- ? ''
25
- : prop.keyPrefix.toLowerCase() + '_') +
26
- prop.metricDetails.operationName.toLowerCase() +
27
- '_' +
28
- prop.metricType.toString().toLowerCase();
29
- let zonalOperationAvailabilityMetric = this.createZonalAvailabilityMetric(prop);
21
+ metrics.forEach((prop, index) => {
22
+ let zonalOperationAvailabilityMetric = AvailabilityAndLatencyMetrics_1.AvailabilityAndLatencyMetrics.createZonalAvailabilityMetric(prop, prop.metricDetails.metricDimensions.zonalDimensions(prop.availabilityZoneId, aws_cdk_lib_1.Aws.REGION));
30
23
  operationMetrics.push(zonalOperationAvailabilityMetric);
31
- usingMetrics[`${keyPrefix}${counter++}`] =
24
+ usingMetrics[`${prop.availabilityZone.substring(prop.availabilityZone.length - 1)}_${prop.metricDetails.operationName}_${prop.metricType.toString().toLowerCase()}_${index}`] =
32
25
  zonalOperationAvailabilityMetric;
33
26
  });
34
27
  let expression = '';
35
- switch (props.availabilityMetricProps[0].metricType) {
28
+ switch (metrics[0].metricType) {
36
29
  case AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_RATE:
37
- expression = `(${Object.keys(usingMetrics).join('+')}) / ${props.availabilityMetricProps.length}`;
30
+ expression = `(${Object.keys(usingMetrics).join('+')}) / ${metrics.length}`;
38
31
  break;
39
32
  case AvailabilityMetricType_1.AvailabilityMetricType.REQUEST_COUNT:
40
33
  expression = `${Object.keys(usingMetrics).join('+')}`;
@@ -43,7 +36,7 @@ class ZonalAvailabilityMetrics {
43
36
  expression = `${Object.keys(usingMetrics).join('+')}`;
44
37
  break;
45
38
  case AvailabilityMetricType_1.AvailabilityMetricType.FAULT_RATE:
46
- expression = `(${Object.keys(usingMetrics).join('+')}) / ${props.availabilityMetricProps.length}`;
39
+ expression = `(${Object.keys(usingMetrics).join('+')}) / ${metrics.length}`;
47
40
  break;
48
41
  case AvailabilityMetricType_1.AvailabilityMetricType.SUCCESS_COUNT:
49
42
  expression = `${Object.keys(usingMetrics).join('+')}`;
@@ -51,21 +44,13 @@ class ZonalAvailabilityMetrics {
51
44
  }
52
45
  let math = new aws_cloudwatch_1.MathExpression({
53
46
  usingMetrics: usingMetrics,
54
- period: props.period,
55
- label: props.label,
47
+ period: period,
48
+ label: label,
56
49
  expression: expression,
57
50
  });
58
51
  operationMetrics.splice(0, 0, math);
59
52
  return operationMetrics;
60
53
  }
61
- /**
62
- * Creates a zonal availability metric
63
- * @param props
64
- * @returns
65
- */
66
- static createZonalAvailabilityMetric(props) {
67
- return AvailabilityAndLatencyMetrics_1.AvailabilityAndLatencyMetrics.createAvailabilityMetric(props, props.metricDetails.metricDimensions.zonalDimensions(props.availabilityZoneId, aws_cdk_lib_1.Aws.REGION));
68
- }
69
54
  }
70
55
  exports.ZonalAvailabilityMetrics = ZonalAvailabilityMetrics;
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21ldHJpY3MvWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFFQUFxRTtBQUNyRSxzQ0FBc0M7QUFDdEMsNkNBQWtDO0FBQ2xDLCtEQUFxRTtBQUNyRSxtRkFBZ0Y7QUFHaEYsZ0ZBQTZFO0FBRTdFLE1BQWEsd0JBQXdCO0lBQ25DOzs7Ozs7T0FNRztJQUNILE1BQU0sQ0FBQyxxQ0FBcUMsQ0FDMUMsS0FBcUM7UUFFckMsSUFBSSxZQUFZLEdBQStCLEVBQUUsQ0FBQztRQUNsRCxJQUFJLGdCQUFnQixHQUFjLEVBQUUsQ0FBQztRQUNyQyxJQUFJLE9BQU8sR0FBVyxDQUFDLENBQUM7UUFFeEIsS0FBSyxDQUFDLHVCQUF1QixDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQzdDLElBQUksU0FBUyxHQUNYLENBQUMsSUFBSSxDQUFDLFNBQVMsS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxFQUFFO2dCQUNuRCxDQUFDLENBQUMsRUFBRTtnQkFDSixDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsR0FBRyxHQUFHLENBQUM7Z0JBQ3ZDLElBQUksQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLFdBQVcsRUFBRTtnQkFDOUMsR0FBRztnQkFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBRTNDLElBQUksZ0NBQWdDLEdBQ2xDLElBQUksQ0FBQyw2QkFBNkIsQ0FDaEMsSUFBb0MsQ0FDckMsQ0FBQztZQUVKLGdCQUFnQixDQUFDLElBQUksQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO1lBQ3hELFlBQVksQ0FBQyxHQUFHLFNBQVMsR0FBRyxPQUFPLEVBQUUsRUFBRSxDQUFDO2dCQUN0QyxnQ0FBZ0MsQ0FBQztRQUNyQyxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksVUFBVSxHQUFXLEVBQUUsQ0FBQztRQUU1QixRQUFRLEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNwRCxLQUFLLCtDQUFzQixDQUFDLFlBQVk7Z0JBQ3RDLFVBQVUsR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEtBQUssQ0FBQyx1QkFBdUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDbEcsTUFBTTtZQUNSLEtBQUssK0NBQXNCLENBQUMsYUFBYTtnQkFDdkMsVUFBVSxHQUFHLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDdEQsTUFBTTtZQUNSLEtBQUssK0NBQXNCLENBQUMsV0FBVztnQkFDckMsVUFBVSxHQUFHLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDdEQsTUFBTTtZQUNSLEtBQUssK0NBQXNCLENBQUMsVUFBVTtnQkFDcEMsVUFBVSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sS0FBSyxDQUFDLHVCQUF1QixDQUFDLE1BQU0sRUFBRSxDQUFDO2dCQUNsRyxNQUFNO1lBQ1IsS0FBSywrQ0FBc0IsQ0FBQyxhQUFhO2dCQUN2QyxVQUFVLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUN0RCxNQUFNO1FBQ1YsQ0FBQztRQUNELElBQUksSUFBSSxHQUFZLElBQUksK0JBQWMsQ0FBQztZQUNyQyxZQUFZLEVBQUUsWUFBWTtZQUMxQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDcEIsS0FBSyxFQUFFLEtBQUssQ0FBQyxLQUFLO1lBQ2xCLFVBQVUsRUFBRSxVQUFVO1NBQ3ZCLENBQUMsQ0FBQztRQUVILGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBRXBDLE9BQU8sZ0JBQWdCLENBQUM7SUFDMUIsQ0FBQztJQUVEOzs7O09BSUc7SUFDSCxNQUFNLENBQUMsNkJBQTZCLENBQ2xDLEtBQW1DO1FBRW5DLE9BQU8sNkRBQTZCLENBQUMsd0JBQXdCLENBQzNELEtBQUssRUFDTCxLQUFLLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FDbEQsS0FBSyxDQUFDLGtCQUFrQixFQUN4QixpQkFBRyxDQUFDLE1BQU0sQ0FDWCxDQUNGLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFqRkQsNERBaUZDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4vLyBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogQXBhY2hlLTIuMFxuaW1wb3J0IHsgQXdzIH0gZnJvbSAnYXdzLWNkay1saWInO1xuaW1wb3J0IHsgSU1ldHJpYywgTWF0aEV4cHJlc3Npb24gfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtY2xvdWR3YXRjaCc7XG5pbXBvcnQgeyBBdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcyB9IGZyb20gJy4vQXZhaWxhYmlsaXR5QW5kTGF0ZW5jeU1ldHJpY3MnO1xuaW1wb3J0IHsgU2VydmljZUF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzIH0gZnJvbSAnLi9wcm9wcy9TZXJ2aWNlQXZhaWxhYmlsaXR5TWV0cmljUHJvcHMnO1xuaW1wb3J0IHsgWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNQcm9wcyB9IGZyb20gJy4vcHJvcHMvWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNQcm9wcyc7XG5pbXBvcnQgeyBBdmFpbGFiaWxpdHlNZXRyaWNUeXBlIH0gZnJvbSAnLi4vdXRpbGl0aWVzL0F2YWlsYWJpbGl0eU1ldHJpY1R5cGUnO1xuXG5leHBvcnQgY2xhc3MgWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNzIHtcbiAgLyoqXG4gICAqIENyZWF0ZXMgYSB6b25hbCBzZXJ2aWNlIGxldmVsIGF2YWlsYWJpbGl0eSBtZXRyaWNzLCBvbmUgbWV0cmljIGZvclxuICAgKiBlYWNoIG9wZXJhdGlvbiBhdCB0aGUgem9uYWwgbGV2ZWwgYW5kIHRoZSBzZXJ2aWNlLlxuICAgKiBAcGFyYW0gcHJvcHNcbiAgICogQHJldHVybnMgVGhlIG1ldHJpYyBhdCBpbmRleCAwIGlzIHRoZSBtZXRyaWMgbWF0aCBleHByZXNzaW9uIGZvciB0aGUgd2hvbGUgc2VydmljZS4gVGhlIGZvbGxvd2luZyBtZXRyaWNzXG4gICAqIGFyZSB0aGUgbWV0cmljcyBmb3IgZWFjaCBvcGVyYXRpb24gaW5jbHVkZWQgaW4gdGhlIHJlcXVlc3QgYXZhaWxhYmlsaXR5IG1ldHJpYyBwcm9wcy5cbiAgICovXG4gIHN0YXRpYyBjcmVhdGVab25hbFNlcnZpY2VBdmFpbGFiaWxpdHlNZXRyaWNzKFxuICAgIHByb3BzOiBTZXJ2aWNlQXZhaWxhYmlsaXR5TWV0cmljUHJvcHMsXG4gICk6IElNZXRyaWNbXSB7XG4gICAgbGV0IHVzaW5nTWV0cmljczogeyBba2V5OiBzdHJpbmddOiBJTWV0cmljIH0gPSB7fTtcbiAgICBsZXQgb3BlcmF0aW9uTWV0cmljczogSU1ldHJpY1tdID0gW107XG4gICAgbGV0IGNvdW50ZXI6IG51bWJlciA9IDA7XG5cbiAgICBwcm9wcy5hdmFpbGFiaWxpdHlNZXRyaWNQcm9wcy5mb3JFYWNoKChwcm9wKSA9PiB7XG4gICAgICBsZXQga2V5UHJlZml4OiBzdHJpbmcgPVxuICAgICAgICAocHJvcC5rZXlQcmVmaXggPT09IHVuZGVmaW5lZCB8fCBwcm9wLmtleVByZWZpeCA9PSAnJ1xuICAgICAgICAgID8gJydcbiAgICAgICAgICA6IHByb3Aua2V5UHJlZml4LnRvTG93ZXJDYXNlKCkgKyAnXycpICtcbiAgICAgICAgcHJvcC5tZXRyaWNEZXRhaWxzLm9wZXJhdGlvbk5hbWUudG9Mb3dlckNhc2UoKSArXG4gICAgICAgICdfJyArXG4gICAgICAgIHByb3AubWV0cmljVHlwZS50b1N0cmluZygpLnRvTG93ZXJDYXNlKCk7XG5cbiAgICAgIGxldCB6b25hbE9wZXJhdGlvbkF2YWlsYWJpbGl0eU1ldHJpYzogSU1ldHJpYyA9XG4gICAgICAgIHRoaXMuY3JlYXRlWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWMoXG4gICAgICAgICAgcHJvcCBhcyBab25hbEF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzLFxuICAgICAgICApO1xuXG4gICAgICBvcGVyYXRpb25NZXRyaWNzLnB1c2goem9uYWxPcGVyYXRpb25BdmFpbGFiaWxpdHlNZXRyaWMpO1xuICAgICAgdXNpbmdNZXRyaWNzW2Ake2tleVByZWZpeH0ke2NvdW50ZXIrK31gXSA9XG4gICAgICAgIHpvbmFsT3BlcmF0aW9uQXZhaWxhYmlsaXR5TWV0cmljO1xuICAgIH0pO1xuXG4gICAgbGV0IGV4cHJlc3Npb246IHN0cmluZyA9ICcnO1xuXG4gICAgc3dpdGNoIChwcm9wcy5hdmFpbGFiaWxpdHlNZXRyaWNQcm9wc1swXS5tZXRyaWNUeXBlKSB7XG4gICAgICBjYXNlIEF2YWlsYWJpbGl0eU1ldHJpY1R5cGUuU1VDQ0VTU19SQVRFOlxuICAgICAgICBleHByZXNzaW9uID0gYCgke09iamVjdC5rZXlzKHVzaW5nTWV0cmljcykuam9pbignKycpfSkgLyAke3Byb3BzLmF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzLmxlbmd0aH1gO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgQXZhaWxhYmlsaXR5TWV0cmljVHlwZS5SRVFVRVNUX0NPVU5UOlxuICAgICAgICBleHByZXNzaW9uID0gYCR7T2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyl9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIEF2YWlsYWJpbGl0eU1ldHJpY1R5cGUuRkFVTFRfQ09VTlQ6XG4gICAgICAgIGV4cHJlc3Npb24gPSBgJHtPYmplY3Qua2V5cyh1c2luZ01ldHJpY3MpLmpvaW4oJysnKX1gO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgQXZhaWxhYmlsaXR5TWV0cmljVHlwZS5GQVVMVF9SQVRFOlxuICAgICAgICBleHByZXNzaW9uID0gYCgke09iamVjdC5rZXlzKHVzaW5nTWV0cmljcykuam9pbignKycpfSkgLyAke3Byb3BzLmF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzLmxlbmd0aH1gO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgQXZhaWxhYmlsaXR5TWV0cmljVHlwZS5TVUNDRVNTX0NPVU5UOlxuICAgICAgICBleHByZXNzaW9uID0gYCR7T2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyl9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGxldCBtYXRoOiBJTWV0cmljID0gbmV3IE1hdGhFeHByZXNzaW9uKHtcbiAgICAgIHVzaW5nTWV0cmljczogdXNpbmdNZXRyaWNzLFxuICAgICAgcGVyaW9kOiBwcm9wcy5wZXJpb2QsXG4gICAgICBsYWJlbDogcHJvcHMubGFiZWwsXG4gICAgICBleHByZXNzaW9uOiBleHByZXNzaW9uLFxuICAgIH0pO1xuXG4gICAgb3BlcmF0aW9uTWV0cmljcy5zcGxpY2UoMCwgMCwgbWF0aCk7XG5cbiAgICByZXR1cm4gb3BlcmF0aW9uTWV0cmljcztcbiAgfVxuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgem9uYWwgYXZhaWxhYmlsaXR5IG1ldHJpY1xuICAgKiBAcGFyYW0gcHJvcHNcbiAgICogQHJldHVybnNcbiAgICovXG4gIHN0YXRpYyBjcmVhdGVab25hbEF2YWlsYWJpbGl0eU1ldHJpYyhcbiAgICBwcm9wczogWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNQcm9wcyxcbiAgKTogSU1ldHJpYyB7XG4gICAgcmV0dXJuIEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzLmNyZWF0ZUF2YWlsYWJpbGl0eU1ldHJpYyhcbiAgICAgIHByb3BzLFxuICAgICAgcHJvcHMubWV0cmljRGV0YWlscy5tZXRyaWNEaW1lbnNpb25zLnpvbmFsRGltZW5zaW9ucyhcbiAgICAgICAgcHJvcHMuYXZhaWxhYmlsaXR5Wm9uZUlkLFxuICAgICAgICBBd3MuUkVHSU9OXG4gICAgICApLFxuICAgICk7XG4gIH1cbn1cbiJdfQ==
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL21ldHJpY3MvWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHFFQUFxRTtBQUNyRSxzQ0FBc0M7QUFDdEMsNkNBQTRDO0FBQzVDLCtEQUFxRTtBQUNyRSxtRkFBZ0Y7QUFFaEYsZ0ZBQTZFO0FBRTdFLE1BQWEsd0JBQXdCO0lBQ25DOzs7Ozs7T0FNRztJQUNILE1BQU0sQ0FBQyxxQ0FBcUMsQ0FDMUMsT0FBdUMsRUFDdkMsTUFBZ0IsRUFDaEIsS0FBYTtRQUViLElBQUksWUFBWSxHQUErQixFQUFFLENBQUM7UUFDbEQsSUFBSSxnQkFBZ0IsR0FBYyxFQUFFLENBQUM7UUFFckMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQWtDLEVBQUUsS0FBYSxFQUFFLEVBQUU7WUFFcEUsSUFBSSxnQ0FBZ0MsR0FDbEMsNkRBQTZCLENBQUMsNkJBQTZCLENBQ3pELElBQUksRUFDSixJQUFJLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FDakQsSUFBSSxDQUFDLGtCQUFrQixFQUN2QixpQkFBRyxDQUFDLE1BQU0sQ0FDWCxDQUNGLENBQUM7WUFFSixnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztZQUN4RCxZQUFZLENBQUMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxhQUFhLElBQUssSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxXQUFXLEVBQUcsSUFBSSxLQUFLLEVBQUUsQ0FBQztnQkFDN0ssZ0NBQWdDLENBQUM7UUFDckMsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLFVBQVUsR0FBVyxFQUFFLENBQUM7UUFFNUIsUUFBUSxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDOUIsS0FBSywrQ0FBc0IsQ0FBQyxZQUFZO2dCQUN0QyxVQUFVLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQzVFLE1BQU07WUFDUixLQUFLLCtDQUFzQixDQUFDLGFBQWE7Z0JBQ3ZDLFVBQVUsR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7Z0JBQ3RELE1BQU07WUFDUixLQUFLLCtDQUFzQixDQUFDLFdBQVc7Z0JBQ3JDLFVBQVUsR0FBRyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7Z0JBQ3RELE1BQU07WUFDUixLQUFLLCtDQUFzQixDQUFDLFVBQVU7Z0JBQ3BDLFVBQVUsR0FBRyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxPQUFPLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDNUUsTUFBTTtZQUNSLEtBQUssK0NBQXNCLENBQUMsYUFBYTtnQkFDdkMsVUFBVSxHQUFHLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDdEQsTUFBTTtRQUNWLENBQUM7UUFDRCxJQUFJLElBQUksR0FBWSxJQUFJLCtCQUFjLENBQUM7WUFDckMsWUFBWSxFQUFFLFlBQVk7WUFDMUIsTUFBTSxFQUFFLE1BQU07WUFDZCxLQUFLLEVBQUUsS0FBSztZQUNaLFVBQVUsRUFBRSxVQUFVO1NBQ3ZCLENBQUMsQ0FBQztRQUVILGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO1FBRXBDLE9BQU8sZ0JBQWdCLENBQUM7SUFDMUIsQ0FBQztDQUNGO0FBOURELDREQThEQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbmltcG9ydCB7IEF3cywgRHVyYXRpb24gfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBJTWV0cmljLCBNYXRoRXhwcmVzc2lvbiB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1jbG91ZHdhdGNoJztcbmltcG9ydCB7IEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzIH0gZnJvbSAnLi9BdmFpbGFiaWxpdHlBbmRMYXRlbmN5TWV0cmljcyc7XG5pbXBvcnQgeyBab25hbEF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzIH0gZnJvbSAnLi9wcm9wcy9ab25hbEF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzJztcbmltcG9ydCB7IEF2YWlsYWJpbGl0eU1ldHJpY1R5cGUgfSBmcm9tICcuLi91dGlsaXRpZXMvQXZhaWxhYmlsaXR5TWV0cmljVHlwZSc7XG5cbmV4cG9ydCBjbGFzcyBab25hbEF2YWlsYWJpbGl0eU1ldHJpY3Mge1xuICAvKipcbiAgICogQ3JlYXRlcyBhIHpvbmFsIHNlcnZpY2UgbGV2ZWwgYXZhaWxhYmlsaXR5IG1ldHJpY3MsIG9uZSBtZXRyaWMgZm9yXG4gICAqIGVhY2ggb3BlcmF0aW9uIGF0IHRoZSB6b25hbCBsZXZlbCBhbmQgdGhlIHNlcnZpY2UuXG4gICAqIEBwYXJhbSBwcm9wc1xuICAgKiBAcmV0dXJucyBUaGUgbWV0cmljIGF0IGluZGV4IDAgaXMgdGhlIG1ldHJpYyBtYXRoIGV4cHJlc3Npb24gZm9yIHRoZSB3aG9sZSBzZXJ2aWNlLiBUaGUgZm9sbG93aW5nIG1ldHJpY3NcbiAgICogYXJlIHRoZSBtZXRyaWNzIGZvciBlYWNoIG9wZXJhdGlvbiBpbmNsdWRlZCBpbiB0aGUgcmVxdWVzdCBhdmFpbGFiaWxpdHkgbWV0cmljIHByb3BzLlxuICAgKi9cbiAgc3RhdGljIGNyZWF0ZVpvbmFsU2VydmljZUF2YWlsYWJpbGl0eU1ldHJpY3MoXG4gICAgbWV0cmljczogWm9uYWxBdmFpbGFiaWxpdHlNZXRyaWNQcm9wc1tdLFxuICAgIHBlcmlvZDogRHVyYXRpb24sXG4gICAgbGFiZWw6IHN0cmluZ1xuICApOiBJTWV0cmljW10ge1xuICAgIGxldCB1c2luZ01ldHJpY3M6IHsgW2tleTogc3RyaW5nXTogSU1ldHJpYyB9ID0ge307XG4gICAgbGV0IG9wZXJhdGlvbk1ldHJpY3M6IElNZXRyaWNbXSA9IFtdO1xuXG4gICAgbWV0cmljcy5mb3JFYWNoKChwcm9wOiBab25hbEF2YWlsYWJpbGl0eU1ldHJpY1Byb3BzLCBpbmRleDogbnVtYmVyKSA9PiB7XG5cbiAgICAgIGxldCB6b25hbE9wZXJhdGlvbkF2YWlsYWJpbGl0eU1ldHJpYzogSU1ldHJpYyA9XG4gICAgICAgIEF2YWlsYWJpbGl0eUFuZExhdGVuY3lNZXRyaWNzLmNyZWF0ZVpvbmFsQXZhaWxhYmlsaXR5TWV0cmljKFxuICAgICAgICAgIHByb3AsXG4gICAgICAgICAgcHJvcC5tZXRyaWNEZXRhaWxzLm1ldHJpY0RpbWVuc2lvbnMuem9uYWxEaW1lbnNpb25zKFxuICAgICAgICAgICAgcHJvcC5hdmFpbGFiaWxpdHlab25lSWQsXG4gICAgICAgICAgICBBd3MuUkVHSU9OXG4gICAgICAgICAgKVxuICAgICAgICApO1xuXG4gICAgICBvcGVyYXRpb25NZXRyaWNzLnB1c2goem9uYWxPcGVyYXRpb25BdmFpbGFiaWxpdHlNZXRyaWMpO1xuICAgICAgdXNpbmdNZXRyaWNzW2Ake3Byb3AuYXZhaWxhYmlsaXR5Wm9uZS5zdWJzdHJpbmcocHJvcC5hdmFpbGFiaWxpdHlab25lLmxlbmd0aCAtIDEpfV8ke3Byb3AubWV0cmljRGV0YWlscy5vcGVyYXRpb25OYW1lfV8keyBwcm9wLm1ldHJpY1R5cGUudG9TdHJpbmcoKS50b0xvd2VyQ2FzZSgpIH1fJHtpbmRleH1gXSA9XG4gICAgICAgIHpvbmFsT3BlcmF0aW9uQXZhaWxhYmlsaXR5TWV0cmljO1xuICAgIH0pO1xuXG4gICAgbGV0IGV4cHJlc3Npb246IHN0cmluZyA9ICcnO1xuXG4gICAgc3dpdGNoIChtZXRyaWNzWzBdLm1ldHJpY1R5cGUpIHtcbiAgICAgIGNhc2UgQXZhaWxhYmlsaXR5TWV0cmljVHlwZS5TVUNDRVNTX1JBVEU6XG4gICAgICAgIGV4cHJlc3Npb24gPSBgKCR7T2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyl9KSAvICR7bWV0cmljcy5sZW5ndGh9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIEF2YWlsYWJpbGl0eU1ldHJpY1R5cGUuUkVRVUVTVF9DT1VOVDpcbiAgICAgICAgZXhwcmVzc2lvbiA9IGAke09iamVjdC5rZXlzKHVzaW5nTWV0cmljcykuam9pbignKycpfWA7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSBBdmFpbGFiaWxpdHlNZXRyaWNUeXBlLkZBVUxUX0NPVU5UOlxuICAgICAgICBleHByZXNzaW9uID0gYCR7T2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyl9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlIEF2YWlsYWJpbGl0eU1ldHJpY1R5cGUuRkFVTFRfUkFURTpcbiAgICAgICAgZXhwcmVzc2lvbiA9IGAoJHtPYmplY3Qua2V5cyh1c2luZ01ldHJpY3MpLmpvaW4oJysnKX0pIC8gJHttZXRyaWNzLmxlbmd0aH1gO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgQXZhaWxhYmlsaXR5TWV0cmljVHlwZS5TVUNDRVNTX0NPVU5UOlxuICAgICAgICBleHByZXNzaW9uID0gYCR7T2JqZWN0LmtleXModXNpbmdNZXRyaWNzKS5qb2luKCcrJyl9YDtcbiAgICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGxldCBtYXRoOiBJTWV0cmljID0gbmV3IE1hdGhFeHByZXNzaW9uKHtcbiAgICAgIHVzaW5nTWV0cmljczogdXNpbmdNZXRyaWNzLFxuICAgICAgcGVyaW9kOiBwZXJpb2QsXG4gICAgICBsYWJlbDogbGFiZWwsXG4gICAgICBleHByZXNzaW9uOiBleHByZXNzaW9uLFxuICAgIH0pO1xuXG4gICAgb3BlcmF0aW9uTWV0cmljcy5zcGxpY2UoMCwgMCwgbWF0aCk7XG5cbiAgICByZXR1cm4gb3BlcmF0aW9uTWV0cmljcztcbiAgfVxufVxuIl19
@@ -8,6 +8,7 @@ export declare class ZonalLatencyMetrics {
8
8
  * @returns
9
9
  */
10
10
  static createZonalLatencyMetrics(props: ZonalLatencyMetricProps): IMetric[];
11
+ static createZonalLatencyMetric(props: ZonalLatencyMetricProps): IMetric;
11
12
  /**
12
13
  * Creates an average zonal latency metric
13
14
  * @param props
@@ -25,5 +26,5 @@ export declare class ZonalLatencyMetrics {
25
26
  * @param props
26
27
  * @returns
27
28
  */
28
- static createZonalServiceLatencyMetrics(props: ServiceLatencyMetricProps): IMetric[];
29
+ static createZonalServiceLatencyMetrics(props: ServiceLatencyMetricProps, includeAZCountAggregate?: boolean): IMetric[];
29
30
  }