@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.
@@ -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,6 @@
1
+ import { PrometheusNodePlugin } from './Plugin';
2
+ export * from './Witness';
3
+ export { PrometheusNodePlugin };
4
+ // eslint-disable-next-line import/no-default-export
5
+ export default PrometheusNodePlugin;
6
+ //# sourceMappingURL=index.js.map
@@ -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,5 @@
1
+ import { PrometheusNodePlugin } from './Plugin';
2
+ export * from './Witness';
3
+ export { PrometheusNodePlugin };
4
+ export default PrometheusNodePlugin;
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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
+ }
package/src/index.ts ADDED
@@ -0,0 +1,8 @@
1
+ import { PrometheusNodePlugin } from './Plugin'
2
+
3
+ export * from './Witness'
4
+
5
+ export { PrometheusNodePlugin }
6
+
7
+ // eslint-disable-next-line import/no-default-export
8
+ export default PrometheusNodePlugin