@codefresh-io/cf-telemetry 2.0.0-alpha.8 → 2.0.0

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 (96) hide show
  1. package/README.md +14 -6
  2. package/dist/global-config.d.ts +2 -2
  3. package/dist/global-config.js +3 -2
  4. package/dist/global-config.js.map +1 -1
  5. package/dist/init.d.mts +1 -1
  6. package/dist/init.d.ts +1 -0
  7. package/dist/{index.js → init.js} +23 -17
  8. package/dist/init.js.map +1 -0
  9. package/dist/init.mjs +1 -5
  10. package/dist/init.mjs.map +1 -1
  11. package/dist/logs/express/http-logger-middleware.d.ts +10 -0
  12. package/dist/logs/express/http-logger-middleware.js +30 -0
  13. package/dist/logs/express/http-logger-middleware.js.map +1 -0
  14. package/dist/logs/express/index.d.ts +1 -0
  15. package/dist/logs/express/index.js +6 -0
  16. package/dist/logs/express/index.js.map +1 -0
  17. package/dist/logs/express/public.d.mts +1 -0
  18. package/dist/logs/express/public.d.ts +1 -0
  19. package/dist/logs/express/public.js +7 -0
  20. package/dist/logs/express/public.js.map +1 -0
  21. package/dist/logs/express/public.mjs +3 -0
  22. package/dist/logs/express/public.mjs.map +1 -0
  23. package/dist/logs/logger.js +13 -0
  24. package/dist/logs/logger.js.map +1 -1
  25. package/dist/logs/nest/index.d.ts +2 -0
  26. package/dist/logs/nest/index.js +8 -0
  27. package/dist/logs/nest/index.js.map +1 -0
  28. package/dist/logs/nest/logger-module.d.ts +4 -0
  29. package/dist/logs/nest/logger-module.js +69 -0
  30. package/dist/logs/nest/logger-module.js.map +1 -0
  31. package/dist/logs/nest/logger.d.ts +4 -0
  32. package/dist/logs/nest/logger.js +69 -0
  33. package/dist/logs/nest/logger.js.map +1 -0
  34. package/dist/logs/nest/public.d.mts +1 -0
  35. package/dist/logs/nest/public.d.ts +1 -0
  36. package/dist/logs/nest/public.js +8 -0
  37. package/dist/logs/nest/public.js.map +1 -0
  38. package/dist/logs/nest/public.mjs +3 -0
  39. package/dist/logs/nest/public.mjs.map +1 -0
  40. package/dist/logs/public.d.mts +1 -0
  41. package/dist/logs/public.js +1 -0
  42. package/dist/logs/public.js.map +1 -1
  43. package/dist/logs/public.mjs +3 -0
  44. package/dist/logs/public.mjs.map +1 -0
  45. package/dist/metrics/mongodb/public.d.mts +1 -0
  46. package/dist/metrics/mongodb/public.d.ts +1 -1
  47. package/dist/metrics/mongodb/public.js +3 -2
  48. package/dist/metrics/mongodb/public.js.map +1 -1
  49. package/dist/metrics/mongodb/public.mjs +3 -0
  50. package/dist/metrics/mongodb/public.mjs.map +1 -0
  51. package/dist/metrics/prometheus/client.js +3 -6
  52. package/dist/metrics/prometheus/client.js.map +1 -1
  53. package/dist/metrics/prometheus/config.d.ts +4 -1
  54. package/dist/metrics/prometheus/config.js +19 -1
  55. package/dist/metrics/prometheus/config.js.map +1 -1
  56. package/dist/metrics/prometheus/helpers.d.ts +5 -0
  57. package/dist/metrics/prometheus/helpers.js +16 -0
  58. package/dist/metrics/prometheus/helpers.js.map +1 -0
  59. package/dist/metrics/prometheus/index.d.ts +1 -1
  60. package/dist/metrics/prometheus/index.js +2 -2
  61. package/dist/metrics/prometheus/index.js.map +1 -1
  62. package/dist/metrics/prometheus/{init-prometheus.js → init.js} +12 -2
  63. package/dist/metrics/prometheus/init.js.map +1 -0
  64. package/dist/metrics/prometheus/metrics.d.ts +13 -11
  65. package/dist/metrics/prometheus/metrics.js.map +1 -1
  66. package/dist/metrics/prometheus/public.d.mts +1 -0
  67. package/dist/metrics/prometheus/public.d.ts +5 -2
  68. package/dist/metrics/prometheus/public.js +12 -3
  69. package/dist/metrics/prometheus/public.js.map +1 -1
  70. package/dist/metrics/prometheus/public.mjs +3 -0
  71. package/dist/metrics/prometheus/public.mjs.map +1 -0
  72. package/dist/otel/index.d.ts +1 -1
  73. package/dist/otel/index.js +1 -1
  74. package/dist/otel/index.js.map +1 -1
  75. package/dist/otel/public.d.mts +1 -0
  76. package/dist/otel/public.d.ts +1 -1
  77. package/dist/otel/public.js +5 -24
  78. package/dist/otel/public.js.map +1 -1
  79. package/dist/otel/public.mjs +3 -0
  80. package/dist/otel/public.mjs.map +1 -0
  81. package/dist/otel/sdk.js +10 -18
  82. package/dist/otel/sdk.js.map +1 -1
  83. package/dist/profiles/config.d.ts +2 -1
  84. package/dist/profiles/config.js +15 -9
  85. package/dist/profiles/config.js.map +1 -1
  86. package/dist/profiles/index.d.ts +2 -1
  87. package/dist/profiles/index.js +27 -10
  88. package/dist/profiles/index.js.map +1 -1
  89. package/package.json +29 -31
  90. package/dist/index.d.ts +0 -7
  91. package/dist/index.js.map +0 -1
  92. package/dist/metrics/mongodb/index.d.ts +0 -1
  93. package/dist/metrics/mongodb/index.js +0 -6
  94. package/dist/metrics/mongodb/index.js.map +0 -1
  95. package/dist/metrics/prometheus/init-prometheus.js.map +0 -1
  96. /package/dist/metrics/prometheus/{init-prometheus.d.ts → init.d.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/config.ts"],"names":[],"mappings":";;;AAAa,QAAA,MAAM,GAAG;IACpB,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,gCAAgC,CAAC,KAAK,MAAM;IACjE,2BAA2B,EAAE,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,KAAK,MAAM;IACrG,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,IAAI,SAAS;IAC9D,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,IAAI,MAAM,EAAE,EAAE,CAAC;IAChF,cAAc,EAAE,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,KAAK,MAAM;CAC1E,CAAC"}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/config.ts"],"names":[],"mappings":";;;AAAA,6CAAuC;AACvC,uDAAmD;AAEnD,MAAM,cAAc,GAAG,GAAG,EAAE;IAC1B,MAAM,WAAW,GAAG;QAClB,UAAU,EAAE,sBAAQ,CAAC,uBAAuB;QAC5C,WAAW,EAAE,sBAAQ,CAAC,wBAAwB;KACtC,CAAC;IACX,8DAA8D;IAC9D,MAAM,WAAW,GAA8B,OAAO,CAAC,GAAG,CAAC,sCAAsC,CAAS,IAAI,aAAa,CAAC;IAC5H,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC5C,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,2DAA2D,WAAW,uBAAuB,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACxI,CAAC;IACD,OAAO,WAAW,CAAC,WAAW,CAAC,CAAC;AAClC,CAAC,CAAC;AAEW,QAAA,MAAM,GAAG;IACpB,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,gCAAgC,CAAC,KAAK,MAAM;IACjE,2BAA2B,EAAE,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,KAAK,MAAM;IACrG,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,IAAI,SAAS;IAC9D,IAAI,EAAE,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,8BAA8B,CAAC,IAAI,MAAM,EAAE,EAAE,CAAC;IAChF,WAAW,EAAE,cAAc,EAAE;IAC7B,aAAa,EAAE;QACb,YAAY,EAAE,4BAAY,CAAC,WAAW;KACvC;CACO,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { ExemplarLabels } from './metrics';
