@xyo-network/prometheus-node-plugin 2.99.6 → 3.0.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.
Files changed (72) hide show
  1. package/dist/node/index.d.ts +61 -5
  2. package/dist/node/index.mjs +8 -11
  3. package/dist/node/index.mjs.map +1 -1
  4. package/package.json +12 -21
  5. package/src/Witness.ts +7 -9
  6. package/src/index.ts +1 -1
  7. package/xy.config.ts +2 -1
  8. package/dist/neutral/Payload.d.cts +0 -10
  9. package/dist/neutral/Payload.d.cts.map +0 -1
  10. package/dist/neutral/Payload.d.mts +0 -10
  11. package/dist/neutral/Payload.d.mts.map +0 -1
  12. package/dist/neutral/Payload.d.ts +0 -10
  13. package/dist/neutral/Payload.d.ts.map +0 -1
  14. package/dist/neutral/Plugin.d.cts +0 -20
  15. package/dist/neutral/Plugin.d.cts.map +0 -1
  16. package/dist/neutral/Plugin.d.mts +0 -20
  17. package/dist/neutral/Plugin.d.mts.map +0 -1
  18. package/dist/neutral/Plugin.d.ts +0 -20
  19. package/dist/neutral/Plugin.d.ts.map +0 -1
  20. package/dist/neutral/Schema.d.cts +0 -3
  21. package/dist/neutral/Schema.d.cts.map +0 -1
  22. package/dist/neutral/Schema.d.mts +0 -3
  23. package/dist/neutral/Schema.d.mts.map +0 -1
  24. package/dist/neutral/Schema.d.ts +0 -3
  25. package/dist/neutral/Schema.d.ts.map +0 -1
  26. package/dist/neutral/Witness.d.cts +0 -25
  27. package/dist/neutral/Witness.d.cts.map +0 -1
  28. package/dist/neutral/Witness.d.mts +0 -25
  29. package/dist/neutral/Witness.d.mts.map +0 -1
  30. package/dist/neutral/Witness.d.ts +0 -25
  31. package/dist/neutral/Witness.d.ts.map +0 -1
  32. package/dist/neutral/index.cjs +0 -94
  33. package/dist/neutral/index.cjs.map +0 -1
  34. package/dist/neutral/index.d.cts +0 -5
  35. package/dist/neutral/index.d.cts.map +0 -1
  36. package/dist/neutral/index.d.mts +0 -5
  37. package/dist/neutral/index.d.mts.map +0 -1
  38. package/dist/neutral/index.d.ts +0 -5
  39. package/dist/neutral/index.d.ts.map +0 -1
  40. package/dist/neutral/index.mjs +0 -71
  41. package/dist/neutral/index.mjs.map +0 -1
  42. package/dist/node/Payload.d.cts +0 -10
  43. package/dist/node/Payload.d.cts.map +0 -1
  44. package/dist/node/Payload.d.mts +0 -10
  45. package/dist/node/Payload.d.mts.map +0 -1
  46. package/dist/node/Payload.d.ts +0 -10
  47. package/dist/node/Payload.d.ts.map +0 -1
  48. package/dist/node/Plugin.d.cts +0 -20
  49. package/dist/node/Plugin.d.cts.map +0 -1
  50. package/dist/node/Plugin.d.mts +0 -20
  51. package/dist/node/Plugin.d.mts.map +0 -1
  52. package/dist/node/Plugin.d.ts +0 -20
  53. package/dist/node/Plugin.d.ts.map +0 -1
  54. package/dist/node/Schema.d.cts +0 -3
  55. package/dist/node/Schema.d.cts.map +0 -1
  56. package/dist/node/Schema.d.mts +0 -3
  57. package/dist/node/Schema.d.mts.map +0 -1
  58. package/dist/node/Schema.d.ts +0 -3
  59. package/dist/node/Schema.d.ts.map +0 -1
  60. package/dist/node/Witness.d.cts +0 -25
  61. package/dist/node/Witness.d.cts.map +0 -1
  62. package/dist/node/Witness.d.mts +0 -25
  63. package/dist/node/Witness.d.mts.map +0 -1
  64. package/dist/node/Witness.d.ts +0 -25
  65. package/dist/node/Witness.d.ts.map +0 -1
  66. package/dist/node/index.cjs +0 -102
  67. package/dist/node/index.cjs.map +0 -1
  68. package/dist/node/index.d.cts +0 -5
  69. package/dist/node/index.d.cts.map +0 -1
  70. package/dist/node/index.d.mts +0 -5
  71. package/dist/node/index.d.mts.map +0 -1
  72. package/dist/node/index.d.ts.map +0 -1
