@mecanizou/telemetry-hub 1.0.1 → 1.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/core/__tests__/logger-types.test.d.ts +1 -0
  3. package/dist/core/__tests__/logger-types.test.js +325 -0
  4. package/dist/core/__tests__/logger.test.d.ts +1 -0
  5. package/dist/core/__tests__/logger.test.js +337 -0
  6. package/dist/core/__tests__/tracer.test.d.ts +1 -0
  7. package/dist/core/__tests__/tracer.test.js +330 -0
  8. package/dist/core/index.d.ts +3 -1
  9. package/dist/core/index.js +4 -2
  10. package/dist/core/logger-types.js +3 -0
  11. package/dist/core/logger.d.ts +1 -1
  12. package/dist/core/logger.js +1 -1
  13. package/dist/core/tracer-types.d.ts +50 -0
  14. package/dist/core/tracer-types.js +3 -0
  15. package/dist/core/tracer.d.ts +10 -0
  16. package/dist/core/tracer.js +114 -0
  17. package/dist/index.d.ts +3 -1
  18. package/dist/index.js +4 -2
  19. package/dist/sst/__tests__/telemetry.test.d.ts +1 -0
  20. package/dist/sst/__tests__/telemetry.test.js +138 -0
  21. package/dist/sst/index.js +1 -1
  22. package/dist/sst/middy/index.js +1 -1
  23. package/dist/sst/middy/middleware.d.ts +1 -1
  24. package/dist/sst/middy/middleware.js +54 -69
  25. package/dist/sst/telemetry.d.ts +2 -1
  26. package/dist/sst/telemetry.js +12 -2
  27. package/dist/telemetry/sst/middy/middleware.d.ts +1 -1
  28. package/dist/telemetry/sst/middy/middleware.js +4 -4
  29. package/dist/tsed/__tests__/config.test.d.ts +1 -0
  30. package/dist/tsed/__tests__/config.test.js +146 -0
  31. package/dist/tsed/__tests__/service.test.d.ts +1 -0
  32. package/dist/tsed/__tests__/service.test.js +63 -0
  33. package/dist/tsed/config.d.ts +6 -0
  34. package/dist/tsed/config.js +65 -12
  35. package/dist/tsed/index.d.ts +1 -0
  36. package/dist/tsed/index.js +2 -1
  37. package/dist/tsed/log-telemetry.js +125 -10
  38. package/dist/tsed/service.d.ts +2 -0
  39. package/dist/tsed/service.js +20 -1
  40. package/dist/tsed/sync-log-record-processor.js +1 -1
  41. package/package.json +1 -1
  42. package/dist/check-if-is-working.d.ts +0 -1
  43. package/dist/check-if-is-working.js +0 -8
  44. package/dist/core/types.js +0 -3
  45. package/dist/services/index.d.ts +0 -1
  46. package/dist/services/index.js +0 -18
  47. package/dist/services/telemetry/config.d.ts +0 -20
  48. package/dist/services/telemetry/config.js +0 -113
  49. package/dist/services/telemetry/external-service.d.ts +0 -20
  50. package/dist/services/telemetry/external-service.js +0 -69
  51. package/dist/services/telemetry/index.d.ts +0 -3
  52. package/dist/services/telemetry/index.js +0 -20
  53. package/dist/services/telemetry/sync-log-record-processor.d.ts +0 -11
  54. package/dist/services/telemetry/sync-log-record-processor.js +0 -74
  55. package/dist/telemetry.d.ts +0 -1
  56. package/dist/telemetry.js +0 -81
  57. /package/dist/core/{types.d.ts → logger-types.d.ts} +0 -0
@@ -1,3 +1,4 @@
1
- import { StandardLogger } from '../core';
1
+ import { StandardLogger, StandardTracer } from '../core';
2
2
  export declare const getStandardLogger: () => StandardLogger;
3
+ export declare const getStandardTracer: () => StandardTracer;
3
4
  export declare const forceFlush: () => Promise<void>;
@@ -42,7 +42,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
42
42
  });
43
43
  };
44
44
  Object.defineProperty(exports, "__esModule", { value: true });
45
- exports.forceFlush = exports.getStandardLogger = void 0;
45
+ exports.forceFlush = exports.getStandardTracer = exports.getStandardLogger = void 0;
46
46
  const sdk_node_1 = require("@opentelemetry/sdk-node");
47
47
  const exporter_trace_otlp_http_1 = require("@opentelemetry/exporter-trace-otlp-http");
48
48
  const exporter_metrics_otlp_http_1 = require("@opentelemetry/exporter-metrics-otlp-http");
@@ -51,6 +51,7 @@ const sdk_metrics_1 = require("@opentelemetry/sdk-metrics");
51
51
  const logs = __importStar(require("@opentelemetry/sdk-logs"));
52
52
  const resources = __importStar(require("@opentelemetry/resources"));
53
53
  const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
54
+ const api_1 = require("@opentelemetry/api");
54
55
  const core_1 = require("../core");
55
56
  const user = process.env.OTEL_EXPORTER_OTLP_USER;
56
57
  const password = process.env.OTEL_EXPORTER_OTLP_PASS;
@@ -94,6 +95,7 @@ const sdk = new sdk_node_1.NodeSDK({
94
95
  });
95
96
  sdk.start();
96
97
  let standardLogger = null;
