@mecanizou/telemetry-hub 1.4.2 → 1.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +22 -0
- package/dist/sst/middy/middleware.d.ts +1 -0
- package/dist/sst/middy/middleware.js +98 -23
- package/dist/sst/telemetry.js +5 -1
- package/package.json +2 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,25 @@
|
|
|
1
|
+
## [1.5.1](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.5.0...v1.5.1) (2026-03-19)
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
### Bug Fixes
|
|
5
|
+
|
|
6
|
+
* Added timeout to both metricReader and tracerExpolrer ([4f6a4a2](https://github.com/mecanizou-eco/telemetry-hub/commit/4f6a4a21ecdce4c7282eb072f0da5e031efb98dc))
|
|
7
|
+
* included timeout to sst logExporter ([a4331e0](https://github.com/mecanizou-eco/telemetry-hub/commit/a4331e09652e6a3946df65312f516d2e2c27da7d))
|
|
8
|
+
|
|
9
|
+
# [1.5.0](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.4.2...v1.5.0) (2026-03-19)
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
### Features
|
|
13
|
+
|
|
14
|
+
* Implemented logic on telemetry middleware to allow functions to use mecaniError as a parameter to determine which message should be launched ([c506b58](https://github.com/mecanizou-eco/telemetry-hub/commit/c506b589134789f93d68091659d8e9a4a93a6983))
|
|
15
|
+
|
|
16
|
+
## [Unreleased]
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
### Bug Fixes
|
|
20
|
+
|
|
21
|
+
* **sst/middy/middleware:** corrige `origin is not defined` no hook `onError` quando `checkMecaniError` é true ao repassar `origin` para `buildErrorContext` na trilha de `MecaniError`.
|
|
22
|
+
|
|
1
23
|
## [1.4.2](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.4.1...v1.4.2) (2026-03-17)
|
|
2
24
|
|
|
3
25
|
|
|
@@ -11,6 +11,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.middyTelemetryMiddleware = void 0;
|
|
13
13
|
const api_1 = require("@opentelemetry/api");
|
|
14
|
+
const mecanizou_errors_1 = require("mecanizou-errors");
|
|
14
15
|
const node_perf_hooks_1 = require("node:perf_hooks");
|
|
15
16
|
const telemetry_1 = require("../telemetry");
|
|
16
17
|
const extraction_1 = require("../extraction");
|
|
@@ -107,7 +108,7 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
107
108
|
}
|
|
108
109
|
}),
|
|
109
110
|
onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
110
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
111
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
111
112
|
try {
|
|
112
113
|
const otelData = request.context.otel;
|
|
113
114
|
if (!otelData)
|
|
@@ -117,12 +118,12 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
117
118
|
if (error) {
|
|
118
119
|
spanResult.setError(error);
|
|
119
120
|
}
|
|
120
|
-
const functionName = ((_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']['name']) || 'unknown';
|
|
121
|
-
const requestId = ((
|
|
122
|
-
const routeKey = ((
|
|
121
|
+
const functionName = ((_b = (_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']) === null || _b === void 0 ? void 0 : _b['name']) || 'unknown';
|
|
122
|
+
const requestId = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['requestId']) || 'unknown';
|
|
123
|
+
const routeKey = ((_e = (_d = spanResult.span.attributes) === null || _d === void 0 ? void 0 : _d['http']) === null || _e === void 0 ? void 0 : _e['routeKey']) || 'unknown';
|
|
123
124
|
failureCounter.add(1, {
|
|
124
125
|
origin,
|
|
125
|
-
error_type: ((
|
|
126
|
+
error_type: ((_f = error === null || error === void 0 ? void 0 : error.constructor) === null || _f === void 0 ? void 0 : _f.name) || 'UnknownError',
|
|
126
127
|
functionName: functionName,
|
|
127
128
|
requestId: requestId,
|
|
128
129
|
routeKey: routeKey,
|
|
@@ -143,24 +144,38 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
143
144
|
scopeAttributes: spanResult.span.attributes,
|
|
144
145
|
forceNewInstance: true,
|
|
145
146
|
});
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
147
|
+
if (!(options === null || options === void 0 ? void 0 : options.checkMecaniError)) {
|
|
148
|
+
yield standardLogger.logError({
|
|
149
|
+
message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
|
|
150
|
+
error: error || undefined,
|
|
151
|
+
environment,
|
|
152
|
+
execution: {
|
|
153
|
+
awsRequestId: (_h = (_g = spanResult.span.attributes) === null || _g === void 0 ? void 0 : _g['function']) === null || _h === void 0 ? void 0 : _h['aws_request_id'],
|
|
154
|
+
origin,
|
|
155
|
+
routeKey: routeKey,
|
|
156
|
+
requestId: requestId,
|
|
157
|
+
},
|
|
158
|
+
performance: {
|
|
159
|
+
durationMs,
|
|
160
|
+
success: false,
|
|
161
|
+
},
|
|
162
|
+
context: {
|
|
163
|
+
errorType: (_j = error === null || error === void 0 ? void 0 : error.constructor) === null || _j === void 0 ? void 0 : _j.name,
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
else if (error) {
|
|
168
|
+
yield launchMecaniErrorLogMessage({
|
|
169
|
+
error,
|
|
170
|
+
standardLogger,
|
|
171
|
+
environment,
|
|
172
|
+
spanResult,
|
|
157
173
|
durationMs,
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
});
|
|
174
|
+
requestId,
|
|
175
|
+
routeKey,
|
|
176
|
+
origin
|
|
177
|
+
});
|
|
178
|
+
}
|
|
164
179
|
spanResult.end();
|
|
165
180
|
yield (0, telemetry_1.forceFlush)();
|
|
166
181
|
}
|
|
@@ -170,4 +185,64 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
170
185
|
}),
|
|
171
186
|
});
|
|
172
187
|
exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'node:perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\n\ninterface MiddyMiddlewareOptions {}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware before hook:',\n        error\n      );\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware after hook:',\n        error\n      );\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        failureCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n        origin,\n      } = otelData;\n      const error = request.error;\n\n      // Marcar span como erro usando StandardTracer\n      if (error) {\n        spanResult.setError(error);\n      }\n\n      const functionName =\n        spanResult.span.attributes?.['function']['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        execution: {\n          awsRequestId:\n            spanResult.span.attributes?.['function']?.['aws_request_id'],\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: false,\n        },\n        context: {\n          errorType: error?.constructor?.name,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware onError hook:',\n        error\n      );\n    }\n  },\n});\n"]}
|
|
188
|
+
const buildErrorContext = ({ message, error, environment, spanResult, durationMs, requestId, routeKey, errorEnum, origin, }) => {
|
|
189
|
+
var _a, _b, _c;
|
|
190
|
+
return ({
|
|
191
|
+
message,
|
|
192
|
+
error: error || undefined,
|
|
193
|
+
environment,
|
|
194
|
+
execution: {
|
|
195
|
+
awsRequestId: (_b = (_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']) === null || _b === void 0 ? void 0 : _b['aws_request_id'],
|
|
196
|
+
origin,
|
|
197
|
+
routeKey,
|
|
198
|
+
requestId,
|
|
199
|
+
},
|
|
200
|
+
performance: {
|
|
201
|
+
durationMs,
|
|
202
|
+
success: false,
|
|
203
|
+
},
|
|
204
|
+
context: {
|
|
205
|
+
errorType: (_c = error === null || error === void 0 ? void 0 : error.constructor) === null || _c === void 0 ? void 0 : _c.name,
|
|
206
|
+
errorEnum,
|
|
207
|
+
},
|
|
208
|
+
});
|
|
209
|
+
};
|
|
210
|
+
const isMecaniError = (error) => {
|
|
211
|
+
const isWarning = (error === null || error === void 0 ? void 0 : error.name) === 'Warning';
|
|
212
|
+
const isException = (error === null || error === void 0 ? void 0 : error.name) === 'Exception';
|
|
213
|
+
return isWarning || isException || (0, mecanizou_errors_1.isMecaniError)(error);
|
|
214
|
+
};
|
|
215
|
+
const getErrorMessageAndEnum = (error) => {
|
|
216
|
+
if (isMecaniError(error)) {
|
|
217
|
+
const mecaniError = error;
|
|
218
|
+
return {
|
|
219
|
+
message: mecaniError.errorDetails,
|
|
220
|
+
errorEnum: mecaniError.errorEnum,
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
return {
|
|
224
|
+
message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
|
|
225
|
+
errorEnum: 'UNDEFINED_ERROR',
|
|
226
|
+
};
|
|
227
|
+
};
|
|
228
|
+
const launchMecaniErrorLogMessage = (_a) => __awaiter(void 0, [_a], void 0, function* ({ error, standardLogger, environment, spanResult, durationMs, requestId, routeKey, origin }) {
|
|
229
|
+
const { message, errorEnum } = getErrorMessageAndEnum(error);
|
|
230
|
+
const context = buildErrorContext({
|
|
231
|
+
message,
|
|
232
|
+
error,
|
|
233
|
+
environment,
|
|
234
|
+
spanResult,
|
|
235
|
+
durationMs,
|
|
236
|
+
requestId,
|
|
237
|
+
routeKey,
|
|
238
|
+
errorEnum,
|
|
239
|
+
origin,
|
|
240
|
+
});
|
|
241
|
+
if ((error === null || error === void 0 ? void 0 : error.name) === 'Warning') {
|
|
242
|
+
return yield standardLogger.logWarn(context);
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
return yield standardLogger.logError(context);
|
|
246
|
+
}
|
|
247
|
+
});
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { isMecaniError as mecaniErrorVerification, MecaniError } from 'mecanizou-errors';\nimport { performance } from 'node:perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\nimport { StandardLogger, StandardSpanResult } from '../../core';\n\ninterface MiddyMiddlewareOptions {\n  checkMecaniError: boolean\n}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware before hook:',\n        error\n      );\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware after hook:',\n        error\n      );\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        failureCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n        origin,\n      } = otelData;\n      const error = request.error;\n\n      // Marcar span como erro usando StandardTracer\n      if (error) {\n        spanResult.setError(error);\n      }\n\n      const functionName =\n        spanResult.span.attributes?.['function']?.['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']?.['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      if (!options?.checkMecaniError) {\n        await standardLogger.logError({\n          message: error?.message || 'Unknown error occurred',\n          error: error || undefined,\n          environment,\n          execution: {\n            awsRequestId:\n              spanResult.span.attributes?.['function']?.['aws_request_id'],\n            origin,\n            routeKey: routeKey,\n            requestId: requestId,\n          },\n          performance: {\n            durationMs,\n            success: false,\n          },\n          context: {\n            errorType: error?.constructor?.name,\n          },\n        });\n      } else if (error) {\n        await launchMecaniErrorLogMessage({ \n          error,\n          standardLogger,\n          environment,\n          spanResult,\n          durationMs,\n          requestId,\n          routeKey,\n          origin\n        })\n      }\n\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware onError hook:',\n        error\n      );\n    }\n  },\n});\n\nconst buildErrorContext = ({ \n  message,\n  error,\n  environment,\n  spanResult,\n  durationMs,\n  requestId,\n  routeKey,\n  errorEnum,\n  origin,\n}: {\n  message: string;\n  error: Error;\n  errorEnum: string;\n  environment: string;\n  spanResult: any;\n  durationMs: number;\n  routeKey: any;\n  requestId: any;\n  origin: string;\n}) => ({\n  message,\n  error: error || undefined,\n  environment,\n  execution: {\n    awsRequestId:\n      spanResult.span.attributes?.['function']?.['aws_request_id'],\n    origin,\n    routeKey,\n    requestId,\n  },\n  performance: {\n    durationMs,\n    success: false,\n  },\n  context: {\n    errorType: error?.constructor?.name,\n    errorEnum,\n  },\n});\n\nconst isMecaniError = (error: Error): boolean => {\n  const isWarning = error?.name === 'Warning'\n  const isException = error?.name === 'Exception'\n\n  return isWarning || isException || mecaniErrorVerification(error)\n}\n\nconst getErrorMessageAndEnum = (error: Error) => {\n  if (isMecaniError(error)) {\n    const mecaniError = error as MecaniError;\n\n    return {\n      message: mecaniError.errorDetails,\n      errorEnum: mecaniError.errorEnum,\n    }\n  }\n\n  return {\n    message: error?.message || 'Unknown error occurred',\n    errorEnum: 'UNDEFINED_ERROR',\n  }\n}\n\nconst launchMecaniErrorLogMessage = async ({ \n  error,\n  standardLogger,\n  environment,\n  spanResult,\n  durationMs,\n  requestId,\n  routeKey,\n  origin\n}: {\n  standardLogger: StandardLogger\n  error: Error;\n  environment: string;\n  spanResult: any;\n  durationMs: number;\n  routeKey: any;\n  requestId: any;\n  origin: string;\n  }): Promise<void> => {\n  \n  const { message, errorEnum } = getErrorMessageAndEnum(error);\n\n  const context = buildErrorContext({\n    message,\n    error,\n    environment,\n    spanResult,\n    durationMs,\n    requestId,\n    routeKey,\n    errorEnum,\n    origin,\n  });\n\n  if (error?.name === 'Warning') {\n    return await standardLogger.logWarn(context);\n  } else {\n    return await standardLogger.logError(context);\n  }\n};\n"]}
|
package/dist/sst/telemetry.js
CHANGED
|
@@ -63,6 +63,7 @@ const traceExporter = new exporter_trace_otlp_http_1.OTLPTraceExporter({
|
|
|
63
63
|
Authorization: `Basic ${basicAuth}`,
|
|
64
64
|
'Content-Type': 'application/json',
|
|
65
65
|
},
|
|
66
|
+
timeoutMillis: 5000,
|
|
66
67
|
});
|
|
67
68
|
const metricExporter = new exporter_metrics_otlp_http_1.OTLPMetricExporter({
|
|
68
69
|
url: `${baseUrl}/metrics`,
|
|
@@ -70,6 +71,7 @@ const metricExporter = new exporter_metrics_otlp_http_1.OTLPMetricExporter({
|
|
|
70
71
|
Authorization: `Basic ${basicAuth}`,
|
|
71
72
|
'Content-Type': 'application/json',
|
|
72
73
|
},
|
|
74
|
+
timeoutMillis: 5000,
|
|
73
75
|
});
|
|
74
76
|
const logExporter = new exporter_logs_otlp_http_1.OTLPLogExporter({
|
|
75
77
|
url: `${baseUrl}/logs`,
|
|
@@ -77,6 +79,8 @@ const logExporter = new exporter_logs_otlp_http_1.OTLPLogExporter({
|
|
|
77
79
|
Authorization: `Basic ${basicAuth}`,
|
|
78
80
|
'Content-Type': 'application/json',
|
|
79
81
|
},
|
|
82
|
+
timeoutMillis: 5000,
|
|
83
|
+
concurrencyLimit: 1,
|
|
80
84
|
});
|
|
81
85
|
const metricReader = new sdk_metrics_1.PeriodicExportingMetricReader({
|
|
82
86
|
exporter: metricExporter,
|
|
@@ -129,4 +133,4 @@ const forceFlush = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
|
129
133
|
yield loggerProvider.forceFlush();
|
|
130
134
|
});
|
|
131
135
|
exports.forceFlush = forceFlush;
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"telemetry.js","sourceRoot":"","sources":["../../src/sst/telemetry.ts"],"names":[],"mappings":"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","sourcesContent":["import { NodeSDK } from '@opentelemetry/sdk-node';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';\nimport { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';\nimport { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';\nimport { PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics';\nimport * as logs from '@opentelemetry/sdk-logs';\nimport * as resources from '@opentelemetry/resources';\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions';\nimport { Attributes, trace } from '@opentelemetry/api';\nimport { StandardLogger, StandardTracer } from '../core';\n\nconst user = process.env.OTEL_EXPORTER_OTLP_USER;\nconst password = process.env.OTEL_EXPORTER_OTLP_PASS;\n\nconst basicAuth = Buffer.from(`${user}:${password}`).toString('base64');\n\nconst baseUrl = `${process.env.OTEL_EXPORTER_OTLP_ENDPOINT}/alloy/v1`;\n\nconst traceExporter = new OTLPTraceExporter({\n  url: `${baseUrl}/traces`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n  timeoutMillis: 5000,\n});\n\nconst metricExporter = new OTLPMetricExporter({\n  url: `${baseUrl}/metrics`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n  timeoutMillis: 5000,\n});\n\nconst logExporter = new OTLPLogExporter({\n  url: `${baseUrl}/logs`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n  timeoutMillis: 5000,\n  concurrencyLimit: 1,\n});\n\nconst metricReader = new PeriodicExportingMetricReader({\n  exporter: metricExporter,\n  exportIntervalMillis: 1000,\n});\n\n// Configurar LoggerProvider\nconst serviceName = process.env.SERVICE_NAME || 'sst-service';\nconst resource = new resources.Resource({\n  [ATTR_SERVICE_NAME]: serviceName,\n});\n\nconst loggerProvider = new logs.LoggerProvider({ resource });\nconst logRecordProcessor = new logs.BatchLogRecordProcessor(logExporter);\nloggerProvider.addLogRecordProcessor(logRecordProcessor);\n\nconst sdk = new NodeSDK({\n  traceExporter,\n  metricReader: metricReader as any, // Type compatibility workaround\n});\n\nsdk.start();\n\n// Criar StandardLogger para ser usado nos middlewares\nlet standardLogger: StandardLogger | null = null;\nlet standardTracer: StandardTracer | null = null;\n\nexport const getStandardLogger = ({\n  scopeAttributes,\n  forceNewInstance = false,\n  disableEmitter = false,\n}:\n  | {\n      scopeAttributes?: Attributes;\n      forceNewInstance?: boolean;\n      disableEmitter?: boolean;\n    }\n  | undefined = {}): StandardLogger => {\n  if (!standardLogger || forceNewInstance) {\n    const tracer = getStandardTracer();\n    const logger = loggerProvider.getLogger('sst-middleware-logger', '1.0.0', {\n      includeTraceContext: true,\n      scopeAttributes,\n    });\n    standardLogger = new StandardLogger(\n      logger,\n      tracer,\n      scopeAttributes,\n      disableEmitter\n    );\n  } else {\n    const hasScope =\n      standardLogger.defaultAttributes?.function?.name !== 'unknown';\n\n    if (!hasScope && scopeAttributes) {\n      standardLogger.defineDefaultAttributes(scopeAttributes);\n    }\n  }\n  return standardLogger;\n};\n\nexport const getStandardTracer = (): StandardTracer => {\n  if (!standardTracer) {\n    const tracer = trace.getTracer(serviceName, '1.0.0');\n    standardTracer = new StandardTracer(tracer, serviceName);\n  }\n  return standardTracer;\n};\n\nexport const forceFlush = async () => {\n  await metricReader.forceFlush();\n  await traceExporter.forceFlush();\n  await loggerProvider.forceFlush();\n};\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mecanizou/telemetry-hub",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.5.1",
|
|
4
4
|
"description": "Mecanizou telemetry lib",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -26,6 +26,7 @@
|
|
|
26
26
|
"eslint-plugin-prettier": "^5.5.4",
|
|
27
27
|
"lint-staged": "^13.3.0",
|
|
28
28
|
"prettier": "^3.6.2",
|
|
29
|
+
"mecanizou-errors": "^1.1.0",
|
|
29
30
|
"semantic-release": "^25.0.2",
|
|
30
31
|
"typescript": "^5.9.3",
|
|
31
32
|
"vitest": "^4.0.13"
|