@@ -1,5 +1,61 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
1
+ import * as _xyo_network_payload_model from '@xyo-network/payload-model';
2
+ import { Payload, Schema } from '@xyo-network/payload-model';
3
+ import { Aggregator, MetricType, Registry } from 'prom-client';
4
+ import * as _xyo_network_payloadset_plugin from '@xyo-network/payloadset-plugin';
5
+ import { Server } from 'node:http';
6
+ import { AbstractWitness } from '@xyo-network/abstract-witness';
7
+ import * as _xyo_network_module_model from '@xyo-network/module-model';
8
+ import { AnyConfigSchema } from '@xyo-network/module-model';
9
+ import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
10
+ import * as _store__xyo_network_account_model_virtual_96c2d52d44_package from '.store/@xyo-network-account-model-virtual-96c2d52d44/package';
11
+ import * as _store__xylabs_object_npm_4_0_1_bb8d73c5f0_package from '.store/@xylabs-object-npm-4.0.1-bb8d73c5f0/package';
12
+
13
+ type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
14
+ declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
15
+
16
+ type PrometheusMetricValuePayload = Payload<{
17
+ aggregator: Aggregator;
18
+ name: string;
19
+ type: MetricType;
20
+ values: (number | string | object)[];
21
+ }, PrometheusMetricValueSchema>;
22
+
23
+ type PrometheusNodeWitnessConfigSchema = 'network.xyo.prometheus.node.witness.config';
24
+ declare const PrometheusNodeWitnessConfigSchema: PrometheusNodeWitnessConfigSchema;
25
+ type PrometheusNodeWitnessConfig = WitnessConfig<{
26
+ port?: number;
27
+ schema: PrometheusNodeWitnessConfigSchema;
28
+ }>;
29
+ type PrometheusNodeWitnessParams = WitnessParams<AnyConfigSchema<PrometheusNodeWitnessConfig>>;
30
+ declare class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams = PrometheusNodeWitnessParams> extends AbstractWitness<TParams> {
31
+ static readonly configSchemas: Schema[];
32
+ static readonly defaultConfigSchema: Schema;
33
+ protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
34
+ protected server?: Server;
35
+ get registry(): Registry;
36
+ protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
37
+ protected startHandler(): Promise<boolean>;
38
+ protected stopHandler(): Promise<boolean>;
39
+ private generateMetricValues;
40
+ }
41
+
42
+ declare const PrometheusNodePlugin: () => _xyo_network_payloadset_plugin.PayloadSetWitnessPlugin<PrometheusNodeWitness<_store__xylabs_object_npm_4_0_1_bb8d73c5f0_package.BaseParamsFields & {
43
+ account?: _store__xyo_network_account_model_virtual_96c2d52d44_package.AccountInstance | "random";
44
+ addToResolvers?: boolean;
45
+ additionalSigners?: _store__xyo_network_account_model_virtual_96c2d52d44_package.AccountInstance[];
46
+ allowNameResolution?: boolean;
47
+ config: _xyo_network_payload_model.SchemaFields & _xyo_network_payload_model.PayloadFields & Omit<_xyo_network_module_model.ArchivingModuleConfig & _xyo_network_module_model.ModuleConfigFields & _xyo_network_payload_model.SchemaFields & _xyo_network_payload_model.PayloadFields & Omit<_xyo_network_module_model.ArchivingModuleConfig & _xyo_network_module_model.ModuleConfigFields & {
48
+ schema: "network.xyo.prometheus.node.witness.config";
49
+ } & {
50
+ port?: number;
51
+ schema: PrometheusNodeWitnessConfigSchema;
52
+ }, "schema"> & {
53
+ schema: "network.xyo.prometheus.node.witness.config";
54
+ }, "schema"> & {
55
+ schema: string;
56
+ };
57
+ ephemeralQueryAccountEnabled?: boolean;
58
+ moduleIdentifierTransformers?: _xyo_network_module_model.ModuleIdentifierTransformer[];
59
+ }>>;
60
+
61
+ export { type PrometheusMetricValuePayload, PrometheusMetricValueSchema, PrometheusNodePlugin, PrometheusNodeWitness, type PrometheusNodeWitnessConfig, PrometheusNodeWitnessConfigSchema, type PrometheusNodeWitnessParams, PrometheusNodePlugin as default };
@@ -7,7 +7,7 @@ var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
7
7
 