98
+ let standardTracer = null;
97
99
  const getStandardLogger = () => {
98
100
  if (!standardLogger) {
99
101
  const logger = loggerProvider.getLogger('sst-middleware-logger', '1.0.0');
@@ -102,10 +104,18 @@ const getStandardLogger = () => {
102
104
  return standardLogger;
103
105
  };
104
106
  exports.getStandardLogger = getStandardLogger;
107
+ const getStandardTracer = () => {
108
+ if (!standardTracer) {
109
+ const tracer = api_1.trace.getTracer(serviceName, '1.0.0');
110
+ standardTracer = new core_1.StandardTracer(tracer, serviceName);
111
+ }
112
+ return standardTracer;
113
+ };
114
+ exports.getStandardTracer = getStandardTracer;
105
115
  const forceFlush = () => __awaiter(void 0, void 0, void 0, function* () {
106
116
  yield metricReader.forceFlush();
107
117
  yield traceExporter.forceFlush();
108
118
  yield loggerProvider.forceFlush();
109
119
  });
110
120
  exports.forceFlush = forceFlush;
111
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsZW1ldHJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3RlbGVtZXRyeS9zc3QvdGVsZW1ldHJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLHNEQUFrRDtBQUNsRCxzRkFBNEU7QUFDNUUsMEZBQStFO0FBQy9FLG9GQUF5RTtBQUN6RSw0REFBMkU7QUFDM0UsOERBQWdEO0FBQ2hELG9FQUFzRDtBQUN0RCw4RUFBd0U7QUFDeEUsa0NBQXlDO0FBRXpDLE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUM7QUFDakQsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQztBQUVyRCxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLFFBQVEsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRXhFLE1BQU0sT0FBTyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsS0FBSyxDQUFDO0FBRWhFLE1BQU0sYUFBYSxHQUFHLElBQUksNENBQWlCLENBQUM7SUFDMUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxTQUFTO0lBQ3hCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSwrQ0FBa0IsQ0FBQztJQUM1QyxHQUFHLEVBQUUsR0FBRyxPQUFPLFVBQVU7SUFDekIsT0FBTyxFQUFFO1FBQ1AsYUFBYSxFQUFFLFNBQVMsU0FBUyxFQUFFO1FBQ25DLGNBQWMsRUFBRSxrQkFBa0I7S0FDbkM7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLFdBQVcsR0FBRyxJQUFJLHlDQUFlLENBQUM7SUFDdEMsR0FBRyxFQUFFLEdBQUcsT0FBTyxPQUFPO0lBQ3RCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSwyQ0FBNkIsQ0FBQztJQUNyRCxRQUFRLEVBQUUsY0FBYztJQUN4QixvQkFBb0IsRUFBRSxJQUFJO0NBQzNCLENBQUMsQ0FBQztBQUdILE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxJQUFJLGFBQWEsQ0FBQztBQUM5RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUM7SUFDdEMsQ0FBQyx3Q0FBaUIsQ0FBQyxFQUFFLFdBQVc7Q0FDakMsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUM3RCxNQUFNLGtCQUFrQixHQUFHLElBQUksSUFBSSxDQUFDLHVCQUF1QixDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3pFLGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBRXpELE1BQU0sR0FBRyxHQUFHLElBQUksa0JBQU8sQ0FBQztJQUN0QixhQUFhO0lBQ2IsWUFBWSxFQUFFLFlBQW1CO0NBQ2xDLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUdaLElBQUksY0FBYyxHQUEwQixJQUFJLENBQUM7QUFFMUMsTUFBTSxpQkFBaUIsR0FBRyxHQUFtQixFQUFFO0lBQ3BELElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUNwQixNQUFNLE1BQU0sR0FBRyxjQUFjLENBQUMsU0FBUyxDQUFDLHVCQUF1QixFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQzFFLGNBQWMsR0FBRyxJQUFJLHFCQUFjLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFDRCxPQUFPLGNBQWMsQ0FBQztBQUN4QixDQUFDLENBQUM7QUFOVyxRQUFBLGlCQUFpQixxQkFNNUI7QUFFSyxNQUFNLFVBQVUsR0FBRyxHQUFTLEVBQUU7SUFDbkMsTUFBTSxZQUFZLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDaEMsTUFBTSxhQUFhLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDakMsTUFBTSxjQUFjLENBQUMsVUFBVSxFQUFFLENBQUM7QUFDcEMsQ0FBQyxDQUFBLENBQUM7QUFKVyxRQUFBLFVBQVUsY0FJckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOb2RlU0RLIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2RrLW5vZGUnO1xyXG5pbXBvcnQgeyBPVExQVHJhY2VFeHBvcnRlciB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L2V4cG9ydGVyLXRyYWNlLW90bHAtaHR0cCc7XHJcbmltcG9ydCB7IE9UTFBNZXRyaWNFeHBvcnRlciB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L2V4cG9ydGVyLW1ldHJpY3Mtb3RscC1odHRwJztcclxuaW1wb3J0IHsgT1RMUExvZ0V4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItbG9ncy1vdGxwLWh0dHAnO1xyXG5pbXBvcnQgeyBQZXJpb2RpY0V4cG9ydGluZ01ldHJpY1JlYWRlciB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Nkay1tZXRyaWNzJztcclxuaW1wb3J0ICogYXMgbG9ncyBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbG9ncyc7XHJcbmltcG9ydCAqIGFzIHJlc291cmNlcyBmcm9tICdAb3BlbnRlbGVtZXRyeS9yZXNvdXJjZXMnO1xyXG5pbXBvcnQgeyBBVFRSX1NFUlZJQ0VfTkFNRSB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L3NlbWFudGljLWNvbnZlbnRpb25zJztcclxuaW1wb3J0IHsgU3RhbmRhcmRMb2dnZXIgfSBmcm9tICcuLi9jb3JlJztcclxuXHJcbmNvbnN0IHVzZXIgPSBwcm9jZXNzLmVudi5PVEVMX0VYUE9SVEVSX09UTFBfVVNFUjtcclxuY29uc3QgcGFzc3dvcmQgPSBwcm9jZXNzLmVudi5PVEVMX0VYUE9SVEVSX09UTFBfUEFTUztcclxuXHJcbmNvbnN0IGJhc2ljQXV0aCA9IEJ1ZmZlci5mcm9tKGAke3VzZXJ9OiR7cGFzc3dvcmR9YCkudG9TdHJpbmcoJ2Jhc2U2NCcpO1xyXG5cclxuY29uc3QgYmFzZVVybCA9IGAke3Byb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9FTkRQT0lOVH0vdjFgO1xyXG5cclxuY29uc3QgdHJhY2VFeHBvcnRlciA9IG5ldyBPVExQVHJhY2VFeHBvcnRlcih7XHJcbiAgdXJsOiBgJHtiYXNlVXJsfS90cmFjZXNgLFxyXG4gIGhlYWRlcnM6IHtcclxuICAgIEF1dGhvcml6YXRpb246IGBCYXNpYyAke2Jhc2ljQXV0aH1gLFxyXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICB9LFxyXG59KTtcclxuXHJcbmNvbnN0IG1ldHJpY0V4cG9ydGVyID0gbmV3IE9UTFBNZXRyaWNFeHBvcnRlcih7XHJcbiAgdXJsOiBgJHtiYXNlVXJsfS9tZXRyaWNzYCxcclxuICBoZWFkZXJzOiB7XHJcbiAgICBBdXRob3JpemF0aW9uOiBgQmFzaWMgJHtiYXNpY0F1dGh9YCxcclxuICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXHJcbiAgfSxcclxufSk7XHJcblxyXG5jb25zdCBsb2dFeHBvcnRlciA9IG5ldyBPVExQTG9nRXhwb3J0ZXIoe1xyXG4gIHVybDogYCR7YmFzZVVybH0vbG9nc2AsXHJcbiAgaGVhZGVyczoge1xyXG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXHJcbiAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxyXG4gIH0sXHJcbn0pO1xyXG5cclxuY29uc3QgbWV0cmljUmVhZGVyID0gbmV3IFBlcmlvZGljRXhwb3J0aW5nTWV0cmljUmVhZGVyKHtcclxuICBleHBvcnRlcjogbWV0cmljRXhwb3J0ZXIsXHJcbiAgZXhwb3J0SW50ZXJ2YWxNaWxsaXM6IDEwMDAsXHJcbn0pO1xyXG5cclxuLy8gQ29uZmlndXJhciBMb2dnZXJQcm92aWRlclxyXG5jb25zdCBzZXJ2aWNlTmFtZSA9IHByb2Nlc3MuZW52LlNFUlZJQ0VfTkFNRSB8fCAnc3N0LXNlcnZpY2UnO1xyXG5jb25zdCByZXNvdXJjZSA9IG5ldyByZXNvdXJjZXMuUmVzb3VyY2Uoe1xyXG4gIFtBVFRSX1NFUlZJQ0VfTkFNRV06IHNlcnZpY2VOYW1lLFxyXG59KTtcclxuXHJcbmNvbnN0IGxvZ2dlclByb3ZpZGVyID0gbmV3IGxvZ3MuTG9nZ2VyUHJvdmlkZXIoeyByZXNvdXJjZSB9KTtcclxuY29uc3QgbG9nUmVjb3JkUHJvY2Vzc29yID0gbmV3IGxvZ3MuQmF0Y2hMb2dSZWNvcmRQcm9jZXNzb3IobG9nRXhwb3J0ZXIpO1xyXG5sb2dnZXJQcm92aWRlci5hZGRMb2dSZWNvcmRQcm9jZXNzb3IobG9nUmVjb3JkUHJvY2Vzc29yKTtcclxuXHJcbmNvbnN0IHNkayA9IG5ldyBOb2RlU0RLKHtcclxuICB0cmFjZUV4cG9ydGVyLFxyXG4gIG1ldHJpY1JlYWRlcjogbWV0cmljUmVhZGVyIGFzIGFueSwgLy8gVHlwZSBjb21wYXRpYmlsaXR5IHdvcmthcm91bmRcclxufSk7XHJcblxyXG5zZGsuc3RhcnQoKTtcclxuXHJcbi8vIENyaWFyIFN0YW5kYXJkTG9nZ2VyIHBhcmEgc2VyIHVzYWRvIG5vcyBtaWRkbGV3YXJlc1xyXG5sZXQgc3RhbmRhcmRMb2dnZXI6IFN0YW5kYXJkTG9nZ2VyIHwgbnVsbCA9IG51bGw7XHJcblxyXG5leHBvcnQgY29uc3QgZ2V0U3RhbmRhcmRMb2dnZXIgPSAoKTogU3RhbmRhcmRMb2dnZXIgPT4ge1xyXG4gIGlmICghc3RhbmRhcmRMb2dnZXIpIHtcclxuICAgIGNvbnN0IGxvZ2dlciA9IGxvZ2dlclByb3ZpZGVyLmdldExvZ2dlcignc3N0LW1pZGRsZXdhcmUtbG9nZ2VyJywgJzEuMC4wJyk7XHJcbiAgICBzdGFuZGFyZExvZ2dlciA9IG5ldyBTdGFuZGFyZExvZ2dlcihsb2dnZXIsIHNlcnZpY2VOYW1lKTtcclxuICB9XHJcbiAgcmV0dXJuIHN0YW5kYXJkTG9nZ2VyO1xyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IGZvcmNlRmx1c2ggPSBhc3luYyAoKSA9PiB7XHJcbiAgYXdhaXQgbWV0cmljUmVhZGVyLmZvcmNlRmx1c2goKTtcclxuICBhd2FpdCB0cmFjZUV4cG9ydGVyLmZvcmNlRmx1c2goKTtcclxuICBhd2FpdCBsb2dnZXJQcm92aWRlci5mb3JjZUZsdXNoKCk7XHJcbn07XHJcbiJdfQ==
121
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsZW1ldHJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NzdC90ZWxlbWV0cnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0RBQWtEO0FBQ2xELHNGQUE0RTtBQUM1RSwwRkFBK0U7QUFDL0Usb0ZBQXlFO0FBQ3pFLDREQUEyRTtBQUMzRSw4REFBZ0Q7QUFDaEQsb0VBQXNEO0FBQ3RELDhFQUF3RTtBQUN4RSw0Q0FBMkM7QUFDM0Msa0NBQXlEO0FBRXpELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUM7QUFDakQsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQztBQUVyRCxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLFFBQVEsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRXhFLE1BQU0sT0FBTyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsS0FBSyxDQUFDO0FBRWhFLE1BQU0sYUFBYSxHQUFHLElBQUksNENBQWlCLENBQUM7SUFDMUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxTQUFTO0lBQ3hCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSwrQ0FBa0IsQ0FBQztJQUM1QyxHQUFHLEVBQUUsR0FBRyxPQUFPLFVBQVU7SUFDekIsT0FBTyxFQUFFO1FBQ1AsYUFBYSxFQUFFLFNBQVMsU0FBUyxFQUFFO1FBQ25DLGNBQWMsRUFBRSxrQkFBa0I7S0FDbkM7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLFdBQVcsR0FBRyxJQUFJLHlDQUFlLENBQUM7SUFDdEMsR0FBRyxFQUFFLEdBQUcsT0FBTyxPQUFPO0lBQ3RCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSwyQ0FBNkIsQ0FBQztJQUNyRCxRQUFRLEVBQUUsY0FBYztJQUN4QixvQkFBb0IsRUFBRSxJQUFJO0NBQzNCLENBQUMsQ0FBQztBQUdILE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxJQUFJLGFBQWEsQ0FBQztBQUM5RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUM7SUFDdEMsQ0FBQyx3Q0FBaUIsQ0FBQyxFQUFFLFdBQVc7Q0FDakMsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUM3RCxNQUFNLGtCQUFrQixHQUFHLElBQUksSUFBSSxDQUFDLHVCQUF1QixDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3pFLGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBRXpELE1BQU0sR0FBRyxHQUFHLElBQUksa0JBQU8sQ0FBQztJQUN0QixhQUFhO0lBQ2IsWUFBWSxFQUFFLFlBQW1CO0NBQ2xDLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUdaLElBQUksY0FBYyxHQUEwQixJQUFJLENBQUM7QUFDakQsSUFBSSxjQUFjLEdBQTBCLElBQUksQ0FBQztBQUUxQyxNQUFNLGlCQUFpQixHQUFHLEdBQW1CLEVBQUU7SUFDcEQsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3BCLE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxTQUFTLENBQUMsdUJBQXVCLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDMUUsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQU5XLFFBQUEsaUJBQWlCLHFCQU01QjtBQUVLLE1BQU0saUJBQWlCLEdBQUcsR0FBbUIsRUFBRTtJQUNwRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDcEIsTUFBTSxNQUFNLEdBQUcsV0FBSyxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDckQsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQU5XLFFBQUEsaUJBQWlCLHFCQU01QjtBQUVLLE1BQU0sVUFBVSxHQUFHLEdBQVMsRUFBRTtJQUNuQyxNQUFNLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNoQyxNQUFNLGFBQWEsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNqQyxNQUFNLGNBQWMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUNwQyxDQUFDLENBQUEsQ0FBQztBQUpXLFFBQUEsVUFBVSxjQUlyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vZGVTREsgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbm9kZSc7XHJcbmltcG9ydCB7IE9UTFBUcmFjZUV4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItdHJhY2Utb3RscC1odHRwJztcclxuaW1wb3J0IHsgT1RMUE1ldHJpY0V4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItbWV0cmljcy1vdGxwLWh0dHAnO1xyXG5pbXBvcnQgeyBPVExQTG9nRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1sb2dzLW90bHAtaHR0cCc7XHJcbmltcG9ydCB7IFBlcmlvZGljRXhwb3J0aW5nTWV0cmljUmVhZGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2RrLW1ldHJpY3MnO1xyXG5pbXBvcnQgKiBhcyBsb2dzIGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Nkay1sb2dzJztcclxuaW1wb3J0ICogYXMgcmVzb3VyY2VzIGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Jlc291cmNlcyc7XHJcbmltcG9ydCB7IEFUVFJfU0VSVklDRV9OQU1FIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2VtYW50aWMtY29udmVudGlvbnMnO1xyXG5pbXBvcnQgeyB0cmFjZSB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L2FwaSc7XHJcbmltcG9ydCB7IFN0YW5kYXJkTG9nZ2VyLCBTdGFuZGFyZFRyYWNlciB9IGZyb20gJy4uL2NvcmUnO1xyXG5cclxuY29uc3QgdXNlciA9IHByb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9VU0VSO1xyXG5jb25zdCBwYXNzd29yZCA9IHByb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9QQVNTO1xyXG5cclxuY29uc3QgYmFzaWNBdXRoID0gQnVmZmVyLmZyb20oYCR7dXNlcn06JHtwYXNzd29yZH1gKS50b1N0cmluZygnYmFzZTY0Jyk7XHJcblxyXG5jb25zdCBiYXNlVXJsID0gYCR7cHJvY2Vzcy5lbnYuT1RFTF9FWFBPUlRFUl9PVExQX0VORFBPSU5UfS92MWA7XHJcblxyXG5jb25zdCB0cmFjZUV4cG9ydGVyID0gbmV3IE9UTFBUcmFjZUV4cG9ydGVyKHtcclxuICB1cmw6IGAke2Jhc2VVcmx9L3RyYWNlc2AsXHJcbiAgaGVhZGVyczoge1xyXG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXHJcbiAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxyXG4gIH0sXHJcbn0pO1xyXG5cclxuY29uc3QgbWV0cmljRXhwb3J0ZXIgPSBuZXcgT1RMUE1ldHJpY0V4cG9ydGVyKHtcclxuICB1cmw6IGAke2Jhc2VVcmx9L21ldHJpY3NgLFxyXG4gIGhlYWRlcnM6IHtcclxuICAgIEF1dGhvcml6YXRpb246IGBCYXNpYyAke2Jhc2ljQXV0aH1gLFxyXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICB9LFxyXG59KTtcclxuXHJcbmNvbnN0IGxvZ0V4cG9ydGVyID0gbmV3IE9UTFBMb2dFeHBvcnRlcih7XHJcbiAgdXJsOiBgJHtiYXNlVXJsfS9sb2dzYCxcclxuICBoZWFkZXJzOiB7XHJcbiAgICBBdXRob3JpemF0aW9uOiBgQmFzaWMgJHtiYXNpY0F1dGh9YCxcclxuICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXHJcbiAgfSxcclxufSk7XHJcblxyXG5jb25zdCBtZXRyaWNSZWFkZXIgPSBuZXcgUGVyaW9kaWNFeHBvcnRpbmdNZXRyaWNSZWFkZXIoe1xyXG4gIGV4cG9ydGVyOiBtZXRyaWNFeHBvcnRlcixcclxuICBleHBvcnRJbnRlcnZhbE1pbGxpczogMTAwMCxcclxufSk7XHJcblxyXG4vLyBDb25maWd1cmFyIExvZ2dlclByb3ZpZGVyXHJcbmNvbnN0IHNlcnZpY2VOYW1lID0gcHJvY2Vzcy5lbnYuU0VSVklDRV9OQU1FIHx8ICdzc3Qtc2VydmljZSc7XHJcbmNvbnN0IHJlc291cmNlID0gbmV3IHJlc291cmNlcy5SZXNvdXJjZSh7XHJcbiAgW0FUVFJfU0VSVklDRV9OQU1FXTogc2VydmljZU5hbWUsXHJcbn0pO1xyXG5cclxuY29uc3QgbG9nZ2VyUHJvdmlkZXIgPSBuZXcgbG9ncy5Mb2dnZXJQcm92aWRlcih7IHJlc291cmNlIH0pO1xyXG5jb25zdCBsb2dSZWNvcmRQcm9jZXNzb3IgPSBuZXcgbG9ncy5CYXRjaExvZ1JlY29yZFByb2Nlc3Nvcihsb2dFeHBvcnRlcik7XHJcbmxvZ2dlclByb3ZpZGVyLmFkZExvZ1JlY29yZFByb2Nlc3Nvcihsb2dSZWNvcmRQcm9jZXNzb3IpO1xyXG5cclxuY29uc3Qgc2RrID0gbmV3IE5vZGVTREsoe1xyXG4gIHRyYWNlRXhwb3J0ZXIsXHJcbiAgbWV0cmljUmVhZGVyOiBtZXRyaWNSZWFkZXIgYXMgYW55LCAvLyBUeXBlIGNvbXBhdGliaWxpdHkgd29ya2Fyb3VuZFxyXG59KTtcclxuXHJcbnNkay5zdGFydCgpO1xyXG5cclxuLy8gQ3JpYXIgU3RhbmRhcmRMb2dnZXIgcGFyYSBzZXIgdXNhZG8gbm9zIG1pZGRsZXdhcmVzXHJcbmxldCBzdGFuZGFyZExvZ2dlcjogU3RhbmRhcmRMb2dnZXIgfCBudWxsID0gbnVsbDtcclxubGV0IHN0YW5kYXJkVHJhY2VyOiBTdGFuZGFyZFRyYWNlciB8IG51bGwgPSBudWxsO1xyXG5cclxuZXhwb3J0IGNvbnN0IGdldFN0YW5kYXJkTG9nZ2VyID0gKCk6IFN0YW5kYXJkTG9nZ2VyID0+IHtcclxuICBpZiAoIXN0YW5kYXJkTG9nZ2VyKSB7XHJcbiAgICBjb25zdCBsb2dnZXIgPSBsb2dnZXJQcm92aWRlci5nZXRMb2dnZXIoJ3NzdC1taWRkbGV3YXJlLWxvZ2dlcicsICcxLjAuMCcpO1xyXG4gICAgc3RhbmRhcmRMb2dnZXIgPSBuZXcgU3RhbmRhcmRMb2dnZXIobG9nZ2VyLCBzZXJ2aWNlTmFtZSk7XHJcbiAgfVxyXG4gIHJldHVybiBzdGFuZGFyZExvZ2dlcjtcclxufTtcclxuXHJcbmV4cG9ydCBjb25zdCBnZXRTdGFuZGFyZFRyYWNlciA9ICgpOiBTdGFuZGFyZFRyYWNlciA9PiB7XHJcbiAgaWYgKCFzdGFuZGFyZFRyYWNlcikge1xyXG4gICAgY29uc3QgdHJhY2VyID0gdHJhY2UuZ2V0VHJhY2VyKHNlcnZpY2VOYW1lLCAnMS4wLjAnKTtcclxuICAgIHN0YW5kYXJkVHJhY2VyID0gbmV3IFN0YW5kYXJkVHJhY2VyKHRyYWNlciwgc2VydmljZU5hbWUpO1xyXG4gIH1cclxuICByZXR1cm4gc3RhbmRhcmRUcmFjZXI7XHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgZm9yY2VGbHVzaCA9IGFzeW5jICgpID0+IHtcclxuICBhd2FpdCBtZXRyaWNSZWFkZXIuZm9yY2VGbHVzaCgpO1xyXG4gIGF3YWl0IHRyYWNlRXhwb3J0ZXIuZm9yY2VGbHVzaCgpO1xyXG4gIGF3YWl0IGxvZ2dlclByb3ZpZGVyLmZvcmNlRmx1c2goKTtcclxufTtcclxuIl19
@@ -1,5 +1,5 @@
1
1
  import middy from '@middy/core';
2
2
  interface MiddyMiddlewareOptions {
3
3
  }
4
- export declare const middyMiddleware: (options?: MiddyMiddlewareOptions) => middy.MiddlewareObj;
4
+ export declare const middyTelemetryMiddleware: (options?: MiddyMiddlewareOptions) => middy.MiddlewareObj;
5
5
  export {};
@@ -9,11 +9,11 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
9
9
  });
