@xyo-network/prometheus-node-plugin 2.74.5 → 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 +576 -576
- package/dist/node/Payload.d.cts.map +1 -0
- package/dist/node/Payload.d.mts.map +1 -0
- package/dist/node/Payload.d.ts +10 -0
- package/dist/node/Payload.d.ts.map +1 -0
- package/dist/node/Payload.js +19 -0
- package/dist/node/Payload.js.map +1 -0
- package/dist/node/Payload.mjs +1 -0
- package/dist/node/Payload.mjs.map +1 -0
- package/dist/node/Plugin.d.cts.map +1 -0
- package/dist/node/Plugin.d.mts.map +1 -0
- package/dist/node/Plugin.d.ts +55 -0
- package/dist/node/Plugin.d.ts.map +1 -0
- package/dist/node/Plugin.js +92 -0
- package/dist/node/Plugin.js.map +1 -0
- package/dist/node/Plugin.mjs +67 -0
- package/dist/node/Plugin.mjs.map +1 -0
- package/dist/node/Schema.d.cts.map +1 -0
- package/dist/node/Schema.d.mts.map +1 -0
- package/dist/node/Schema.d.ts +3 -0
- package/dist/node/Schema.d.ts.map +1 -0
- package/dist/node/Schema.js +31 -0
- package/dist/node/Schema.js.map +1 -0
- package/dist/node/Schema.mjs +6 -0
- package/dist/node/Schema.mjs.map +1 -0
- package/dist/node/Witness.d.cts.map +1 -0
- package/dist/node/Witness.d.mts.map +1 -0
- package/dist/node/Witness.d.ts +24 -0
- package/dist/node/Witness.d.ts.map +1 -0
- package/dist/node/Witness.js +81 -0
- package/dist/node/Witness.js.map +1 -0
- package/dist/node/Witness.mjs +55 -0
- package/dist/node/Witness.mjs.map +1 -0
- package/dist/node/index.d.cts.map +1 -0
- package/dist/node/index.d.mts.map +1 -0
- package/dist/node/index.d.ts +7 -0
- package/dist/node/index.d.ts.map +1 -0
- package/dist/{index.js → node/index.js} +2 -1
- package/dist/node/index.js.map +1 -0
- package/dist/{index.mjs → node/index.mjs} +2 -1
- package/dist/node/index.mjs.map +1 -0
- package/package.json +28 -27
- package/dist/Payload.d.mts.map +0 -1
- package/dist/Payload.d.ts.map +0 -1
- package/dist/Plugin.d.mts.map +0 -1
- package/dist/Plugin.d.ts.map +0 -1
- package/dist/Schema.d.mts.map +0 -1
- package/dist/Schema.d.ts.map +0 -1
- package/dist/Witness.d.mts.map +0 -1
- package/dist/Witness.d.ts.map +0 -1
- package/dist/index.d.mts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/index.mjs.map +0 -1
- /package/dist/{Payload.d.mts → node/Payload.d.cts} +0 -0
- /package/dist/{Payload.d.ts → node/Payload.d.mts} +0 -0
- /package/dist/{Plugin.d.mts → node/Plugin.d.cts} +0 -0
- /package/dist/{Plugin.d.ts → node/Plugin.d.mts} +0 -0
- /package/dist/{Schema.d.mts → node/Schema.d.cts} +0 -0
- /package/dist/{Schema.d.ts → node/Schema.d.mts} +0 -0
- /package/dist/{Witness.d.mts → node/Witness.d.cts} +0 -0
- /package/dist/{Witness.d.ts → node/Witness.d.mts} +0 -0
- /package/dist/{index.d.mts → node/index.d.cts} +0 -0
- /package/dist/{index.d.ts → node/index.d.mts} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts","../../src/index.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","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":";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;;;AGNF,IAAO,cAAQ;","names":[]}
|
package/package.json
CHANGED
|
@@ -10,48 +10,41 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@xylabs/lodash": "^2.
|
|
14
|
-
"@xyo-network/module": "~2.
|
|
15
|
-
"@xyo-network/payload-model": "~2.
|
|
16
|
-
"@xyo-network/payloadset-plugin": "~2.
|
|
17
|
-
"@xyo-network/witness": "~2.
|
|
13
|
+
"@xylabs/lodash": "^2.12.10",
|
|
14
|
+
"@xyo-network/module": "~2.75.2",
|
|
15
|
+
"@xyo-network/payload-model": "~2.75.2",
|
|
16
|
+
"@xyo-network/payloadset-plugin": "~2.75.2",
|
|
17
|
+
"@xyo-network/witness": "~2.75.2",
|
|
18
18
|
"prom-client": "^14.2.0"
|
|
19
19
|
},
|
|
20
20
|
"devDependencies": {
|
|
21
|
-
"@xylabs/ts-scripts-yarn3": "^3.0.
|
|
22
|
-
"@xylabs/tsconfig": "^3.0.
|
|
21
|
+
"@xylabs/ts-scripts-yarn3": "^3.0.77",
|
|
22
|
+
"@xylabs/tsconfig": "^3.0.77",
|
|
23
23
|
"typescript": "^5.2.2"
|
|
24
24
|
},
|
|
25
25
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
26
26
|
"docs": "dist/docs.json",
|
|
27
|
-
"types": "dist/index.d.ts",
|
|
27
|
+
"types": "dist/node/index.d.ts",
|
|
28
28
|
"exports": {
|
|
29
29
|
".": {
|
|
30
|
-
"
|
|
31
|
-
"
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
"
|
|
36
|
-
|
|
30
|
+
"node": {
|
|
31
|
+
"require": {
|
|
32
|
+
"types": "./dist/node/index.d.ts",
|
|
33
|
+
"default": "./dist/node/index.js"
|
|
34
|
+
},
|
|
35
|
+
"import": {
|
|
36
|
+
"types": "./dist/node/index.d.mts",
|
|
37
|
+
"default": "./dist/node/index.mjs"
|
|
38
|
+
}
|
|
37
39
|
}
|
|
38
40
|
},
|
|
39
|
-
"./dist/docs.json": {
|
|
40
|
-
"default": "./dist/docs.json"
|
|
41
|
-
},
|
|
42
|
-
"./cjs": {
|
|
43
|
-
"default": "./dist/index.js"
|
|
44
|
-
},
|
|
45
41
|
"./docs": {
|
|
46
42
|
"default": "./dist/docs.json"
|
|
47
43
|
},
|
|
48
|
-
"./esm": {
|
|
49
|
-
"default": "./dist/index.mjs"
|
|
50
|
-
},
|
|
51
44
|
"./package.json": "./package.json"
|
|
52
45
|
},
|
|
53
|
-
"main": "dist/index.js",
|
|
54
|
-
"module": "dist/index.mjs",
|
|
46
|
+
"main": "dist/node/index.js",
|
|
47
|
+
"module": "dist/node/index.mjs",
|
|
55
48
|
"homepage": "https://xyo.network",
|
|
56
49
|
"license": "LGPL-3.0",
|
|
57
50
|
"publishConfig": {
|
|
@@ -62,5 +55,13 @@
|
|
|
62
55
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
63
56
|
},
|
|
64
57
|
"sideEffects": false,
|
|
65
|
-
"version": "2.
|
|
58
|
+
"version": "2.75.2",
|
|
59
|
+
"xy": {
|
|
60
|
+
"compile": {
|
|
61
|
+
"browser": false,
|
|
62
|
+
"node": {
|
|
63
|
+
"src": true
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
66
67
|
}
|
package/dist/Payload.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Payload.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Plugin.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Plugin.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Schema.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Schema.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Witness.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/Witness.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/index.d.mts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
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;AAC/B,SAAK,QAAQ,MAAM;AACnB,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":[]}
|
package/dist/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/Plugin.ts","../src/Schema.ts","../src/Witness.ts","../src/index.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","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":";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;AAC/B,SAAK,QAAQ,MAAM;AACnB,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;;;AGNF,IAAO,cAAQ;","names":[]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|