8
8
  // src/Witness.ts
9
9
  import { createServer } from "node:http";
10
- import { compact } from "@xylabs/lodash";
10
+ import { exists } from "@xylabs/exists";
11
11
  import { AbstractWitness } from "@xyo-network/abstract-witness";
12
12
  import { creatableModule } from "@xyo-network/module-model";
13
13
  import { collectDefaultMetrics, Registry } from "prom-client";
@@ -36,19 +36,16 @@ var PrometheusNodeWitness = class extends AbstractWitness {
36
36
  return await super.startHandler();
37
37
  }
38
38
  async stopHandler() {
39
- var _a;
40
- (_a = this.server) == null ? void 0 : _a.close();
39
+ this.server?.close();
41
40
  return await super.stopHandler();
42
41
  }
43
42
  async generateMetricValues() {
44
- return compact(
45
- (await this._registry.getMetricsAsJSON()).map((metric) => {
46
- const values = metric.values;
47
- if (values) {
48
- return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
49
- }
50
- })
51
- );
43
+ return (await this._registry.getMetricsAsJSON()).map((metric) => {
44
+ const values = metric.values;
45
+ if (values) {
46
+ return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
47
+ }
48
+ }).filter(exists);
52
49
  }
53
50
  };
54
51
 
@@ -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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\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 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<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACAvC,IAAM,8BAA2D;;;ACDxE,SAAS,oBAA4B;AAErC,SAAS,eAAe;AACxB,SAAS,uBAAuB;AAChC,SAA0B,uBAAuB;AAGjD,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAuE;AASpF,gBAAgB;AACT,IAAM,wBAAN,cAA+G,gBAAyB;AAAA,EAC7I,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,cAAgC;AAnD3D;AAoDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,WAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF5DO,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":[]}
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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { exists } from '@xylabs/exists'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\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 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<boolean> {\n this.server?.close()\n return 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 { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }).filter(exists)\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACAvC,IAAM,8BAA2D;;;ACDxE,SAAS,oBAA4B;AAErC,SAAS,cAAc;AACvB,SAAS,uBAAuB;AAChC,SAA0B,uBAAuB;AAGjD,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAuE;AASpF,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,cAAgC;AACvD,SAAK,QAAQ,MAAM;AACnB,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,YAAQ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AAC/D,YAAM,SAAS,OAAO;AACtB,UAAI,QAAQ;AACV,eAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,MAC5H;AAAA,IACF,CAAC,EAAE,OAAO,MAAM;AAAA,EAClB;AACF;;;AF1DO,IAAM,uBAAuB,MAClC;AAAA,EACE,EAAE,UAAU,EAAE,CAAC,2BAA2B,GAAG,EAAE,GAAG,QAAQ,iBAAiB;AAAA,EAC3E;AAAA,IACE,SAAS,OAAO,WAAW;AACzB,YAAM,SAAS,MAAM,sBAAsB,OAAO,MAAM;AACxD,aAAO;AAAA,IACT;AAAA,EACF;AACF;","names":[]}
package/package.json CHANGED
@@ -10,37 +10,28 @@
10
10
  "url": "https://github.com/XYOracleNetwork/plugins/issues"
11
11
  },
12
12
  "dependencies": {
13
- "@xylabs/lodash": "^3.6.12",
14
- "@xyo-network/abstract-witness": "^2.111.3",
15
- "@xyo-network/module-model": "^2.111.3",
16
- "@xyo-network/payload-model": "^2.111.3",
17
- "@xyo-network/payloadset-plugin": "^2.111.3",
18
- "@xyo-network/witness-model": "^2.111.3",
13
+ "@xylabs/exists": "^4.0.1",
14
+ "@xyo-network/abstract-witness": "^3.0.2",
15
+ "@xyo-network/module-model": "^3.0.2",
16
+ "@xyo-network/payload-model": "^3.0.2",
17
+ "@xyo-network/payloadset-plugin": "^3.0.2",
18
+ "@xyo-network/witness-model": "^3.0.2",
19
19
  "prom-client": "^15.1.3"
20
20
  },
