@xyo-network/prometheus-node-plugin 2.75.0 → 2.75.2
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/docs.json +23102 -0
- package/dist/node/Payload.d.cts +10 -0
- package/dist/node/Payload.d.cts.map +1 -0
- package/dist/node/Payload.js +2 -0
- package/dist/node/Payload.js.map +1 -1
- package/dist/node/Plugin.d.cts +55 -0
- package/dist/node/Plugin.d.cts.map +1 -0
- package/dist/node/Plugin.js +56 -5
- package/dist/node/Plugin.js.map +1 -1
- package/dist/node/Plugin.mjs +53 -3
- package/dist/node/Plugin.mjs.map +1 -1
- package/dist/node/Schema.d.cts +3 -0
- package/dist/node/Schema.d.cts.map +1 -0
- package/dist/node/Schema.js +3 -1
- package/dist/node/Schema.js.map +1 -1
- package/dist/node/Schema.mjs +2 -1
- package/dist/node/Schema.mjs.map +1 -1
- package/dist/node/Witness.d.cts +24 -0
- package/dist/node/Witness.d.cts.map +1 -0
- package/dist/node/Witness.js +13 -6
- package/dist/node/Witness.js.map +1 -1
- package/dist/node/Witness.mjs +11 -5
- package/dist/node/Witness.mjs.map +1 -1
- package/dist/node/index.d.cts +7 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.js +76 -10
- package/dist/node/index.js.map +1 -1
- package/dist/node/index.mjs +68 -4
- package/dist/node/index.mjs.map +1 -1
- package/package.json +8 -8
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { Payload } from '@xyo-network/payload-model';
|
|
2
|
+
import { Aggregator, MetricType } from 'prom-client';
|
|
3
|
+
import { PrometheusMetricValueSchema } from './Schema';
|
|
4
|
+
export type PrometheusMetricValuePayload = Payload<{
|
|
5
|
+
aggregator: Aggregator;
|
|
6
|
+
name: string;
|
|
7
|
+
type: MetricType;
|
|
8
|
+
values: (number | string | object)[];
|
|
9
|
+
}, PrometheusMetricValueSchema>;
|
|
10
|
+
//# sourceMappingURL=Payload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Payload.d.ts","sourceRoot":"","sources":["../../src/Payload.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAEpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,UAAU,CAAA;AAEtD,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"}
|
package/dist/node/Payload.js
CHANGED
|
@@ -12,6 +12,8 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
12
12
|
return to;
|
|
13
13
|
};
|
|
14
14
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
15
|
+
|
|
16
|
+
// src/Payload.ts
|
|
15
17
|
var Payload_exports = {};
|
|
16
18
|
module.exports = __toCommonJS(Payload_exports);
|
|
17
19
|
//# sourceMappingURL=Payload.js.map
|
package/dist/node/Payload.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Payload.ts"],"sourcesContent":["import { Payload } from '@xyo-network/payload-model'\nimport { Aggregator, MetricType } from 'prom-client'\n\nimport { PrometheusMetricValueSchema } from './Schema'\n\nexport type PrometheusMetricValuePayload = Payload<\n {\n aggregator: Aggregator\n name: string\n type: MetricType\n values: (number | string | object)[]\n },\n PrometheusMetricValueSchema\n>\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Payload.ts"],"sourcesContent":["import { Payload } from '@xyo-network/payload-model'\nimport { Aggregator, MetricType } from 'prom-client'\n\nimport { PrometheusMetricValueSchema } from './Schema'\n\nexport type PrometheusMetricValuePayload = Payload<\n {\n aggregator: Aggregator\n name: string\n type: MetricType\n values: (number | string | object)[]\n },\n PrometheusMetricValueSchema\n>\n"],"mappings":";;;;;;;;;;;;;;;;AAAA;AAAA;","names":[]}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { PrometheusNodeWitness } from './Witness';
|
|
2
|
+
export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import("@xyo-network/core").BaseParamsFields & {
|
|
3
|
+
account?: import("@xyo-network/account-model").AccountInstance | "random" | undefined;
|
|
4
|
+
config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
|
|
5
|
+
accountDerivationPath?: string | undefined;
|
|
6
|
+
readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
|
|
7
|
+
readonly labels?: import("@xyo-network/module-model").Labels | undefined;
|
|
8
|
+
readonly name?: string | undefined;
|
|
9
|
+
readonly paging?: Record<string, {
|
|
10
|
+
size?: number | undefined;
|
|
11
|
+
}> | undefined;
|
|
12
|
+
readonly security?: {
|
|
13
|
+
readonly allowAnonymous?: boolean | undefined;
|
|
14
|
+
readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
|
|
15
|
+
readonly disallowed?: Record<string, string[]> | undefined;
|
|
16
|
+
} | undefined;
|
|
17
|
+
readonly sign?: boolean | undefined;
|
|
18
|
+
readonly storeQueries?: boolean | undefined;
|
|
19
|
+
readonly timestamp?: boolean | undefined;
|
|
20
|
+
} & Omit<import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<{
|
|
21
|
+
accountDerivationPath?: string | undefined;
|
|
22
|
+
readonly archivist?: import("@xyo-network/module-model").ArchivistModuleConfig | undefined;
|
|
23
|
+
readonly labels?: import("@xyo-network/module-model").Labels | undefined;
|
|
24
|
+
readonly name?: string | undefined;
|
|
25
|
+
readonly paging?: Record<string, {
|
|
26
|
+
size?: number | undefined;
|
|
27
|
+
}> | undefined;
|
|
28
|
+
readonly security?: {
|
|
29
|
+
readonly allowAnonymous?: boolean | undefined;
|
|
30
|
+
readonly allowed?: Record<string, (string | import("@xyo-network/module-model").CosigningAddressSet)[]> | undefined;
|
|
31
|
+
readonly disallowed?: Record<string, string[]> | undefined;
|
|
32
|
+
} | undefined;
|
|
33
|
+
readonly sign?: boolean | undefined;
|
|
34
|
+
readonly storeQueries?: boolean | undefined;
|
|
35
|
+
readonly timestamp?: boolean | undefined;
|
|
36
|
+
} & {
|
|
37
|
+
archivist?: string | undefined;
|
|
38
|
+
schema: "network.xyo.prometheus.node.witness.config";
|
|
39
|
+
targetSet?: (import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & import("@xyo-network/payload-model").PayloadSet & {
|
|
40
|
+
schema: "network.xyo.payload.set";
|
|
41
|
+
}) | undefined;
|
|
42
|
+
} & {
|
|
43
|
+
port?: number | undefined;
|
|
44
|
+
schema: "network.xyo.prometheus.node.witness.config";
|
|
45
|
+
}, "schema"> & {
|
|
46
|
+
schema: "network.xyo.prometheus.node.witness.config";
|
|
47
|
+
}, "schema"> & {
|
|
48
|
+
schema: string;
|
|
49
|
+
}, "schema"> & {
|
|
50
|
+
schema: string;
|
|
51
|
+
};
|
|
52
|
+
ephemeralQueryAccountEnabled?: boolean | undefined;
|
|
53
|
+
wallet?: import("@xyo-network/wallet-model").WalletInstance | undefined;
|
|
54
|
+
}>>;
|
|
55
|
+
//# sourceMappingURL=Plugin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
|
package/dist/node/Plugin.js
CHANGED
|
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/Plugin.ts
|
|
19
21
|
var Plugin_exports = {};
|
|
20
22
|
__export(Plugin_exports, {
|
|
21
23
|
PrometheusNodePlugin: () => PrometheusNodePlugin
|
|
@@ -23,13 +25,62 @@ __export(Plugin_exports, {
|
|
|
23
25
|
module.exports = __toCommonJS(Plugin_exports);
|
|
24
26
|
var import_payload_model = require("@xyo-network/payload-model");
|
|
25
27
|
var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
28
|
+
|
|
29
|
+
// src/Schema.ts
|
|
30
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
31
|
+
|
|
32
|
+
// src/Witness.ts
|
|
33
|
+
var import_lodash = require("@xylabs/lodash");
|
|
34
|
+
var import_module = require("@xyo-network/module");
|
|
35
|
+
var import_witness = require("@xyo-network/witness");
|
|
36
|
+
var import_http = require("http");
|
|
37
|
+
var import_prom_client = require("prom-client");
|
|
38
|
+
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
39
|
+
(0, import_module.creatableModule)();
|
|
40
|
+
var PrometheusNodeWitness = class extends import_witness.AbstractWitness {
|
|
41
|
+
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
42
|
+
_registry = new import_prom_client.Registry();
|
|
43
|
+
server;
|
|
44
|
+
get registry() {
|
|
45
|
+
return this._registry;
|
|
46
|
+
}
|
|
47
|
+
async observeHandler(_payloads) {
|
|
48
|
+
return await this.generateMetricValues();
|
|
49
|
+
}
|
|
50
|
+
async startHandler() {
|
|
51
|
+
(0, import_prom_client.collectDefaultMetrics)({ register: this._registry });
|
|
52
|
+
if (this.config.port) {
|
|
53
|
+
this.server = (0, import_http.createServer)(async (_request, response) => {
|
|
54
|
+
response.writeHead(200);
|
|
55
|
+
response.end(await this._registry.metrics());
|
|
56
|
+
});
|
|
57
|
+
this.server.listen(this.config.port);
|
|
58
|
+
}
|
|
59
|
+
return await super.startHandler();
|
|
60
|
+
}
|
|
61
|
+
stopHandler() {
|
|
62
|
+
var _a;
|
|
63
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
64
|
+
return super.stopHandler();
|
|
65
|
+
}
|
|
66
|
+
async generateMetricValues() {
|
|
67
|
+
return (0, import_lodash.compact)(
|
|
68
|
+
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
69
|
+
const values = metric.values;
|
|
70
|
+
if (values) {
|
|
71
|
+
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
|
|
72
|
+
}
|
|
73
|
+
})
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
|
|
78
|
+
// src/Plugin.ts
|
|
79
|
+
var PrometheusNodePlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
|
|
80
|
+
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
|
|
30
81
|
{
|
|
31
82
|
witness: async (params) => {
|
|
32
|
-
const result = await
|
|
83
|
+
const result = await PrometheusNodeWitness.create(params);
|
|
33
84
|
return result;
|
|
34
85
|
}
|
|
35
86
|
}
|
package/dist/node/Plugin.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Plugin.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"],"mappings":"
|
|
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 { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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,2BAAiC;AACjC,+BAA8C;;;ACAvC,IAAM,8BAA2D;;;ACDxE,oBAAwB;AACxB,oBAAiD;AAEjD,qBAA8D;AAC9D,kBAAqC;AACrC,yBAAgD;AAMzC,IAAM,oCAAuE;AAAA,IASpF,+BAAgB;AACT,IAAM,wBAAN,cAA+G,+BAAyB;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,0BAAa,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,EAEmB,cAAc;AA/CnC;AAgDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,YAAY;AAAA,EAC3B;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;;;AFxDO,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/Plugin.mjs
CHANGED
|
@@ -1,8 +1,58 @@
|
|
|
1
|
+
// src/Plugin.ts
|
|
1
2
|
import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
2
3
|
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
|
|
5
|
+
// src/Schema.ts
|
|
6
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
7
|
+
|
|
8
|
+
// src/Witness.ts
|
|
9
|
+
import { compact } from "@xylabs/lodash";
|
|
10
|
+
import { creatableModule } from "@xyo-network/module";
|
|
11
|
+
import { AbstractWitness } from "@xyo-network/witness";
|
|
12
|
+
import { createServer } from "http";
|
|
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
|
+
stopHandler() {
|
|
38
|
+
var _a;
|
|
39
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
40
|
+
return 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(
|
|
6
56
|
{ required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },
|
|
7
57
|
{
|
|
8
58
|
witness: async (params) => {
|
package/dist/node/Plugin.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Plugin.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"],"mappings":"AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;
|
|
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 { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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,eAAe;AACxB,SAA0B,uBAAuB;AAEjD,SAAS,uBAAqD;AAC9D,SAAS,oBAA4B;AACrC,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,EAEmB,cAAc;AA/CnC;AAgDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,YAAY;AAAA,EAC3B;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;;;AFxDO,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":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,2BAA2B,GAAG,qCAAqC,CAAA;AAC/E,eAAO,MAAM,2BAA2B,EAAE,2BAAmE,CAAA"}
|
package/dist/node/Schema.js
CHANGED
|
@@ -16,12 +16,14 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/Schema.ts
|
|
19
21
|
var Schema_exports = {};
|
|
20
22
|
__export(Schema_exports, {
|
|
21
23
|
PrometheusMetricValueSchema: () => PrometheusMetricValueSchema
|
|
22
24
|
});
|
|
23
25
|
module.exports = __toCommonJS(Schema_exports);
|
|
24
|
-
|
|
26
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
25
27
|
// Annotate the CommonJS export names for ESM import in node:
|
|
26
28
|
0 && (module.exports = {
|
|
27
29
|
PrometheusMetricValueSchema
|
package/dist/node/Schema.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACO,IAAM,8BAA2D;","names":[]}
|
package/dist/node/Schema.mjs
CHANGED
package/dist/node/Schema.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":"AACO,
|
|
1
|
+
{"version":3,"sources":["../../src/Schema.ts"],"sourcesContent":["export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":";AACO,IAAM,8BAA2D;","names":[]}
|
|
@@ -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, WitnessConfig, WitnessParams } 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 = WitnessConfig<{
|
|
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 configSchemas: "network.xyo.prometheus.node.witness.config"[];
|
|
16
|
+
protected _registry: Registry;
|
|
17
|
+
protected server?: Server;
|
|
18
|
+
get registry(): Registry;
|
|
19
|
+
protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
|
|
20
|
+
protected startHandler(): Promise<boolean>;
|
|
21
|
+
protected stopHandler(): import("@xyo-network/promise").Promisable<boolean>;
|
|
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":";AACA,OAAO,EAAE,eAAe,EAAmB,MAAM,qBAAqB,CAAA;AACtE,OAAO,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AACpD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpF,OAAO,EAAgB,MAAM,EAAE,MAAM,MAAM,CAAA;AAC3C,OAAO,EAAyB,QAAQ,EAAE,MAAM,aAAa,CAAA;AAK7D,MAAM,MAAM,iCAAiC,GAAG,4CAA4C,CAAA;AAC5F,eAAO,MAAM,iCAAiC,EAAE,iCAAgF,CAAA;AAEhI,MAAM,MAAM,2BAA2B,GAAG,aAAa,CAAC;IACtD,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;AAGrG,qBAAa,qBAAqB,CAAC,OAAO,SAAS,2BAA2B,GAAG,2BAA2B,CAAE,SAAQ,eAAe,CAAC,OAAO,CAAC;IAC5I,OAAgB,aAAa,iDAAsC;IACnE,SAAS,CAAC,SAAS,WAAiB;IACpC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM,CAAA;IAEzB,IAAI,QAAQ,IAAI,QAAQ,CAEvB;cAEwB,cAAc,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;cAIlE,YAAY;cAalB,WAAW;YAKhB,oBAAoB;CAUnC"}
|
package/dist/node/Witness.js
CHANGED
|
@@ -16,6 +16,8 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/Witness.ts
|
|
19
21
|
var Witness_exports = {};
|
|
20
22
|
__export(Witness_exports, {
|
|
21
23
|
PrometheusNodeWitness: () => PrometheusNodeWitness,
|
|
@@ -27,10 +29,14 @@ var import_module = require("@xyo-network/module");
|
|
|
27
29
|
var import_witness = require("@xyo-network/witness");
|
|
28
30
|
var import_http = require("http");
|
|
29
31
|
var import_prom_client = require("prom-client");
|
|
30
|
-
|
|
31
|
-
|
|
32
|
+
|
|
33
|
+
// src/Schema.ts
|
|
34
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
35
|
+
|
|
36
|
+
// src/Witness.ts
|
|
37
|
+
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
32
38
|
(0, import_module.creatableModule)();
|
|
33
|
-
|
|
39
|
+
var PrometheusNodeWitness = class extends import_witness.AbstractWitness {
|
|
34
40
|
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
35
41
|
_registry = new import_prom_client.Registry();
|
|
36
42
|
server;
|
|
@@ -52,7 +58,8 @@ class PrometheusNodeWitness extends import_witness.AbstractWitness {
|
|
|
52
58
|
return await super.startHandler();
|
|
53
59
|
}
|
|
54
60
|
stopHandler() {
|
|
55
|
-
|
|
61
|
+
var _a;
|
|
62
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
56
63
|
return super.stopHandler();
|
|
57
64
|
}
|
|
58
65
|
async generateMetricValues() {
|
|
@@ -60,12 +67,12 @@ class PrometheusNodeWitness extends import_witness.AbstractWitness {
|
|
|
60
67
|
(await this._registry.getMetricsAsJSON()).map((metric) => {
|
|
61
68
|
const values = metric.values;
|
|
62
69
|
if (values) {
|
|
63
|
-
return { aggregator: metric.aggregator, name: metric.name, schema:
|
|
70
|
+
return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
|
|
64
71
|
}
|
|
65
72
|
})
|
|
66
73
|
);
|
|
67
74
|
}
|
|
68
|
-
}
|
|
75
|
+
};
|
|
69
76
|
// Annotate the CommonJS export names for ESM import in node:
|
|
70
77
|
0 && (module.exports = {
|
|
71
78
|
PrometheusNodeWitness,
|
package/dist/node/Witness.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Witness.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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":"
|
|
1
|
+
{"version":3,"sources":["../../src/Witness.ts","../../src/Schema.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAAwB;AACxB,oBAAiD;AAEjD,qBAA8D;AAC9D,kBAAqC;AACrC,yBAAgD;;;ACJzC,IAAM,8BAA2D;;;ADUjE,IAAM,oCAAuE;AAAA,IASpF,+BAAgB;AACT,IAAM,wBAAN,cAA+G,+BAAyB;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,0BAAa,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,EAEmB,cAAc;AA/CnC;AAgDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,YAAY;AAAA,EAC3B;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;","names":[]}
|
package/dist/node/Witness.mjs
CHANGED
|
@@ -1,12 +1,17 @@
|
|
|
1
|
+
// src/Witness.ts
|
|
1
2
|
import { compact } from "@xylabs/lodash";
|
|
2
3
|
import { creatableModule } from "@xyo-network/module";
|
|
3
4
|
import { AbstractWitness } from "@xyo-network/witness";
|
|
4
5
|
import { createServer } from "http";
|
|
5
6
|
import { collectDefaultMetrics, Registry } from "prom-client";
|
|
6
|
-
|
|
7
|
-
|
|
7
|
+
|
|
8
|
+
// src/Schema.ts
|
|
9
|
+
var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
|
|
10
|
+
|
|
11
|
+
// src/Witness.ts
|
|
12
|
+
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
8
13
|
creatableModule();
|
|
9
|
-
|
|
14
|
+
var PrometheusNodeWitness = class extends AbstractWitness {
|
|
10
15
|
static configSchemas = [PrometheusNodeWitnessConfigSchema];
|
|
11
16
|
_registry = new Registry();
|
|
12
17
|
server;
|
|
@@ -28,7 +33,8 @@ class PrometheusNodeWitness extends AbstractWitness {
|
|
|
28
33
|
return await super.startHandler();
|
|
29
34
|
}
|
|
30
35
|
stopHandler() {
|
|
31
|
-
|
|
36
|
+
var _a;
|
|
37
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
32
38
|
return super.stopHandler();
|
|
33
39
|
}
|
|
34
40
|
async generateMetricValues() {
|
|
@@ -41,7 +47,7 @@ class PrometheusNodeWitness extends AbstractWitness {
|
|
|
41
47
|
})
|
|
42
48
|
);
|
|
43
49
|
}
|
|
44
|
-
}
|
|
50
|
+
};
|
|
45
51
|
export {
|
|
46
52
|
PrometheusNodeWitness,
|
|
47
53
|
PrometheusNodeWitnessConfigSchema
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Witness.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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,eAAe;AACxB,SAA0B,uBAAuB;AAEjD,SAAS,uBAAqD;AAC9D,SAAS,oBAA4B;AACrC,SAAS,uBAAuB,gBAAgB
|
|
1
|
+
{"version":3,"sources":["../../src/Witness.ts","../../src/Schema.ts"],"sourcesContent":["import { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n"],"mappings":";AAAA,SAAS,eAAe;AACxB,SAA0B,uBAAuB;AAEjD,SAAS,uBAAqD;AAC9D,SAAS,oBAA4B;AACrC,SAAS,uBAAuB,gBAAgB;;;ACJzC,IAAM,8BAA2D;;;ADUjE,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,EAEmB,cAAc;AA/CnC;AAgDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,YAAY;AAAA,EAC3B;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;","names":[]}
|
|
@@ -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;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,WAAW,CAAA;AAEzB,OAAO,EAAE,oBAAoB,EAAE,CAAA;AAG/B,eAAe,oBAAoB,CAAA"}
|
package/dist/node/index.js
CHANGED
|
@@ -15,24 +15,90 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
15
15
|
}
|
|
16
16
|
return to;
|
|
17
17
|
};
|
|
18
|
-
var __reExport = (target, mod, secondTarget) => (__copyProps(target, mod, "default"), secondTarget && __copyProps(secondTarget, mod, "default"));
|
|
19
18
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/index.ts
|
|
20
21
|
var src_exports = {};
|
|
21
22
|
__export(src_exports, {
|
|
22
|
-
|
|
23
|
+
PrometheusMetricValueSchema: () => PrometheusMetricValueSchema,
|
|
24
|
+
PrometheusNodePlugin: () => PrometheusNodePlugin,
|
|
25
|
+
PrometheusNodeWitness: () => PrometheusNodeWitness,
|
|
26
|
+
PrometheusNodeWitnessConfigSchema: () => PrometheusNodeWitnessConfigSchema,
|
|
23
27
|
default: () => src_default
|
|
24
28
|
});
|
|
25
29
|
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
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_lodash = require("@xylabs/lodash");
|
|
40
|
+
var import_module = require("@xyo-network/module");
|
|
41
|
+
var import_witness = require("@xyo-network/witness");
|
|
42
|
+
var import_http = require("http");
|
|
43
|
+
var import_prom_client = require("prom-client");
|
|
44
|
+
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
45
|
+
(0, import_module.creatableModule)();
|
|
46
|
+
var PrometheusNodeWitness = class extends import_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_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
|
+
stopHandler() {
|
|
68
|
+
var _a;
|
|
69
|
+
(_a = this.server) == null ? void 0 : _a.close();
|
|
70
|
+
return 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
|
+
|
|
95
|
+
// src/index.ts
|
|
96
|
+
var src_default = PrometheusNodePlugin;
|
|
31
97
|
// Annotate the CommonJS export names for ESM import in node:
|
|
32
98
|
0 && (module.exports = {
|
|
99
|
+
PrometheusMetricValueSchema,
|
|
33
100
|
PrometheusNodePlugin,
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
...require("./Witness")
|
|
101
|
+
PrometheusNodeWitness,
|
|
102
|
+
PrometheusNodeWitnessConfigSchema
|
|
37
103
|
});
|
|
38
104
|
//# sourceMappingURL=index.js.map
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts"],"sourcesContent":["import { PrometheusNodePlugin } from './Plugin'\n\nexport * from './Payload'\nexport * from './Schema'\nexport * from './Witness'\n\nexport { PrometheusNodePlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default PrometheusNodePlugin\n"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["import { PrometheusNodePlugin } from './Plugin'\n\nexport * from './Payload'\nexport * from './Schema'\nexport * from './Witness'\n\nexport { PrometheusNodePlugin }\n\n// eslint-disable-next-line import/no-default-export\nexport default PrometheusNodePlugin\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 { compact } from '@xylabs/lodash'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module'\nimport { Payload } from '@xyo-network/payload-model'\nimport { AbstractWitness, WitnessConfig, WitnessParams } from '@xyo-network/witness'\nimport { createServer, Server } from 'http'\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 stopHandler() {\n this.server?.close()\n return 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,oBAAwB;AACxB,oBAAiD;AAEjD,qBAA8D;AAC9D,kBAAqC;AACrC,yBAAgD;AAMzC,IAAM,oCAAuE;AAAA,IASpF,+BAAgB;AACT,IAAM,wBAAN,cAA+G,+BAAyB;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,0BAAa,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,EAEmB,cAAc;AA/CnC;AAgDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,YAAY;AAAA,EAC3B;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;;;AFxDO,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;;;ADNF,IAAO,cAAQ;","names":[]}
|