10
10
  };
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.middyMiddleware = void 0;
12
+ exports.middyTelemetryMiddleware = void 0;
13
13
  const api_1 = require("@opentelemetry/api");
14
14
  const telemetry_1 = require("../telemetry");
15
15
  const perf_hooks_1 = require("perf_hooks");
16
- const middyMiddleware = (options) => ({
16
+ const middyTelemetryMiddleware = (options) => ({
17
17
  before: (request) => __awaiter(void 0, void 0, void 0, function* () {
18
18
  const startTime = perf_hooks_1.performance.now();
19
19
  const { context: lambdaContext } = request;
@@ -153,5 +153,5 @@ const middyMiddleware = (options) => ({
153
153
  yield (0, telemetry_1.forceFlush)();
154
154
  }),
155
155
  });
156
- exports.middyMiddleware = middyMiddleware;
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../../src/telemetry/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\r\nimport { metrics, ValueType } from '@opentelemetry/api';\r\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\r\nimport { performance } from 'perf_hooks';\r\n\r\ninterface MiddyMiddlewareOptions {}\r\n\r\nexport const middyMiddleware = (\r\n  options?: MiddyMiddlewareOptions\r\n): middy.MiddlewareObj => ({\r\n  before: async (request) => {\r\n    const startTime = performance.now();\r\n\r\n    const { context: lambdaContext } = request;\r\n    const functionName = lambdaContext.functionName;\r\n    const invocationId = lambdaContext.awsRequestId;\r\n    const serviceName = process.env.SERVICE_NAME || 'sst-service';\r\n    const event = request.event as any;\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n    let stage = process.env.STAGE || 'development';\r\n    if (stage === 'prod') stage = 'production';\r\n\r\n    // Usar StandardTracer para criar span com atributos padronizados\r\n    const standardTracer = getStandardTracer();\r\n    const spanResult = standardTracer.startSpan({\r\n      spanName: functionName,\r\n      serviceName,\r\n      environment: stage,\r\n      execution: {\r\n        functionName,\r\n        invocationId,\r\n        awsRequestId: invocationId,\r\n        origin,\r\n      },\r\n    });\r\n\r\n    const meter = metrics.getMeter(origin);\r\n\r\n    const executionTimeHistogram = meter.createHistogram(\r\n      'lambda_execution_duration',\r\n      {\r\n        description: 'Tempo total de execução do Lambda em ms',\r\n        unit: 'ms',\r\n        valueType: ValueType.DOUBLE,\r\n      }\r\n    );\r\n    const successCounter = meter.createCounter('total_successful_purchases', {\r\n      description: 'Total de compras bem-sucedidas',\r\n    });\r\n    const failureCounter = meter.createCounter('total_failed_purchases', {\r\n      description: 'Total de compras com falha',\r\n    });\r\n\r\n    (request.context as any).otel = {\r\n      spanResult,\r\n      meter,\r\n      executionTimeHistogram,\r\n      successCounter,\r\n      failureCounter,\r\n      startTime,\r\n      serviceName,\r\n      environment: stage,\r\n      origin,\r\n    };\r\n  },\r\n\r\n  after: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n    const event = request.event as any;\r\n\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n\r\n    const {\r\n      spanResult,\r\n      successCounter,\r\n      executionTimeHistogram,\r\n      startTime,\r\n      serviceName,\r\n      environment,\r\n    } = otelData;\r\n\r\n    // Marcar span como sucesso usando StandardTracer\r\n    spanResult.setSuccess(true);\r\n\r\n    // Métricas\r\n    successCounter.add(1, {\r\n      origin,\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin,\r\n      status: 'success',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    // Log estruturado de sucesso\r\n    const standardLogger = getStandardLogger();\r\n\r\n    await standardLogger.logInfo({\r\n      message: 'Request completed successfully',\r\n      serviceName,\r\n      environment,\r\n      execution: {\r\n        functionName: spanResult.span.attributes?.['faas.name'] as string,\r\n        invocationId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: true,\r\n      },\r\n    });\r\n\r\n    // Finalizar span\r\n    spanResult.end();\r\n    await forceFlush();\r\n  },\r\n\r\n  onError: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n\r\n    const {\r\n      spanResult,\r\n      failureCounter,\r\n      executionTimeHistogram,\r\n      startTime,\r\n      serviceName,\r\n      environment,\r\n      origin,\r\n    } = otelData;\r\n    const error = request.error;\r\n\r\n    // Marcar span como erro usando StandardTracer\r\n    if (error) {\r\n      spanResult.setError(error);\r\n    }\r\n\r\n    // Métricas\r\n    failureCounter.add(1, {\r\n      origin,\r\n      error_type: error?.constructor?.name || 'UnknownError',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin,\r\n      status: 'error',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    // Log estruturado de erro\r\n    const standardLogger = getStandardLogger();\r\n\r\n    await standardLogger.logError({\r\n      message: error?.message || 'Unknown error occurred',\r\n      error: error || undefined,\r\n      serviceName,\r\n      environment,\r\n      execution: {\r\n        functionName: spanResult.span.attributes?.['faas.name'] as string,\r\n        invocationId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        awsRequestId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: false,\r\n      },\r\n      context: {\r\n        errorType: error?.constructor?.name,\r\n      },\r\n    });\r\n\r\n    // Finalizar span\r\n    spanResult.end();\r\n    await forceFlush();\r\n  },\r\n});\r\n"]}
156
+ exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../../src/telemetry/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\r\nimport { metrics, ValueType } from '@opentelemetry/api';\r\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\r\nimport { performance } from 'perf_hooks';\r\n\r\ninterface MiddyMiddlewareOptions {}\r\n\r\nexport const middyTelemetryMiddleware = (\r\n  options?: MiddyMiddlewareOptions\r\n): middy.MiddlewareObj => ({\r\n  before: async (request) => {\r\n    const startTime = performance.now();\r\n\r\n    const { context: lambdaContext } = request;\r\n    const functionName = lambdaContext.functionName;\r\n    const invocationId = lambdaContext.awsRequestId;\r\n    const serviceName = process.env.SERVICE_NAME || 'sst-service';\r\n    const event = request.event as any;\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n    let stage = process.env.STAGE || 'development';\r\n    if (stage === 'prod') stage = 'production';\r\n\r\n    // Usar StandardTracer para criar span com atributos padronizados\r\n    const standardTracer = getStandardTracer();\r\n    const spanResult = standardTracer.startSpan({\r\n      spanName: functionName,\r\n      serviceName,\r\n      environment: stage,\r\n      execution: {\r\n        functionName,\r\n        invocationId,\r\n        awsRequestId: invocationId,\r\n        origin,\r\n      },\r\n    });\r\n\r\n    const meter = metrics.getMeter(origin);\r\n\r\n    const executionTimeHistogram = meter.createHistogram(\r\n      'lambda_execution_duration',\r\n      {\r\n        description: 'Tempo total de execução do Lambda em ms',\r\n        unit: 'ms',\r\n        valueType: ValueType.DOUBLE,\r\n      }\r\n    );\r\n    const successCounter = meter.createCounter('total_successful_purchases', {\r\n      description: 'Total de compras bem-sucedidas',\r\n    });\r\n    const failureCounter = meter.createCounter('total_failed_purchases', {\r\n      description: 'Total de compras com falha',\r\n    });\r\n\r\n    (request.context as any).otel = {\r\n      spanResult,\r\n      meter,\r\n      executionTimeHistogram,\r\n      successCounter,\r\n      failureCounter,\r\n      startTime,\r\n      serviceName,\r\n      environment: stage,\r\n      origin,\r\n    };\r\n  },\r\n\r\n  after: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n    const event = request.event as any;\r\n\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n\r\n    const {\r\n      spanResult,\r\n      successCounter,\r\n      executionTimeHistogram,\r\n      startTime,\r\n      serviceName,\r\n      environment,\r\n    } = otelData;\r\n\r\n    // Marcar span como sucesso usando StandardTracer\r\n    spanResult.setSuccess(true);\r\n\r\n    // Métricas\r\n    successCounter.add(1, {\r\n      origin,\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin,\r\n      status: 'success',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    // Log estruturado de sucesso\r\n    const standardLogger = getStandardLogger();\r\n\r\n    await standardLogger.logInfo({\r\n      message: 'Request completed successfully',\r\n      serviceName,\r\n      environment,\r\n      execution: {\r\n        functionName: spanResult.span.attributes?.['faas.name'] as string,\r\n        invocationId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: true,\r\n      },\r\n    });\r\n\r\n    // Finalizar span\r\n    spanResult.end();\r\n    await forceFlush();\r\n  },\r\n\r\n  onError: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n\r\n    const {\r\n      spanResult,\r\n      failureCounter,\r\n      executionTimeHistogram,\r\n      startTime,\r\n      serviceName,\r\n      environment,\r\n      origin,\r\n    } = otelData;\r\n    const error = request.error;\r\n\r\n    // Marcar span como erro usando StandardTracer\r\n    if (error) {\r\n      spanResult.setError(error);\r\n    }\r\n\r\n    // Métricas\r\n    failureCounter.add(1, {\r\n      origin,\r\n      error_type: error?.constructor?.name || 'UnknownError',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin,\r\n      status: 'error',\r\n      'faas.name': spanResult.span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': serviceName,\r\n      'deployment.environment.name': environment,\r\n    });\r\n\r\n    // Log estruturado de erro\r\n    const standardLogger = getStandardLogger();\r\n\r\n    await standardLogger.logError({\r\n      message: error?.message || 'Unknown error occurred',\r\n      error: error || undefined,\r\n      serviceName,\r\n      environment,\r\n      execution: {\r\n        functionName: spanResult.span.attributes?.['faas.name'] as string,\r\n        invocationId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        awsRequestId: spanResult.span.attributes?.[\r\n          'faas.invocation_id'\r\n        ] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: false,\r\n      },\r\n      context: {\r\n        errorType: error?.constructor?.name,\r\n      },\r\n    });\r\n\r\n    // Finalizar span\r\n    spanResult.end();\r\n    await forceFlush();\r\n  },\r\n});\r\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,146 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const vitest_1 = require("vitest");
13
+ const config_1 = require("../config");
14
+ (0, vitest_1.describe)('TsedTelemetryProvider', () => {
15
+ let provider;
16
+ (0, vitest_1.beforeEach)(() => {
17
+ process.env.OTEL_EXPORTER_OTLP_ENDPOINT = 'https://test.com';
18
+ process.env.OTEL_EXPORTER_OTLP_USER = 'test-user';
19
+ process.env.OTEL_EXPORTER_OTLP_PASS = 'test-pass';
20
+ process.env.SERVICE_NAME = 'test-service';
21
+ process.env.STAGE = 'test';
22
+ provider = new config_1.TsedTelemetryProvider();
23
+ });
24
+ (0, vitest_1.describe)('initialize', () => {
25
+ (0, vitest_1.it)('deve inicializar com configuração válida', () => {
26
+ provider.initialize({
27
+ endpoint: 'https://test.com',
28
+ username: 'user',
29
+ password: 'pass',
30
+ serviceName: 'test-service',
31
+ serviceVersion: '1.0.0',
32
+ enabled: true,
33
+ });
34
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(true);
35
+ });
36
+ (0, vitest_1.it)('não deve inicializar se já estiver inicializado', () => {
37
+ provider.initialize({
38
+ endpoint: 'https://test.com',
39
+ username: 'user',
40
+ password: 'pass',
41
+ serviceName: 'test-service',
42
+ });
43
+ const firstInit = provider.isInitialized();
44
+ provider.initialize({
45
+ endpoint: 'https://other.com',
46
+ username: 'other',
47
+ password: 'other',
48
+ serviceName: 'other-service',
49
+ });
50
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(firstInit);
51
+ });
52
+ (0, vitest_1.it)('não deve inicializar se enabled=false', () => {
53
+ delete process.env.OTEL_EXPORTER_OTLP_ENDPOINT;
54
+ const newProvider = new config_1.TsedTelemetryProvider();
55
+ newProvider.initialize({
56
+ endpoint: 'https://test.com',
57
+ username: 'user',
58
+ password: 'pass',
59
+ enabled: false,
60
+ });
61
+ (0, vitest_1.expect)(newProvider.isInitialized()).toBe(false);
62
+ });
63
+ });
64
+ (0, vitest_1.describe)('getLoggerProvider', () => {
65
+ (0, vitest_1.it)('deve retornar LoggerProvider após inicialização', () => {
66
+ provider.initialize({
67
+ endpoint: 'https://test.com',
68
+ username: 'user',
69
+ password: 'pass',
70
+ serviceName: 'test-service',
71
+ });
72
+ const loggerProvider = provider.getLoggerProvider();
73
+ (0, vitest_1.expect)(loggerProvider).toBeDefined();
74
+ });
75
+ (0, vitest_1.it)('deve retornar null se não inicializado', () => {
76
+ const newProvider = new config_1.TsedTelemetryProvider();
77
+ delete process.env.OTEL_EXPORTER_OTLP_ENDPOINT;
78
+ const emptyProvider = new config_1.TsedTelemetryProvider();
79
+ (0, vitest_1.expect)(emptyProvider.getLoggerProvider()).toBeNull();
80
+ });
81
+ });
82
+ (0, vitest_1.describe)('getTracerProvider', () => {
83
+ (0, vitest_1.it)('deve retornar TracerProvider após inicialização', () => {
84
+ provider.initialize({
85
+ endpoint: 'https://test.com',
86
+ username: 'user',
87
+ password: 'pass',
88
+ serviceName: 'test-service',
89
+ });
90
+ const tracerProvider = provider.getTracerProvider();
91
+ (0, vitest_1.expect)(tracerProvider).toBeDefined();
92
+ });
93
+ });
94
+ (0, vitest_1.describe)('getMeterProvider', () => {
95
+ (0, vitest_1.it)('deve retornar MeterProvider após inicialização', () => {
96
+ provider.initialize({
97
+ endpoint: 'https://test.com',
98
+ username: 'user',
99
+ password: 'pass',
100
+ serviceName: 'test-service',
101
+ });
102
+ const meterProvider = provider.getMeterProvider();
103
+ (0, vitest_1.expect)(meterProvider).toBeDefined();
104
+ });
105
+ });
106
+ (0, vitest_1.describe)('forceFlush', () => {
107
+ (0, vitest_1.it)('deve executar forceFlush sem erros', () => __awaiter(void 0, void 0, void 0, function* () {
108
+ provider.initialize({
109
+ endpoint: 'https://test.com',
110
+ username: 'user',
111
+ password: 'pass',
112
+ serviceName: 'test-service',
113
+ });
114
+ yield (0, vitest_1.expect)(provider.forceFlush()).resolves.not.toThrow();
115
+ }));
116
+ });
117
+ (0, vitest_1.describe)('shutdown', () => {
118
+ (0, vitest_1.it)('deve fazer shutdown e marcar como não inicializado', () => __awaiter(void 0, void 0, void 0, function* () {
119
+ provider.initialize({
120
+ endpoint: 'https://test.com',
121
+ username: 'user',
122
+ password: 'pass',
123
+ serviceName: 'test-service',
124
+ });
125
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(true);
126
+ yield provider.shutdown();
127
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(false);
128
+ }));
129
+ });
130
+ (0, vitest_1.describe)('integração completa', () => {
131
+ (0, vitest_1.it)('deve criar provider completo com logs, traces e métricas', () => {
132
+ provider.initialize({
133
+ endpoint: 'https://test.com',
134
+ username: 'user',
135
+ password: 'pass',
136
+ serviceName: 'test-service',
137
+ serviceVersion: '2.0.0',
138
+ });
139
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(true);
140
+ (0, vitest_1.expect)(provider.getLoggerProvider()).toBeDefined();
141
+ (0, vitest_1.expect)(provider.getTracerProvider()).toBeDefined();
142
+ (0, vitest_1.expect)(provider.getMeterProvider()).toBeDefined();
143
+ });
144
+ });
145
+ });
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.test.js","sourceRoot":"","sources":["../../../src/tsed/__tests__/config.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, vi, beforeEach } from 'vitest';\r\nimport { TsedTelemetryProvider } from '../config';\r\n\r\ndescribe('TsedTelemetryProvider', () => {\r\n  let provider: TsedTelemetryProvider;\r\n\r\n  beforeEach(() => {\r\n    // Mock das variáveis de ambiente\r\n    process.env.OTEL_EXPORTER_OTLP_ENDPOINT = 'https://test.com';\r\n    process.env.OTEL_EXPORTER_OTLP_USER = 'test-user';\r\n    process.env.OTEL_EXPORTER_OTLP_PASS = 'test-pass';\r\n    process.env.SERVICE_NAME = 'test-service';\r\n    process.env.STAGE = 'test';\r\n\r\n    provider = new TsedTelemetryProvider();\r\n  });\r\n\r\n  describe('initialize', () => {\r\n    it('deve inicializar com configuração válida', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n        serviceVersion: '1.0.0',\r\n        enabled: true,\r\n      });\r\n\r\n      expect(provider.isInitialized()).toBe(true);\r\n    });\r\n\r\n    it('não deve inicializar se já estiver inicializado', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      const firstInit = provider.isInitialized();\r\n\r\n      provider.initialize({\r\n        endpoint: 'https://other.com',\r\n        username: 'other',\r\n        password: 'other',\r\n        serviceName: 'other-service',\r\n      });\r\n\r\n      expect(provider.isInitialized()).toBe(firstInit);\r\n    });\r\n\r\n    it('não deve inicializar se enabled=false', () => {\r\n      // Criar provider sem env vars para não auto-inicializar\r\n      delete process.env.OTEL_EXPORTER_OTLP_ENDPOINT;\r\n      const newProvider = new TsedTelemetryProvider();\r\n\r\n      newProvider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        enabled: false,\r\n      });\r\n\r\n      expect(newProvider.isInitialized()).toBe(false);\r\n    });\r\n  });\r\n\r\n  describe('getLoggerProvider', () => {\r\n    it('deve retornar LoggerProvider após inicialização', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      const loggerProvider = provider.getLoggerProvider();\r\n      expect(loggerProvider).toBeDefined();\r\n    });\r\n\r\n    it('deve retornar null se não inicializado', () => {\r\n      const newProvider = new TsedTelemetryProvider();\r\n      // Limpar env vars para não auto-inicializar\r\n      delete process.env.OTEL_EXPORTER_OTLP_ENDPOINT;\r\n\r\n      const emptyProvider = new TsedTelemetryProvider();\r\n      expect(emptyProvider.getLoggerProvider()).toBeNull();\r\n    });\r\n  });\r\n\r\n  describe('getTracerProvider', () => {\r\n    it('deve retornar TracerProvider após inicialização', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      const tracerProvider = provider.getTracerProvider();\r\n      expect(tracerProvider).toBeDefined();\r\n    });\r\n  });\r\n\r\n  describe('getMeterProvider', () => {\r\n    it('deve retornar MeterProvider após inicialização', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      const meterProvider = provider.getMeterProvider();\r\n      expect(meterProvider).toBeDefined();\r\n    });\r\n  });\r\n\r\n  describe('forceFlush', () => {\r\n    it('deve executar forceFlush sem erros', async () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      await expect(provider.forceFlush()).resolves.not.toThrow();\r\n    });\r\n  });\r\n\r\n  describe('shutdown', () => {\r\n    it('deve fazer shutdown e marcar como não inicializado', async () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n      });\r\n\r\n      expect(provider.isInitialized()).toBe(true);\r\n\r\n      await provider.shutdown();\r\n\r\n      expect(provider.isInitialized()).toBe(false);\r\n    });\r\n  });\r\n\r\n  describe('integração completa', () => {\r\n    it('deve criar provider completo com logs, traces e métricas', () => {\r\n      provider.initialize({\r\n        endpoint: 'https://test.com',\r\n        username: 'user',\r\n        password: 'pass',\r\n        serviceName: 'test-service',\r\n        serviceVersion: '2.0.0',\r\n      });\r\n\r\n      expect(provider.isInitialized()).toBe(true);\r\n      expect(provider.getLoggerProvider()).toBeDefined();\r\n      expect(provider.getTracerProvider()).toBeDefined();\r\n      expect(provider.getMeterProvider()).toBeDefined();\r\n    });\r\n  });\r\n});\r\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ const vitest_1 = require("vitest");
13
+ const config_1 = require("../config");
14
+ (0, vitest_1.describe)('TsedTelemetryService', () => {
15
+ let mockProvider;
16
+ (0, vitest_1.beforeEach)(() => {
17
+ mockProvider = {
18
+ isInitialized: vitest_1.vi.fn().mockReturnValue(true),
19
+ getLoggerProvider: vitest_1.vi.fn().mockReturnValue({
20
+ getLogger: vitest_1.vi.fn().mockReturnValue({
21
+ emit: vitest_1.vi.fn(),
22
+ }),
23
+ }),
24
+ getTracerProvider: vitest_1.vi.fn().mockReturnValue({}),
25
+ forceFlush: vitest_1.vi.fn().mockResolvedValue(undefined),
26
+ };
27
+ process.env.SERVICE_NAME = 'test-service';
28
+ process.env.STAGE = 'test';
29
+ });
30
+ (0, vitest_1.describe)('TsedTelemetryProvider integration', () => {
31
+ (0, vitest_1.it)('deve criar provider com logs, traces e métricas', () => {
32
+ const provider = new config_1.TsedTelemetryProvider();
33
+ provider.initialize({
34
+ endpoint: 'https://test.com',
35
+ username: 'user',
36
+ password: 'pass',
37
+ serviceName: 'test-service',
38
+ });
39
+ (0, vitest_1.expect)(provider.isInitialized()).toBe(true);
40
+ (0, vitest_1.expect)(provider.getLoggerProvider()).toBeDefined();
41
+ (0, vitest_1.expect)(provider.getTracerProvider()).toBeDefined();
42
+ (0, vitest_1.expect)(provider.getMeterProvider()).toBeDefined();
43
+ });
44
+ (0, vitest_1.it)('deve retornar null quando não inicializado', () => {
45
+ delete process.env.OTEL_EXPORTER_OTLP_ENDPOINT;
46
+ const provider = new config_1.TsedTelemetryProvider();
47
+ (0, vitest_1.expect)(provider.getLoggerProvider()).toBeNull();
48
+ (0, vitest_1.expect)(provider.getTracerProvider()).toBeNull();
49
+ (0, vitest_1.expect)(provider.getMeterProvider()).toBeNull();
50
+ });
51
+ (0, vitest_1.it)('deve fazer forceFlush de todos os providers', () => __awaiter(void 0, void 0, void 0, function* () {
52
+ const provider = new config_1.TsedTelemetryProvider();
53
+ provider.initialize({
54
+ endpoint: 'https://test.com',
55
+ username: 'user',
56
+ password: 'pass',
57
+ serviceName: 'test-service',
58
+ });
59
+ yield (0, vitest_1.expect)(provider.forceFlush()).resolves.not.toThrow();
60
+ }));
61
+ });
62
+ });
63
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS50ZXN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3RzZWQvX190ZXN0c19fL3NlcnZpY2UudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLG1DQUE4RDtBQUM5RCxzQ0FBa0Q7QUFFbEQsSUFBQSxpQkFBUSxFQUFDLHNCQUFzQixFQUFFLEdBQUcsRUFBRTtJQUNwQyxJQUFJLFlBQWlCLENBQUM7SUFFdEIsSUFBQSxtQkFBVSxFQUFDLEdBQUcsRUFBRTtRQUVkLFlBQVksR0FBRztZQUNiLGFBQWEsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQztZQUM1QyxpQkFBaUIsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDO2dCQUN6QyxTQUFTLEVBQUUsV0FBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQztvQkFDakMsSUFBSSxFQUFFLFdBQUUsQ0FBQyxFQUFFLEVBQUU7aUJBQ2QsQ0FBQzthQUNILENBQUM7WUFDRixpQkFBaUIsRUFBRSxXQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsZUFBZSxDQUFDLEVBQUUsQ0FBQztZQUM5QyxVQUFVLEVBQUUsV0FBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDLFNBQVMsQ0FBQztTQUNqRCxDQUFDO1FBR0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxZQUFZLEdBQUcsY0FBYyxDQUFDO1FBQzFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQztJQUM3QixDQUFDLENBQUMsQ0FBQztJQUVILElBQUEsaUJBQVEsRUFBQyxtQ0FBbUMsRUFBRSxHQUFHLEVBQUU7UUFDakQsSUFBQSxXQUFFLEVBQUMsaURBQWlELEVBQUUsR0FBRyxFQUFFO1lBQ3pELE1BQU0sUUFBUSxHQUFHLElBQUksOEJBQXFCLEVBQUUsQ0FBQztZQUU3QyxRQUFRLENBQUMsVUFBVSxDQUFDO2dCQUNsQixRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixRQUFRLEVBQUUsTUFBTTtnQkFDaEIsUUFBUSxFQUFFLE1BQU07Z0JBQ2hCLFdBQVcsRUFBRSxjQUFjO2FBQzVCLENBQUMsQ0FBQztZQUVILElBQUEsZUFBTSxFQUFDLFFBQVEsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM1QyxJQUFBLGVBQU0sRUFBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ25ELElBQUEsZUFBTSxFQUFDLFFBQVEsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDbkQsSUFBQSxlQUFNLEVBQUMsUUFBUSxDQUFDLGdCQUFnQixFQUFFLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNwRCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUEsV0FBRSxFQUFDLDRDQUE0QyxFQUFFLEdBQUcsRUFBRTtZQUNwRCxPQUFPLE9BQU8sQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUM7WUFDL0MsTUFBTSxRQUFRLEdBQUcsSUFBSSw4QkFBcUIsRUFBRSxDQUFDO1lBRTdDLElBQUEsZUFBTSxFQUFDLFFBQVEsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDaEQsSUFBQSxlQUFNLEVBQUMsUUFBUSxDQUFDLGlCQUFpQixFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUNoRCxJQUFBLGVBQU0sRUFBQyxRQUFRLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBQSxXQUFFLEVBQUMsNkNBQTZDLEVBQUUsR0FBUyxFQUFFO1lBQzNELE1BQU0sUUFBUSxHQUFHLElBQUksOEJBQXFCLEVBQUUsQ0FBQztZQUU3QyxRQUFRLENBQUMsVUFBVSxDQUFDO2dCQUNsQixRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixRQUFRLEVBQUUsTUFBTTtnQkFDaEIsUUFBUSxFQUFFLE1BQU07Z0JBQ2hCLFdBQVcsRUFBRSxjQUFjO2FBQzVCLENBQUMsQ0FBQztZQUVILE1BQU0sSUFBQSxlQUFNLEVBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUM3RCxDQUFDLENBQUEsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7QUFDTCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlc2NyaWJlLCBpdCwgZXhwZWN0LCB2aSwgYmVmb3JlRWFjaCB9IGZyb20gJ3ZpdGVzdCc7XHJcbmltcG9ydCB7IFRzZWRUZWxlbWV0cnlQcm92aWRlciB9IGZyb20gJy4uL2NvbmZpZyc7XHJcblxyXG5kZXNjcmliZSgnVHNlZFRlbGVtZXRyeVNlcnZpY2UnLCAoKSA9PiB7XHJcbiAgbGV0IG1vY2tQcm92aWRlcjogYW55O1xyXG5cclxuICBiZWZvcmVFYWNoKCgpID0+IHtcclxuICAgIC8vIE1vY2sgZG8gcHJvdmlkZXJcclxuICAgIG1vY2tQcm92aWRlciA9IHtcclxuICAgICAgaXNJbml0aWFsaXplZDogdmkuZm4oKS5tb2NrUmV0dXJuVmFsdWUodHJ1ZSksXHJcbiAgICAgIGdldExvZ2dlclByb3ZpZGVyOiB2aS5mbigpLm1vY2tSZXR1cm5WYWx1ZSh7XHJcbiAgICAgICAgZ2V0TG9nZ2VyOiB2aS5mbigpLm1vY2tSZXR1cm5WYWx1ZSh7XHJcbiAgICAgICAgICBlbWl0OiB2aS5mbigpLFxyXG4gICAgICAgIH0pLFxyXG4gICAgICB9KSxcclxuICAgICAgZ2V0VHJhY2VyUHJvdmlkZXI6IHZpLmZuKCkubW9ja1JldHVyblZhbHVlKHt9KSxcclxuICAgICAgZm9yY2VGbHVzaDogdmkuZm4oKS5tb2NrUmVzb2x2ZWRWYWx1ZSh1bmRlZmluZWQpLFxyXG4gICAgfTtcclxuXHJcbiAgICAvLyBNb2NrIGVudiB2YXJzXHJcbiAgICBwcm9jZXNzLmVudi5TRVJWSUNFX05BTUUgPSAndGVzdC1zZXJ2aWNlJztcclxuICAgIHByb2Nlc3MuZW52LlNUQUdFID0gJ3Rlc3QnO1xyXG4gIH0pO1xyXG5cclxuICBkZXNjcmliZSgnVHNlZFRlbGVtZXRyeVByb3ZpZGVyIGludGVncmF0aW9uJywgKCkgPT4ge1xyXG4gICAgaXQoJ2RldmUgY3JpYXIgcHJvdmlkZXIgY29tIGxvZ3MsIHRyYWNlcyBlIG3DqXRyaWNhcycsICgpID0+IHtcclxuICAgICAgY29uc3QgcHJvdmlkZXIgPSBuZXcgVHNlZFRlbGVtZXRyeVByb3ZpZGVyKCk7XHJcblxyXG4gICAgICBwcm92aWRlci5pbml0aWFsaXplKHtcclxuICAgICAgICBlbmRwb2ludDogJ2h0dHBzOi8vdGVzdC5jb20nLFxyXG4gICAgICAgIHVzZXJuYW1lOiAndXNlcicsXHJcbiAgICAgICAgcGFzc3dvcmQ6ICdwYXNzJyxcclxuICAgICAgICBzZXJ2aWNlTmFtZTogJ3Rlc3Qtc2VydmljZScsXHJcbiAgICAgIH0pO1xyXG5cclxuICAgICAgZXhwZWN0KHByb3ZpZGVyLmlzSW5pdGlhbGl6ZWQoKSkudG9CZSh0cnVlKTtcclxuICAgICAgZXhwZWN0KHByb3ZpZGVyLmdldExvZ2dlclByb3ZpZGVyKCkpLnRvQmVEZWZpbmVkKCk7XHJcbiAgICAgIGV4cGVjdChwcm92aWRlci5nZXRUcmFjZXJQcm92aWRlcigpKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgICBleHBlY3QocHJvdmlkZXIuZ2V0TWV0ZXJQcm92aWRlcigpKS50b0JlRGVmaW5lZCgpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgaXQoJ2RldmUgcmV0b3JuYXIgbnVsbCBxdWFuZG8gbsOjbyBpbmljaWFsaXphZG8nLCAoKSA9PiB7XHJcbiAgICAgIGRlbGV0ZSBwcm9jZXNzLmVudi5PVEVMX0VYUE9SVEVSX09UTFBfRU5EUE9JTlQ7XHJcbiAgICAgIGNvbnN0IHByb3ZpZGVyID0gbmV3IFRzZWRUZWxlbWV0cnlQcm92aWRlcigpO1xyXG5cclxuICAgICAgZXhwZWN0KHByb3ZpZGVyLmdldExvZ2dlclByb3ZpZGVyKCkpLnRvQmVOdWxsKCk7XHJcbiAgICAgIGV4cGVjdChwcm92aWRlci5nZXRUcmFjZXJQcm92aWRlcigpKS50b0JlTnVsbCgpO1xyXG4gICAgICBleHBlY3QocHJvdmlkZXIuZ2V0TWV0ZXJQcm92aWRlcigpKS50b0JlTnVsbCgpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgaXQoJ2RldmUgZmF6ZXIgZm9yY2VGbHVzaCBkZSB0b2RvcyBvcyBwcm92aWRlcnMnLCBhc3luYyAoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHByb3ZpZGVyID0gbmV3IFRzZWRUZWxlbWV0cnlQcm92aWRlcigpO1xyXG5cclxuICAgICAgcHJvdmlkZXIuaW5pdGlhbGl6ZSh7XHJcbiAgICAgICAgZW5kcG9pbnQ6ICdodHRwczovL3Rlc3QuY29tJyxcclxuICAgICAgICB1c2VybmFtZTogJ3VzZXInLFxyXG4gICAgICAgIHBhc3N3b3JkOiAncGFzcycsXHJcbiAgICAgICAgc2VydmljZU5hbWU6ICd0ZXN0LXNlcnZpY2UnLFxyXG4gICAgICB9KTtcclxuXHJcbiAgICAgIGF3YWl0IGV4cGVjdChwcm92aWRlci5mb3JjZUZsdXNoKCkpLnJlc29sdmVzLm5vdC50b1Rocm93KCk7XHJcbiAgICB9KTtcclxuICB9KTtcclxufSk7XHJcbiJdfQ==
@@ -1,4 +1,6 @@
1
1
  import { LoggerProvider } from '@opentelemetry/sdk-logs';
2
+ import { NodeTracerProvider } from '@opentelemetry/sdk-trace-node';
3
+ import { MeterProvider } from '@opentelemetry/sdk-metrics';
2
4
  export interface TsedTelemetryConfig {
3
5
  endpoint: string;
4
6
  username: string;
@@ -9,10 +11,14 @@ export interface TsedTelemetryConfig {
9
11
  }
10
12
  export declare class TsedTelemetryProvider {
11
13
  private loggerProvider;
14
+ private tracerProvider;
15
+ private meterProvider;
12
16
  private initialized;
13
17
  constructor();
14
18
  initialize(config: TsedTelemetryConfig): void;
15
19
  getLoggerProvider(): LoggerProvider | null;
20
+ getTracerProvider(): NodeTracerProvider | null;
21
+ getMeterProvider(): MeterProvider | null;
16
22
  isInitialized(): boolean;
17
23
  forceFlush(): Promise<void>;
18
24
  shutdown(): Promise<void>;