2
+ /**
3
+ * Get exemplar labels for Prometheus metrics with enabled exemplars.
4
+ */
5
+ export declare const getExemplarLabels: () => ExemplarLabels;
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getExemplarLabels = void 0;
4
+ const sdk_node_1 = require("@opentelemetry/sdk-node");
5
+ /**
6
+ * Get exemplar labels for Prometheus metrics with enabled exemplars.
7
+ */
8
+ const getExemplarLabels = () => {
9
+ const { spanId, traceId } = sdk_node_1.api.trace.getActiveSpan()?.spanContext() ?? {};
10
+ return {
11
+ ...spanId && { span_id: spanId },
12
+ ...traceId && { trace_id: traceId },
13
+ };
14
+ };
15
+ exports.getExemplarLabels = getExemplarLabels;
16
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/helpers.ts"],"names":[],"mappings":";;;AAAA,sDAA8C;AAG9C;;GAEG;AACI,MAAM,iBAAiB,GAAG,GAAmB,EAAE;IACpD,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,cAAG,CAAC,KAAK,CAAC,aAAa,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;IAC3E,OAAO;QACL,GAAG,MAAM,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE;QAChC,GAAG,OAAO,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE;KACpC,CAAC;AACJ,CAAC,CAAC;AANW,QAAA,iBAAiB,qBAM5B"}
@@ -1,3 +1,3 @@
1
1
  export { client, register } from './client';
2
- export { init } from './init-prometheus';
2
+ export { init } from './init';
3
3
  export * as metrics from './metrics';
@@ -37,7 +37,7 @@ exports.metrics = exports.init = exports.register = exports.client = void 0;
37
37
  var client_1 = require("./client");
38
38
  Object.defineProperty(exports, "client", { enumerable: true, get: function () { return client_1.client; } });
39
39
  Object.defineProperty(exports, "register", { enumerable: true, get: function () { return client_1.register; } });
40
- var init_prometheus_1 = require("./init-prometheus");
41
- Object.defineProperty(exports, "init", { enumerable: true, get: function () { return init_prometheus_1.init; } });
40
+ var init_1 = require("./init");
41
+ Object.defineProperty(exports, "init", { enumerable: true, get: function () { return init_1.init; } });
42
42
  exports.metrics = __importStar(require("./metrics"));
43
43
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAA4C;AAAnC,gGAAA,MAAM,OAAA;AAAE,kGAAA,QAAQ,OAAA;AACzB,qDAAyC;AAAhC,uGAAA,IAAI,OAAA;AACb,qDAAqC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAA4C;AAAnC,gGAAA,MAAM,OAAA;AAAE,kGAAA,QAAQ,OAAA;AACzB,+BAA8B;AAArB,4FAAA,IAAI,OAAA;AACb,qDAAqC"}
@@ -5,8 +5,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.init = void 0;
7
7
  const fastify_1 = __importDefault(require("fastify"));
8
+ const global_config_1 = require("../../global-config");
8
9
  const client_1 = require("./client");
9
10
  const config_1 = require("./config");