21
21
  "devDependencies": {
22
- "@xylabs/ts-scripts-yarn3": "^3.15.14",
23
- "@xylabs/tsconfig": "^3.15.14",
24
- "@xyo-network/payload-wrapper": "^2.111.3",
22
+ "@xylabs/ts-scripts-yarn3": "^4.0.0-rc.15",
23
+ "@xylabs/tsconfig": "^4.0.0-rc.15",
24
+ "@xyo-network/payload-wrapper": "^3.0.2",
25
25
  "typescript": "^5.5.4"
26
26
  },
27
27
  "description": "Typescript/Javascript Plugins for XYO Platform",
28
28
  "exports": {
29
29
  ".": {
30
- "node": {
31
- "require": {
32
- "types": "./dist/node/index.d.cts",
33
- "default": "./dist/node/index.cjs"
34
- },
35
- "import": {
36
- "types": "./dist/node/index.d.mts",
37
- "default": "./dist/node/index.mjs"
38
- }
39
- }
30
+ "types": "./dist/node/index.d.ts",
31
+ "default": "./dist/node/index.mjs"
40
32
  },
41
33
  "./package.json": "./package.json"
42
34
  },
43
- "main": "dist/node/index.cjs",
44
35
  "module": "dist/node/index.mjs",
45
36
  "types": "dist/node/index.d.ts",
46
37
  "homepage": "https://xyo.network",
@@ -53,6 +44,6 @@
53
44
  "url": "https://github.com/XYOracleNetwork/plugins.git"
54
45
  },
55
46
  "sideEffects": false,
56
- "version": "2.99.6",
47
+ "version": "3.0.1",
57
48
  "type": "module"
58
49
  }
package/src/Witness.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { createServer, Server } from 'node:http'
2
2
 
3
- import { compact } from '@xylabs/lodash'
3
+ import { exists } from '@xylabs/exists'
4
4
  import { AbstractWitness } from '@xyo-network/abstract-witness'
5
5
  import { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'
6
6
  import { Payload, Schema } from '@xyo-network/payload-model'
@@ -55,13 +55,11 @@ export class PrometheusNodeWitness<TParams extends PrometheusNodeWitnessParams =
55
55
  }
56
56
 
57
57
  private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {
58
- return compact(
59
- (await this._registry.getMetricsAsJSON()).map((metric) => {
60
- const values = metric.values
61
- if (values) {
62
- return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }
63
- }
64
- }),
65
- )
58
+ return (await this._registry.getMetricsAsJSON()).map((metric) => {
59
+ const values = metric.values
60
+ if (values) {
61
+ return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }
62
+ }
63
+ }).filter(exists)
66
64
  }
67
65
  }
package/src/index.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  export * from './Payload.ts'
2
- // eslint-disable-next-line import/no-default-export
2
+ // eslint-disable-next-line import-x/no-default-export
3
3
  export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts'
4
4
  export * from './Schema.ts'
5
5
  export * from './Witness.ts'
package/xy.config.ts CHANGED
@@ -5,8 +5,9 @@ const config: XyTsupConfig = {
5
5
  node: {
6
6
  src: true,
7
7
  },
8
+ neutral: {},
8
9
  },
9
10
  }
10
11
 
