@xyo-network/prometheus-node-plugin 2.86.4 → 2.86.5
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/dist/node/index.cjs +101 -0
- package/dist/node/index.cjs.map +1 -0
- package/dist/node/index.js +19 -49
- package/dist/node/index.js.map +1 -1
- package/package.json +18 -18
- package/dist/node/index.mjs +0 -71
- package/dist/node/index.mjs.map +0 -1
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/index.ts
|
|
21
|
+
var src_exports = {};
|
|
22
|
+
__export(src_exports, {
|
|
23
|
+
PrometheusMetricValueSchema: () => PrometheusMetricValueSchema,
|
|
24
|
+
PrometheusNodePlugin: () => PrometheusNodePlugin,
|
|
25
|
+
PrometheusNodeWitness: () => PrometheusNodeWitness,
|
|
26
|
+
PrometheusNodeWitnessConfigSchema: () => PrometheusNodeWitnessConfigSchema,
|
|
27
|
+
default: () => PrometheusNodePlugin
|
|
28
|
+
});
|
|
29
|
+
module.exports = __toCommonJS(src_exports);
|
|
30
|
+
|
|
31
|
+
// src/Plugin.ts
|
|
32
|
+
var import_payload_model = require("@xyo-network/payload-model");
|
|
33
|
+
var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
|
|
34
|
+
|
|
35
|
+
// src/Schema.ts
|
|
36
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
37
|
+
|
|
38
|
+
// src/Witness.ts
|
|
39
|
+
var import_node_http = require("http");
|
|
40
|
+
var import_lodash = require("@xylabs/lodash");
|
|
41
|
+
var import_abstract_witness = require("@xyo-network/abstract-witness");
|
|
42
|
+
var import_module_model = require("@xyo-network/module-model");
|
|
43
|
+
var import_prom_client = require("prom-client");
|
|
44
|
+
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
45
|
+
(0, import_module_model.creatableModule)();
|
|
46
|
+
var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitness {
|
|
47
|
+
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
48
|
+
_registry = new import_prom_client.Registry();
|
|
49
|
+
server;
|
|
50
|
+
get registry() {
|
|
51
|
+
return this._registry;
|
|
52
|
+
}
|
|
53
|
+
async observeHandler(_payloads) {
|
|
54
|
+
return await this.generateMetricValues();
|
|
55
|
+
}
|
|
56
|
+
async startHandler() {
|
|
57
|
+
(0, import_prom_client.collectDefaultMetrics)({ register: this._registry });
|
|
58
|
+
if (this.config.port) {
|
|
59
|
+
this.server = (0, import_node_http.createServer)(async (_request, response) => {
|
|
60
|
+
response.writeHead(200);
|
|
61
|
+
response.end(await this._registry.metrics());
|
|
62
|
+
});
|
|
63
|
+
this.server.listen(this.config.port);
|
|
64
|
+
}
|
|
65
|
+
return await super.startHandler();
|
|
66
|
+
}
|
|
67
|
+
async stopHandler() {
|
|
68
|
+
var _a;
|
|
69
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
70
|
+
return await super.stopHandler();
|
|
71
|
+
}
|
|
72
|
+
async generateMetricValues() {
|
|
73
|
+
return (0, import_lodash.compact)(
|
|
74
|
+
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
75
|
+
const values = metric.values;
|
|
76
|
+
if (values) {
|
|
77
|
+
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
|
|
78
|
+
}
|
|
79
|
+
})
|
|
80
|
+
);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
// src/Plugin.ts
|
|
85
|
+
var PrometheusNodePlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
|
|
86
|
+
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
|
|
87
|
+
{
|
|
88
|
+
witness: async (params) => {
|
|
89
|
+
const result = await PrometheusNodeWitness.create(params);
|
|
90
|
+
return result;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
);
|
|
94
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
95
|
+
0 && (module.exports = {
|
|
96
|
+
PrometheusMetricValueSchema,
|
|
97
|
+
PrometheusNodePlugin,
|
|
98
|
+
PrometheusNodeWitness,
|
|
99
|
+
PrometheusNodeWitnessConfigSchema
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["export * from './Payload'\nexport { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin'\nexport * from './Schema'\nexport * from './Witness'\n","import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { PrometheusMetricValueSchema } from './Schema'\nimport { PrometheusNodeWitness } from './Witness'\n\nexport const PrometheusNodePlugin = () =>\n createPayloadSetWitnessPlugin<PrometheusNodeWitness>(\n { required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await PrometheusNodeWitness.create(params)\n return result\n },\n },\n )\n","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload'\nimport { PrometheusMetricValueSchema } from './Schema'\n\nexport type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\nexport const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\n\nexport type PrometheusNodeWitnessConfig = WitnessConfig<{\n port?: number\n schema: PrometheusNodeWitnessConfigSchema\n}>\n\nexport type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>\n\ncreatableModule()\nexport class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [PrometheusNodeWitnessConfigSchema]\n protected _registry = new Registry()\n protected server?: Server\n\n get registry(): Registry {\n return this._registry\n }\n\n protected override async observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]> {\n return await this.generateMetricValues()\n }\n\n protected override async startHandler() {\n collectDefaultMetrics({ register: this._registry })\n if (this.config.port) {\n this.server = createServer(async (_request, response) => {\n response.writeHead(200)\n\n response.end(await this._registry.metrics())\n })\n this.server.listen(this.config.port)\n }\n return await super.startHandler()\n }\n\n protected override async stopHandler(): Promise<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,2BAAiC;AACjC,+BAA8C;;;ACAvC,IAAM,8BAA2D;;;ACDxE,uBAAqC;AAErC,oBAAwB;AACxB,8BAAgC;AAChC,0BAAiD;AAGjD,yBAAgD;AAMzC,IAAM,oCAAuE;AAAA,IASpF,qCAAgB;AACT,IAAM,wBAAN,cAA+G,wCAAyB;AAAA,EAC7I,OAAgB,gBAAgB,CAAC,iCAAiC;AAAA,EACxD,YAAY,IAAI,4BAAS;AAAA,EACzB;AAAA,EAEV,IAAI,WAAqB;AACvB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAyB,eAAe,WAAoD;AAC1F,WAAO,MAAM,KAAK,qBAAqB;AAAA,EACzC;AAAA,EAEA,MAAyB,eAAe;AACtC,kDAAsB,EAAE,UAAU,KAAK,UAAU,CAAC;AAClD,QAAI,KAAK,OAAO,MAAM;AACpB,WAAK,aAAS,+BAAa,OAAO,UAAU,aAAa;AACvD,iBAAS,UAAU,GAAG;AAEtB,iBAAS,IAAI,MAAM,KAAK,UAAU,QAAQ,CAAC;AAAA,MAC7C,CAAC;AACD,WAAK,OAAO,OAAO,KAAK,OAAO,IAAI;AAAA,IACrC;AACA,WAAO,MAAM,MAAM,aAAa;AAAA,EAClC;AAAA,EAEA,MAAyB,cAAgC;AAjD3D;AAkDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,eAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF1DO,IAAM,uBAAuB,UAClC;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,2BAA2B,GAAG,EAAE,GAAG,QAAQ,sCAAiB;AAAA,EAC3E;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,sBAAsB,OAAO,MAAM;AACxD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
|
package/dist/node/index.js
CHANGED
|
@@ -1,51 +1,21 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
PrometheusMetricValueSchema: () => PrometheusMetricValueSchema,
|
|
24
|
-
PrometheusNodePlugin: () => PrometheusNodePlugin,
|
|
25
|
-
PrometheusNodeWitness: () => PrometheusNodeWitness,
|
|
26
|
-
PrometheusNodeWitnessConfigSchema: () => PrometheusNodeWitnessConfigSchema,
|
|
27
|
-
default: () => PrometheusNodePlugin
|
|
28
|
-
});
|
|
29
|
-
module.exports = __toCommonJS(src_exports);
|
|
30
|
-
|
|
31
1
|
// src/Plugin.ts
|
|
32
|
-
|
|
33
|
-
|
|
2
|
+
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
3
|
+
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
34
4
|
|
|
35
5
|
// src/Schema.ts
|
|
36
6
|
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
37
7
|
|
|
38
8
|
// src/Witness.ts
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
9
|
+
import { createServer } from "node:http";
|
|
10
|
+
import { compact } from "@xylabs/lodash";
|
|
11
|
+
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
12
|
+
import { creatableModule } from "@xyo-network/module-model";
|
|
13
|
+
import { collectDefaultMetrics, Registry } from "prom-client";
|
|
44
14
|
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
45
|
-
|
|
46
|
-
var PrometheusNodeWitness = class extends
|
|
15
|
+
creatableModule();
|
|
16
|
+
var PrometheusNodeWitness = class extends AbstractWitness {
|
|
47
17
|
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
48
|
-
_registry = new
|
|
18
|
+
_registry = new Registry();
|
|
49
19
|
server;
|
|
50
20
|
get registry() {
|
|
51
21
|
return this._registry;
|
|
@@ -54,9 +24,9 @@ var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitnes
|
|
|
54
24
|
return await this.generateMetricValues();
|
|
55
25
|
}
|
|
56
26
|
async startHandler() {
|
|
57
|
-
|
|
27
|
+
collectDefaultMetrics({ register: this._registry });
|
|
58
28
|
if (this.config.port) {
|
|
59
|
-
this.server =
|
|
29
|
+
this.server = createServer(async (_request, response) => {
|
|
60
30
|
response.writeHead(200);
|
|
61
31
|
response.end(await this._registry.metrics());
|
|
62
32
|
});
|
|
@@ -70,7 +40,7 @@ var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitnes
|
|
|
70
40
|
return await super.stopHandler();
|
|
71
41
|
}
|
|
72
42
|
async generateMetricValues() {
|
|
73
|
-
return
|
|
43
|
+
return compact(
|
|
74
44
|
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
75
45
|
const values = metric.values;
|
|
76
46
|
if (values) {
|
|
@@ -82,8 +52,8 @@ var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitnes
|
|
|
82
52
|
};
|
|
83
53
|
|
|
84
54
|
// src/Plugin.ts
|
|
85
|
-
var PrometheusNodePlugin = () =>
|
|
86
|
-
{ required: { [PrometheusMetricValueSchema]: 1 }, schema:
|
|
55
|
+
var PrometheusNodePlugin = () => createPayloadSetWitnessPlugin(
|
|
56
|
+
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },
|
|
87
57
|
{
|
|
88
58
|
witness: async (params) => {
|
|
89
59
|
const result = await PrometheusNodeWitness.create(params);
|
|
@@ -91,11 +61,11 @@ var PrometheusNodePlugin = () => (0, import_payloadset_plugin.createPayloadSetWi
|
|
|
91
61
|
}
|
|
92
62
|
}
|
|
93
63
|
);
|
|
94
|
-
|
|
95
|
-
0 && (module.exports = {
|
|
64
|
+
export {
|
|
96
65
|
PrometheusMetricValueSchema,
|
|
97
66
|
PrometheusNodePlugin,
|
|
98
67
|
PrometheusNodeWitness,
|
|
99
|
-
PrometheusNodeWitnessConfigSchema
|
|
100
|
-
|
|
68
|
+
PrometheusNodeWitnessConfigSchema,
|
|
69
|
+
PrometheusNodePlugin as default
|
|
70
|
+
};
|
|
101
71
|
//# sourceMappingURL=index.js.map
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/
|
|
1
|
+
{"version":3,"sources":["../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { PrometheusMetricValueSchema } from './Schema'\nimport { PrometheusNodeWitness } from './Witness'\n\nexport const PrometheusNodePlugin = () =>\n createPayloadSetWitnessPlugin<PrometheusNodeWitness>(\n { required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await PrometheusNodeWitness.create(params)\n return result\n },\n },\n )\n","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload'\nimport { PrometheusMetricValueSchema } from './Schema'\n\nexport type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\nexport const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\n\nexport type PrometheusNodeWitnessConfig = WitnessConfig<{\n port?: number\n schema: PrometheusNodeWitnessConfigSchema\n}>\n\nexport type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>\n\ncreatableModule()\nexport class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [PrometheusNodeWitnessConfigSchema]\n protected _registry = new Registry()\n protected server?: Server\n\n get registry(): Registry {\n return this._registry\n }\n\n protected override async observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]> {\n return await this.generateMetricValues()\n }\n\n protected override async startHandler() {\n collectDefaultMetrics({ register: this._registry })\n if (this.config.port) {\n this.server = createServer(async (_request, response) => {\n response.writeHead(200)\n\n response.end(await this._registry.metrics())\n })\n this.server.listen(this.config.port)\n }\n return await super.startHandler()\n }\n\n protected override async stopHandler(): Promise<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACAvC,IAAM,8BAA2D;;;ACDxE,SAAS,oBAA4B;AAErC,SAAS,eAAe;AACxB,SAAS,uBAAuB;AAChC,SAA0B,uBAAuB;AAGjD,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAuE;AASpF,gBAAgB;AACT,IAAM,wBAAN,cAA+G,gBAAyB;AAAA,EAC7I,OAAgB,gBAAgB,CAAC,iCAAiC;AAAA,EACxD,YAAY,IAAI,SAAS;AAAA,EACzB;AAAA,EAEV,IAAI,WAAqB;AACvB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAyB,eAAe,WAAoD;AAC1F,WAAO,MAAM,KAAK,qBAAqB;AAAA,EACzC;AAAA,EAEA,MAAyB,eAAe;AACtC,0BAAsB,EAAE,UAAU,KAAK,UAAU,CAAC;AAClD,QAAI,KAAK,OAAO,MAAM;AACpB,WAAK,SAAS,aAAa,OAAO,UAAU,aAAa;AACvD,iBAAS,UAAU,GAAG;AAEtB,iBAAS,IAAI,MAAM,KAAK,UAAU,QAAQ,CAAC;AAAA,MAC7C,CAAC;AACD,WAAK,OAAO,OAAO,KAAK,OAAO,IAAI;AAAA,IACrC;AACA,WAAO,MAAM,MAAM,aAAa;AAAA,EAClC;AAAA,EAEA,MAAyB,cAAgC;AAjD3D;AAkDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,WAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF1DO,IAAM,uBAAuB,MAClC;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,2BAA2B,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EAC3E;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,sBAAsB,OAAO,MAAM;AACxD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
|
package/package.json
CHANGED
|
@@ -10,41 +10,40 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/plugins/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/lodash": "^2.13.
|
|
14
|
-
"@xyo-network/abstract-witness": "^2.
|
|
15
|
-
"@xyo-network/module-model": "^2.
|
|
16
|
-
"@xyo-network/payload-model": "^2.
|
|
17
|
-
"@xyo-network/payloadset-plugin": "^2.
|
|
18
|
-
"@xyo-network/witness-model": "^2.
|
|
13
|
+
"@xylabs/lodash": "^2.13.25",
|
|
14
|
+
"@xyo-network/abstract-witness": "^2.88.2",
|
|
15
|
+
"@xyo-network/module-model": "^2.88.2",
|
|
16
|
+
"@xyo-network/payload-model": "^2.88.2",
|
|
17
|
+
"@xyo-network/payloadset-plugin": "^2.88.2",
|
|
18
|
+
"@xyo-network/witness-model": "^2.88.2",
|
|
19
19
|
"prom-client": "^15.1.0"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
|
-
"@xylabs/ts-scripts-yarn3": "^3.2.
|
|
23
|
-
"@xylabs/tsconfig": "^3.2.
|
|
24
|
-
"@xyo-network/account": "^2.
|
|
25
|
-
"@xyo-network/payload-wrapper": "^2.
|
|
22
|
+
"@xylabs/ts-scripts-yarn3": "^3.2.42",
|
|
23
|
+
"@xylabs/tsconfig": "^3.2.42",
|
|
24
|
+
"@xyo-network/account": "^2.88.2",
|
|
25
|
+
"@xyo-network/payload-wrapper": "^2.88.2",
|
|
26
26
|
"typescript": "^5.3.3"
|
|
27
27
|
},
|
|
28
28
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
29
|
-
"docs": "dist/docs.json",
|
|
30
|
-
"types": "dist/node/index.d.ts",
|
|
31
29
|
"exports": {
|
|
32
30
|
".": {
|
|
33
31
|
"node": {
|
|
34
32
|
"require": {
|
|
35
|
-
"types": "./dist/node/index.d.
|
|
36
|
-
"default": "./dist/node/index.
|
|
33
|
+
"types": "./dist/node/index.d.cts",
|
|
34
|
+
"default": "./dist/node/index.cjs"
|
|
37
35
|
},
|
|
38
36
|
"import": {
|
|
39
37
|
"types": "./dist/node/index.d.mts",
|
|
40
|
-
"default": "./dist/node/index.
|
|
38
|
+
"default": "./dist/node/index.js"
|
|
41
39
|
}
|
|
42
40
|
}
|
|
43
41
|
},
|
|
44
42
|
"./package.json": "./package.json"
|
|
45
43
|
},
|
|
46
|
-
"main": "dist/node/index.
|
|
47
|
-
"module": "dist/node/index.
|
|
44
|
+
"main": "dist/node/index.cjs",
|
|
45
|
+
"module": "dist/node/index.js",
|
|
46
|
+
"types": "dist/node/index.d.ts",
|
|
48
47
|
"homepage": "https://xyo.network",
|
|
49
48
|
"license": "LGPL-3.0-only",
|
|
50
49
|
"publishConfig": {
|
|
@@ -55,5 +54,6 @@
|
|
|
55
54
|
"url": "https://github.com/XYOracleNetwork/plugins.git"
|
|
56
55
|
},
|
|
57
56
|
"sideEffects": false,
|
|
58
|
-
"version": "2.86.
|
|
57
|
+
"version": "2.86.5",
|
|
58
|
+
"type": "module"
|
|
59
59
|
}
|
package/dist/node/index.mjs
DELETED
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
// src/Plugin.ts
|
|
2
|
-
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
3
|
-
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
4
|
-
|
|
5
|
-
// src/Schema.ts
|
|
6
|
-
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
7
|
-
|
|
8
|
-
// src/Witness.ts
|
|
9
|
-
import { createServer } from "node:http";
|
|
10
|
-
import { compact } from "@xylabs/lodash";
|
|
11
|
-
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
12
|
-
import { creatableModule } from "@xyo-network/module-model";
|
|
13
|
-
import { collectDefaultMetrics, Registry } from "prom-client";
|
|
14
|
-
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
15
|
-
creatableModule();
|
|
16
|
-
var PrometheusNodeWitness = class extends AbstractWitness {
|
|
17
|
-
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
18
|
-
_registry = new Registry();
|
|
19
|
-
server;
|
|
20
|
-
get registry() {
|
|
21
|
-
return this._registry;
|
|
22
|
-
}
|
|
23
|
-
async observeHandler(_payloads) {
|
|
24
|
-
return await this.generateMetricValues();
|
|
25
|
-
}
|
|
26
|
-
async startHandler() {
|
|
27
|
-
collectDefaultMetrics({ register: this._registry });
|
|
28
|
-
if (this.config.port) {
|
|
29
|
-
this.server = createServer(async (_request, response) => {
|
|
30
|
-
response.writeHead(200);
|
|
31
|
-
response.end(await this._registry.metrics());
|
|
32
|
-
});
|
|
33
|
-
this.server.listen(this.config.port);
|
|
34
|
-
}
|
|
35
|
-
return await super.startHandler();
|
|
36
|
-
}
|
|
37
|
-
async stopHandler() {
|
|
38
|
-
var _a;
|
|
39
|
-
(_a = this.server) == null ? void 0 : _a.close();
|
|
40
|
-
return await super.stopHandler();
|
|
41
|
-
}
|
|
42
|
-
async generateMetricValues() {
|
|
43
|
-
return compact(
|
|
44
|
-
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
45
|
-
const values = metric.values;
|
|
46
|
-
if (values) {
|
|
47
|
-
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
|
|
48
|
-
}
|
|
49
|
-
})
|
|
50
|
-
);
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
// src/Plugin.ts
|
|
55
|
-
var PrometheusNodePlugin = () => createPayloadSetWitnessPlugin(
|
|
56
|
-
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },
|
|
57
|
-
{
|
|
58
|
-
witness: async (params) => {
|
|
59
|
-
const result = await PrometheusNodeWitness.create(params);
|
|
60
|
-
return result;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
);
|
|
64
|
-
export {
|
|
65
|
-
PrometheusMetricValueSchema,
|
|
66
|
-
PrometheusNodePlugin,
|
|
67
|
-
PrometheusNodeWitness,
|
|
68
|
-
PrometheusNodeWitnessConfigSchema,
|
|
69
|
-
PrometheusNodePlugin as default
|
|
70
|
-
};
|
|
71
|
-
//# sourceMappingURL=index.mjs.map
|
package/dist/node/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { PrometheusMetricValueSchema } from './Schema'\nimport { PrometheusNodeWitness } from './Witness'\n\nexport const PrometheusNodePlugin = () =>\n createPayloadSetWitnessPlugin<PrometheusNodeWitness>(\n { required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },\n {\n witness: async (params) => {\n const result = await PrometheusNodeWitness.create(params)\n return result\n },\n },\n )\n","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload'\nimport { PrometheusMetricValueSchema } from './Schema'\n\nexport type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\nexport const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config'\n\nexport type PrometheusNodeWitnessConfig = WitnessConfig<{\n port?: number\n schema: PrometheusNodeWitnessConfigSchema\n}>\n\nexport type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>\n\ncreatableModule()\nexport class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {\n static override configSchemas = [PrometheusNodeWitnessConfigSchema]\n protected _registry = new Registry()\n protected server?: Server\n\n get registry(): Registry {\n return this._registry\n }\n\n protected override async observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]> {\n return await this.generateMetricValues()\n }\n\n protected override async startHandler() {\n collectDefaultMetrics({ register: this._registry })\n if (this.config.port) {\n this.server = createServer(async (_request, response) => {\n response.writeHead(200)\n\n response.end(await this._registry.metrics())\n })\n this.server.listen(this.config.port)\n }\n return await super.startHandler()\n }\n\n protected override async stopHandler(): Promise<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACAvC,IAAM,8BAA2D;;;ACDxE,SAAS,oBAA4B;AAErC,SAAS,eAAe;AACxB,SAAS,uBAAuB;AAChC,SAA0B,uBAAuB;AAGjD,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAuE;AASpF,gBAAgB;AACT,IAAM,wBAAN,cAA+G,gBAAyB;AAAA,EAC7I,OAAgB,gBAAgB,CAAC,iCAAiC;AAAA,EACxD,YAAY,IAAI,SAAS;AAAA,EACzB;AAAA,EAEV,IAAI,WAAqB;AACvB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAyB,eAAe,WAAoD;AAC1F,WAAO,MAAM,KAAK,qBAAqB;AAAA,EACzC;AAAA,EAEA,MAAyB,eAAe;AACtC,0BAAsB,EAAE,UAAU,KAAK,UAAU,CAAC;AAClD,QAAI,KAAK,OAAO,MAAM;AACpB,WAAK,SAAS,aAAa,OAAO,UAAU,aAAa;AACvD,iBAAS,UAAU,GAAG;AAEtB,iBAAS,IAAI,MAAM,KAAK,UAAU,QAAQ,CAAC;AAAA,MAC7C,CAAC;AACD,WAAK,OAAO,OAAO,KAAK,OAAO,IAAI;AAAA,IACrC;AACA,WAAO,MAAM,MAAM,aAAa;AAAA,EAClC;AAAA,EAEA,MAAyB,cAAgC;AAjD3D;AAkDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,WAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF1DO,IAAM,uBAAuB,MAClC;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,2BAA2B,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EAC3E;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,sBAAsB,OAAO,MAAM;AACxD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
|