@adalo/metrics 0.1.113 → 0.1.115

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.
@@ -0,0 +1,171 @@
1
+ /**
2
+ * BaseMetricsClient provides common functionality for all metrics clients.
3
+ * Handles registry setup, pushgateway, default labels, and common operations.
4
+ */
5
+ export class BaseMetricsClient {
6
+ /**
7
+ * @param {Object} config
8
+ * @param {string} [config.appName] Name of the application
9
+ * @param {string} [config.dynoId] Dyno/instance ID
10
+ * @param {string} [config.processType] Process type (web, worker, etc.)
11
+ * @param {boolean} [config.enabled] Enable metrics collection
12
+ * @param {boolean} [config.logValues] Log metrics values to console
13
+ * @param {string} [config.pushgatewayUrl] PushGateway URL
14
+ * @param {string} [config.pushgatewaySecret] PushGateway secret token
15
+ * @param {number} [config.intervalSec] Interval in seconds for pushing metrics
16
+ * @param {boolean} [config.removeOldMetrics] Enable to clear metrics by service name
17
+ * @param {function} [config.startupValidation] Add to validate on start push.
18
+ */
19
+ constructor(config?: {
20
+ appName?: string | undefined;
21
+ dynoId?: string | undefined;
22
+ processType?: string | undefined;
23
+ enabled?: boolean | undefined;
24
+ logValues?: boolean | undefined;
25
+ pushgatewayUrl?: string | undefined;
26
+ pushgatewaySecret?: string | undefined;
27
+ intervalSec?: number | undefined;
28
+ removeOldMetrics?: boolean | undefined;
29
+ startupValidation?: Function | undefined;
30
+ });
31
+ appName: string;
32
+ dynoId: string;
33
+ processType: string;
34
+ enabled: boolean;
35
+ logValues: boolean;
36
+ pushgatewayUrl: string;
37
+ authToken: string;
38
+ intervalSec: number;
39
+ startupValidation: Function | undefined;
40
+ prefixLogs: string;
41
+ _registry: client.Registry<"text/plain; version=0.0.4; charset=utf-8">;
42
+ defaultLabels: {
43
+ app: string;
44
+ dyno_id: string;
45
+ process_type: string;
46
+ };
47
+ gateway: client.Pushgateway<"text/plain; version=0.0.4; charset=utf-8">;
48
+ gauges: {};
49
+ counters: {};
50
+ countersFunctions: {};
51
+ /** @type {Object<string, function(): number | Promise<number>>} */
52
+ gaugeUpdaters: {
53
+ [x: string]: () => number | Promise<number>;
54
+ };
55
+ /**
56
+ * Create a gauge metric.
57
+ * @param {Object} options - Gauge configuration
58
+ * @param {string} options.name - Name of the gauge
59
+ * @param {string} options.help - Help text describing the gauge
60
+ * @param {function(): number|Promise<number>} [options.updateFn] - Optional function returning the gauge value
61
+ * @param {string[]} [options.labelNames] - Optional custom label names
62
+ * @returns {import('prom-client').Gauge} The created Prometheus gauge
63
+ */
64
+ createGauge: ({ name, help, updateFn, labelNames, }: {
65
+ name: string;
66
+ help: string;
67
+ updateFn?: (() => number | Promise<number>) | undefined;
68
+ labelNames?: string[] | undefined;
69
+ }) => import('prom-client').Gauge;
70
+ /**
71
+ * Create a Prometheus Counter metric.
72
+ *
73
+ * @param {Object} params - Counter configuration
74
+ * @param {string} params.name - Metric name
75
+ * @param {string} params.help - Metric description
76
+ * @param {string[]} [params.labelNames] - Optional list of label names. Defaults to this.defaultLabels keys.
77
+ *
78
+ * @returns {(labels?: Object, incrementValue?: number) => void}
79
+ * A function to increment the counter.
80
+ * Usage: (labels?, incrementValue?)
81
+ */
82
+ createCounter({ name, help, labelNames }: {
83
+ name: string;
84
+ help: string;
85
+ labelNames?: string[] | undefined;
86
+ }): (labels?: Object, incrementValue?: number) => void;
87
+ /**
88
+ * Clear all collected counters
89
+ */
90
+ clearAllCounters: () => void;
91
+ /**
92
+ * Push all gauges and counters to PushGateway and optionally log.
93
+ */
94
+ pushMetrics: () => Promise<void>;
95
+ _startPush: (interval?: number, customPushMetics?: undefined) => void;
96
+ /**
97
+ * Start periodic metrics collection and push.
98
+ *
99
+ * This method wraps the internal `_startPush` method.
100
+ * If a `customPushMetrics` function is provided, it will be executed
101
+ * at the given interval instead of the default `pushMetrics` behavior.
102
+ *
103
+ * @param {number} [interval=this.intervalSec] - Interval in seconds between pushes.
104
+ * @param {() => void | Promise<void>} [customPushMetrics] - Optional custom push function. If provided, Prometheus push is skipped.
105
+ */
106
+ startPush: (interval?: number | undefined, customPushMetics?: undefined) => void;
107
+ /**
108
+ * Cleanup metrics and exit process.
109
+ * @returns {Promise<void>}
110
+ */
111
+ cleanup: () => Promise<void>;
112
+ /**
113
+ * Remove old/stale dyno/instance metrics from PushGateway.
114
+ *
115
+ * Compares existing PushGateway metrics for this job and deletes any instances
116
+ * that do not match the current dynoId.
117
+ *
118
+ * @param {boolean} removeOldMetrics If true, performs cleanup; otherwise does nothing
119
+ * @returns {Promise<void>}
120
+ * @private
121
+ */
122
+ private _clearOldWorkers;
123
+ /**
124
+ * Delete metrics for this job/instance from PushGateway.
125
+ *
126
+ * @param {Object} [params]
127
+ * @param {string} [params.jobName] Job name (defaults to appName)
128
+ * @param {Object} [params.groupings] Grouping labels
129
+ * @param {string} [params.groupings.process_type] Process type label
130
+ * @param {string} [params.groupings.instance] Instance/dyno ID
131
+ * @returns {Promise<void>}
132
+ */
133
+ gatewayDelete: (params?: {
134
+ jobName?: string | undefined;
135
+ groupings?: {
136
+ process_type?: string | undefined;
137
+ instance?: string | undefined;
138
+ } | undefined;
139
+ } | undefined) => Promise<void>;
140
+ /**
141
+ * Push metrics to PushGateway.
142
+ *
143
+ * @param {object} [params]
144
+ * @param {string} [params.jobName]
145
+ * @param {object} [params.groupings]
146
+ * @returns {Promise<void>}
147
+ */
148
+ gatewayPush: (params?: {
149
+ jobName?: string | undefined;
150
+ groupings?: object | undefined;
151
+ } | undefined) => Promise<void>;
152
+ /**
153
+ * Merge the default metric labels (`app`, `dyno_id`, `process_type`)
154
+ * with custom label names.
155
+ *
156
+ * @param {string[]} labels Additional label names
157
+ * @returns {string[]} Combined label names
158
+ */
159
+ withDefaultLabels: (labels?: string[]) => string[];
160
+ getDefaultLabels: (labels?: any[]) => {
161
+ app: string;
162
+ dyno_id: string;
163
+ process_type: string;
164
+ };
165
+ _setCleanupHandlers: () => void;
166
+ get metricsEnabled(): boolean;
167
+ get metricsLogValues(): boolean;
168
+ get registry(): client.Registry<"text/plain; version=0.0.4; charset=utf-8">;
169
+ }
170
+ import client = require("prom-client");
171
+ //# sourceMappingURL=baseMetricsClient.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseMetricsClient.d.ts","sourceRoot":"","sources":["../src/baseMetricsClient.js"],"names":[],"mappings":"AAGA;;;GAGG;AACH;IACE;;;;;;;;;;;;OAYG;IACH;QAX2B,OAAO;QACP,MAAM;QACN,WAAW;QACV,OAAO;QACP,SAAS;QACV,cAAc;QACd,iBAAiB;QACjB,WAAW;QACV,gBAAgB;QACf,iBAAiB;OAkD7C;IA/CC,gBAA4E;IAC5E,eAAqE;IACrE,oBAG6B;IAC7B,iBAAuE;IACvE,mBAC+D;IAC/D,uBACoE;IACpE,kBAC0E;IAC1E,oBAGI;IACJ,wCAAiD;IAEjD,mBAAyF;IAEzF,uEAAsC;IAGtC;;;;MAIC;IAED,wEAOC;IACD,WAAgB;IAChB,aAAkB;IAClB,sBAA2B;IAE3B,mEAAmE;IACnE;YADkB,MAAM,SAAc,MAAM,GAAG,QAAQ,MAAM,CAAC;MACvC;IAMzB;;;;;;;;OAQG;IACH;QAN2B,IAAI,EAApB,MAAM;QACU,IAAI,EAApB,MAAM;QACuC,QAAQ,UAAzC,MAAM,GAAC,QAAQ,MAAM,CAAC;QACf,UAAU;UAC3B,OAAO,aAAa,EAAE,KAAK,CAuBvC;IAED;;;;;;;;;;;OAWG;IACH;QAR0B,IAAI,EAAnB,MAAM;QACS,IAAI,EAAnB,MAAM;QACY,UAAU;kBAEhB,MAAM,mBAAmB,MAAM,KAAK,IAAI,CAuB9D;IAED;;OAEG;IACH,6BAKC;IAED;;OAEG;IACH,iCA+BC;IAED,sEAuBC;IAED;;;;;;;;;OASG;IACH,iFAEC;IAED;;;OAGG;IACH,eAFa,QAAQ,IAAI,CAAC,CAOzB;IAED;;;;;;;;;OASG;IACH,yBA0FC;IAED;;;;;;;;;OASG;IACH;;;;;;sBAFa,QAAQ,IAAI,CAAC,CAUzB;IAED;;;;;;;OAOG;IACH;;;sBAFa,QAAQ,IAAI,CAAC,CAYzB;IAED;;;;;;OAMG;IACH,6BAHW,MAAM,EAAE,KACN,MAAM,EAAE,CAIpB;IAED;;;;MAEC;IAED,gCAGC;IAID,8BAEC;IAED,gCAEC;IAED,4EAEC;CACF"}
@@ -0,0 +1,353 @@
1
+ "use strict";
2
+
3
+ const client = require('prom-client');
4
+ const https = require('https');
5
+
6
+ /**
7
+ * BaseMetricsClient provides common functionality for all metrics clients.
8
+ * Handles registry setup, pushgateway, default labels, and common operations.
9
+ */
10
+ class BaseMetricsClient {
11
+ /**
12
+ * @param {Object} config
13
+ * @param {string} [config.appName] Name of the application
14
+ * @param {string} [config.dynoId] Dyno/instance ID
15
+ * @param {string} [config.processType] Process type (web, worker, etc.)
16
+ * @param {boolean} [config.enabled] Enable metrics collection
17
+ * @param {boolean} [config.logValues] Log metrics values to console
18
+ * @param {string} [config.pushgatewayUrl] PushGateway URL
19
+ * @param {string} [config.pushgatewaySecret] PushGateway secret token
20
+ * @param {number} [config.intervalSec] Interval in seconds for pushing metrics
21
+ * @param {boolean} [config.removeOldMetrics] Enable to clear metrics by service name
22
+ * @param {function} [config.startupValidation] Add to validate on start push.
23
+ */
24
+ constructor(config = {}) {
25
+ this.appName = config.appName || process.env.BUILD_APP_NAME || 'unknown-app';
26
+ this.dynoId = config.dynoId || process.env.HOSTNAME || 'unknown-dyno';
27
+ this.processType = config.processType || process.env.BUILD_DYNO_PROCESS_TYPE || 'undefined_build_dyno_type';
28
+ this.enabled = config.enabled ?? process.env.METRICS_ENABLED === 'true';
29
+ this.logValues = config.logValues ?? process.env.METRICS_LOG_VALUES === 'true';
30
+ this.pushgatewayUrl = config.pushgatewayUrl || process.env.METRICS_PUSHGATEWAY_URL || '';
31
+ this.authToken = config.pushgatewaySecret || process.env.METRICS_PUSHGATEWAY_SECRET || '';
32
+ this.intervalSec = config.intervalSec || parseInt(process.env.METRICS_INTERVAL_SEC || '', 10) || 15;
33
+ this.startupValidation = config.startupValidation;
34
+ this.prefixLogs = `[${this.processType}] [${this.appName}] [${this.dynoId}] [Monitoring]`;
35
+ this._registry = new client.Registry();
36
+ client.collectDefaultMetrics({
37
+ register: this._registry
38
+ });
39
+ this.defaultLabels = {
40
+ app: this.appName,
41
+ dyno_id: this.dynoId,
42
+ process_type: this.processType
43
+ };
44
+ this.gateway = new client.Pushgateway(this.pushgatewayUrl, {
45
+ headers: {
46
+ Authorization: `Basic ${this.authToken}`
47
+ },
48
+ agent: new https.Agent({
49
+ keepAlive: true
50
+ })
51
+ }, this._registry);
52
+ this.gauges = {};
53
+ this.counters = {};
54
+ this.countersFunctions = {};
55
+
56
+ /** @type {Object<string, function(): number | Promise<number>>} */
57
+ this.gaugeUpdaters = {};
58
+ this._clearOldWorkers(config.removeOldMetrics);
59
+ this._setCleanupHandlers();
60
+ }
61
+
62
+ /**
63
+ * Create a gauge metric.
64
+ * @param {Object} options - Gauge configuration
65
+ * @param {string} options.name - Name of the gauge
66
+ * @param {string} options.help - Help text describing the gauge
67
+ * @param {function(): number|Promise<number>} [options.updateFn] - Optional function returning the gauge value
68
+ * @param {string[]} [options.labelNames] - Optional custom label names
69
+ * @returns {import('prom-client').Gauge} The created Prometheus gauge
70
+ */
71
+ createGauge = ({
72
+ name,
73
+ help,
74
+ updateFn,
75
+ labelNames = Object.keys(this.defaultLabels)
76
+ }) => {
77
+ if (this.gauges[name]) return this.gauges[name];
78
+ const g = new client.Gauge({
79
+ name,
80
+ help,
81
+ labelNames,
82
+ registers: [this._registry]
83
+ });
84
+ this.gauges[name] = g;
85
+ if (updateFn && typeof updateFn === 'function') {
86
+ this.gaugeUpdaters[name] = updateFn;
87
+ }
88
+ return g;
89
+ };
90
+
91
+ /**
92
+ * Create a Prometheus Counter metric.
93
+ *
94
+ * @param {Object} params - Counter configuration
95
+ * @param {string} params.name - Metric name
96
+ * @param {string} params.help - Metric description
97
+ * @param {string[]} [params.labelNames] - Optional list of label names. Defaults to this.defaultLabels keys.
98
+ *
99
+ * @returns {(labels?: Object, incrementValue?: number) => void}
100
+ * A function to increment the counter.
101
+ * Usage: (labels?, incrementValue?)
102
+ */
103
+ createCounter({
104
+ name,
105
+ help,
106
+ labelNames = Object.keys(this.defaultLabels)
107
+ }) {
108
+ if (this.counters[name]) return this.countersFunctions[name];
109
+ const c = new client.Counter({
110
+ name,
111
+ help,
112
+ labelNames,
113
+ registers: [this._registry]
114
+ });
115
+ this.counters[name] = c;
116
+ this.countersFunctions = {
117
+ ...this.countersFunctions,
118
+ [name]: (data = {}, value = 1) => {
119
+ c.inc({
120
+ ...this.defaultLabels,
121
+ ...data
122
+ }, value);
123
+ }
124
+ };
125
+ return this.countersFunctions[name];
126
+ }
127
+
128
+ /**
129
+ * Clear all collected counters
130
+ */
131
+ clearAllCounters = () => {
132
+ if (this.metricsLogValues) {
133
+ console.log('Counters to clear: ', Object.keys(this.counters));
134
+ }
135
+ Object.values(this.counters).forEach(counter => counter.reset());
136
+ };
137
+
138
+ /**
139
+ * Push all gauges and counters to PushGateway and optionally log.
140
+ */
141
+ pushMetrics = async () => {
142
+ try {
143
+ for (const [name, updateFn] of Object.entries(this.gaugeUpdaters)) {
144
+ try {
145
+ if (!updateFn) {
146
+ return;
147
+ }
148
+ const result = updateFn();
149
+ const val = result instanceof Promise ? await result : result;
150
+ if (val !== undefined) this.gauges[name].set(this.defaultLabels, val);
151
+ } catch (err) {
152
+ console.error(`${this.prefixLogs} Failed to update gauge ${name}:`, err);
153
+ }
154
+ }
155
+ await this.gatewayPush();
156
+ this.clearAllCounters();
157
+ if (this.logValues) {
158
+ const metrics = await this._registry.getMetricsAsJSON();
159
+ console.log(`${this.prefixLogs} Metrics:\n`, JSON.stringify(metrics, null, 2));
160
+ }
161
+ } catch (err) {
162
+ console.error(`${this.prefixLogs} Failed to push metrics:`, err);
163
+ }
164
+ };
165
+ _startPush = (interval = this.intervalSec, customPushMetics = undefined) => {
166
+ if (!this.enabled) {
167
+ console.warn(`${this.prefixLogs} Metrics disabled`);
168
+ return;
169
+ }
170
+ if (this.startupValidation && !this.startupValidation()) {
171
+ return;
172
+ }
173
+ if (customPushMetics && typeof customPushMetics === 'function') {
174
+ setInterval(() => customPushMetics(), interval * 1000);
175
+ } else {
176
+ setInterval(() => {
177
+ this.pushMetrics().catch(err => {
178
+ console.error(`${this.prefixLogs} Failed to push metrics:`, err);
179
+ });
180
+ }, interval * 1000);
181
+ }
182
+ console.warn(`${this.prefixLogs} Metrics collection started. (interval: ${this.intervalSec}s)`);
183
+ };
184
+
185
+ /**
186
+ * Start periodic metrics collection and push.
187
+ *
188
+ * This method wraps the internal `_startPush` method.
189
+ * If a `customPushMetrics` function is provided, it will be executed
190
+ * at the given interval instead of the default `pushMetrics` behavior.
191
+ *
192
+ * @param {number} [interval=this.intervalSec] - Interval in seconds between pushes.
193
+ * @param {() => void | Promise<void>} [customPushMetrics] - Optional custom push function. If provided, Prometheus push is skipped.
194
+ */
195
+ startPush = (interval, customPushMetics = undefined) => {
196
+ this._startPush(interval, customPushMetics);
197
+ };
198
+
199
+ /**
200
+ * Cleanup metrics and exit process.
201
+ * @returns {Promise<void>}
202
+ */
203
+ cleanup = async () => {
204
+ if (this.enabled) {
205
+ await this.gatewayDelete();
206
+ }
207
+ process.exit(0);
208
+ };
209
+
210
+ /**
211
+ * Remove old/stale dyno/instance metrics from PushGateway.
212
+ *
213
+ * Compares existing PushGateway metrics for this job and deletes any instances
214
+ * that do not match the current dynoId.
215
+ *
216
+ * @param {boolean} removeOldMetrics If true, performs cleanup; otherwise does nothing
217
+ * @returns {Promise<void>}
218
+ * @private
219
+ */
220
+ _clearOldWorkers = async removeOldMetrics => {
221
+ if (!removeOldMetrics) return;
222
+ try {
223
+ const url = `${this.pushgatewayUrl}/metrics`;
224
+ const res = await fetch(url, {
225
+ headers: {
226
+ Authorization: `Basic ${this.authToken}`,
227
+ Accept: 'text/plain'
228
+ }
229
+ });
230
+ if (!res.ok) {
231
+ console.error(`${this.prefixLogs} Failed to fetch metrics: ${res.status}`);
232
+ return;
233
+ }
234
+ const text = await res.text();
235
+ const metricRegex = /([a-zA-Z_:][a-zA-Z0-9_:]*)\{([^}]*)\}/gm;
236
+ const labelRegex = /(\w+)="([^"]*)"/g;
237
+ const uniqueLabelSets = new Set();
238
+ let match;
239
+ // eslint-disable-next-line no-cond-assign
240
+ while ((match = metricRegex.exec(text)) !== null) {
241
+ const rawLabels = match[2];
242
+ let lr;
243
+ const labels = {};
244
+
245
+ // eslint-disable-next-line no-cond-assign
246
+ while ((lr = labelRegex.exec(rawLabels)) !== null) {
247
+ // eslint-disable-next-line prefer-destructuring
248
+ labels[lr[1]] = lr[2];
249
+ }
250
+ if (labels.job === this.appName && labels.process_type === this.processType) {
251
+ uniqueLabelSets.add(JSON.stringify(labels));
252
+ }
253
+ }
254
+ if (uniqueLabelSets.size === 0) {
255
+ console.log(`${this.prefixLogs} No metrics found for job ${this.appName}`);
256
+ return;
257
+ }
258
+ const oldLabelSets = [...uniqueLabelSets].map(s => JSON.parse(s)).filter(labels => labels.instance && labels.instance !== this.dynoId && labels.process_type === this.processType);
259
+ if (oldLabelSets.length === 0) {
260
+ console.log(`${this.prefixLogs} No old dynos to delete.`);
261
+ return;
262
+ }
263
+ for (const labels of oldLabelSets) {
264
+ try {
265
+ await this.gatewayDelete({
266
+ jobName: this.appName,
267
+ groupings: labels
268
+ });
269
+ console.log(`${this.prefixLogs} Deleted metrics for dyno: ${labels.instance}, labels: ${Object.keys(labels)} `);
270
+ } catch (err) {
271
+ console.error(`${this.prefixLogs} Failed to delete metrics for ${labels.instance}:`, err);
272
+ }
273
+ }
274
+ console.log(`${this.prefixLogs} Cleared all old instances for job ${this.appName}`);
275
+ } catch (err) {
276
+ console.error(`${this.prefixLogs} Error deleting old metrics:`, err);
277
+ }
278
+ };
279
+
280
+ /**
281
+ * Delete metrics for this job/instance from PushGateway.
282
+ *
283
+ * @param {Object} [params]
284
+ * @param {string} [params.jobName] Job name (defaults to appName)
285
+ * @param {Object} [params.groupings] Grouping labels
286
+ * @param {string} [params.groupings.process_type] Process type label
287
+ * @param {string} [params.groupings.instance] Instance/dyno ID
288
+ * @returns {Promise<void>}
289
+ */
290
+ gatewayDelete = async (params = {}) => {
291
+ return this.gateway.delete({
292
+ jobName: params.jobName || this.appName,
293
+ groupings: params.groupings || {
294
+ process_type: this.processType,
295
+ instance: this.dynoId
296
+ }
297
+ });
298
+ };
299
+
300
+ /**
301
+ * Push metrics to PushGateway.
302
+ *
303
+ * @param {object} [params]
304
+ * @param {string} [params.jobName]
305
+ * @param {object} [params.groupings]
306
+ * @returns {Promise<void>}
307
+ */
308
+ gatewayPush = async (params = {}) => {
309
+ const groupings = {
310
+ process_type: this.processType,
311
+ instance: this.dynoId,
312
+ ...(params.groupings || {})
313
+ };
314
+ return this.gateway.push({
315
+ jobName: params.jobName || this.appName,
316
+ groupings
317
+ });
318
+ };
319
+
320
+ /**
321
+ * Merge the default metric labels (`app`, `dyno_id`, `process_type`)
322
+ * with custom label names.
323
+ *
324
+ * @param {string[]} labels Additional label names
325
+ * @returns {string[]} Combined label names
326
+ */
327
+ withDefaultLabels = (labels = []) => {
328
+ return [...Object.keys(this.defaultLabels), ...labels];
329
+ };
330
+ getDefaultLabels = (labels = []) => {
331
+ return this.defaultLabels;
332
+ };
333
+ _setCleanupHandlers = () => {
334
+ process.on('SIGINT', this.cleanup);
335
+ process.on('SIGTERM', this.cleanup);
336
+ };
337
+
338
+ // GETTERS
339
+
340
+ get metricsEnabled() {
341
+ return this.enabled;
342
+ }
343
+ get metricsLogValues() {
344
+ return this.logValues;
345
+ }
346
+ get registry() {
347
+ return this._registry;
348
+ }
349
+ }
350
+ module.exports = {
351
+ BaseMetricsClient
352
+ };
353
+ //# sourceMappingURL=baseMetricsClient.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"baseMetricsClient.js","names":["client","require","https","BaseMetricsClient","constructor","config","appName","process","env","BUILD_APP_NAME","dynoId","HOSTNAME","processType","BUILD_DYNO_PROCESS_TYPE","enabled","METRICS_ENABLED","logValues","METRICS_LOG_VALUES","pushgatewayUrl","METRICS_PUSHGATEWAY_URL","authToken","pushgatewaySecret","METRICS_PUSHGATEWAY_SECRET","intervalSec","parseInt","METRICS_INTERVAL_SEC","startupValidation","prefixLogs","_registry","Registry","collectDefaultMetrics","register","defaultLabels","app","dyno_id","process_type","gateway","Pushgateway","headers","Authorization","agent","Agent","keepAlive","gauges","counters","countersFunctions","gaugeUpdaters","_clearOldWorkers","removeOldMetrics","_setCleanupHandlers","createGauge","name","help","updateFn","labelNames","Object","keys","g","Gauge","registers","createCounter","c","Counter","data","value","inc","clearAllCounters","metricsLogValues","console","log","values","forEach","counter","reset","pushMetrics","entries","result","val","Promise","undefined","set","err","error","gatewayPush","metrics","getMetricsAsJSON","JSON","stringify","_startPush","interval","customPushMetics","warn","setInterval","catch","startPush","cleanup","gatewayDelete","exit","url","res","fetch","Accept","ok","status","text","metricRegex","labelRegex","uniqueLabelSets","Set","match","exec","rawLabels","lr","labels","job","add","size","oldLabelSets","map","s","parse","filter","instance","length","jobName","groupings","params","delete","push","withDefaultLabels","getDefaultLabels","on","metricsEnabled","registry","module","exports"],"sources":["../src/baseMetricsClient.js"],"sourcesContent":["const client = require('prom-client')\nconst https = require('https')\n\n/**\n * BaseMetricsClient provides common functionality for all metrics clients.\n * Handles registry setup, pushgateway, default labels, and common operations.\n */\nclass BaseMetricsClient {\n /**\n * @param {Object} config\n * @param {string} [config.appName] Name of the application\n * @param {string} [config.dynoId] Dyno/instance ID\n * @param {string} [config.processType] Process type (web, worker, etc.)\n * @param {boolean} [config.enabled] Enable metrics collection\n * @param {boolean} [config.logValues] Log metrics values to console\n * @param {string} [config.pushgatewayUrl] PushGateway URL\n * @param {string} [config.pushgatewaySecret] PushGateway secret token\n * @param {number} [config.intervalSec] Interval in seconds for pushing metrics\n * @param {boolean} [config.removeOldMetrics] Enable to clear metrics by service name\n * @param {function} [config.startupValidation] Add to validate on start push.\n */\n constructor(config = {}) {\n this.appName = config.appName || process.env.BUILD_APP_NAME || 'unknown-app'\n this.dynoId = config.dynoId || process.env.HOSTNAME || 'unknown-dyno'\n this.processType =\n config.processType ||\n process.env.BUILD_DYNO_PROCESS_TYPE ||\n 'undefined_build_dyno_type'\n this.enabled = config.enabled ?? process.env.METRICS_ENABLED === 'true'\n this.logValues =\n config.logValues ?? process.env.METRICS_LOG_VALUES === 'true'\n this.pushgatewayUrl =\n config.pushgatewayUrl || process.env.METRICS_PUSHGATEWAY_URL || ''\n this.authToken =\n config.pushgatewaySecret || process.env.METRICS_PUSHGATEWAY_SECRET || ''\n this.intervalSec =\n config.intervalSec ||\n parseInt(process.env.METRICS_INTERVAL_SEC || '', 10) ||\n 15\n this.startupValidation = config.startupValidation\n\n this.prefixLogs = `[${this.processType}] [${this.appName}] [${this.dynoId}] [Monitoring]`\n\n this._registry = new client.Registry()\n client.collectDefaultMetrics({ register: this._registry })\n\n this.defaultLabels = {\n app: this.appName,\n dyno_id: this.dynoId,\n process_type: this.processType,\n }\n\n this.gateway = new client.Pushgateway(\n this.pushgatewayUrl,\n {\n headers: { Authorization: `Basic ${this.authToken}` },\n agent: new https.Agent({ keepAlive: true }),\n },\n this._registry\n )\n this.gauges = {}\n this.counters = {}\n this.countersFunctions = {}\n\n /** @type {Object<string, function(): number | Promise<number>>} */\n this.gaugeUpdaters = {}\n\n this._clearOldWorkers(config.removeOldMetrics)\n this._setCleanupHandlers()\n }\n\n /**\n * Create a gauge metric.\n * @param {Object} options - Gauge configuration\n * @param {string} options.name - Name of the gauge\n * @param {string} options.help - Help text describing the gauge\n * @param {function(): number|Promise<number>} [options.updateFn] - Optional function returning the gauge value\n * @param {string[]} [options.labelNames] - Optional custom label names\n * @returns {import('prom-client').Gauge} The created Prometheus gauge\n */\n createGauge = ({\n name,\n help,\n updateFn,\n labelNames = Object.keys(this.defaultLabels),\n }) => {\n if (this.gauges[name]) return this.gauges[name]\n\n const g = new client.Gauge({\n name,\n help,\n labelNames,\n registers: [this._registry],\n })\n this.gauges[name] = g\n\n if (updateFn && typeof updateFn === 'function') {\n this.gaugeUpdaters[name] = updateFn\n }\n\n return g\n }\n\n /**\n * Create a Prometheus Counter metric.\n *\n * @param {Object} params - Counter configuration\n * @param {string} params.name - Metric name\n * @param {string} params.help - Metric description\n * @param {string[]} [params.labelNames] - Optional list of label names. Defaults to this.defaultLabels keys.\n *\n * @returns {(labels?: Object, incrementValue?: number) => void}\n * A function to increment the counter.\n * Usage: (labels?, incrementValue?)\n */\n createCounter({ name, help, labelNames = Object.keys(this.defaultLabels) }) {\n if (this.counters[name]) return this.countersFunctions[name]\n\n const c = new client.Counter({\n name,\n help,\n labelNames,\n registers: [this._registry],\n })\n this.counters[name] = c\n\n this.countersFunctions = {\n ...this.countersFunctions,\n [name]: (data = {}, value = 1) => {\n c.inc({ ...this.defaultLabels, ...data }, value)\n },\n }\n\n return this.countersFunctions[name]\n }\n\n /**\n * Clear all collected counters\n */\n clearAllCounters = () => {\n if (this.metricsLogValues) {\n console.log('Counters to clear: ', Object.keys(this.counters))\n }\n Object.values(this.counters).forEach(counter => counter.reset())\n }\n\n /**\n * Push all gauges and counters to PushGateway and optionally log.\n */\n pushMetrics = async () => {\n try {\n for (const [name, updateFn] of Object.entries(this.gaugeUpdaters)) {\n try {\n if (!updateFn) {\n return\n }\n const result = updateFn()\n const val = result instanceof Promise ? await result : result\n if (val !== undefined) this.gauges[name].set(this.defaultLabels, val)\n } catch (err) {\n console.error(\n `${this.prefixLogs} Failed to update gauge ${name}:`,\n err\n )\n }\n }\n\n await this.gatewayPush()\n this.clearAllCounters()\n\n if (this.logValues) {\n const metrics = await this._registry.getMetricsAsJSON()\n console.log(\n `${this.prefixLogs} Metrics:\\n`,\n JSON.stringify(metrics, null, 2)\n )\n }\n } catch (err) {\n console.error(`${this.prefixLogs} Failed to push metrics:`, err)\n }\n }\n\n _startPush = (interval = this.intervalSec, customPushMetics = undefined) => {\n if (!this.enabled) {\n console.warn(`${this.prefixLogs} Metrics disabled`)\n return\n }\n\n if (this.startupValidation && !this.startupValidation()) {\n return\n }\n\n if (customPushMetics && typeof customPushMetics === 'function') {\n setInterval(() => customPushMetics(), interval * 1000)\n } else {\n setInterval(() => {\n this.pushMetrics().catch(err => {\n console.error(`${this.prefixLogs} Failed to push metrics:`, err)\n })\n }, interval * 1000)\n }\n\n console.warn(\n `${this.prefixLogs} Metrics collection started. (interval: ${this.intervalSec}s)`\n )\n }\n\n /**\n * Start periodic metrics collection and push.\n *\n * This method wraps the internal `_startPush` method.\n * If a `customPushMetrics` function is provided, it will be executed\n * at the given interval instead of the default `pushMetrics` behavior.\n *\n * @param {number} [interval=this.intervalSec] - Interval in seconds between pushes.\n * @param {() => void | Promise<void>} [customPushMetrics] - Optional custom push function. If provided, Prometheus push is skipped.\n */\n startPush = (interval, customPushMetics = undefined) => {\n this._startPush(interval, customPushMetics)\n }\n\n /**\n * Cleanup metrics and exit process.\n * @returns {Promise<void>}\n */\n cleanup = async () => {\n if (this.enabled) {\n await this.gatewayDelete()\n }\n process.exit(0)\n }\n\n /**\n * Remove old/stale dyno/instance metrics from PushGateway.\n *\n * Compares existing PushGateway metrics for this job and deletes any instances\n * that do not match the current dynoId.\n *\n * @param {boolean} removeOldMetrics If true, performs cleanup; otherwise does nothing\n * @returns {Promise<void>}\n * @private\n */\n _clearOldWorkers = async removeOldMetrics => {\n if (!removeOldMetrics) return\n\n try {\n const url = `${this.pushgatewayUrl}/metrics`\n const res = await fetch(url, {\n headers: {\n Authorization: `Basic ${this.authToken}`,\n Accept: 'text/plain',\n },\n })\n\n if (!res.ok) {\n console.error(\n `${this.prefixLogs} Failed to fetch metrics: ${res.status}`\n )\n return\n }\n\n const text = await res.text()\n\n const metricRegex = /([a-zA-Z_:][a-zA-Z0-9_:]*)\\{([^}]*)\\}/gm\n const labelRegex = /(\\w+)=\"([^\"]*)\"/g\n\n const uniqueLabelSets = new Set()\n\n let match\n // eslint-disable-next-line no-cond-assign\n while ((match = metricRegex.exec(text)) !== null) {\n const rawLabels = match[2]\n let lr\n const labels = {}\n\n // eslint-disable-next-line no-cond-assign\n while ((lr = labelRegex.exec(rawLabels)) !== null) {\n // eslint-disable-next-line prefer-destructuring\n labels[lr[1]] = lr[2]\n }\n\n if (\n labels.job === this.appName &&\n labels.process_type === this.processType\n ) {\n uniqueLabelSets.add(JSON.stringify(labels))\n }\n }\n\n if (uniqueLabelSets.size === 0) {\n console.log(\n `${this.prefixLogs} No metrics found for job ${this.appName}`\n )\n return\n }\n\n const oldLabelSets = [...uniqueLabelSets]\n .map(s => JSON.parse(s))\n .filter(\n labels =>\n labels.instance &&\n labels.instance !== this.dynoId &&\n labels.process_type === this.processType\n )\n\n if (oldLabelSets.length === 0) {\n console.log(`${this.prefixLogs} No old dynos to delete.`)\n return\n }\n\n for (const labels of oldLabelSets) {\n try {\n await this.gatewayDelete({ jobName: this.appName, groupings: labels })\n console.log(\n `${this.prefixLogs} Deleted metrics for dyno: ${\n labels.instance\n }, labels: ${Object.keys(labels)} `\n )\n } catch (err) {\n console.error(\n `${this.prefixLogs} Failed to delete metrics for ${labels.instance}:`,\n err\n )\n }\n }\n\n console.log(\n `${this.prefixLogs} Cleared all old instances for job ${this.appName}`\n )\n } catch (err) {\n console.error(`${this.prefixLogs} Error deleting old metrics:`, err)\n }\n }\n\n /**\n * Delete metrics for this job/instance from PushGateway.\n *\n * @param {Object} [params]\n * @param {string} [params.jobName] Job name (defaults to appName)\n * @param {Object} [params.groupings] Grouping labels\n * @param {string} [params.groupings.process_type] Process type label\n * @param {string} [params.groupings.instance] Instance/dyno ID\n * @returns {Promise<void>}\n */\n gatewayDelete = async (params = {}) => {\n return this.gateway.delete({\n jobName: params.jobName || this.appName,\n groupings: params.groupings || {\n process_type: this.processType,\n instance: this.dynoId,\n },\n })\n }\n\n /**\n * Push metrics to PushGateway.\n *\n * @param {object} [params]\n * @param {string} [params.jobName]\n * @param {object} [params.groupings]\n * @returns {Promise<void>}\n */\n gatewayPush = async (params = {}) => {\n const groupings = {\n process_type: this.processType,\n instance: this.dynoId,\n ...(params.groupings || {}),\n }\n return this.gateway.push({\n jobName: params.jobName || this.appName,\n groupings,\n })\n }\n\n /**\n * Merge the default metric labels (`app`, `dyno_id`, `process_type`)\n * with custom label names.\n *\n * @param {string[]} labels Additional label names\n * @returns {string[]} Combined label names\n */\n withDefaultLabels = (labels = []) => {\n return [...Object.keys(this.defaultLabels), ...labels]\n }\n\n getDefaultLabels = (labels = []) => {\n return this.defaultLabels\n }\n\n _setCleanupHandlers = () => {\n process.on('SIGINT', this.cleanup)\n process.on('SIGTERM', this.cleanup)\n }\n\n // GETTERS\n\n get metricsEnabled() {\n return this.enabled\n }\n\n get metricsLogValues() {\n return this.logValues\n }\n\n get registry() {\n return this._registry\n }\n}\n\nmodule.exports = { BaseMetricsClient }\n\n"],"mappings":";;AAAA,MAAMA,MAAM,GAAGC,OAAO,CAAC,aAAa,CAAC;AACrC,MAAMC,KAAK,GAAGD,OAAO,CAAC,OAAO,CAAC;;AAE9B;AACA;AACA;AACA;AACA,MAAME,iBAAiB,CAAC;EACtB;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAWA,CAACC,MAAM,GAAG,CAAC,CAAC,EAAE;IACvB,IAAI,CAACC,OAAO,GAAGD,MAAM,CAACC,OAAO,IAAIC,OAAO,CAACC,GAAG,CAACC,cAAc,IAAI,aAAa;IAC5E,IAAI,CAACC,MAAM,GAAGL,MAAM,CAACK,MAAM,IAAIH,OAAO,CAACC,GAAG,CAACG,QAAQ,IAAI,cAAc;IACrE,IAAI,CAACC,WAAW,GACdP,MAAM,CAACO,WAAW,IAClBL,OAAO,CAACC,GAAG,CAACK,uBAAuB,IACnC,2BAA2B;IAC7B,IAAI,CAACC,OAAO,GAAGT,MAAM,CAACS,OAAO,IAAIP,OAAO,CAACC,GAAG,CAACO,eAAe,KAAK,MAAM;IACvE,IAAI,CAACC,SAAS,GACZX,MAAM,CAACW,SAAS,IAAIT,OAAO,CAACC,GAAG,CAACS,kBAAkB,KAAK,MAAM;IAC/D,IAAI,CAACC,cAAc,GACjBb,MAAM,CAACa,cAAc,IAAIX,OAAO,CAACC,GAAG,CAACW,uBAAuB,IAAI,EAAE;IACpE,IAAI,CAACC,SAAS,GACZf,MAAM,CAACgB,iBAAiB,IAAId,OAAO,CAACC,GAAG,CAACc,0BAA0B,IAAI,EAAE;IAC1E,IAAI,CAACC,WAAW,GACdlB,MAAM,CAACkB,WAAW,IAClBC,QAAQ,CAACjB,OAAO,CAACC,GAAG,CAACiB,oBAAoB,IAAI,EAAE,EAAE,EAAE,CAAC,IACpD,EAAE;IACJ,IAAI,CAACC,iBAAiB,GAAGrB,MAAM,CAACqB,iBAAiB;IAEjD,IAAI,CAACC,UAAU,GAAG,IAAI,IAAI,CAACf,WAAW,MAAM,IAAI,CAACN,OAAO,MAAM,IAAI,CAACI,MAAM,gBAAgB;IAEzF,IAAI,CAACkB,SAAS,GAAG,IAAI5B,MAAM,CAAC6B,QAAQ,CAAC,CAAC;IACtC7B,MAAM,CAAC8B,qBAAqB,CAAC;MAAEC,QAAQ,EAAE,IAAI,CAACH;IAAU,CAAC,CAAC;IAE1D,IAAI,CAACI,aAAa,GAAG;MACnBC,GAAG,EAAE,IAAI,CAAC3B,OAAO;MACjB4B,OAAO,EAAE,IAAI,CAACxB,MAAM;MACpByB,YAAY,EAAE,IAAI,CAACvB;IACrB,CAAC;IAED,IAAI,CAACwB,OAAO,GAAG,IAAIpC,MAAM,CAACqC,WAAW,CACnC,IAAI,CAACnB,cAAc,EACnB;MACEoB,OAAO,EAAE;QAAEC,aAAa,EAAE,SAAS,IAAI,CAACnB,SAAS;MAAG,CAAC;MACrDoB,KAAK,EAAE,IAAItC,KAAK,CAACuC,KAAK,CAAC;QAAEC,SAAS,EAAE;MAAK,CAAC;IAC5C,CAAC,EACD,IAAI,CAACd,SACP,CAAC;IACD,IAAI,CAACe,MAAM,GAAG,CAAC,CAAC;IAChB,IAAI,CAACC,QAAQ,GAAG,CAAC,CAAC;IAClB,IAAI,CAACC,iBAAiB,GAAG,CAAC,CAAC;;IAE3B;IACA,IAAI,CAACC,aAAa,GAAG,CAAC,CAAC;IAEvB,IAAI,CAACC,gBAAgB,CAAC1C,MAAM,CAAC2C,gBAAgB,CAAC;IAC9C,IAAI,CAACC,mBAAmB,CAAC,CAAC;EAC5B;;EAEA;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEC,WAAW,GAAGA,CAAC;IACbC,IAAI;IACJC,IAAI;IACJC,QAAQ;IACRC,UAAU,GAAGC,MAAM,CAACC,IAAI,CAAC,IAAI,CAACxB,aAAa;EAC7C,CAAC,KAAK;IACJ,IAAI,IAAI,CAACW,MAAM,CAACQ,IAAI,CAAC,EAAE,OAAO,IAAI,CAACR,MAAM,CAACQ,IAAI,CAAC;IAE/C,MAAMM,CAAC,GAAG,IAAIzD,MAAM,CAAC0D,KAAK,CAAC;MACzBP,IAAI;MACJC,IAAI;MACJE,UAAU;MACVK,SAAS,EAAE,CAAC,IAAI,CAAC/B,SAAS;IAC5B,CAAC,CAAC;IACF,IAAI,CAACe,MAAM,CAACQ,IAAI,CAAC,GAAGM,CAAC;IAErB,IAAIJ,QAAQ,IAAI,OAAOA,QAAQ,KAAK,UAAU,EAAE;MAC9C,IAAI,CAACP,aAAa,CAACK,IAAI,CAAC,GAAGE,QAAQ;IACrC;IAEA,OAAOI,CAAC;EACV,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEG,aAAaA,CAAC;IAAET,IAAI;IAAEC,IAAI;IAAEE,UAAU,GAAGC,MAAM,CAACC,IAAI,CAAC,IAAI,CAACxB,aAAa;EAAE,CAAC,EAAE;IAC1E,IAAI,IAAI,CAACY,QAAQ,CAACO,IAAI,CAAC,EAAE,OAAO,IAAI,CAACN,iBAAiB,CAACM,IAAI,CAAC;IAE5D,MAAMU,CAAC,GAAG,IAAI7D,MAAM,CAAC8D,OAAO,CAAC;MAC3BX,IAAI;MACJC,IAAI;MACJE,UAAU;MACVK,SAAS,EAAE,CAAC,IAAI,CAAC/B,SAAS;IAC5B,CAAC,CAAC;IACF,IAAI,CAACgB,QAAQ,CAACO,IAAI,CAAC,GAAGU,CAAC;IAEvB,IAAI,CAAChB,iBAAiB,GAAG;MACvB,GAAG,IAAI,CAACA,iBAAiB;MACzB,CAACM,IAAI,GAAG,CAACY,IAAI,GAAG,CAAC,CAAC,EAAEC,KAAK,GAAG,CAAC,KAAK;QAChCH,CAAC,CAACI,GAAG,CAAC;UAAE,GAAG,IAAI,CAACjC,aAAa;UAAE,GAAG+B;QAAK,CAAC,EAAEC,KAAK,CAAC;MAClD;IACF,CAAC;IAED,OAAO,IAAI,CAACnB,iBAAiB,CAACM,IAAI,CAAC;EACrC;;EAEA;AACF;AACA;EACEe,gBAAgB,GAAGA,CAAA,KAAM;IACvB,IAAI,IAAI,CAACC,gBAAgB,EAAE;MACzBC,OAAO,CAACC,GAAG,CAAC,qBAAqB,EAAEd,MAAM,CAACC,IAAI,CAAC,IAAI,CAACZ,QAAQ,CAAC,CAAC;IAChE;IACAW,MAAM,CAACe,MAAM,CAAC,IAAI,CAAC1B,QAAQ,CAAC,CAAC2B,OAAO,CAACC,OAAO,IAAIA,OAAO,CAACC,KAAK,CAAC,CAAC,CAAC;EAClE,CAAC;;EAED;AACF;AACA;EACEC,WAAW,GAAG,MAAAA,CAAA,KAAY;IACxB,IAAI;MACF,KAAK,MAAM,CAACvB,IAAI,EAAEE,QAAQ,CAAC,IAAIE,MAAM,CAACoB,OAAO,CAAC,IAAI,CAAC7B,aAAa,CAAC,EAAE;QACjE,IAAI;UACF,IAAI,CAACO,QAAQ,EAAE;YACb;UACF;UACA,MAAMuB,MAAM,GAAGvB,QAAQ,CAAC,CAAC;UACzB,MAAMwB,GAAG,GAAGD,MAAM,YAAYE,OAAO,GAAG,MAAMF,MAAM,GAAGA,MAAM;UAC7D,IAAIC,GAAG,KAAKE,SAAS,EAAE,IAAI,CAACpC,MAAM,CAACQ,IAAI,CAAC,CAAC6B,GAAG,CAAC,IAAI,CAAChD,aAAa,EAAE6C,GAAG,CAAC;QACvE,CAAC,CAAC,OAAOI,GAAG,EAAE;UACZb,OAAO,CAACc,KAAK,CACX,GAAG,IAAI,CAACvD,UAAU,2BAA2BwB,IAAI,GAAG,EACpD8B,GACF,CAAC;QACH;MACF;MAEA,MAAM,IAAI,CAACE,WAAW,CAAC,CAAC;MACxB,IAAI,CAACjB,gBAAgB,CAAC,CAAC;MAEvB,IAAI,IAAI,CAAClD,SAAS,EAAE;QAClB,MAAMoE,OAAO,GAAG,MAAM,IAAI,CAACxD,SAAS,CAACyD,gBAAgB,CAAC,CAAC;QACvDjB,OAAO,CAACC,GAAG,CACT,GAAG,IAAI,CAAC1C,UAAU,aAAa,EAC/B2D,IAAI,CAACC,SAAS,CAACH,OAAO,EAAE,IAAI,EAAE,CAAC,CACjC,CAAC;MACH;IACF,CAAC,CAAC,OAAOH,GAAG,EAAE;MACZb,OAAO,CAACc,KAAK,CAAC,GAAG,IAAI,CAACvD,UAAU,0BAA0B,EAAEsD,GAAG,CAAC;IAClE;EACF,CAAC;EAEDO,UAAU,GAAGA,CAACC,QAAQ,GAAG,IAAI,CAAClE,WAAW,EAAEmE,gBAAgB,GAAGX,SAAS,KAAK;IAC1E,IAAI,CAAC,IAAI,CAACjE,OAAO,EAAE;MACjBsD,OAAO,CAACuB,IAAI,CAAC,GAAG,IAAI,CAAChE,UAAU,mBAAmB,CAAC;MACnD;IACF;IAEA,IAAI,IAAI,CAACD,iBAAiB,IAAI,CAAC,IAAI,CAACA,iBAAiB,CAAC,CAAC,EAAE;MACvD;IACF;IAEA,IAAIgE,gBAAgB,IAAI,OAAOA,gBAAgB,KAAK,UAAU,EAAE;MAC9DE,WAAW,CAAC,MAAMF,gBAAgB,CAAC,CAAC,EAAED,QAAQ,GAAG,IAAI,CAAC;IACxD,CAAC,MAAM;MACLG,WAAW,CAAC,MAAM;QAChB,IAAI,CAAClB,WAAW,CAAC,CAAC,CAACmB,KAAK,CAACZ,GAAG,IAAI;UAC9Bb,OAAO,CAACc,KAAK,CAAC,GAAG,IAAI,CAACvD,UAAU,0BAA0B,EAAEsD,GAAG,CAAC;QAClE,CAAC,CAAC;MACJ,CAAC,EAAEQ,QAAQ,GAAG,IAAI,CAAC;IACrB;IAEArB,OAAO,CAACuB,IAAI,CACV,GAAG,IAAI,CAAChE,UAAU,2CAA2C,IAAI,CAACJ,WAAW,IAC/E,CAAC;EACH,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEuE,SAAS,GAAGA,CAACL,QAAQ,EAAEC,gBAAgB,GAAGX,SAAS,KAAK;IACtD,IAAI,CAACS,UAAU,CAACC,QAAQ,EAAEC,gBAAgB,CAAC;EAC7C,CAAC;;EAED;AACF;AACA;AACA;EACEK,OAAO,GAAG,MAAAA,CAAA,KAAY;IACpB,IAAI,IAAI,CAACjF,OAAO,EAAE;MAChB,MAAM,IAAI,CAACkF,aAAa,CAAC,CAAC;IAC5B;IACAzF,OAAO,CAAC0F,IAAI,CAAC,CAAC,CAAC;EACjB,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACElD,gBAAgB,GAAG,MAAMC,gBAAgB,IAAI;IAC3C,IAAI,CAACA,gBAAgB,EAAE;IAEvB,IAAI;MACF,MAAMkD,GAAG,GAAG,GAAG,IAAI,CAAChF,cAAc,UAAU;MAC5C,MAAMiF,GAAG,GAAG,MAAMC,KAAK,CAACF,GAAG,EAAE;QAC3B5D,OAAO,EAAE;UACPC,aAAa,EAAE,SAAS,IAAI,CAACnB,SAAS,EAAE;UACxCiF,MAAM,EAAE;QACV;MACF,CAAC,CAAC;MAEF,IAAI,CAACF,GAAG,CAACG,EAAE,EAAE;QACXlC,OAAO,CAACc,KAAK,CACX,GAAG,IAAI,CAACvD,UAAU,6BAA6BwE,GAAG,CAACI,MAAM,EAC3D,CAAC;QACD;MACF;MAEA,MAAMC,IAAI,GAAG,MAAML,GAAG,CAACK,IAAI,CAAC,CAAC;MAE7B,MAAMC,WAAW,GAAG,yCAAyC;MAC7D,MAAMC,UAAU,GAAG,kBAAkB;MAErC,MAAMC,eAAe,GAAG,IAAIC,GAAG,CAAC,CAAC;MAEjC,IAAIC,KAAK;MACT;MACA,OAAO,CAACA,KAAK,GAAGJ,WAAW,CAACK,IAAI,CAACN,IAAI,CAAC,MAAM,IAAI,EAAE;QAChD,MAAMO,SAAS,GAAGF,KAAK,CAAC,CAAC,CAAC;QAC1B,IAAIG,EAAE;QACN,MAAMC,MAAM,GAAG,CAAC,CAAC;;QAEjB;QACA,OAAO,CAACD,EAAE,GAAGN,UAAU,CAACI,IAAI,CAACC,SAAS,CAAC,MAAM,IAAI,EAAE;UACjD;UACAE,MAAM,CAACD,EAAE,CAAC,CAAC,CAAC,CAAC,GAAGA,EAAE,CAAC,CAAC,CAAC;QACvB;QAEA,IACEC,MAAM,CAACC,GAAG,KAAK,IAAI,CAAC5G,OAAO,IAC3B2G,MAAM,CAAC9E,YAAY,KAAK,IAAI,CAACvB,WAAW,EACxC;UACA+F,eAAe,CAACQ,GAAG,CAAC7B,IAAI,CAACC,SAAS,CAAC0B,MAAM,CAAC,CAAC;QAC7C;MACF;MAEA,IAAIN,eAAe,CAACS,IAAI,KAAK,CAAC,EAAE;QAC9BhD,OAAO,CAACC,GAAG,CACT,GAAG,IAAI,CAAC1C,UAAU,6BAA6B,IAAI,CAACrB,OAAO,EAC7D,CAAC;QACD;MACF;MAEA,MAAM+G,YAAY,GAAG,CAAC,GAAGV,eAAe,CAAC,CACtCW,GAAG,CAACC,CAAC,IAAIjC,IAAI,CAACkC,KAAK,CAACD,CAAC,CAAC,CAAC,CACvBE,MAAM,CACLR,MAAM,IACJA,MAAM,CAACS,QAAQ,IACfT,MAAM,CAACS,QAAQ,KAAK,IAAI,CAAChH,MAAM,IAC/BuG,MAAM,CAAC9E,YAAY,KAAK,IAAI,CAACvB,WACjC,CAAC;MAEH,IAAIyG,YAAY,CAACM,MAAM,KAAK,CAAC,EAAE;QAC7BvD,OAAO,CAACC,GAAG,CAAC,GAAG,IAAI,CAAC1C,UAAU,0BAA0B,CAAC;QACzD;MACF;MAEA,KAAK,MAAMsF,MAAM,IAAII,YAAY,EAAE;QACjC,IAAI;UACF,MAAM,IAAI,CAACrB,aAAa,CAAC;YAAE4B,OAAO,EAAE,IAAI,CAACtH,OAAO;YAAEuH,SAAS,EAAEZ;UAAO,CAAC,CAAC;UACtE7C,OAAO,CAACC,GAAG,CACT,GAAG,IAAI,CAAC1C,UAAU,8BAChBsF,MAAM,CAACS,QAAQ,aACJnE,MAAM,CAACC,IAAI,CAACyD,MAAM,CAAC,GAClC,CAAC;QACH,CAAC,CAAC,OAAOhC,GAAG,EAAE;UACZb,OAAO,CAACc,KAAK,CACX,GAAG,IAAI,CAACvD,UAAU,iCAAiCsF,MAAM,CAACS,QAAQ,GAAG,EACrEzC,GACF,CAAC;QACH;MACF;MAEAb,OAAO,CAACC,GAAG,CACT,GAAG,IAAI,CAAC1C,UAAU,sCAAsC,IAAI,CAACrB,OAAO,EACtE,CAAC;IACH,CAAC,CAAC,OAAO2E,GAAG,EAAE;MACZb,OAAO,CAACc,KAAK,CAAC,GAAG,IAAI,CAACvD,UAAU,8BAA8B,EAAEsD,GAAG,CAAC;IACtE;EACF,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;EACEe,aAAa,GAAG,MAAAA,CAAO8B,MAAM,GAAG,CAAC,CAAC,KAAK;IACrC,OAAO,IAAI,CAAC1F,OAAO,CAAC2F,MAAM,CAAC;MACzBH,OAAO,EAAEE,MAAM,CAACF,OAAO,IAAI,IAAI,CAACtH,OAAO;MACvCuH,SAAS,EAAEC,MAAM,CAACD,SAAS,IAAI;QAC7B1F,YAAY,EAAE,IAAI,CAACvB,WAAW;QAC9B8G,QAAQ,EAAE,IAAI,CAAChH;MACjB;IACF,CAAC,CAAC;EACJ,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;EACEyE,WAAW,GAAG,MAAAA,CAAO2C,MAAM,GAAG,CAAC,CAAC,KAAK;IACnC,MAAMD,SAAS,GAAG;MAChB1F,YAAY,EAAE,IAAI,CAACvB,WAAW;MAC9B8G,QAAQ,EAAE,IAAI,CAAChH,MAAM;MACrB,IAAIoH,MAAM,CAACD,SAAS,IAAI,CAAC,CAAC;IAC5B,CAAC;IACD,OAAO,IAAI,CAACzF,OAAO,CAAC4F,IAAI,CAAC;MACvBJ,OAAO,EAAEE,MAAM,CAACF,OAAO,IAAI,IAAI,CAACtH,OAAO;MACvCuH;IACF,CAAC,CAAC;EACJ,CAAC;;EAED;AACF;AACA;AACA;AACA;AACA;AACA;EACEI,iBAAiB,GAAGA,CAAChB,MAAM,GAAG,EAAE,KAAK;IACnC,OAAO,CAAC,GAAG1D,MAAM,CAACC,IAAI,CAAC,IAAI,CAACxB,aAAa,CAAC,EAAE,GAAGiF,MAAM,CAAC;EACxD,CAAC;EAEDiB,gBAAgB,GAAGA,CAACjB,MAAM,GAAG,EAAE,KAAK;IAClC,OAAO,IAAI,CAACjF,aAAa;EAC3B,CAAC;EAEDiB,mBAAmB,GAAGA,CAAA,KAAM;IAC1B1C,OAAO,CAAC4H,EAAE,CAAC,QAAQ,EAAE,IAAI,CAACpC,OAAO,CAAC;IAClCxF,OAAO,CAAC4H,EAAE,CAAC,SAAS,EAAE,IAAI,CAACpC,OAAO,CAAC;EACrC,CAAC;;EAED;;EAEA,IAAIqC,cAAcA,CAAA,EAAG;IACnB,OAAO,IAAI,CAACtH,OAAO;EACrB;EAEA,IAAIqD,gBAAgBA,CAAA,EAAG;IACrB,OAAO,IAAI,CAACnD,SAAS;EACvB;EAEA,IAAIqH,QAAQA,CAAA,EAAG;IACb,OAAO,IAAI,CAACzG,SAAS;EACvB;AACF;AAEA0G,MAAM,CAACC,OAAO,GAAG;EAAEpI;AAAkB,CAAC","ignoreList":[]}
package/lib/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ export * from './baseMetricsClient';
1
2
  export * from './metricsClient';