11
- // eslint-disable-next-line import/no-default-export
12
+ // eslint-disable-next-line import-x/no-default-export
12
13
  export default config
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,94 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- PrometheusMetricValueSchema: () => PrometheusMetricValueSchema,
24
- PrometheusNodePlugin: () => PrometheusNodePlugin,
25
- PrometheusNodeWitness: () => PrometheusNodeWitness,
26
- PrometheusNodeWitnessConfigSchema: () => PrometheusNodeWitnessConfigSchema,
27
- default: () => PrometheusNodePlugin
28
- });
29
- module.exports = __toCommonJS(src_exports);
30
-
31
- // src/Plugin.ts
32
- var import_payload_model = require("@xyo-network/payload-model");
33
- var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
34
-
35
- // src/Schema.ts
36
- var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
37
-
38
- // src/Witness.ts
39
- var import_node_http = require("http");
40
- var import_lodash = require("@xylabs/lodash");
41
- var import_abstract_witness = require("@xyo-network/abstract-witness");
42
- var import_module_model = require("@xyo-network/module-model");
43
- var import_prom_client = require("prom-client");
44
- var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
45
- (0, import_module_model.creatableModule)();
46
- var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitness {
47
- static configSchemas = [...super.configSchemas, PrometheusNodeWitnessConfigSchema];
48
- static defaultConfigSchema = PrometheusNodeWitnessConfigSchema;
49
- _registry = new import_prom_client.Registry();
50
- server;
51
- get registry() {
52
- return this._registry;
53
- }
54
- async observeHandler(_payloads) {
55
- return await this.generateMetricValues();
56
- }
57
- async startHandler() {
58
- (0, import_prom_client.collectDefaultMetrics)({ register: this._registry });
59
- if (this.config.port) {
60
- this.server = (0, import_node_http.createServer)(async (_request, response) => {
61
- response.writeHead(200);
62
- response.end(await this._registry.metrics());
63
- });
64
- this.server.listen(this.config.port);
65
- }
66
- return await super.startHandler();
67
- }
68
- async stopHandler() {
69
- this.server?.close();
70
- return await super.stopHandler();
71
- }
72
- async generateMetricValues() {
73
- return (0, import_lodash.compact)(
74
- (await this._registry.getMetricsAsJSON()).map((metric) => {
75
- const values = metric.values;
76
- if (values) {
77
- return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
78
- }
79
- })
80
- );
81
- }
82
- };
83
-
84
- // src/Plugin.ts
85
- var PrometheusNodePlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
86
- { required: { [PrometheusMetricValueSchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
87
- {
88
- witness: async (params) => {
89
- const result = await PrometheusNodeWitness.create(params);
90
- return result;
91
- }
92
- }
93
- );
94
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["export * from './Payload.ts'\n// eslint-disable-next-line import/no-default-export\nexport { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts'\nexport * from './Schema.ts'\nexport * from './Witness.ts'\n","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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\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 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<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,2BAAiC;AACjC,+BAA8C;;;ACAvC,IAAM,8BAA2D;;;ACDxE,uBAAqC;AAErC,oBAAwB;AACxB,8BAAgC;AAChC,0BAAiD;AAGjD,yBAAgD;AAMzC,IAAM,oCAAuE;AAAA,IASpF,qCAAgB;AACT,IAAM,wBAAN,cAA+G,wCAAyB;AAAA,EAC7I,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,iCAAiC;AAAA,EAC7G,OAAyB,sBAA8B;AAAA,EAC7C,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;AAEpB,WAAK,aAAS,+BAAa,OAAO,UAAU,aAAa;AACvD,iBAAS,UAAU,GAAG;AAEtB,iBAAS,IAAI,MAAM,KAAK,UAAU,QAAQ,CAAC;AAAA,MAC7C,CAAC;AACD,WAAK,OAAO,OAAO,KAAK,OAAO,IAAI;AAAA,IACrC;AACA,WAAO,MAAM,MAAM,aAAa;AAAA,EAClC;AAAA,EAEA,MAAyB,cAAgC;AACvD,SAAK,QAAQ,MAAM;AACnB,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,eAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF5DO,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":[]}
@@ -1,5 +0,0 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
@@ -1,5 +0,0 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
@@ -1,5 +0,0 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
@@ -1,71 +0,0 @@
1
- // src/Plugin.ts
2
- import { PayloadSetSchema } from "@xyo-network/payload-model";
3
- import { createPayloadSetWitnessPlugin } from "@xyo-network/payloadset-plugin";
4
-
5
- // src/Schema.ts
6
- var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
7
-
8
- // src/Witness.ts
9
- import { createServer } from "node:http";
10
- import { compact } from "@xylabs/lodash";
11
- import { AbstractWitness } from "@xyo-network/abstract-witness";
12
- import { creatableModule } from "@xyo-network/module-model";
13
- import { collectDefaultMetrics, Registry } from "prom-client";
14
- var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
15
- creatableModule();
16
- var PrometheusNodeWitness = class extends AbstractWitness {
17
- static configSchemas = [...super.configSchemas, PrometheusNodeWitnessConfigSchema];
18
- static defaultConfigSchema = PrometheusNodeWitnessConfigSchema;
19
- _registry = new Registry();
20
- server;
21
- get registry() {
22
- return this._registry;
23
- }
24
- async observeHandler(_payloads) {
25
- return await this.generateMetricValues();
26
- }
27
- async startHandler() {
28
- collectDefaultMetrics({ register: this._registry });
29
- if (this.config.port) {
30
- this.server = createServer(async (_request, response) => {
31
- response.writeHead(200);
32
- response.end(await this._registry.metrics());
33
- });
34
- this.server.listen(this.config.port);
35
- }
36
- return await super.startHandler();
37
- }
38
- async stopHandler() {
39
- this.server?.close();
40
- return await super.stopHandler();
41
- }
42
- async generateMetricValues() {
43
- return compact(
44
- (await this._registry.getMetricsAsJSON()).map((metric) => {
45
- const values = metric.values;
46
- if (values) {
47
- return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
48
- }
49
- })
50
- );
51
- }
52
- };
53
-
54
- // src/Plugin.ts
55
- var PrometheusNodePlugin = () => createPayloadSetWitnessPlugin(
56
- { required: { [PrometheusMetricValueSchema]: 1 }, schema: PayloadSetSchema },
57
- {
58
- witness: async (params) => {
59
- const result = await PrometheusNodeWitness.create(params);
60
- return result;
61
- }
62
- }
63
- );
64
- export {
65
- PrometheusMetricValueSchema,
66
- PrometheusNodePlugin,
67
- PrometheusNodeWitness,
68
- PrometheusNodeWitnessConfigSchema,
69
- PrometheusNodePlugin as default
70
- };
71
- //# sourceMappingURL=index.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["import { PayloadSetSchema } from '@xyo-network/payload-model'\nimport { createPayloadSetWitnessPlugin } from '@xyo-network/payloadset-plugin'\n\nimport { PrometheusMetricValueSchema } from './Schema.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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\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 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<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";AAAA,SAAS,wBAAwB;AACjC,SAAS,qCAAqC;;;ACAvC,IAAM,8BAA2D;;;ACDxE,SAAS,oBAA4B;AAErC,SAAS,eAAe;AACxB,SAAS,uBAAuB;AAChC,SAA0B,uBAAuB;AAGjD,SAAS,uBAAuB,gBAAgB;AAMzC,IAAM,oCAAuE;AASpF,gBAAgB;AACT,IAAM,wBAAN,cAA+G,gBAAyB;AAAA,EAC7I,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,cAAgC;AACvD,SAAK,QAAQ,MAAM;AACnB,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,WAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF5DO,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":[]}
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,10 +0,0 @@
1
- import { Payload } from '@xyo-network/payload-model';
2
- import { Aggregator, MetricType } from 'prom-client';
3
- import { PrometheusMetricValueSchema } from './Schema.ts';
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
@@ -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,aAAa,CAAA;AAEzD,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"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,20 +0,0 @@
1
- import { PrometheusNodeWitness } from './Witness.ts';
2
- export declare const PrometheusNodePlugin: () => import("@xyo-network/payloadset-plugin").PayloadSetWitnessPlugin<PrometheusNodeWitness<import(".store/@xylabs-object-npm-3.6.12-443b813787/package").BaseParamsFields & {
3
- account?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance | "random";
4
- addToResolvers?: boolean;
5
- additionalSigners?: import(".store/@xyo-network-account-model-virtual-c593258ccf/package").AccountInstance[];
6
- allowNameResolution?: boolean;
7
- config: import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & import("@xyo-network/payload-model").SchemaFields & import("@xyo-network/payload-model").PayloadFields & Omit<import("@xyo-network/module-model").ArchivingModuleConfig & import("@xyo-network/module-model").ModuleConfigFields & {
8
- schema: "network.xyo.prometheus.node.witness.config";
9
- } & {
10
- port?: number;
11
- schema: import("./Witness.ts").PrometheusNodeWitnessConfigSchema;
12
- }, "schema"> & {
13
- schema: "network.xyo.prometheus.node.witness.config";
14
- }, "schema"> & {
15
- schema: string;
16
- };
17
- ephemeralQueryAccountEnabled?: boolean;
18
- moduleIdentifierTransformers?: import("@xyo-network/module-model").ModuleIdentifierTransformer[];
19
- }>>;
20
- //# sourceMappingURL=Plugin.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Plugin.d.ts","sourceRoot":"","sources":["../../src/Plugin.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAEpD,eAAO,MAAM,oBAAoB;;;;;;;;;;;;;;;;;GAS9B,CAAA"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,3 +0,0 @@
1
- export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value';
2
- export declare const PrometheusMetricValueSchema: PrometheusMetricValueSchema;
3
- //# sourceMappingURL=Schema.d.ts.map
@@ -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"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,25 +0,0 @@
1
- import { Server } from 'node:http';
2
- import { AbstractWitness } from '@xyo-network/abstract-witness';
3
- import { AnyConfigSchema } from '@xyo-network/module-model';
4
- import { Payload, Schema } from '@xyo-network/payload-model';
5
- import { WitnessConfig, WitnessParams } from '@xyo-network/witness-model';
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 readonly configSchemas: Schema[];
16
- static readonly defaultConfigSchema: Schema;
17
- protected _registry: Registry<"text/plain; version=0.0.4; charset=utf-8">;
18
- protected server?: Server;
19
- get registry(): Registry;
20
- protected observeHandler(_payloads?: Partial<Payload>[]): Promise<Payload[]>;
21
- protected startHandler(): Promise<boolean>;
22
- protected stopHandler(): Promise<boolean>;
23
- private generateMetricValues;
24
- }
25
- //# sourceMappingURL=Witness.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Witness.d.ts","sourceRoot":"","sources":["../../src/Witness.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,MAAM,EAAE,MAAM,WAAW,CAAA;AAGhD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAC/D,OAAO,EAAE,eAAe,EAAmB,MAAM,2BAA2B,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAC5D,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAA;AACzE,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,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,OAAO,CAAC;YAK1C,oBAAoB;CAUnC"}
@@ -1,102 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/index.ts
21
- var src_exports = {};
22
- __export(src_exports, {
23
- PrometheusMetricValueSchema: () => PrometheusMetricValueSchema,
24
- PrometheusNodePlugin: () => PrometheusNodePlugin,
25
- PrometheusNodeWitness: () => PrometheusNodeWitness,
26
- PrometheusNodeWitnessConfigSchema: () => PrometheusNodeWitnessConfigSchema,
27
- default: () => PrometheusNodePlugin
28
- });
29
- module.exports = __toCommonJS(src_exports);
30
-
31
- // src/Plugin.ts
32
- var import_payload_model = require("@xyo-network/payload-model");
33
- var import_payloadset_plugin = require("@xyo-network/payloadset-plugin");
34
-
35
- // src/Schema.ts
36
- var PrometheusMetricValueSchema = "network.xyo.prometheus.metric.value";
37
-
38
- // src/Witness.ts
39
- var import_node_http = require("http");
40
- var import_lodash = require("@xylabs/lodash");
41
- var import_abstract_witness = require("@xyo-network/abstract-witness");
42
- var import_module_model = require("@xyo-network/module-model");
43
- var import_prom_client = require("prom-client");
44
- var PrometheusNodeWitnessConfigSchema = "network.xyo.prometheus.node.witness.config";
45
- (0, import_module_model.creatableModule)();
46
- var PrometheusNodeWitness = class extends import_abstract_witness.AbstractWitness {
47
- static configSchemas = [...super.configSchemas, PrometheusNodeWitnessConfigSchema];
48
- static defaultConfigSchema = PrometheusNodeWitnessConfigSchema;
49
- _registry = new import_prom_client.Registry();
50
- server;
51
- get registry() {
52
- return this._registry;
53
- }
54
- async observeHandler(_payloads) {
55
- return await this.generateMetricValues();
56
- }
57
- async startHandler() {
58
- (0, import_prom_client.collectDefaultMetrics)({ register: this._registry });
59
- if (this.config.port) {
60
- this.server = (0, import_node_http.createServer)(async (_request, response) => {
61
- response.writeHead(200);
62
- response.end(await this._registry.metrics());
63
- });
64
- this.server.listen(this.config.port);
65
- }
66
- return await super.startHandler();
67
- }
68
- async stopHandler() {
69
- var _a;
70
- (_a = this.server) == null ? void 0 : _a.close();
71
- return await super.stopHandler();
72
- }
73
- async generateMetricValues() {
74
- return (0, import_lodash.compact)(
75
- (await this._registry.getMetricsAsJSON()).map((metric) => {
76
- const values = metric.values;
77
- if (values) {
78
- return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values };
79
- }
80
- })
81
- );
82
- }
83
- };
84
-
85
- // src/Plugin.ts
86
- var PrometheusNodePlugin = () => (0, import_payloadset_plugin.createPayloadSetWitnessPlugin)(
87
- { required: { [PrometheusMetricValueSchema]: 1 }, schema: import_payload_model.PayloadSetSchema },
88
- {
89
- witness: async (params) => {
90
- const result = await PrometheusNodeWitness.create(params);
91
- return result;
92
- }
93
- }
94
- );
95
- // Annotate the CommonJS export names for ESM import in node:
96
- 0 && (module.exports = {
97
- PrometheusMetricValueSchema,
98
- PrometheusNodePlugin,
99
- PrometheusNodeWitness,
100
- PrometheusNodeWitnessConfigSchema
101
- });
102
- //# sourceMappingURL=index.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/Plugin.ts","../../src/Schema.ts","../../src/Witness.ts"],"sourcesContent":["export * from './Payload.ts'\n// eslint-disable-next-line import/no-default-export\nexport { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts'\nexport * from './Schema.ts'\nexport * from './Witness.ts'\n","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","export type PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\nexport const PrometheusMetricValueSchema: PrometheusMetricValueSchema = 'network.xyo.prometheus.metric.value'\n","import { createServer, Server } from 'node:http'\n\nimport { compact } from '@xylabs/lodash'\nimport { AbstractWitness } from '@xyo-network/abstract-witness'\nimport { AnyConfigSchema, creatableModule } from '@xyo-network/module-model'\nimport { Payload, Schema } from '@xyo-network/payload-model'\nimport { WitnessConfig, WitnessParams } from '@xyo-network/witness-model'\nimport { collectDefaultMetrics, Registry } from 'prom-client'\n\nimport { PrometheusMetricValuePayload } from './Payload.ts'\nimport { PrometheusMetricValueSchema } from './Schema.ts'\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 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<boolean> {\n this.server?.close()\n return await super.stopHandler()\n }\n\n private async generateMetricValues(): Promise<PrometheusMetricValuePayload[]> {\n return compact(\n (await this._registry.getMetricsAsJSON()).map((metric) => {\n const values = metric.values\n if (values) {\n return { aggregator: metric.aggregator, name: metric.name, schema: PrometheusMetricValueSchema, type: metric.type, values }\n }\n }),\n )\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAA,2BAAiC;AACjC,+BAA8C;;;ACAvC,IAAM,8BAA2D;;;ACDxE,uBAAqC;AAErC,oBAAwB;AACxB,8BAAgC;AAChC,0BAAiD;AAGjD,yBAAgD;AAMzC,IAAM,oCAAuE;AAAA,IASpF,qCAAgB;AACT,IAAM,wBAAN,cAA+G,wCAAyB;AAAA,EAC7I,OAAyB,gBAA0B,CAAC,GAAG,MAAM,eAAe,iCAAiC;AAAA,EAC7G,OAAyB,sBAA8B;AAAA,EAC7C,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;AAEpB,WAAK,aAAS,+BAAa,OAAO,UAAU,aAAa;AACvD,iBAAS,UAAU,GAAG;AAEtB,iBAAS,IAAI,MAAM,KAAK,UAAU,QAAQ,CAAC;AAAA,MAC7C,CAAC;AACD,WAAK,OAAO,OAAO,KAAK,OAAO,IAAI;AAAA,IACrC;AACA,WAAO,MAAM,MAAM,aAAa;AAAA,EAClC;AAAA,EAEA,MAAyB,cAAgC;AAnD3D;AAoDI,eAAK,WAAL,mBAAa;AACb,WAAO,MAAM,MAAM,YAAY;AAAA,EACjC;AAAA,EAEA,MAAc,uBAAgE;AAC5E,eAAO;AAAA,OACJ,MAAM,KAAK,UAAU,iBAAiB,GAAG,IAAI,CAAC,WAAW;AACxD,cAAM,SAAS,OAAO;AACtB,YAAI,QAAQ;AACV,iBAAO,EAAE,YAAY,OAAO,YAAY,MAAM,OAAO,MAAM,QAAQ,6BAA6B,MAAM,OAAO,MAAM,OAAO;AAAA,QAC5H;AAAA,MACF,CAAC;AAAA,IACH;AAAA,EACF;AACF;;;AF5DO,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":[]}
@@ -1,5 +0,0 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
@@ -1,5 +0,0 @@
1
- export * from './Payload.ts';
2
- export { PrometheusNodePlugin as default, PrometheusNodePlugin } from './Plugin.ts';
3
- export * from './Schema.ts';
4
- export * from './Witness.ts';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAE5B,OAAO,EAAE,oBAAoB,IAAI,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAA;AACnF,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA"}