1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | exports.dispatchMetric = exports.metricPeriod = exports.metricKey = void 0;
|
4 | const core_1 = require("@aws-cdk/core");
|
5 | const METRICKEY_SYMBOL = Symbol('@aws-cdk/aws-cloudwatch.MetricKey');
|
6 | /**
|
7 | * Return a unique string representation for this metric.
|
8 | *
|
9 | * Can be used to determine as a hash key to determine if 2 Metric objects
|
10 | * represent the same metric. Excludes rendering properties.
|
11 | */
|
12 | function metricKey(metric) {
|
13 | // Cache on the object itself. This is safe because Metric objects are immutable.
|
14 | if (metric.hasOwnProperty(METRICKEY_SYMBOL)) {
|
15 | return metric[METRICKEY_SYMBOL];
|
16 | }
|
17 | const parts = new Array();
|
18 | const conf = metric.toMetricConfig();
|
19 | if (conf.mathExpression) {
|
20 | parts.push(conf.mathExpression.expression);
|
21 | for (const id of Object.keys(conf.mathExpression.usingMetrics).sort()) {
|
22 | parts.push(id);
|
23 | parts.push(metricKey(conf.mathExpression.usingMetrics[id]));
|
24 | }
|
25 | if (conf.mathExpression.searchRegion) {
|
26 | parts.push(conf.mathExpression.searchRegion);
|
27 | }
|
28 | if (conf.mathExpression.searchAccount) {
|
29 | parts.push(conf.mathExpression.searchAccount);
|
30 | }
|
31 | }
|
32 | if (conf.metricStat) {
|
33 | parts.push(conf.metricStat.namespace);
|
34 | parts.push(conf.metricStat.metricName);
|
35 | for (const dim of conf.metricStat.dimensions || []) {
|
36 | parts.push(dim.name);
|
37 | parts.push(dim.value);
|
38 | }
|
39 | if (conf.metricStat.statistic) {
|
40 | parts.push(conf.metricStat.statistic);
|
41 | }
|
42 | if (conf.metricStat.period) {
|
43 | parts.push(`${conf.metricStat.period.toSeconds()}`);
|
44 | }
|
45 | if (conf.metricStat.region) {
|
46 | parts.push(conf.metricStat.region);
|
47 | }
|
48 | if (conf.metricStat.account) {
|
49 | parts.push(conf.metricStat.account);
|
50 | }
|
51 | }
|
52 | const ret = parts.join('|');
|
53 | Object.defineProperty(metric, METRICKEY_SYMBOL, { value: ret });
|
54 | return ret;
|
55 | }
|
56 | exports.metricKey = metricKey;
|
57 | /**
|
58 | * Return the period of a metric
|
59 | *
|
60 | * For a stat metric, return the immediate period.
|
61 | *
|
62 | * For an expression metric, all metrics used in it have been made to have the
|
63 | * same period, so we return the period of the first inner metric.
|
64 | */
|
65 | function metricPeriod(metric) {
|
66 | return dispatchMetric(metric, {
|
67 | withStat(stat) {
|
68 | return stat.period;
|
69 | },
|
70 | withExpression() {
|
71 | return metric.period || core_1.Duration.minutes(5);
|
72 | },
|
73 | });
|
74 | }
|
75 | exports.metricPeriod = metricPeriod;
|
76 | /**
|
77 | * Given a metric object, inspect it and call the correct function for the type of output
|
78 | *
|
79 | * In addition to the metric object itself, takes a callback object with two
|
80 | * methods, to be invoked for the particular type of metric.
|
81 | *
|
82 | * If the metric represent a metric query (nominally generated through an
|
83 | * instantiation of `Metric` but can be generated by any class that implements
|
84 | * `IMetric`) a particular field in its `toMetricConfig()` output will be set
|
85 | * (to wit, `metricStat`) and the `withStat()` callback will be called with
|
86 | * that object.
|
87 | *
|
88 | * If the metric represents an expression (usually by instantiating `MathExpression`
|
89 | * but users can implement `IMetric` arbitrarily) the `mathExpression` field
|
90 | * will be set in the object returned from `toMetricConfig` and the callback
|
91 | * called `withExpression` will be applied to that object.
|
92 | *
|
93 | * Will return the values returned by the callbacks.
|
94 | *
|
95 | * To be used as such:
|
96 | *
|
97 | * ```ts
|
98 | * const ret = dispatchMetric(someMetric, {
|
99 | * withStat(stat) {
|
100 | * // do something with stat
|
101 | * return 1;
|
102 | * },
|
103 | * withExpression(expr) {
|
104 | * // do something with expr
|
105 | * return 2;
|
106 | * },
|
107 | * });
|
108 | * ```
|
109 | *
|
110 | * This function encapsulates some type analysis that would otherwise have to be
|
111 | * repeated in all places where code needs to make a distinction on the type
|
112 | * of metric object that is being passed.
|
113 | */
|
114 | // eslint-disable-next-line max-len
|
115 | function dispatchMetric(metric, fns) {
|
116 | const conf = metric.toMetricConfig();
|
117 | if (conf.metricStat && conf.mathExpression) {
|
118 | throw new Error('Metric object must not produce both \'metricStat\' and \'mathExpression\'');
|
119 | }
|
120 | else if (conf.metricStat) {
|
121 | return fns.withStat(conf.metricStat, conf);
|
122 | }
|
123 | else if (conf.mathExpression) {
|
124 | return fns.withExpression(conf.mathExpression, conf);
|
125 | }
|
126 | else {
|
127 | throw new Error('Metric object must have either \'metricStat\' or \'mathExpression\'');
|
128 | }
|
129 | }
|
130 | exports.dispatchMetric = dispatchMetric;
|
131 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric-util.js","sourceRoot":"","sources":["metric-util.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration } from '@aws-cdk/core';\nimport { MathExpression } from '../metric';\nimport { IMetric, MetricConfig, MetricExpressionConfig, MetricStatConfig } from '../metric-types';\n\nconst METRICKEY_SYMBOL = Symbol('@aws-cdk/aws-cloudwatch.MetricKey');\n\n/**\n * Return a unique string representation for this metric.\n *\n * Can be used to determine as a hash key to determine if 2 Metric objects\n * represent the same metric. Excludes rendering properties.\n */\nexport function metricKey(metric: IMetric): string {\n  // Cache on the object itself. This is safe because Metric objects are immutable.\n  if (metric.hasOwnProperty(METRICKEY_SYMBOL)) {\n    return (metric as any)[METRICKEY_SYMBOL];\n  }\n\n  const parts = new Array<string>();\n\n  const conf = metric.toMetricConfig();\n  if (conf.mathExpression) {\n    parts.push(conf.mathExpression.expression);\n    for (const id of Object.keys(conf.mathExpression.usingMetrics).sort()) {\n      parts.push(id);\n      parts.push(metricKey(conf.mathExpression.usingMetrics[id]));\n    }\n    if (conf.mathExpression.searchRegion) {\n      parts.push(conf.mathExpression.searchRegion);\n    }\n    if (conf.mathExpression.searchAccount) {\n      parts.push(conf.mathExpression.searchAccount);\n    }\n  }\n  if (conf.metricStat) {\n    parts.push(conf.metricStat.namespace);\n    parts.push(conf.metricStat.metricName);\n    for (const dim of conf.metricStat.dimensions || []) {\n      parts.push(dim.name);\n      parts.push(dim.value);\n    }\n    if (conf.metricStat.statistic) {\n      parts.push(conf.metricStat.statistic);\n    }\n    if (conf.metricStat.period) {\n      parts.push(`${conf.metricStat.period.toSeconds()}`);\n    }\n    if (conf.metricStat.region) {\n      parts.push(conf.metricStat.region);\n    }\n    if (conf.metricStat.account) {\n      parts.push(conf.metricStat.account);\n    }\n  }\n\n  const ret = parts.join('|');\n  Object.defineProperty(metric, METRICKEY_SYMBOL, { value: ret });\n  return ret;\n}\n\n/**\n * Return the period of a metric\n *\n * For a stat metric, return the immediate period.\n *\n * For an expression metric, all metrics used in it have been made to have the\n * same period, so we return the period of the first inner metric.\n */\nexport function metricPeriod(metric: IMetric): Duration {\n  return dispatchMetric(metric, {\n    withStat(stat) {\n      return stat.period;\n    },\n    withExpression() {\n      return (metric as MathExpression).period || Duration.minutes(5);\n    },\n  });\n}\n\n/**\n * Given a metric object, inspect it and call the correct function for the type of output\n *\n * In addition to the metric object itself, takes a callback object with two\n * methods, to be invoked for the particular type of metric.\n *\n * If the metric represent a metric query (nominally generated through an\n * instantiation of `Metric` but can be generated by any class that implements\n * `IMetric`) a particular field in its `toMetricConfig()` output will be set\n * (to wit, `metricStat`) and the `withStat()` callback will be called with\n * that object.\n *\n * If the metric represents an expression (usually by instantiating `MathExpression`\n * but users can implement `IMetric` arbitrarily) the `mathExpression` field\n * will be set in the object returned from `toMetricConfig` and the callback\n * called `withExpression` will be applied to that object.\n *\n * Will return the values returned by the callbacks.\n *\n * To be used as such:\n *\n * ```ts\n * const ret = dispatchMetric(someMetric, {\n *   withStat(stat) {\n *     // do something with stat\n *     return 1;\n *   },\n *   withExpression(expr) {\n *     // do something with expr\n *     return 2;\n *   },\n * });\n * ```\n *\n * This function encapsulates some type analysis that would otherwise have to be\n * repeated in all places where code needs to make a distinction on the type\n * of metric object that is being passed.\n */\n// eslint-disable-next-line max-len\nexport function dispatchMetric<A, B>(metric: IMetric, fns: { withStat: (x: MetricStatConfig, c: MetricConfig) => A, withExpression: (x: MetricExpressionConfig, c: MetricConfig) => B }): A | B {\n  const conf = metric.toMetricConfig();\n  if (conf.metricStat && conf.mathExpression) {\n    throw new Error('Metric object must not produce both \\'metricStat\\' and \\'mathExpression\\'');\n  } else if (conf.metricStat) {\n    return fns.withStat(conf.metricStat, conf);\n  } else if (conf.mathExpression) {\n    return fns.withExpression(conf.mathExpression, conf);\n  } else {\n    throw new Error('Metric object must have either \\'metricStat\\' or \\'mathExpression\\'');\n  }\n}"]} |
\ | No newline at end of file |