2
3
  export * from './metricsRedisClient';
3
4
  export * from './metricsQueueRedisClient';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,sBAAsB,CAAA;AACpC,cAAc,2BAA2B,CAAA;AACzC,cAAc,yBAAyB,CAAA;AACvC,cAAc,cAAc,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAA;AACnC,cAAc,iBAAiB,CAAA;AAC/B,cAAc,sBAAsB,CAAA;AACpC,cAAc,2BAA2B,CAAA;AACzC,cAAc,yBAAyB,CAAA;AACvC,cAAc,cAAc,CAAA"}
package/lib/index.js CHANGED
@@ -3,6 +3,17 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
+ var _baseMetricsClient = require("./baseMetricsClient");
7
+ Object.keys(_baseMetricsClient).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _baseMetricsClient[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _baseMetricsClient[key];
14
+ }
15
+ });
16
+ });
6
17
  var _metricsClient = require("./metricsClient");
7
18
  Object.keys(_metricsClient).forEach(function (key) {
8
19
  if (key === "default" || key === "__esModule") return;
package/lib/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_metricsClient","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_metricsRedisClient","_metricsQueueRedisClient","_metricsDatabaseClient","_redisUtils"],"sources":["../src/index.ts"],"sourcesContent":["export * from './metricsClient'\nexport * from './metricsRedisClient'\nexport * from './metricsQueueRedisClient'\nexport * from './metricsDatabaseClient'\nexport * from './redisUtils'\n"],"mappings":";;;;;AAAA,IAAAA,cAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,cAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,cAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,cAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,mBAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,mBAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,mBAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,mBAAA,CAAAL,GAAA;IAAA;EAAA;AAAA;AACA,IAAAM,wBAAA,GAAAV,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAQ,wBAAA,EAAAP,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAM,wBAAA,CAAAN,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAE,wBAAA,CAAAN,GAAA;IAAA;EAAA;AAAA;AACA,IAAAO,sBAAA,GAAAX,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAS,sBAAA,EAAAR,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAO,sBAAA,CAAAP,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAG,sBAAA,CAAAP,GAAA;IAAA;EAAA;AAAA;AACA,IAAAQ,WAAA,GAAAZ,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAU,WAAA,EAAAT,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAQ,WAAA,CAAAR,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAI,WAAA,CAAAR,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}
1
+ {"version":3,"file":"index.js","names":["_baseMetricsClient","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get","_metricsClient","_metricsRedisClient","_metricsQueueRedisClient","_metricsDatabaseClient","_redisUtils"],"sources":["../src/index.ts"],"sourcesContent":["export * from './baseMetricsClient'\nexport * from './metricsClient'\nexport * from './metricsRedisClient'\nexport * from './metricsQueueRedisClient'\nexport * from './metricsDatabaseClient'\nexport * from './redisUtils'\n"],"mappings":";;;;;AAAA,IAAAA,kBAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,kBAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,kBAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,kBAAA,CAAAK,GAAA;IAAA;EAAA;AAAA;AACA,IAAAK,cAAA,GAAAT,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAO,cAAA,EAAAN,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAK,cAAA,CAAAL,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAC,cAAA,CAAAL,GAAA;IAAA;EAAA;AAAA;AACA,IAAAM,mBAAA,GAAAV,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAQ,mBAAA,EAAAP,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAM,mBAAA,CAAAN,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAE,mBAAA,CAAAN,GAAA;IAAA;EAAA;AAAA;AACA,IAAAO,wBAAA,GAAAX,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAS,wBAAA,EAAAR,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAO,wBAAA,CAAAP,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAG,wBAAA,CAAAP,GAAA;IAAA;EAAA;AAAA;AACA,IAAAQ,sBAAA,GAAAZ,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAU,sBAAA,EAAAT,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAQ,sBAAA,CAAAR,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAI,sBAAA,CAAAR,GAAA;IAAA;EAAA;AAAA;AACA,IAAAS,WAAA,GAAAb,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAW,WAAA,EAAAV,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAS,WAAA,CAAAT,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAK,WAAA,CAAAT,GAAA;IAAA;EAAA;AAAA","ignoreList":[]}