@xyo-network/prometheus-node-plugin 2.53.4
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.
- package/LICENSE +165 -0
- package/README.md +13 -0
- package/dist/cjs/Plugin.js +16 -0
- package/dist/cjs/Plugin.js.map +1 -0
- package/dist/cjs/Witness.js +61 -0
- package/dist/cjs/Witness.js.map +1 -0
- package/dist/cjs/index.js +10 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/docs.json +8388 -0
- package/dist/esm/Plugin.js +11 -0
- package/dist/esm/Plugin.js.map +1 -0
- package/dist/esm/Witness.js +41 -0
- package/dist/esm/Witness.js.map +1 -0
- package/dist/esm/index.js +6 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/types/Plugin.d.ts +13 -0
- package/dist/types/Plugin.d.ts.map +1 -0
- package/dist/types/Witness.d.ts +24 -0
- package/dist/types/Witness.d.ts.map +1 -0
- package/dist/types/index.d.ts +5 -0
- package/dist/types/index.d.ts.map +1 -0
- package/package.json +60 -0
- package/src/Plugin.ts +29 -0
- package/src/Witness.ts +61 -0
- package/src/index.ts +8 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { PayloadSetSchema } from '@xyo-network/payload-model';
|
|
2
|
+
import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin';
|
|
3
|
+
import { PrometheusNodeWitness } from './Witness';
|
|
4
|
+
export const PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
|
|
5
|
+
export const PrometheusNodePlugin = () => createPayloadSetWitnessPlugin({ required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema }, {
|
|
6
|
+
witness: async (params) => {
|
|
7
|
+
const result = await PrometheusNodeWitness.create(params);
|
|
8
|
+
return result;
|
|
9
|
+
},
|
|
10
|
+
});
|
|
11
|
+
//# sourceMappingURL=Plugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Plugin.js","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AACtE,OAAO,EAAE,6BAA6B,EAAE,MAAM,gCAAgC,CAAA;AAG9E,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAGjD,MAAM,CAAC,MAAM,2BAA2B,GAAgC,qCAAqC,CAAA;AAY7G,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE,CACvC,6BAA6B,CAC3B,EAAE,QAAQ,EAAE,EAAE,CAAC,2BAA2B,CAAC,EAAE,CAAC,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAC5E;IACE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,EAAE;QACxB,MAAM,MAAM,GAAG,MAAM,qBAAqB,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QACzD,OAAO,MAAM,CAAA;IACf,CAAC;CACF,CACF,CAAA"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { AbstractWitness } from '@xyo-network/witness';
|
|
2
|
+
import { createServer } from 'http';
|
|
3
|
+
import compact from 'lodash/compact';
|
|
4
|
+
import { collectDefaultMetrics, Registry } from 'prom-client';
|
|
5
|
+
import { PrometheusMetricValueSchema } from './Plugin';
|
|
6
|
+
export const PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config';
|
|
7
|
+
export class PrometheusNodeWitness extends AbstractWitness {
|
|
8
|
+
static configSchema = PrometheusNodeWitnessConfigSchema;
|
|
9
|
+
_registry = new Registry();
|
|
10
|
+
server;
|
|
11
|
+
get registry() {
|
|
12
|
+
return this._registry;
|
|
13
|
+
}
|
|
14
|
+
async observe(_payloads) {
|
|
15
|
+
return await super.observe(await this.generateMetricValues());
|
|
16
|
+
}
|
|
17
|
+
async start(timeout) {
|
|
18
|
+
collectDefaultMetrics({ register: this._registry });
|
|
19
|
+
if (this.config.port) {
|
|
20
|
+
this.server = createServer(async (_request, response) => {
|
|
21
|
+
response.writeHead(200);
|
|
22
|
+
response.end(await this._registry.metrics());
|
|
23
|
+
});
|
|
24
|
+
this.server.listen(this.config.port);
|
|
25
|
+
}
|
|
26
|
+
return await super.start(timeout);
|
|
27
|
+
}
|
|
28
|
+
stop(_timeout) {
|
|
29
|
+
this.server?.close();
|
|
30
|
+
return this;
|
|
31
|
+
}
|
|
32
|
+
async generateMetricValues() {
|
|
33
|
+
return compact((await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
34
|
+
const values = metric.values;
|
|
35
|
+
if (values) {
|
|
36
|
+
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
|
|
37
|
+
}
|
|
38
|
+
}));
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=Witness.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.js","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAmC,MAAM,sBAAsB,CAAA;AACvF,OAAO,EAAE,YAAY,EAAU,MAAM,MAAM,CAAA;AAC3C,OAAO,OAAO,MAAM,gBAAgB,CAAA;AACpC,OAAO,EAAE,qBAAqB,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAA;AAE7D,OAAO,EAAgC,2BAA2B,EAAE,MAAM,UAAU,CAAA;AAGpF,MAAM,CAAC,MAAM,iCAAiC,GAAsC,4CAA4C,CAAA;AAShI,MAAM,OAAO,qBAAiG,SAAQ,eAAwB;IAC5I,MAAM,CAAU,YAAY,GAAG,iCAAiC,CAAA;IACtD,SAAS,GAAG,IAAI,QAAQ,EAAE,CAAA;IAC1B,MAAM,CAAS;IAEzB,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAA;IACvB,CAAC;IAEQ,KAAK,CAAC,OAAO,CAAC,SAA8B;QACnD,OAAO,MAAM,KAAK,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,oBAAoB,EAAE,CAAC,CAAA;IAC/D,CAAC;IAEQ,KAAK,CAAC,KAAK,CAAC,OAAgB;QACnC,qBAAqB,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAA;QACnD,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE;YACpB,IAAI,CAAC,MAAM,GAAG,YAAY,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE;gBACtD,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;gBAEvB,QAAQ,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAA;YAC9C,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;SACrC;QACD,OAAO,MAAM,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IACnC,CAAC;IAEQ,IAAI,CAAC,QAAiB;QAC7B,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,CAAA;QACpB,OAAO,IAAI,CAAA;IACb,CAAC;IAEO,KAAK,CAAC,oBAAoB;QAChC,OAAO,OAAO,CACZ,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACvD,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAA;YAC5B,IAAI,MAAM,EAAE;gBACV,OAAO,EAAE,UAAU,EAAE,MAAM,CAAC,UAAU,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,2BAA2B,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,CAAA;aAC5H;QACH,CAAC,CAAC,CACH,CAAA;IACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAA;AAE/C,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,oBAAoB,EAAE,CAAA;AAE/B,oDAAoD;AACpD,eAAe,oBAAoB,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
+
import { Aggregator, MetricType } from 'prom-client';
|
|
3
|
+
import { PrometheusNodeWitness } from './Witness';
|
|
4
|
+
export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
|
|
5
|
+
export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
|
|
6
|
+
export type PrometheusMetricValuePayload = Payload<{
|
|
7
|
+
aggregator: Aggregator;
|
|
8
|
+
name: string;
|
|
9
|
+
type: MetricType;
|
|
10
|
+
values: (number | string | object)[];
|
|
11
|
+
}, PrometheusMetricValueSchema>;
|
|
12
|
+
export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import("./Witness").PrometheusNodeWitnessParams>>;
|
|
13
|
+
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAoB,MAAM,4BAA4B,CAAA;AAEtE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAEpD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA;AAE7G,MAAM,MAAM,4BAA4B,GAAG,OAAO,CAChD;IACE,UAAU,EAAE,UAAU,CAAA;IACtB,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,UAAU,CAAA;IAChB,MAAM,EAAE,CAAC,MAAM,GAAG,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;CACrC,EACD,2BAA2B,CAC5B,CAAA;AAED,eAAO,MAAM,oBAAoB,gJAS9B,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { AnyConfigSchema } from '@xyo-network/module';
|
|
3
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
4
|
+
import { AbstractWitness, WitnessParams, XyoWitnessConfig } from '@xyo-network/witness';
|
|
5
|
+
import { Server } from 'http';
|
|
6
|
+
import { Registry } from 'prom-client';
|
|
7
|
+
export type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config';
|
|
8
|
+
export declare const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema;
|
|
9
|
+
export type PrometheusNodeWitnessConfig = XyoWitnessConfig<{
|
|
10
|
+
port?: number;
|
|
11
|
+
schema: PrometheusNodeWitnessConfigSchema;
|
|
12
|
+
}>;
|
|
13
|
+
export type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>;
|
|
14
|
+
export declare class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {
|
|
15
|
+
static configSchema: "network.xyo.prometheus.node.witness.config";
|
|
16
|
+
protected _registry: Registry;
|
|
17
|
+
protected server?: Server;
|
|
18
|
+
get registry(): Registry;
|
|
19
|
+
observe(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
|
|
20
|
+
start(timeout?: number): Promise<void>;
|
|
21
|
+
stop(_timeout?: number): this;
|
|
22
|
+
private generateMetricValues;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=Witness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AACvF,OAAO,EAAgB,MAAM,EAAE,MAAM,MAAM,CAAA;AAE3C,OAAO,EAAyB,QAAQ,EAAE,MAAM,aAAa,CAAA;AAI7D,MAAM,MAAM,iCAAiC,GAAG,4CAA4C,CAAA;AAC5F,eAAO,MAAM,iCAAiC,EAAE,iCAAgF,CAAA;AAEhI,MAAM,MAAM,2BAA2B,GAAG,gBAAgB,CAAC;IACzD,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,EAAE,iCAAiC,CAAA;CAC1C,CAAC,CAAA;AAEF,MAAM,MAAM,2BAA2B,GAAG,aAAa,CAAC,eAAe,CAAC,2BAA2B,CAAC,CAAC,CAAA;AAErG,qBAAa,qBAAqB,CAAC,OAAO,SAAS,2BAA2B,GAAG,2BAA2B,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC5I,OAAgB,YAAY,+CAAoC;IAChE,SAAS,CAAC,SAAS,WAAiB;IACpC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IAEzB,IAAI,QAAQ,IAAI,QAAQ,CAEvB;IAEc,OAAO,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAI3D,KAAK,CAAC,OAAO,CAAC,EAAE,MAAM;IAa5B,IAAI,CAAC,QAAQ,CAAC,EAAE,MAAM;YAKjB,oBAAoB;CAUnC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,UAAU,CAAA;AAE/C,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,oBAAoB,EAAE,CAAA;AAG/B,eAAe,oBAAoB,CAAA"}
|
package/package.json
ADDED
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@xyo-network/prometheus-node-plugin",
|
|
3
|
+
"author": {
|
|
4
|
+
"email": "support@xyo.network",
|
|
5
|
+
"name": "XYO Development Team",
|
|
6
|
+
"url": "https://xyo.network"
|
|
7
|
+
},
|
|
8
|
+
"bugs": {
|
|
9
|
+
"email": "support@xyo.network",
|
|
10
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
|
+
},
|
|
12
|
+
"dependencies": {
|
|
13
|
+
"@xyo-network/module": "^2.53.4",
|
|
14
|
+
"@xyo-network/payload-model": "^2.53.4",
|
|
15
|
+
"@xyo-network/payloadset-plugin": "^2.53.4",
|
|
16
|
+
"@xyo-network/witness": "^2.53.4",
|
|
17
|
+
"lodash": "^4.17.21",
|
|
18
|
+
"prom-client": "^14.2.0"
|
|
19
|
+
},
|
|
20
|
+
"devDependencies": {
|
|
21
|
+
"@types/lodash": "^4.14.191",
|
|
22
|
+
"@xylabs/ts-scripts-yarn3": "^2.16.1",
|
|
23
|
+
"@xylabs/tsconfig": "^2.16.1",
|
|
24
|
+
"typescript": "^4.9.5"
|
|
25
|
+
},
|
|
26
|
+
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
27
|
+
"browser": "dist/esm/index.js",
|
|
28
|
+
"docs": "dist/docs.json",
|
|
29
|
+
"exports": {
|
|
30
|
+
".": {
|
|
31
|
+
"node": {
|
|
32
|
+
"import": "./dist/esm/index.js",
|
|
33
|
+
"require": "./dist/cjs/index.js"
|
|
34
|
+
},
|
|
35
|
+
"browser": {
|
|
36
|
+
"import": "./dist/esm/index.js",
|
|
37
|
+
"require": "./dist/cjs/index.js"
|
|
38
|
+
},
|
|
39
|
+
"default": "./dist/esm/index.js"
|
|
40
|
+
},
|
|
41
|
+
"./dist/docs.json": {
|
|
42
|
+
"default": "./dist/docs.json"
|
|
43
|
+
},
|
|
44
|
+
"./package.json": "./package.json"
|
|
45
|
+
},
|
|
46
|
+
"main": "dist/cjs/index.js",
|
|
47
|
+
"module": "dist/esm/index.js",
|
|
48
|
+
"homepage": "https://xyo.network",
|
|
49
|
+
"license": "LGPL-3.0",
|
|
50
|
+
"publishConfig": {
|
|
51
|
+
"access": "public"
|
|
52
|
+
},
|
|
53
|
+
"repository": {
|
|
54
|
+
"type": "git",
|
|
55
|
+
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
56
|
+
},
|
|
57
|
+
"sideEffects": false,
|
|
58
|
+
"types": "dist/types/index.d.ts",
|
|
59
|
+
"version": "2.53.4"
|
|
60
|
+
}
|
package/src/Plugin.ts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Payload, PayloadSetSchema } from '@xyo-network/payload-model'
|
|
2
|
+
import { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'
|
|
3
|
+
import { Aggregator, MetricType } from 'prom-client'
|
|
4
|
+
|
|
5
|
+
import { PrometheusNodeWitness } from './Witness'
|
|
6
|
+
|
|
7
|
+
export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'
|
|
8
|
+
export const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'
|
|
9
|
+
|
|
10
|
+
export type PrometheusMetricValuePayload = Payload<
|
|
11
|
+
{
|
|
12
|
+
aggregator: Aggregator
|
|
13
|
+
name: string
|
|
14
|
+
type: MetricType
|
|
15
|
+
values: (number | string | object)[]
|
|
16
|
+
},
|
|
17
|
+
PrometheusMetricValueSchema
|
|
18
|
+
>
|
|
19
|
+
|
|
20
|
+
export const PrometheusNodePlugin = () =>
|
|
21
|
+
createPayloadSetWitnessPlugin<PrometheusNodeWitness>(
|
|
22
|
+
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },
|
|
23
|
+
{
|
|
24
|
+
witness: async (params) => {
|
|
25
|
+
const result = await PrometheusNodeWitness.create(params)
|
|
26
|
+
return result
|
|
27
|
+
},
|
|
28
|
+
},
|
|
29
|
+
)
|
package/src/Witness.ts
ADDED
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { AnyConfigSchema } from '@xyo-network/module'
|
|
2
|
+
import { Payload } from '@xyo-network/payload-model'
|
|
3
|
+
import { AbstractWitness, WitnessParams, XyoWitnessConfig } from '@xyo-network/witness'
|
|
4
|
+
import { createServer, Server } from 'http'
|
|
5
|
+
import compact from 'lodash/compact'
|
|
6
|
+
import { collectDefaultMetrics, Registry } from 'prom-client'
|
|
7
|
+
|
|
8
|
+
import { PrometheusMetricValuePayload, PrometheusMetricValueSchema } from './Plugin'
|
|
9
|
+
|
|
10
|
+
export type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'
|
|
11
|
+
export const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'
|
|
12
|
+
|
|
13
|
+
export type PrometheusNodeWitnessConfig = XyoWitnessConfig<{
|
|
14
|
+
port?: number
|
|
15
|
+
schema: PrometheusNodeWitnessConfigSchema
|
|
16
|
+
}>
|
|
17
|
+
|
|
18
|
+
export type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>
|
|
19
|
+
|
|
20
|
+
export class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {
|
|
21
|
+
static override configSchema = PrometheusNodeWitnessConfigSchema
|
|
22
|
+
protected _registry = new Registry()
|
|
23
|
+
protected server?: Server
|
|
24
|
+
|
|
25
|
+
get registry(): Registry {
|
|
26
|
+
return this._registry
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
override async observe(_payloads?: Partial<Payload>[]): Promise<Payload[]> {
|
|
30
|
+
return await super.observe(await this.generateMetricValues())
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
override async start(timeout?: number) {
|
|
34
|
+
collectDefaultMetrics({ register: this._registry })
|
|
35
|
+
if (this.config.port) {
|
|
36
|
+
this.server = createServer(async (_request, response) => {
|
|
37
|
+
response.writeHead(200)
|
|
38
|
+
|
|
39
|
+
response.end(await this._registry.metrics())
|
|
40
|
+
})
|
|
41
|
+
this.server.listen(this.config.port)
|
|
42
|
+
}
|
|
43
|
+
return await super.start(timeout)
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
override stop(_timeout?: number) {
|
|
47
|
+
this.server?.close()
|
|
48
|
+
return this
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {
|
|
52
|
+
return compact(
|
|
53
|
+
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
54
|
+
const values = metric.values
|
|
55
|
+
if (values) {
|
|
56
|
+
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }
|
|
57
|
+
}
|
|
58
|
+
}),
|
|
59
|
+
)
|
|
60
|
+
}
|
|
61
|
+
}
|