@mecanizou/telemetry-hub 1.3.4 → 1.3.5

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,10 @@
1
+ ## [1.3.5](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.4...v1.3.5) (2026-01-21)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * ajust scope attr ([312b46f](https://github.com/mecanizou-eco/telemetry-hub/commit/312b46f79cfdd443238709310f42967efc68a8b4))
7
+
1
8
  ## [1.3.4](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.3...v1.3.4) (2026-01-21)
2
9
 
3
10
 
@@ -2,8 +2,8 @@ import middy from '@middy/core';
2
2
  interface MiddyMiddlewareOptions {
3
3
  }
4
4
  export declare function extractLoggedUser(event: any): {
5
- email?: string;
6
- uid?: string;
5
+ 'user.email'?: string;
6
+ 'user.uid'?: string;
7
7
  } | undefined;
8
8
  export declare const middyTelemetryMiddleware: (options?: MiddyMiddlewareOptions) => middy.MiddlewareObj;
9
9
  export {};
@@ -19,21 +19,21 @@ function extractHttpAttributes(event) {
19
19
  var _a, _b, _c, _d;
20
20
  if (event.requestContext) {
21
21
  return {
22
- method: ((_a = event.requestContext.http) === null || _a === void 0 ? void 0 : _a.method) || 'unknown',
23
- url: event.requestContext.domainName && ((_b = event.requestContext.http) === null || _b === void 0 ? void 0 : _b.path),
24
- agent: ((_c = event.headers) === null || _c === void 0 ? void 0 : _c['user-agent']) || 'unknown',
25
- pathParameters: event.pathParameters || {},
26
- queryStringParameters: event.queryStringParameters || {},
27
- body: event.body || {},
22
+ 'http.method': ((_a = event.requestContext.http) === null || _a === void 0 ? void 0 : _a.method) || 'unknown',
23
+ 'http.url': event.requestContext.domainName && ((_b = event.requestContext.http) === null || _b === void 0 ? void 0 : _b.path),
24
+ 'http.user_agent': ((_c = event.headers) === null || _c === void 0 ? void 0 : _c['user-agent']) || 'unknown',
25
+ 'http.path_parameters': event.pathParameters || {},
26
+ 'http.query_string_parameters': event.queryStringParameters || {},
27
+ 'http.body': event.body || {},
28
28
  };
29
29
  }
30
30
  return {
31
- method: event.httpMethod || 'unknown',
32
- url: event.path || 'unknown',
33
- agent: ((_d = event.headers) === null || _d === void 0 ? void 0 : _d['User-Agent']) || 'unknown',
34
- pathParameters: event.pathParameters || {},
35
- queryStringParameters: event.queryStringParameters || {},
36
- body: event.body || {},
31
+ 'http.method': event.httpMethod || 'unknown',
32
+ 'http.url': event.path || 'unknown',
33
+ 'http.user_agent': ((_d = event.headers) === null || _d === void 0 ? void 0 : _d['User-Agent']) || 'unknown',
34
+ 'http.path_parameters': event.pathParameters || {},
35
+ 'http.query_string_parameters': event.queryStringParameters || {},
36
+ 'http.body': event.body || {},
37
37
  };
38
38
  }
39
39
  function extractLoggedUser(event) {
@@ -46,8 +46,8 @@ function extractLoggedUser(event) {
46
46
  ((_d = loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) === null || _d === void 0 ? void 0 : _d.account_user) &&
47
47
  ((_f = (_e = loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) === null || _e === void 0 ? void 0 : _e.account_user) === null || _f === void 0 ? void 0 : _f.account)) {
48
48
  return {
49
- email: loggedUser.user.email,
50
- uid: loggedUser.user.account_user.account.uid,
49
+ 'user.email': loggedUser.user.email,
50
+ 'user.uid': loggedUser.user.account_user.account.uid,
51
51
  };
52
52
  }
53
53
  }
