@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 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
 
@@ -1,5 +1,6 @@
1
1
  import middy from '@middy/core';
2
2
  interface MiddyMiddlewareOptions {
3
+ checkMecaniError: boolean;
3
4
  }
4
5
  export declare const middyTelemetryMiddleware: (options?: MiddyMiddlewareOptions) => middy.MiddlewareObj;
5
6
  export {};
@@ -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 = ((_b = spanResult.span.attributes) === null || _b === void 0 ? void 0 : _b['requestId']) || 'unknown';
122
- const routeKey = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['http']['routeKey']) || 'unknown';
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: ((_d = error === null || error === void 0 ? void 0 : error.constructor) === null || _d === void 0 ? void 0 : _d.name) || 'UnknownError',
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
- yield standardLogger.logError({
147
- message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
148
- error: error || undefined,
149
- environment,
150
- execution: {
151
- awsRequestId: (_f = (_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['function']) === null || _f === void 0 ? void 0 : _f['aws_request_id'],
152
- origin,
153
- routeKey: routeKey,
154
- requestId: requestId,
155
- },
156
- performance: {
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
- success: false,
159
- },
160
- context: {
161
- errorType: (_g = error === null || error === void 0 ? void 0 : error.constructor) === null || _g === void 0 ? void 0 : _g.name,
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"]}
@@ -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,{"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});\n\nconst metricExporter = new OTLPMetricExporter({\n  url: `${baseUrl}/metrics`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n});\n\nconst logExporter = new OTLPLogExporter({\n  url: `${baseUrl}/logs`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\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"]}
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.4.2",
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"