@xyo-network/prometheus-node-plugin 5.2.4 → 5.3.1
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/Schema.d.ts +4 -2
- package/dist/node/Schema.d.ts.map +1 -1
- package/dist/node/Witness.d.ts +5 -3
- package/dist/node/Witness.d.ts.map +1 -1
- package/dist/node/index.mjs +6 -2
- package/dist/node/index.mjs.map +1 -1
- package/package.json +13 -13
- package/src/Schema.ts +4 -2
- package/src/Witness.ts +5 -3
package/dist/node/Schema.d.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
export type PrometheusMetricValueSchema =
|
|
2
|
-
export declare const PrometheusMetricValueSchema:
|
|
1
|
+
export type PrometheusMetricValueSchema = typeof PrometheusMetricValueSchema;
|
|
2
|
+
export declare const PrometheusMetricValueSchema: "network.xyo.prometheus.metric.value" & {
|
|
3
|
+
readonly __schema: true;
|
|
4
|
+
};
|
|
3
5
|
//# sourceMappingURL=Schema.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Schema.d.ts","sourceRoot":"","sources":["../../src/Schema.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,2BAA2B,GAAG,OAAO,2BAA2B,CAAA;AAC5E,eAAO,MAAM,2BAA2B;;CAAwD,CAAA"}
|
package/dist/node/Witness.d.ts
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import type { Server } from 'node:http';
|
|
2
2
|
import { AbstractWitness } from '@xyo-network/abstract-witness';
|
|
3
3
|
import type { AnyConfigSchema } from '@xyo-network/module-model';
|
|
4
|
-
import type
|
|
4
|
+
import { type Payload, type Schema } from '@xyo-network/payload-model';
|
|
5
5
|
import type { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
|
|
6
6
|
import { Registry } from 'prom-client';
|
|
7
|
-
export type PrometheusNodeWitnessConfigSchema =
|
|
8
|
-
export declare const PrometheusNodeWitnessConfigSchema:
|
|
7
|
+
export type PrometheusNodeWitnessConfigSchema = typeof PrometheusNodeWitnessConfigSchema;
|
|
8
|
+
export declare const PrometheusNodeWitnessConfigSchema: "network.xyo.prometheus.node.witness.config" & {
|
|
9
|
+
readonly __schema: true;
|
|
10
|
+
};
|
|
9
11
|
export type PrometheusNodeWitnessConfig = WitnessConfig<{
|
|
10
12
|
port?: number;
|
|
11
13
|
schema: PrometheusNodeWitnessConfigSchema;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAIvC,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,WAAW,CAAA;AAIvC,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,EACK,KAAK,OAAO,EAAE,KAAK,MAAM,EACpC,MAAM,4BAA4B,CAAA;AACnC,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AAC9E,OAAO,EAAyB,QAAQ,EAAE,MAAM,aAAa,CAAA;AAK7D,MAAM,MAAM,iCAAiC,GAAG,OAAO,iCAAiC,CAAA;AACxF,eAAO,MAAM,iCAAiC;;CAA+D,CAAA;AAE7G,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,gBAAyB,aAAa,EAAE,MAAM,EAAE,CAA8D;IAC9G,gBAAyB,mBAAmB,EAAE,MAAM,CAAoC;IACxF,SAAS,CAAC,SAAS,uDAAiB;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;cAcZ,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;YAKvC,oBAAoB;CAUnC"}
|
package/dist/node/index.mjs
CHANGED
|
@@ -3,15 +3,19 @@ import { PayloadSetSchema } from "@xyo-network/payload-model";
|
|
|
3
3
|
import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
|
|
4
4
|
|
|
5
5
|
// src/Schema.ts
|
|
6
|
-
|
|
6
|
+
import { asSchema } from "@xyo-network/payload-model";
|
|
7
|
+
var PrometheusMetricValueSchema = asSchema("network.xyo.prometheus.metric.value", true);
|
|
7
8
|
|
|
8
9
|
// src/Witness.ts
|
|
9
10
|
import { createServer } from "http";
|
|
10
11
|
import { exists } from "@xylabs/exists";
|
|
11
12
|
import { AbstractWitness } from "@xyo-network/abstract-witness";
|
|
12
13
|
import { creatableModule } from "@xyo-network/module-model";
|
|
14
|
+
import {
|
|
15
|
+
asSchema as asSchema2
|
|
16
|
+
} from "@xyo-network/payload-model";
|
|
13
17
|
import { collectDefaultMetrics, Registry } from "prom-client";
|
|
14
|
-
var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
|
|
18
|
+
var PrometheusNodeWitnessConfigSchema = asSchema2("network.xyo.prometheus.node.witness.config", true);
|
|
15
19
|
creatableModule();
|
|
16
20
|
var PrometheusNodeWitness = class extends AbstractWitness {
|
|
17
21
|
static configSchemas = [...super.configSchemas, PrometheusNodeWitnessConfigSchema];
|
package/dist/node/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
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.ts'\nimport { PrometheusNodeWitness } from './Witness.ts'\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","
|
|
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.ts'\nimport { PrometheusNodeWitness } from './Witness.ts'\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","import { asSchema } from '@xyo-network/payload-model'\n\nexport type PrometheusMetricValueSchema = typeof PrometheusMetricValueSchema\nexport const PrometheusMetricValueSchema = asSchema('network.xyo.prometheus.metric.value', true)\n","import type { Server } from 'node:http'\nimport { createServer } from 'node:http'\n\nimport { exists } from '@xylabs/exists'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport type { AnyConfigSchema } from '@xyo-network/module-model'\nimport { creatableModule } from '@xyo-network/module-model'\nimport {\n asSchema, type Payload, type Schema,\n} from '@xyo-network/payload-model'\nimport type { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport type { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\n\nexport type PrometheusNodeWitnessConfigSchema = typeof PrometheusNodeWitnessConfigSchema\nexport const PrometheusNodeWitnessConfigSchema = asSchema('network.xyo.prometheus.node.witness.config', true)\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 readonly configSchemas: Schema[] = [...super.configSchemas, PrometheusNodeWitnessConfigSchema]\n static override readonly defaultConfigSchema: Schema = 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 // eslint-disable-next-line @typescript-eslint/no-misused-promises\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<void> {\n this.server?.close()\n await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return {\n aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values,\n }\n }\n }).filter(exists)\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACD9C,SAAS,gBAAgB;AAGlB,IAAM,8BAA8B,SAAS,uCAAuC,IAAI;;;ACF/F,SAAS,oBAAoB;AAE7B,SAAS,cAAc;AACvB,SAAS,uBAAuB;AAEhC,SAAS,uBAAuB;AAChC;AAAA,EACE,YAAAA;AAAA,OACK;AAEP,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAoCC,UAAS,8CAA8C,IAAI;AAS5G,gBAAgB;AACT,IAAM,wBAAN,cAA+G,gBAAyB;AAAA,EAC7I,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,iCAAiC;AAAA,EAC7G,OAAyB,sBAA8B;AAAA,EAC7C,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;AAEpB,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,cAA6B;AACpD,SAAK,QAAQ,MAAM;AACnB,UAAM,MAAM,YAAY;AAAA,EAC1B;AAAA,EAEA,MAAc,uBAAgE;AAC5E,YAAQ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AAC/D,YAAM,SAAS,OAAO;AACtB,UAAI,QAAQ;AACV,eAAO;AAAA,UACL,YAAY,OAAO;AAAA,UAAY,MAAM,OAAO;AAAA,UAAM,QAAQ;AAAA,UAA6B,MAAM,OAAO;AAAA,UAAM;AAAA,QAC5G;AAAA,MACF;AAAA,IACF,CAAC,EAAE,OAAO,MAAM;AAAA,EAClB;AACF;;;AFhEO,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":["asSchema","asSchema"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/prometheus-node-plugin",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.3.1",
|
|
4
4
|
"description": "Typescript/Javascript Plugins for XYO Platform",
|
|
5
5
|
"homepage": "https://xyo.network",
|
|
6
6
|
"bugs": {
|
|
@@ -36,23 +36,23 @@
|
|
|
36
36
|
"!**/*.test.*"
|
|
37
37
|
],
|
|
38
38
|
"dependencies": {
|
|
39
|
-
"@xylabs/exists": "~5.0.
|
|
40
|
-
"@xyo-network/abstract-witness": "~5.2
|
|
41
|
-
"@xyo-network/module-model": "~5.2
|
|
42
|
-
"@xyo-network/payload-model": "~5.2
|
|
43
|
-
"@xyo-network/payloadset-plugin": "~5.2
|
|
44
|
-
"@xyo-network/witness-model": "~5.2
|
|
39
|
+
"@xylabs/exists": "~5.0.64",
|
|
40
|
+
"@xyo-network/abstract-witness": "~5.3.2",
|
|
41
|
+
"@xyo-network/module-model": "~5.3.2",
|
|
42
|
+
"@xyo-network/payload-model": "~5.3.2",
|
|
43
|
+
"@xyo-network/payloadset-plugin": "~5.3.2",
|
|
44
|
+
"@xyo-network/witness-model": "~5.3.2",
|
|
45
45
|
"prom-client": "~15.1.3"
|
|
46
46
|
},
|
|
47
47
|
"devDependencies": {
|
|
48
|
-
"@xylabs/ts-scripts-yarn3": "~7.2
|
|
49
|
-
"@xylabs/tsconfig": "~7.2
|
|
50
|
-
"@xylabs/vitest-extended": "~5.0.
|
|
51
|
-
"@xyo-network/payload-wrapper": "~5.2
|
|
48
|
+
"@xylabs/ts-scripts-yarn3": "~7.3.2",
|
|
49
|
+
"@xylabs/tsconfig": "~7.3.2",
|
|
50
|
+
"@xylabs/vitest-extended": "~5.0.64",
|
|
51
|
+
"@xyo-network/payload-wrapper": "~5.3.2",
|
|
52
52
|
"typescript": "~5.9.3",
|
|
53
|
-
"vitest": "~4.0.
|
|
53
|
+
"vitest": "~4.0.18"
|
|
54
54
|
},
|
|
55
55
|
"publishConfig": {
|
|
56
56
|
"access": "public"
|
|
57
57
|
}
|
|
58
|
-
}
|
|
58
|
+
}
|
package/src/Schema.ts
CHANGED
|
@@ -1,2 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { asSchema } from '@xyo-network/payload-model'
|
|
2
|
+
|
|
3
|
+
export type PrometheusMetricValueSchema = typeof PrometheusMetricValueSchema
|
|
4
|
+
export const PrometheusMetricValueSchema = asSchema('network.xyo.prometheus.metric.value', true)
|
package/src/Witness.ts
CHANGED
|
@@ -5,15 +5,17 @@ import { exists } from '@xylabs/exists'
|
|
|
5
5
|
import { AbstractWitness } from '@xyo-network/abstract-witness'
|
|
6
6
|
import type { AnyConfigSchema } from '@xyo-network/module-model'
|
|
7
7
|
import { creatableModule } from '@xyo-network/module-model'
|
|
8
|
-
import
|
|
8
|
+
import {
|
|
9
|
+
asSchema, type Payload, type Schema,
|
|
10
|
+
} from '@xyo-network/payload-model'
|
|
9
11
|
import type { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'
|
|
10
12
|
import { collectDefaultMetrics, Registry } from 'prom-client'
|
|
11
13
|
|
|
12
14
|
import type { PrometheusMetricValuePayload } from './Payload.ts'
|
|
13
15
|
import { PrometheusMetricValueSchema } from './Schema.ts'
|
|
14
16
|
|
|
15
|
-
export type PrometheusNodeWitnessConfigSchema =
|
|
16
|
-
export const PrometheusNodeWitnessConfigSchema
|
|
17
|
+
export type PrometheusNodeWitnessConfigSchema = typeof PrometheusNodeWitnessConfigSchema
|
|
18
|
+
export const PrometheusNodeWitnessConfigSchema = asSchema('network.xyo.prometheus.node.witness.config', true)
|
|
17
19
|
|
|
18
20
|
export type PrometheusNodeWitnessConfig = WitnessConfig<{
|
|
19
21
|
port?: number
|