@@ -67,37 +67,42 @@ function extractDefaultAttributes(request) {
67
67
  const requestId = (event === null || event === void 0 ? void 0 : event.requestId) || ((_b = event === null || event === void 0 ? void 0 : event.requestContext) === null || _b === void 0 ? void 0 : _b.requestId) || 'unknown';
68
68
  const loggedUser = extractLoggedUser(event);
69
69
  const stage = (0, core_1.getEnvironmentStage)();
70
- return {
71
- functionName,
70
+ return Object.assign(Object.assign({ functionName,
72
71
  invocationId,
73
72
  serviceName,
74
- http,
75
73
  origin,
76
74
  routeKey,
77
75
  requestId,
78
- loggedUser,
79
- stage,
80
- };
76
+ stage }, http), loggedUser);
81
77
  }
82
78
  const middyTelemetryMiddleware = (options) => ({
83
79
  before: (request) => __awaiter(void 0, void 0, void 0, function* () {
84
80
  try {
85
81
  const startTime = perf_hooks_1.performance.now();
86
- const { functionName, invocationId, serviceName, http, origin, routeKey, requestId, loggedUser, stage, } = extractDefaultAttributes(request);
82
+ const attributes = extractDefaultAttributes(request);
87
83
  const standardTracer = (0, telemetry_1.getStandardTracer)();
88
84
  const spanResult = standardTracer.startSpan({
89
- spanName: functionName,
90
- serviceName,
91
- environment: stage,
92
- http,
85
+ spanName: attributes.functionName,
86
+ serviceName: attributes.serviceName,
87
+ environment: attributes.stage,
88
+ http: {
89
+ method: attributes['http.method'],
90
+ url: attributes['http.url'],
91
+ agent: attributes['http.user_agent'],
92
+ params: attributes['http.path_parameters'],
93
+ query: attributes['http.query_string_parameters'],
94
+ },
93
95
  execution: {
94
- functionName,
95
- invocationId,
96
- awsRequestId: invocationId,
97
- origin,
98
- routeKey,
99
- requestId,
100
- loggedUser,
96
+ functionName: attributes.functionName,
97
+ invocationId: attributes.invocationId,
98
+ awsRequestId: attributes.invocationId,
99
+ origin: attributes.origin,
100
+ routeKey: attributes.routeKey,
101
+ requestId: attributes.requestId,
102
+ loggedUser: {
103
+ email: attributes['user.email'],
104
+ uid: attributes['user.uid'],
105
+ },
101
106
  },
102
107
  });
103
108
  const meter = api_1.metrics.getMeter(origin);
@@ -119,12 +124,15 @@ const middyTelemetryMiddleware = (options) => ({
119
124
  successCounter,
120
125
  failureCounter,
121
126
  startTime,
122
- serviceName,
123
- environment: stage,
124
- origin,
125
- routeKey,
126
- requestId,
127
- loggedUser,
127
+ serviceName: attributes.serviceName,
128
+ environment: attributes.stage,
129
+ origin: attributes.origin,
130
+ routeKey: attributes.routeKey,
131
+ requestId: attributes.requestId,
132
+ loggedUser: {
133
+ email: attributes['user.email'],
134
+ uid: attributes['user.uid'],
135
+ },
128
136
  };
129
137
  }
130
138
  catch (error) {
@@ -132,7 +140,7 @@ const middyTelemetryMiddleware = (options) => ({
132
140
  }
133
141
  }),
134
142
  after: (request) => __awaiter(void 0, void 0, void 0, function* () {
135
- var _a, _b, _c, _d, _e, _f, _g, _h;
143
+ var _a, _b, _c, _d, _e, _f;
136
144
  try {
137
145
  const otelData = request.context.otel;
138
146
  if (!otelData)
@@ -165,10 +173,22 @@ const middyTelemetryMiddleware = (options) => ({
165
173
  'service.name': serviceName,
166
174
  'deployment.environment.name': environment,
167
175
  });
168
- const standardLogger = (0, telemetry_1.getStandardLogger)(spanResult.span.attributes);
176
+ const standardLogger = (0, telemetry_1.getStandardLogger)(attributes);
169
177
  yield standardLogger.logInfo({
170
178
  message: 'Request completed successfully',
171
179
  environment,
180
+ http: {
181
+ agent: attributes['http.user_agent'],
182
+ method: attributes['http.method'],
183
+ url: attributes['http.url'],
184
+ params: attributes['http.path_parameters'],
185
+ query: attributes['http.query_string_parameters'],
186
+ body: attributes['http.body'],
187
+ },
188
+ user: {
189
+ uid: attributes['user.uid'],
190
+ email: attributes['user.email'],
191
+ },
172
192
  execution: {
173
193
  functionName: functionName,
174
194
  invocationId: ((_d = spanResult.span.attributes) === null || _d === void 0 ? void 0 : _d['function.invocation_id']) ||
@@ -178,9 +198,9 @@ const middyTelemetryMiddleware = (options) => ({
178
198
  requestId: requestId,
179
199
  loggedUser: {
180
200
  uid: (((_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['logged_user.uid']) ||
181
- ((_f = attributes.loggedUser) === null || _f === void 0 ? void 0 : _f.uid)),
182
- email: (((_g = spanResult.span.attributes) === null || _g === void 0 ? void 0 : _g['logged_user.email']) ||
183
- ((_h = attributes.loggedUser) === null || _h === void 0 ? void 0 : _h.email)),
201
+ attributes['user.uid']),
202
+ email: (((_f = spanResult.span.attributes) === null || _f === void 0 ? void 0 : _f['logged_user.email']) ||
203
+ attributes['user.email']),
184
204
  },
185
205
  },
186
206
  performance: {
@@ -196,7 +216,7 @@ const middyTelemetryMiddleware = (options) => ({
196
216
  }
197
217
  }),
198
218
  onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
199
- var _a, _b, _c, _d, _e, _f, _g;
219
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
200
220
  try {
201
221
  const otelData = request.context.otel;
202
222
  if (!otelData)
@@ -235,11 +255,23 @@ const middyTelemetryMiddleware = (options) => ({
235
255
  'service.name': serviceName,
236
256
  'deployment.environment.name': environment,
237
257
  });
238
- const standardLogger = (0, telemetry_1.getStandardLogger)(spanResult.span.attributes);
258
+ const standardLogger = (0, telemetry_1.getStandardLogger)(attributes);
239
259
  yield standardLogger.logError({
240
260
  message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
241
261
  error: error || undefined,
242
262
  environment,
263
+ http: {
264
+ agent: attributes['http.user_agent'],
265
+ method: attributes['http.method'],
266
+ url: attributes['http.url'],
267
+ params: attributes['http.path_parameters'],
268
+ query: attributes['http.query_string_parameters'],
269
+ body: attributes['http.body'],
270
+ },
271
+ user: {
272
+ uid: attributes['user.uid'],
273
+ email: attributes['user.email'],
274
+ },
243
275
  execution: {
244
276
  functionName: functionName,
245
277
  invocationId: ((_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['function.invocation_id']) ||
@@ -248,13 +280,19 @@ const middyTelemetryMiddleware = (options) => ({
248
280
  origin,
249
281
  routeKey: routeKey,
250
282
  requestId: requestId,
283
+ loggedUser: {
284
+ uid: (((_g = spanResult.span.attributes) === null || _g === void 0 ? void 0 : _g['logged_user.uid']) ||
285
+ attributes['user.uid']),
286
+ email: (((_h = spanResult.span.attributes) === null || _h === void 0 ? void 0 : _h['logged_user.email']) ||
287
+ attributes['user.email']),
288
+ },
251
289
  },
252
290
  performance: {
253
291
  durationMs,
254
292
  success: false,
255
293
  },
256
294
  context: {
257
- errorType: (_g = error === null || error === void 0 ? void 0 : error.constructor) === null || _g === void 0 ? void 0 : _g.name,
295
+ errorType: (_j = error === null || error === void 0 ? void 0 : error.constructor) === null || _j === void 0 ? void 0 : _j.name,
258
296
  },
259
297
  });
260
298
  spanResult.end();
@@ -266,4 +304,4 @@ const middyTelemetryMiddleware = (options) => ({
266
304
  }),
267
305
  });
268
306
  exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
269
- //# 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 { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { performance } from 'perf_hooks';\nimport { getEnvironmentStage } from '../../core';\n\ninterface MiddyMiddlewareOptions {}\n\nfunction extractHttpAttributes(event: any): Record<string, any> {\n  if (event.requestContext) {\n    return {\n      method: event.requestContext.http?.method || 'unknown',\n      url: event.requestContext.domainName && event.requestContext.http?.path,\n      agent: event.headers?.['user-agent'] || 'unknown',\n      pathParameters: event.pathParameters || {},\n      queryStringParameters: event.queryStringParameters || {},\n      body: event.body || {},\n    };\n  }\n\n  return {\n    method: event.httpMethod || 'unknown',\n    url: event.path || 'unknown',\n    agent: event.headers?.['User-Agent'] || 'unknown',\n    pathParameters: event.pathParameters || {},\n    queryStringParameters: event.queryStringParameters || {},\n    body: event.body || {},\n  };\n}\n\nexport function extractLoggedUser(\n  event: any\n): { email?: string; uid?: string } | undefined {\n  let loggedUser = event?.requestContext?.authorizer?.lambda?.loggerUser;\n\n  if (loggedUser) {\n    loggedUser =\n      typeof loggedUser === 'string' ? JSON.parse(loggedUser) : loggedUser;\n    if (\n      loggedUser?.user &&\n      loggedUser?.user?.account_user &&\n      loggedUser?.user?.account_user?.account\n    ) {\n      return {\n        email: loggedUser.user.email,\n        uid: loggedUser.user.account_user.account.uid,\n      };\n    }\n  }\n\n  return undefined;\n}\n\nfunction extractDefaultAttributes(request: any) {\n  const { context: lambdaContext } = request;\n  const functionName = lambdaContext.functionName;\n  const invocationId = lambdaContext.awsRequestId;\n  const serviceName = process.env.SERVICE_NAME || 'sst-service';\n  const event = request.event as any;\n  const queryStringParameters = event?.queryStringParameters || {};\n  const http = extractHttpAttributes(event);\n  const origin = queryStringParameters.origin || 'unknown';\n  const routeKey =\n    event?.routeKey || event?.requestContext?.routeKey || 'unknown';\n  const requestId =\n    event?.requestId || event?.requestContext?.requestId || 'unknown';\n  const loggedUser = extractLoggedUser(event);\n  const stage = getEnvironmentStage();\n\n  return {\n    functionName,\n    invocationId,\n    serviceName,\n    http,\n    origin,\n    routeKey,\n    requestId,\n    loggedUser,\n    stage,\n  };\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 {\n        functionName,\n        invocationId,\n        serviceName,\n        http,\n        origin,\n        routeKey,\n        requestId,\n        loggedUser,\n        stage,\n      } = extractDefaultAttributes(request);\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        spanName: functionName,\n        serviceName,\n        environment: stage,\n        http,\n        execution: {\n          functionName,\n          invocationId,\n          awsRequestId: invocationId,\n          origin,\n          routeKey,\n          requestId,\n          loggedUser,\n        },\n      });\n\n      const meter = metrics.getMeter(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_purchases', {\n        description: 'Total de compras bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed_purchases', {\n        description: 'Total de compras com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName,\n        environment: stage,\n        origin,\n        routeKey,\n        requestId,\n        loggedUser,\n      };\n    } catch (error) {\n      console.error('Error in middyTelemetryMiddleware before hook:', error);\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n      const event = request.event as any;\n\n      const attributes = extractDefaultAttributes(event);\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName =\n        spanResult.span.attributes?.['function.name'] ||\n        (attributes.functionName as string);\n      const routeKey =\n        spanResult.span.attributes?.['route.key'] ||\n        (attributes.routeKey as string);\n      const requestId =\n        spanResult.span.attributes?.['request.id'] ||\n        (attributes.requestId as string);\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger(spanResult.span.attributes);\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        environment,\n        execution: {\n          functionName: functionName,\n          invocationId:\n            spanResult.span.attributes?.['function.invocation_id'] ||\n            (attributes.invocationId as string),\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n          loggedUser: {\n            uid: (spanResult.span.attributes?.['logged_user.uid'] ||\n              attributes.loggedUser?.uid) as string,\n            email: (spanResult.span.attributes?.['logged_user.email'] ||\n              attributes.loggedUser?.email) as string,\n          },\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('Error in middyTelemetryMiddleware after hook:', error);\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const attributes = extractDefaultAttributes(request.event);\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'] ||\n        attributes.functionName ||\n        'unknown';\n      const requestId =\n        spanResult.span.attributes?.['request.id'] ||\n        attributes.requestId ||\n        'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['route.key'] ||\n        attributes.routeKey ||\n        'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger(spanResult.span.attributes);\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        execution: {\n          functionName: functionName,\n          invocationId:\n            spanResult.span.attributes?.['function.invocation_id'] ||\n            (attributes.invocationId as string),\n          awsRequestId: spanResult.span.attributes?.[\n            'function.aws_request_id'\n          ] as string,\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('Error in middyTelemetryMiddleware onError hook:', error);\n    }\n  },\n});\n"]}
307
+ //# 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 { Attributes, metrics, ValueType } from '@opentelemetry/api';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { performance } from 'perf_hooks';\nimport { getEnvironmentStage } from '../../core';\n\ninterface MiddyMiddlewareOptions {}\n\nfunction extractHttpAttributes(event: any): {\n  'http.method': string;\n  'http.url': string;\n  'http.user_agent': string;\n  'http.path_parameters': Record<string, string>;\n  'http.query_string_parameters': Record<string, string>;\n  'http.body': any;\n} {\n  if (event.requestContext) {\n    return {\n      'http.method': event.requestContext.http?.method || 'unknown',\n      'http.url':\n        event.requestContext.domainName && event.requestContext.http?.path,\n      'http.user_agent': event.headers?.['user-agent'] || 'unknown',\n      'http.path_parameters': event.pathParameters || {},\n      'http.query_string_parameters': event.queryStringParameters || {},\n      'http.body': event.body || {},\n    };\n  }\n\n  return {\n    'http.method': event.httpMethod || 'unknown',\n    'http.url': event.path || 'unknown',\n    'http.user_agent': event.headers?.['User-Agent'] || 'unknown',\n    'http.path_parameters': event.pathParameters || {},\n    'http.query_string_parameters': event.queryStringParameters || {},\n    'http.body': event.body || {},\n  };\n}\n\nexport function extractLoggedUser(\n  event: any\n): { 'user.email'?: string; 'user.uid'?: string } | undefined {\n  let loggedUser = event?.requestContext?.authorizer?.lambda?.loggerUser;\n\n  if (loggedUser) {\n    loggedUser =\n      typeof loggedUser === 'string' ? JSON.parse(loggedUser) : loggedUser;\n    if (\n      loggedUser?.user &&\n      loggedUser?.user?.account_user &&\n      loggedUser?.user?.account_user?.account\n    ) {\n      return {\n        'user.email': loggedUser.user.email,\n        'user.uid': loggedUser.user.account_user.account.uid,\n      };\n    }\n  }\n\n  return undefined;\n}\n\nfunction extractDefaultAttributes(request: any) {\n  const { context: lambdaContext } = request;\n  const functionName = lambdaContext.functionName;\n  const invocationId = lambdaContext.awsRequestId;\n  const serviceName = process.env.SERVICE_NAME || 'sst-service';\n  const event = request.event;\n  const queryStringParameters = event?.queryStringParameters || {};\n  const http = extractHttpAttributes(event);\n  const origin = queryStringParameters.origin || 'unknown';\n  const routeKey =\n    event?.routeKey || event?.requestContext?.routeKey || 'unknown';\n  const requestId =\n    event?.requestId || event?.requestContext?.requestId || 'unknown';\n  const loggedUser = extractLoggedUser(event);\n  const stage = getEnvironmentStage();\n\n  return {\n    functionName,\n    invocationId,\n    serviceName,\n    origin,\n    routeKey,\n    requestId,\n    stage,\n    ...http,\n    ...loggedUser,\n  };\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);\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        spanName: attributes.functionName,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        http: {\n          method: attributes['http.method'],\n          url: attributes['http.url'],\n          agent: attributes['http.user_agent'],\n          params: attributes['http.path_parameters'],\n          query: attributes['http.query_string_parameters'],\n        },\n        execution: {\n          functionName: attributes.functionName,\n          invocationId: attributes.invocationId,\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n          loggedUser: {\n            email: attributes['user.email'],\n            uid: attributes['user.uid'],\n          },\n        },\n      });\n\n      const meter = metrics.getMeter(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_purchases', {\n        description: 'Total de compras bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed_purchases', {\n        description: 'Total de compras 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        loggedUser: {\n          email: attributes['user.email'],\n          uid: attributes['user.uid'],\n        },\n      };\n    } catch (error) {\n      console.error('Error in middyTelemetryMiddleware before hook:', error);\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n      const event = request.event as any;\n\n      const attributes = extractDefaultAttributes(event);\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName =\n        spanResult.span.attributes?.['function.name'] ||\n        (attributes.functionName as string);\n      const routeKey =\n        spanResult.span.attributes?.['route.key'] ||\n        (attributes.routeKey as string);\n      const requestId =\n        spanResult.span.attributes?.['request.id'] ||\n        (attributes.requestId as string);\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger(attributes as any as Attributes);\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        environment,\n        http: {\n          agent: attributes['http.user_agent'],\n          method: attributes['http.method'],\n          url: attributes['http.url'],\n          params: attributes['http.path_parameters'],\n          query: attributes['http.query_string_parameters'],\n          body: attributes['http.body'],\n        },\n        user: {\n          uid: attributes['user.uid'],\n          email: attributes['user.email'],\n        },\n        execution: {\n          functionName: functionName,\n          invocationId:\n            spanResult.span.attributes?.['function.invocation_id'] ||\n            (attributes.invocationId as string),\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n          loggedUser: {\n            uid: (spanResult.span.attributes?.['logged_user.uid'] ||\n              attributes['user.uid']) as string,\n            email: (spanResult.span.attributes?.['logged_user.email'] ||\n              attributes['user.email']) as string,\n          },\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('Error in middyTelemetryMiddleware after hook:', error);\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const attributes = extractDefaultAttributes(request.event);\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'] ||\n        attributes.functionName ||\n        'unknown';\n      const requestId =\n        spanResult.span.attributes?.['request.id'] ||\n        attributes.requestId ||\n        'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['route.key'] ||\n        attributes.routeKey ||\n        'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        'function.name': functionName,\n        'request.id': requestId,\n        'route.key': routeKey,\n        'service.name': serviceName,\n        'deployment.environment.name': environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger(attributes as any as Attributes);\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        http: {\n          agent: attributes['http.user_agent'],\n          method: attributes['http.method'],\n          url: attributes['http.url'],\n          params: attributes['http.path_parameters'],\n          query: attributes['http.query_string_parameters'],\n          body: attributes['http.body'],\n        },\n        user: {\n          uid: attributes['user.uid'],\n          email: attributes['user.email'],\n        },\n        execution: {\n          functionName: functionName,\n          invocationId:\n            spanResult.span.attributes?.['function.invocation_id'] ||\n            (attributes.invocationId as string),\n          awsRequestId: spanResult.span.attributes?.[\n            'function.aws_request_id'\n          ] as string,\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n          loggedUser: {\n            uid: (spanResult.span.attributes?.['logged_user.uid'] ||\n              attributes['user.uid']) as string,\n            email: (spanResult.span.attributes?.['logged_user.email'] ||\n              attributes['user.email']) as string,\n          },\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('Error in middyTelemetryMiddleware onError hook:', error);\n    }\n  },\n});\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mecanizou/telemetry-hub",
3
- "version": "1.3.4",
3
+ "version": "1.3.5",
4
4
  "description": "Mecanizou telemetry lib",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",