@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.
- package/CHANGELOG.md +14 -0
- package/dist/core/__tests__/logger-types.test.d.ts +1 -0
- package/dist/core/__tests__/logger-types.test.js +325 -0
- package/dist/core/__tests__/logger.test.d.ts +1 -0
- package/dist/core/__tests__/logger.test.js +337 -0
- package/dist/core/__tests__/tracer.test.d.ts +1 -0
- package/dist/core/__tests__/tracer.test.js +330 -0
- package/dist/core/index.d.ts +3 -1
- package/dist/core/index.js +4 -2
- package/dist/core/logger-types.js +3 -0
- package/dist/core/logger.d.ts +1 -1
- package/dist/core/logger.js +1 -1
- package/dist/core/tracer-types.d.ts +50 -0
- package/dist/core/tracer-types.js +3 -0
- package/dist/core/tracer.d.ts +10 -0
- package/dist/core/tracer.js +114 -0
- package/dist/index.d.ts +3 -1
- package/dist/index.js +4 -2
- package/dist/sst/__tests__/telemetry.test.d.ts +1 -0
- package/dist/sst/__tests__/telemetry.test.js +138 -0
- package/dist/sst/index.js +1 -1
- package/dist/sst/middy/index.js +1 -1
- package/dist/sst/middy/middleware.d.ts +1 -1
- package/dist/sst/middy/middleware.js +54 -69
- package/dist/sst/telemetry.d.ts +2 -1
- package/dist/sst/telemetry.js +12 -2
- package/dist/telemetry/sst/middy/middleware.d.ts +1 -1
- package/dist/telemetry/sst/middy/middleware.js +4 -4
- package/dist/tsed/__tests__/config.test.d.ts +1 -0
- package/dist/tsed/__tests__/config.test.js +146 -0
- package/dist/tsed/__tests__/service.test.d.ts +1 -0
- package/dist/tsed/__tests__/service.test.js +63 -0
- package/dist/tsed/config.d.ts +6 -0
- package/dist/tsed/config.js +65 -12
- package/dist/tsed/index.d.ts +1 -0
- package/dist/tsed/index.js +2 -1
- package/dist/tsed/log-telemetry.js +125 -10
- package/dist/tsed/service.d.ts +2 -0
- package/dist/tsed/service.js +20 -1
- package/dist/tsed/sync-log-record-processor.js +1 -1
- package/package.json +1 -1
- package/dist/check-if-is-working.d.ts +0 -1
- package/dist/check-if-is-working.js +0 -8
- package/dist/core/types.js +0 -3
- package/dist/services/index.d.ts +0 -1
- package/dist/services/index.js +0 -18
- package/dist/services/telemetry/config.d.ts +0 -20
- package/dist/services/telemetry/config.js +0 -113
- package/dist/services/telemetry/external-service.d.ts +0 -20
- package/dist/services/telemetry/external-service.js +0 -69
- package/dist/services/telemetry/index.d.ts +0 -3
- package/dist/services/telemetry/index.js +0 -20
- package/dist/services/telemetry/sync-log-record-processor.d.ts +0 -11
- package/dist/services/telemetry/sync-log-record-processor.js +0 -74
- package/dist/telemetry.d.ts +0 -1
- package/dist/telemetry.js +0 -81
- /package/dist/core/{types.d.ts → logger-types.d.ts} +0 -0
package/dist/sst/telemetry.d.ts
CHANGED
|
@@ -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>;
|
package/dist/sst/telemetry.js
CHANGED
|
@@ -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,
|
|
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
|
|
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.
|
|
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
|
|
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.
|
|
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==
|
package/dist/tsed/config.d.ts
CHANGED
|
@@ -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>;
|