11
+ const metrics_1 = require("./metrics");
10
12
  const init = async (logger) => {
11
13
  logger = logger.child('prometheus');
12
14
  try {
@@ -19,8 +21,16 @@ const init = async (logger) => {
19
21
  logger.debug('Prometheus configuration', config_1.config);
20
22
  if (config_1.config.shouldCollectProcessMetrics)
21
23
  client_1.client.collectDefaultMetrics();
24
+ new metrics_1.Gauge({
25
+ name: 'codefresh_service_info',
26
+ help: 'Service information',
27
+ labelNames: ['service_name', 'service_version'],
28
+ }).set({
29
+ service_name: global_config_1.globalConfig.serviceName,
30
+ service_version: global_config_1.globalConfig.serviceVersion,
31
+ }, 1);
22
32
  const metricsServer = (0, fastify_1.default)();
23
- metricsServer.get('/metrics', async (_request, reply) => {
33
+ metricsServer.get('/metrics', (_request, reply) => {
24
34
  reply.type(client_1.register.contentType);
25
35
  return client_1.register.metrics();
26
36
  });
@@ -36,4 +46,4 @@ const init = async (logger) => {
36
46
  }
37
47
  };
38
48
  exports.init = init;
39
- //# sourceMappingURL=init-prometheus.js.map
49
+ //# sourceMappingURL=init.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"init.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/init.ts"],"names":[],"mappings":";;;;;;AAAA,sDAA8B;AAC9B,uDAAmD;AAEnD,qCAA4C;AAC5C,qCAAkC;AAClC,uCAAkC;AAE3B,MAAM,IAAI,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC1D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IACpC,IAAI,CAAC;QACH,IAAI,eAAM,CAAC,OAAO,KAAK,KAAK,EAAE,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,qFAAqF,CAAC,CAAC;YACnG,OAAO;QACT,CAAC;QAAA,CAAC;QAEF,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QACvC,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE,eAAM,CAAC,CAAC;QAEjD,IAAI,eAAM,CAAC,2BAA2B;YAAE,eAAM,CAAC,qBAAqB,EAAE,CAAC;QACvE,IAAI,eAAK,CAAC;YACR,IAAI,EAAE,wBAAwB;YAC9B,IAAI,EAAE,qBAAqB;YAC3B,UAAU,EAAE,CAAC,cAAc,EAAE,iBAAiB,CAAC;SAChD,CAAC,CAAC,GAAG,CAAC;YACL,YAAY,EAAE,4BAAY,CAAC,WAAW;YACtC,eAAe,EAAE,4BAAY,CAAC,cAAc;SAC7C,EAAE,CAAC,CAAC,CAAC;QAEN,MAAM,aAAa,GAAG,IAAA,iBAAO,GAAE,CAAC;QAChC,aAAa,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;YAChD,KAAK,CAAC,IAAI,CAAC,iBAAQ,CAAC,WAAW,CAAC,CAAC;YACjC,OAAO,iBAAQ,CAAC,OAAO,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC;YACzC,IAAI,EAAE,eAAM,CAAC,IAAI;YACjB,IAAI,EAAE,eAAM,CAAC,IAAI;SAClB,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,kCAAkC,OAAO,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACxC,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,SAAS,CAAC,CAAC;IAC7D,CAAC;AACH,CAAC,CAAC;AAnCW,QAAA,IAAI,QAmCf"}
@@ -1,22 +1,24 @@
1
- import type { CounterConfiguration as CounterConfigurationOriginal, GaugeConfiguration as GaugeConfigurationOriginal, HistogramConfiguration as HistogramConfigurationOriginal, MetricConfiguration as MetricConfigurationOriginal, SummaryConfiguration as SummaryConfigurationOriginal } from 'prom-client';
1
+ import type { CounterConfiguration as CounterConfigurationOriginal, GaugeConfiguration as GaugeConfigurationOriginal, HistogramConfiguration as HistogramConfigurationOriginal, LabelValues, MetricConfiguration as MetricConfigurationOriginal, SummaryConfiguration as SummaryConfigurationOriginal } from 'prom-client';
2
2
  import { Counter as CounterOriginal, Gauge as GaugeOriginal, Histogram as HistogramOriginal, Summary as SummaryOriginal } from 'prom-client';
3
- export type MetricConfiguration<T extends string> = MetricConfigurationOriginal<T> & {
3
+ export type ExemplarLabelName = 'span_id' | 'trace_id';
4
+ export type ExemplarLabels = LabelValues<ExemplarLabelName>;
5
+ export type MetricConfiguration<T extends string = string> = MetricConfigurationOriginal<T> & {
4
6
  name: `codefresh_${string}`;
5
7
  };
6
- export type CounterConfiguration<T extends string> = CounterConfigurationOriginal<T> & MetricConfiguration<T>;
7
- export declare class Counter<T extends string> extends CounterOriginal<T> {
8
+ export type CounterConfiguration<T extends string = string> = CounterConfigurationOriginal<T> & MetricConfiguration<T>;
9
+ export declare class Counter<T extends string = string> extends CounterOriginal<T | ExemplarLabelName> {
8
10
  constructor(config: CounterConfiguration<T>);
9
11
  }
10
- export type GaugeConfiguration<T extends string> = GaugeConfigurationOriginal<T> & MetricConfiguration<T>;
11
- export declare class Gauge<T extends string> extends GaugeOriginal<T> {
12
+ export type GaugeConfiguration<T extends string = string> = GaugeConfigurationOriginal<T> & MetricConfiguration<T>;
13
+ export declare class Gauge<T extends string = string> extends GaugeOriginal<T> {
12
14
  constructor(config: GaugeConfiguration<T>);
13
15
  }
14
- export type HistogramConfiguration<T extends string> = HistogramConfigurationOriginal<T> & MetricConfiguration<T>;
15
- export declare class Histogram<T extends string> extends HistogramOriginal<T> {
16
+ export type HistogramConfiguration<T extends string = string> = HistogramConfigurationOriginal<T> & MetricConfiguration<T>;
17
+ export declare class Histogram<T extends string = string> extends HistogramOriginal<T | ExemplarLabelName> {
16
18
  constructor(config: HistogramConfiguration<T>);
17
19
  }
18
- export type SummaryConfiguration<T extends string> = SummaryConfigurationOriginal<T> & MetricConfiguration<T>;
19
- export declare class Summary<T extends string> extends SummaryOriginal<T> {
20
+ export type SummaryConfiguration<T extends string = string> = SummaryConfigurationOriginal<T> & MetricConfiguration<T>;
21
+ export declare class Summary<T extends string = string> extends SummaryOriginal<T> {
20
22
  constructor(config: SummaryConfiguration<T>);
21
23
  }
22
- export type Metric<T extends string> = Counter<T> | Gauge<T> | Histogram<T> | Summary<T>;
24
+ export type Metric<T extends string = string> = Counter<T> | Gauge<T> | Histogram<T> | Summary<T>;
@@ -1 +1 @@
1
- {"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/metrics.ts"],"names":[],"mappings":";;;AAOA,6CAKqB;AAKrB,MAAa,OAA0B,SAAQ,qBAAkB;IAC/D,YAAY,MAA+B;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,0BAIC;AAGD,MAAa,KAAwB,SAAQ,mBAAgB;IAC3D,YAAY,MAA6B;QACvC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,sBAIC;AAGD,MAAa,SAA4B,SAAQ,uBAAoB;IACnE,YAAY,MAAiC;QAC3C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,8BAIC;AAGD,MAAa,OAA0B,SAAQ,qBAAkB;IAC/D,YAAY,MAA+B;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,0BAIC"}
1
+ {"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/metrics.ts"],"names":[],"mappings":";;;AAQA,6CAKqB;AAOrB,MAAa,OAAmC,SAAQ,qBAAsC;IAC5F,YAAY,MAA+B;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,0BAIC;AAGD,MAAa,KAAiC,SAAQ,mBAAgB;IACpE,YAAY,MAA6B;QACvC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,sBAIC;AAGD,MAAa,SAAqC,SAAQ,uBAAwC;IAChG,YAAY,MAAiC;QAC3C,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,8BAIC;AAGD,MAAa,OAAmC,SAAQ,qBAAkB;IACxE,YAAY,MAA+B;QACzC,KAAK,CAAC,MAAM,CAAC,CAAC;IAChB,CAAC;CACF;AAJD,0BAIC"}
@@ -0,0 +1 @@
1
+ export * from './public.js';
@@ -1,2 +1,5 @@
1
- export { client, register } from './client';
2
- export * as metrics from './metrics';
1
+ export * from 'prom-client';
2
+ export { register } from './client';
3
+ export { Counter, Gauge, Histogram, Summary, } from './metrics';
4
+ export type { CounterConfiguration, GaugeConfiguration, HistogramConfiguration, MetricConfiguration, Metric, SummaryConfiguration, } from './metrics';
5
+ export * as helpers from './helpers';
@@ -1,4 +1,5 @@
1
1
  "use strict";
2
+ // Public API (CommonJS)
2
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
4
  if (k2 === undefined) k2 = k;
4
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -15,6 +16,9 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
16
  }) : function(o, v) {
16
17
  o["default"] = v;
17
18
  });
19
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
20
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
21
+ };
18
22
  var __importStar = (this && this.__importStar) || (function () {
19
23
  var ownKeys = function(o) {
20
24
  ownKeys = Object.getOwnPropertyNames || function (o) {
@@ -33,9 +37,14 @@ var __importStar = (this && this.__importStar) || (function () {
33
37
  };
34
38
  })();
35
39
  Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.metrics = exports.register = exports.client = void 0;
40
+ exports.helpers = exports.Summary = exports.Histogram = exports.Gauge = exports.Counter = exports.register = void 0;
41
+ __exportStar(require("prom-client"), exports);
37
42
  var client_1 = require("./client");
38
- Object.defineProperty(exports, "client", { enumerable: true, get: function () { return client_1.client; } });
39
43
  Object.defineProperty(exports, "register", { enumerable: true, get: function () { return client_1.register; } });
40
- exports.metrics = __importStar(require("./metrics"));
44
+ var metrics_1 = require("./metrics");
45
+ Object.defineProperty(exports, "Counter", { enumerable: true, get: function () { return metrics_1.Counter; } });
46
+ Object.defineProperty(exports, "Gauge", { enumerable: true, get: function () { return metrics_1.Gauge; } });
47
+ Object.defineProperty(exports, "Histogram", { enumerable: true, get: function () { return metrics_1.Histogram; } });
48
+ Object.defineProperty(exports, "Summary", { enumerable: true, get: function () { return metrics_1.Summary; } });
49
+ exports.helpers = __importStar(require("./helpers"));
41
50
  //# sourceMappingURL=public.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"public.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/public.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mCAA4C;AAAnC,gGAAA,MAAM,OAAA;AAAE,kGAAA,QAAQ,OAAA;AACzB,qDAAqC"}
1
+ {"version":3,"file":"public.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/public.ts"],"names":[],"mappings":";AAAA,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAExB,8CAA4B;AAC5B,mCAAoC;AAA3B,kGAAA,QAAQ,OAAA;AACjB,qCAKmB;AAJjB,kGAAA,OAAO,OAAA;AACP,gGAAA,KAAK,OAAA;AACL,oGAAA,SAAS,OAAA;AACT,kGAAA,OAAO,OAAA;AAUT,qDAAqC"}
@@ -0,0 +1,3 @@
1
+ // Public API (ESM)
2
+ export * from './public.js';
3
+ //# sourceMappingURL=public.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"public.mjs","sourceRoot":"","sources":["../../../src/metrics/prometheus/public.mts"],"names":[],"mappings":"AAAA,mBAAmB;AAEnB,cAAc,aAAa,CAAC"}
@@ -1,3 +1,3 @@
1
1
  import type { Logger } from '../logs';
2
- export declare const init: (logger: Logger) => Promise<void>;
2
+ export declare const init: (logger: Logger) => void;
3
3
  export declare const terminate: (logger: Logger) => Promise<void>;
@@ -3,7 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.terminate = exports.init = void 0;
4
4
  const config_1 = require("./config");
5
5
  const sdk_1 = require("./sdk");
6
- const init = async (logger) => {
6
+ const init = (logger) => {
7
7
  logger = logger.child('otel');
8
8
  try {
9
9
  if (!config_1.config.enabled) {
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/otel/index.ts"],"names":[],"mappings":";;;AACA,qCAAkC;AAClC,+BAA4B;AAErB,MAAM,IAAI,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC1D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,IAAI,CAAC;QACH,IAAI,CAAC,eAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,2EAA2E,CAAC,CAAC;YACzF,OAAO;QACT,CAAC;QACD,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,6BAA6B,EAAE,eAAM,CAAC,CAAC;QACpD,SAAG,CAAC,KAAK,EAAE,CAAC;QACZ,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAC3C,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,oCAAoC,EAAE,SAAS,CAAC,CAAC;IAChE,CAAC;AACH,CAAC,CAAC;AAdW,QAAA,IAAI,QAcf;AAEK,MAAM,SAAS,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC/D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,IAAI,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QACzC,MAAM,SAAG,CAAC,QAAQ,EAAE,CAAC;QACrB,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAC1C,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,mCAAmC,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;AACH,CAAC,CAAC;AATW,QAAA,SAAS,aASpB"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/otel/index.ts"],"names":[],"mappings":";;;AACA,qCAAkC;AAClC,+BAA4B;AAErB,MAAM,IAAI,GAAG,CAAC,MAAc,EAAQ,EAAE;IAC3C,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,IAAI,CAAC;QACH,IAAI,CAAC,eAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,2EAA2E,CAAC,CAAC;YACzF,OAAO;QACT,CAAC;QACD,MAAM,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAC1C,MAAM,CAAC,KAAK,CAAC,6BAA6B,EAAE,eAAM,CAAC,CAAC;QACpD,SAAG,CAAC,KAAK,EAAE,CAAC;QACZ,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAC3C,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,oCAAoC,EAAE,SAAS,CAAC,CAAC;IAChE,CAAC;AACH,CAAC,CAAC;AAdW,QAAA,IAAI,QAcf;AAEK,MAAM,SAAS,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC/D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC9B,IAAI,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QACzC,MAAM,SAAG,CAAC,QAAQ,EAAE,CAAC;QACrB,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IAC1C,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,mCAAmC,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;AACH,CAAC,CAAC;AATW,QAAA,SAAS,aASpB"}
@@ -0,0 +1 @@
1
+ export * from './public.js';
@@ -1 +1 @@
1
- export * as api from '@opentelemetry/api';
1
+ export * from '@opentelemetry/sdk-node';
@@ -1,4 +1,5 @@
1
1
  "use strict";
2
+ // Public API (CommonJS)
2
3
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
4
  if (k2 === undefined) k2 = k;
4
5
  var desc = Object.getOwnPropertyDescriptor(m, k);
@@ -10,29 +11,9 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
10
11
  if (k2 === undefined) k2 = k;
11
12
  o[k2] = m[k];
12
13
  }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
14
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
15
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
16
+ };
35
17
  Object.defineProperty(exports, "__esModule", { value: true });
36
- exports.api = void 0;
37
- exports.api = __importStar(require("@opentelemetry/api"));
18
+ __exportStar(require("@opentelemetry/sdk-node"), exports);
38
19
  //# sourceMappingURL=public.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"public.js","sourceRoot":"","sources":["../../src/otel/public.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,0DAA0C"}
1
+ {"version":3,"file":"public.js","sourceRoot":"","sources":["../../src/otel/public.ts"],"names":[],"mappings":";AAAA,wBAAwB;;;;;;;;;;;;;;;;AAExB,0DAAwC"}
@@ -0,0 +1,3 @@
1
+ // Public API (ESM)
2
+ export * from './public.js';
3
+ //# sourceMappingURL=public.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"public.mjs","sourceRoot":"","sources":["../../src/otel/public.mts"],"names":[],"mappings":"AAAA,mBAAmB;AAEnB,cAAc,aAAa,CAAC"}
package/dist/otel/sdk.js CHANGED
@@ -3,11 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.sdk = void 0;
4
4
  const auto_instrumentations_node_1 = require("@opentelemetry/auto-instrumentations-node");
5
5
  const baggage_span_processor_1 = require("@opentelemetry/baggage-span-processor");
6
- const context_async_hooks_1 = require("@opentelemetry/context-async-hooks");
7
- const core_1 = require("@opentelemetry/core");
8
- const exporter_prometheus_1 = require("@opentelemetry/exporter-prometheus");
9
6
  const exporter_trace_otlp_grpc_1 = require("@opentelemetry/exporter-trace-otlp-grpc");
10
- const propagator_b3_1 = require("@opentelemetry/propagator-b3");
11
7
  const resources_1 = require("@opentelemetry/resources");
12
8
  const sdk_node_1 = require("@opentelemetry/sdk-node");
13
9
  const sdk_trace_base_1 = require("@opentelemetry/sdk-trace-base");
@@ -15,27 +11,23 @@ const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
15
11
  const global_config_1 = require("../global-config");
16
12
  exports.sdk = new sdk_node_1.NodeSDK({
17
13
  serviceName: global_config_1.globalConfig.serviceName,
18
- resource: new resources_1.Resource({
14
+ autoDetectResources: true,
15
+ resource: (0, resources_1.resourceFromAttributes)({
19
16
  [semantic_conventions_1.ATTR_SERVICE_NAME]: global_config_1.globalConfig.serviceName,
20
17
  [semantic_conventions_1.ATTR_SERVICE_VERSION]: global_config_1.globalConfig.serviceVersion,
21
18
  }),
22
- metricReader: new exporter_prometheus_1.PrometheusExporter(),
23
19
  spanProcessors: [
24
20
  new sdk_trace_base_1.BatchSpanProcessor(new exporter_trace_otlp_grpc_1.OTLPTraceExporter()),
25
21
  // It copies baggage info from parent span to child span
26
22
  new baggage_span_processor_1.BaggageSpanProcessor(baggage_span_processor_1.ALLOW_ALL_BAGGAGE_KEYS),
27
23
  ],
28
- contextManager: new context_async_hooks_1.AsyncLocalStorageContextManager(),
29
- textMapPropagator: new core_1.CompositePropagator({
30
- propagators: [
31
- new core_1.W3CTraceContextPropagator(),
32
- new core_1.W3CBaggagePropagator(),
33
- new propagator_b3_1.B3Propagator(),
34
- new propagator_b3_1.B3Propagator({
35
- injectEncoding: propagator_b3_1.B3InjectEncoding.MULTI_HEADER,
36
- }),
37
- ],
38
- }),
39
- instrumentations: [(0, auto_instrumentations_node_1.getNodeAutoInstrumentations)()],
24
+ instrumentations: [(0, auto_instrumentations_node_1.getNodeAutoInstrumentations)({
25
+ '@opentelemetry/instrumentation-http': {
26
+ responseHook: (span, response) => {
27
+ if ('setHeader' in response)
28
+ response.setHeader('cf-trace-id', span.spanContext().traceId);
29
+ },
30
+ },
31
+ })],
40
32
  });
41
33
  //# sourceMappingURL=sdk.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"sdk.js","sourceRoot":"","sources":["../../src/otel/sdk.ts"],"names":[],"mappings":";;;AAAA,0FAAwF;AACxF,kFAAqG;AACrG,4EAAqF;AACrF,8CAA2G;AAC3G,4EAAwE;AACxE,sFAA4E;AAC5E,gEAA8E;AAC9E,wDAAoD;AACpD,sDAAkD;AAClD,kEAAmE;AACnE,8EAA8F;AAC9F,oDAAgD;AAEnC,QAAA,GAAG,GAAG,IAAI,kBAAO,CAAC;IAC7B,WAAW,EAAE,4BAAY,CAAC,WAAW;IACrC,QAAQ,EAAE,IAAI,oBAAQ,CAAC;QACrB,CAAC,wCAAiB,CAAC,EAAE,4BAAY,CAAC,WAAW;QAC7C,CAAC,2CAAoB,CAAC,EAAE,4BAAY,CAAC,cAAc;KACpD,CAAC;IACF,YAAY,EAAE,IAAI,wCAAkB,EAAE;IACtC,cAAc,EAAE;QACd,IAAI,mCAAkB,CAAC,IAAI,4CAAiB,EAAE,CAAC;QAC/C,wDAAwD;QACxD,IAAI,6CAAoB,CAAC,+CAAsB,CAAC;KACjD;IACD,cAAc,EAAE,IAAI,qDAA+B,EAAE;IACrD,iBAAiB,EAAE,IAAI,0BAAmB,CAAC;QACzC,WAAW,EAAE;YACX,IAAI,gCAAyB,EAAE;YAC/B,IAAI,2BAAoB,EAAE;YAC1B,IAAI,4BAAY,EAAE;YAClB,IAAI,4BAAY,CAAC;gBACf,cAAc,EAAE,gCAAgB,CAAC,YAAY;aAC9C,CAAC;SACH;KACF,CAAC;IACF,gBAAgB,EAAE,CAAC,IAAA,wDAA2B,GAAE,CAAC;CAClD,CAAC,CAAC"}
1
+ {"version":3,"file":"sdk.js","sourceRoot":"","sources":["../../src/otel/sdk.ts"],"names":[],"mappings":";;;AAAA,0FAAwF;AACxF,kFAAqG;AACrG,sFAA4E;AAC5E,wDAAkE;AAClE,sDAAkD;AAClD,kEAAmE;AACnE,8EAA8F;AAC9F,oDAAgD;AAEnC,QAAA,GAAG,GAAG,IAAI,kBAAO,CAAC;IAC7B,WAAW,EAAE,4BAAY,CAAC,WAAW;IACrC,mBAAmB,EAAE,IAAI;IACzB,QAAQ,EAAE,IAAA,kCAAsB,EAAC;QAC/B,CAAC,wCAAiB,CAAC,EAAE,4BAAY,CAAC,WAAW;QAC7C,CAAC,2CAAoB,CAAC,EAAE,4BAAY,CAAC,cAAc;KACpD,CAAC;IACF,cAAc,EAAE;QACd,IAAI,mCAAkB,CAAC,IAAI,4CAAiB,EAAE,CAAC;QAC/C,wDAAwD;QACxD,IAAI,6CAAoB,CAAC,+CAAsB,CAAC;KACjD;IACD,gBAAgB,EAAE,CAAC,IAAA,wDAA2B,EAAC;YAC7C,qCAAqC,EAAE;gBACrC,YAAY,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;oBAC/B,IAAI,WAAW,IAAI,QAAQ;wBAAE,QAAQ,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,CAAC;gBAC7F,CAAC;aACF;SACF,CAAC,CAAC;CACJ,CAAC,CAAC"}
@@ -1,6 +1,7 @@
1
1
  export declare const config: {
2
2
  readonly enabled: boolean;
3
3
  readonly config: {
4
- tags: Record<string, string> | undefined;
4
+ appName: string;
5
+ tags: Record<string, string>;
5
6
  };
6
7
  };
@@ -1,18 +1,24 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.config = void 0;
4
+ const global_config_1 = require("../global-config");
5
+ const getTags = () => {
6
+ const rawTags = process.env['CF_TELEMETRY_PYROSCOPE_TAGS'] ?? '';
7
+ return rawTags.split(',').reduce((acc, pair) => {
8
+ const [key, value] = pair.split('=');
9
+ if (!key || !value)
10
+ return acc;
11
+ acc[key] = value;
12
+ return acc;
13
+ }, {
14
+ service_version: global_config_1.globalConfig.serviceVersion,
15
+ });
16
+ };
4
17
  exports.config = {
5
18
  enabled: process.env['CF_TELEMETRY_PYROSCOPE_ENABLE'] === 'true',
6
19
  config: {
7
- tags: process.env['CF_TELEMETRY_PYROSCOPE_TAGS']
8
- ? process.env['CF_TELEMETRY_PYROSCOPE_TAGS'].split(',').reduce((acc, pair) => {
9
- const [key, value] = pair.split('=');
10
- if (!key || !value)
11
- return acc;
12
- acc[key] = value;
13
- return acc;
14
- }, {})
15
- : undefined,
20
+ appName: process.env['PYROSCOPE_APPLICATION_NAME'] ?? global_config_1.globalConfig.serviceName,
21
+ tags: getTags(),
16
22
  },
17
23
  };
18
24
  //# sourceMappingURL=config.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/profiles/config.ts"],"names":[],"mappings":";;;AAEa,QAAA,MAAM,GAAG;IACpB,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,KAAK,MAAM;IAChE,MAAM,EAAE;QACN,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC;YAC9C,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;gBACzE,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACrC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK;oBAAE,OAAO,GAAG,CAAC;gBAC/B,GAAG,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBACjB,OAAO,GAAG,CAAC;YACb,CAAC,EAAE,EAA4B,CAAC;YAClC,CAAC,CAAC,SAAS;KACY;CACnB,CAAC"}
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/profiles/config.ts"],"names":[],"mappings":";;;AACA,oDAAgD;AAEhD,MAAM,OAAO,GAAG,GAAG,EAAE;IACnB,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,IAAI,EAAE,CAAC;IACjE,OAAO,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;QAC7C,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK;YAAE,OAAO,GAAG,CAAC;QAC/B,GAAG,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QACjB,OAAO,GAAG,CAAC;IACb,CAAC,EAAE;QACD,eAAe,EAAE,4BAAY,CAAC,cAAc;KACnB,CAAC,CAAC;AAC/B,CAAC,CAAC;AAEW,QAAA,MAAM,GAAG;IACpB,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,KAAK,MAAM;IAChE,MAAM,EAAE;QACN,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,4BAA4B,CAAC,IAAI,4BAAY,CAAC,WAAW;QAC9E,IAAI,EAAE,OAAO,EAAE;KACU;CACnB,CAAC"}
@@ -1,2 +1,3 @@
1
1
  import type { Logger } from '../logs';
2
- export declare const init: (logger: Logger) => Promise<void>;
2
+ export declare const init: (logger: Logger) => void;
3
+ export declare const terminate: (logger: Logger) => Promise<void>;
@@ -3,20 +3,37 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.init = void 0;
6
+ exports.terminate = exports.init = void 0;
7
7
  const nodejs_1 = __importDefault(require("@pyroscope/nodejs"));
8
8
  const config_1 = require("./config");
9
- const init = async (logger) => {
9
+ const init = (logger) => {
10
10
  logger = logger.child('pyroscope');
11
- if (!config_1.config.enabled) {
12
- logger.info('Pyroscope is disabled. Set CF_TELEMETRY_PYROSCOPE_ENABLE=true to enable it');
13
- return;
11
+ try {
12
+ if (!config_1.config.enabled) {
13
+ logger.info('Pyroscope is disabled. Set CF_TELEMETRY_PYROSCOPE_ENABLE=true to enable it');
14
+ return;
15
+ }
16
+ logger.info('Initializing Pyroscope');
17
+ logger.debug('Pyroscope configuration', config_1.config);
18
+ nodejs_1.default.init(config_1.config.config);
19
+ nodejs_1.default.start();
20
+ logger.info('Pyroscope initialized');
21
+ }
22
+ catch (exception) {
23
+ logger.error('Failed to initialize Pyroscope', exception);
14
24
  }
15
- logger.info('Initializing Pyroscope');
16
- logger.debug('Pyroscope configuration', config_1.config);
17
- nodejs_1.default.init(config_1.config.config);
18
- nodejs_1.default.start();
19
- logger.info('Pyroscope initialized');
20
25
  };
21
26
  exports.init = init;
27
+ const terminate = async (logger) => {
28
+ logger = logger.child('pyroscope');
29
+ try {
30
+ logger.info('Terminating Pyroscope');
31
+ await nodejs_1.default.stop();
32
+ logger.info('Pyroscope terminated');
33
+ }
34
+ catch (exception) {
35
+ logger.error('Failed to terminate Pyroscope', exception);
36
+ }
37
+ };
38
+ exports.terminate = terminate;
22
39
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/profiles/index.ts"],"names":[],"mappings":";;;;;;AAAA,+DAA0C;AAE1C,qCAAkC;AAE3B,MAAM,IAAI,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC1D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACnC,IAAI,CAAC,eAAM,CAAC,OAAO,EAAE,CAAC;QACpB,MAAM,CAAC,IAAI,CAAC,4EAA4E,CAAC,CAAC;QAC1F,OAAO;IACT,CAAC;IAED,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACtC,MAAM,CAAC,KAAK,CAAC,yBAAyB,EAAE,eAAM,CAAC,CAAC;IAChD,gBAAS,CAAC,IAAI,CAAC,eAAM,CAAC,MAAM,CAAC,CAAC;IAC9B,gBAAS,CAAC,KAAK,EAAE,CAAC;IAClB,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;AACvC,CAAC,CAAC;AAZW,QAAA,IAAI,QAYf"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/profiles/index.ts"],"names":[],"mappings":";;;;;;AAAA,+DAA0C;AAE1C,qCAAkC;AAE3B,MAAM,IAAI,GAAG,CAAC,MAAc,EAAQ,EAAE;IAC3C,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACnC,IAAI,CAAC;QACH,IAAI,CAAC,eAAM,CAAC,OAAO,EAAE,CAAC;YACpB,MAAM,CAAC,IAAI,CAAC,4EAA4E,CAAC,CAAC;YAC1F,OAAO;QACT,CAAC;QAED,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACtC,MAAM,CAAC,KAAK,CAAC,yBAAyB,EAAE,eAAM,CAAC,CAAC;QAChD,gBAAS,CAAC,IAAI,CAAC,eAAM,CAAC,MAAM,CAAC,CAAC;QAC9B,gBAAS,CAAC,KAAK,EAAE,CAAC;QAClB,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IACvC,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,gCAAgC,EAAE,SAAS,CAAC,CAAC;IAC5D,CAAC;AACH,CAAC,CAAC;AAhBW,QAAA,IAAI,QAgBf;AAEK,MAAM,SAAS,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC/D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IACnC,IAAI,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QACrC,MAAM,gBAAS,CAAC,IAAI,EAAE,CAAC;QACvB,MAAM,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACtC,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,+BAA+B,EAAE,SAAS,CAAC,CAAC;IAC3D,CAAC;AACH,CAAC,CAAC;AATW,QAAA,SAAS,aASpB"}
package/package.json CHANGED
@@ -1,36 +1,33 @@
1
1
  {
2
2
  "name": "@codefresh-io/cf-telemetry",
3
- "version": "2.0.0-alpha.8",
3
+ "version": "2.0.0",
4
4
  "exports": {
5
- "./init": "./dist/init.mjs",
6
- ".": {
7
- "types": "./dist/index.d.ts",
8
- "node": "./dist/index.js",
9
- "import": "./dist/index.js",
10
- "require": "./dist/index.js"
5
+ "./init": {
6
+ "import": "./dist/init.mjs",
7
+ "require": "./dist/init.js"
11
8
  },
12
9
  "./logs": {
13
- "types": "./dist/logs/public.d.ts",
14
- "node": "./dist/logs/public.js",
15
- "import": "./dist/logs/public.js",
10
+ "import": "./dist/logs/public.mjs",
16
11
  "require": "./dist/logs/public.js"
17
12
  },
13
+ "./logs/nest": {
14
+ "import": "./dist/logs/nest/public.mjs",
15
+ "require": "./dist/logs/nest/public.js"
16
+ },
17
+ "./logs/express": {
18
+ "import": "./dist/logs/express/public.mjs",
19
+ "require": "./dist/logs/express/public.js"
20
+ },
18
21
  "./metrics/mongodb": {
19
- "types": "./dist/metrics/mongodb/public.d.ts",
20
- "node": "./dist/metrics/mongodb/public.js",
21
- "import": "./dist/metrics/mongodb/public.js",
22
+ "import": "./dist/metrics/mongodb/public.mjs",
22
23
  "require": "./dist/metrics/mongodb/public.js"
23
24
  },
24
25
  "./metrics/prometheus": {
25
- "types": "./dist/metrics/prometheus/public.d.ts",
26
- "node": "./dist/metrics/prometheus/public.js",
27
- "import": "./dist/metrics/prometheus/public.js",
26
+ "import": "./dist/metrics/prometheus/public.mjs",
28
27
  "require": "./dist/metrics/prometheus/public.js"
29
28
  },
30
29
  "./otel": {
31
- "types": "./dist/otel/public.d.ts",
32
- "node": "./dist/otel/public.js",
33
- "import": "./dist/otel/public.js",
30
+ "import": "./dist/otel/public.mjs",
34
31
  "require": "./dist/otel/public.js"
35
32
  }
36
33
  },
@@ -55,26 +52,27 @@
55
52
  },
56
53
  "devDependencies": {
57
54
  "@eslint/js": "^9.19.0",
58
- "@nestjs/common": "^11.0.7",
55
+ "@nestjs/common": "^11.0.15",
59
56
  "@stylistic/eslint-plugin": "^3.0.1",
57
+ "@types/express": "^5.0.1",
60
58
  "@types/node": "^22.12.0",
61
59
  "eslint": "^9.19.0",
62
60
  "mongodb": "^6.13.0",
63
61
  "rimraf": "^6.0.1",
64
- "typescript": "^5.7.3",
65
- "typescript-eslint": "^8.22.0",
66
- "vitest": "^3.0.4"
62
+ "typescript": "^5.8.2",
63
+ "typescript-eslint": "^8.27.0",
64
+ "vitest": "^3.1.1"
67
65
  },
68
66
  "dependencies": {
69
67
  "@christiangalsterer/mongodb-driver-prometheus-exporter": "^2.3.0",
70
- "@opentelemetry/api": "^1.9.0",
71
- "@opentelemetry/auto-instrumentations-node": "^0.56.0",
72
- "@opentelemetry/baggage-span-processor": "^0.3.1",
73
- "@opentelemetry/sdk-metrics": "^1.30.1",
74
- "@opentelemetry/sdk-node": "^0.57.2",
75
- "@opentelemetry/sdk-trace-node": "^1.30.1",
76
- "@pyroscope/nodejs": "^0.4.3",
77
- "fastify": "^5.2.1",
68
+ "@opentelemetry/api": "~1.9.0",
69
+ "@opentelemetry/auto-instrumentations-node": "~0.57.1",
70
+ "@opentelemetry/baggage-span-processor": "~0.4.0",
71
+ "@opentelemetry/core": "~2.0.0",
72
+ "@opentelemetry/sdk-metrics": "~2.0.0",
73
+ "@opentelemetry/sdk-trace-node": "~2.0.0",
74
+ "@pyroscope/nodejs": "^0.4.5",
75
+ "fastify": "^5.2.2",
78
76
  "pino": "^9.6.0",
79
77
  "pino-pretty": "^13.0.0",
80
78
  "prom-client": "^15.1.3"
package/dist/index.d.ts DELETED
@@ -1,7 +0,0 @@
1
- /**
2
- * Initializes telemetry services. Should be called once as early as possible in the application lifecycle.
3
- * Preferred method of initialization is to add `--import=@codefresh-io/cf-telemetry/init` Node.js flag,
4
- * instead of calling this function directly.
5
- */
6
- export declare const init: () => Promise<void>;
7
- export declare const terminate: () => Promise<void>;
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,6BAA6B;AAC7B,6CAA+B;AAC/B,6BAA6B;AAE7B,6CAA+B;AAC/B,iEAAmD;AACnD,qDAAuC;AAEvC,IAAI,aAAa,GAAG,KAAK,CAAC;AAE1B;;;;GAIG;AACI,MAAM,IAAI,GAAG,KAAK,IAAmB,EAAE;IAC5C,IAAI,aAAa;QAAE,OAAO;IAE1B,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAC5C,MAAM,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAC;IAC/C,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5C,MAAM,OAAO,CAAC,GAAG,CAAC;QAChB,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAC3C,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;KAC1C,CAAC,CAAC;IACH,aAAa,GAAG,IAAI,CAAC;IACrB,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;AAChD,CAAC,CAAC;AAZW,QAAA,IAAI,QAYf;AAEK,MAAM,SAAS,GAAG,KAAK,IAAmB,EAAE;IACjD,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;IAC5C,IAAI,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;QAC9C,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACjD,aAAa,GAAG,KAAK,CAAC;QACtB,MAAM,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;IAC/C,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,wCAAwC,EAAE,SAAS,CAAC,CAAC;IACpE,CAAC;AACH,CAAC,CAAC;AAVW,QAAA,SAAS,aAUpB"}
@@ -1 +0,0 @@
1
- export { monitorMongoDBClient } from './monitor-mongodb-client';
@@ -1,6 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.monitorMongoDBClient = void 0;
4
- var monitor_mongodb_client_1 = require("./monitor-mongodb-client");
5
- Object.defineProperty(exports, "monitorMongoDBClient", { enumerable: true, get: function () { return monitor_mongodb_client_1.monitorMongoDBClient; } });
6
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/metrics/mongodb/index.ts"],"names":[],"mappings":";;;AAAA,mEAAgE;AAAvD,8HAAA,oBAAoB,OAAA"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"init-prometheus.js","sourceRoot":"","sources":["../../../src/metrics/prometheus/init-prometheus.ts"],"names":[],"mappings":";;;;;;AAAA,sDAA8B;AAE9B,qCAA4C;AAC5C,qCAAkC;AAE3B,MAAM,IAAI,GAAG,KAAK,EAAE,MAAc,EAAiB,EAAE;IAC1D,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;IACpC,IAAI,CAAC;QACH,IAAI,eAAM,CAAC,OAAO,KAAK,KAAK,EAAE,CAAC;YAC7B,MAAM,CAAC,IAAI,CAAC,qFAAqF,CAAC,CAAC;YACnG,OAAO;QACT,CAAC;QAAA,CAAC;QACF,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QACvC,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE,eAAM,CAAC,CAAC;QACjD,IAAI,eAAM,CAAC,2BAA2B;YAAE,eAAM,CAAC,qBAAqB,EAAE,CAAC;QACvE,MAAM,aAAa,GAAG,IAAA,iBAAO,GAAE,CAAC;QAChC,aAAa,CAAC,GAAG,CAAC,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE;YACtD,KAAK,CAAC,IAAI,CAAC,iBAAQ,CAAC,WAAW,CAAC,CAAC;YACjC,OAAO,iBAAQ,CAAC,OAAO,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,MAAM,CAAC;YACzC,IAAI,EAAE,eAAM,CAAC,IAAI;YACjB,IAAI,EAAE,eAAM,CAAC,IAAI;SAClB,CAAC,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,kCAAkC,OAAO,EAAE,CAAC,CAAC;QACzD,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACxC,CAAC;IAAC,OAAO,SAAS,EAAE,CAAC;QACnB,MAAM,CAAC,KAAK,CAAC,iCAAiC,EAAE,SAAS,CAAC,CAAC;IAC7D,CAAC;AACH,CAAC,CAAC;AAxBW,QAAA,IAAI,QAwBf"}