@mecanizou/telemetry-hub 1.3.3 → 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 +14 -0
- package/dist/core/logger.js +9 -1
- package/dist/sst/middy/middleware.d.ts +2 -2
- package/dist/sst/middy/middleware.js +128 -59
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,3 +1,17 @@
|
|
|
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
|
+
|
|
8
|
+
## [1.3.4](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.3...v1.3.4) (2026-01-21)
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
### Bug Fixes
|
|
12
|
+
|
|
13
|
+
* ajust pass params to logger ([89fb843](https://github.com/mecanizou-eco/telemetry-hub/commit/89fb843cae8371686e3b64741afe71a74e789754))
|
|
14
|
+
|
|
1
15
|
## [1.3.3](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.2...v1.3.3) (2026-01-21)
|
|
2
16
|
|
|
3
17
|
|
package/dist/core/logger.js
CHANGED
|
@@ -26,6 +26,8 @@ class StandardLogger {
|
|
|
26
26
|
'span.id': this.spanContext.spanContext().spanId,
|
|
27
27
|
'function.name': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['function.name']) || 'unknown-function',
|
|
28
28
|
'function.invocation_id': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['function.invocation_id']) || 'unknown-invocation-id',
|
|
29
|
+
'request.id': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['request.id']) || 'unknown-request-id',
|
|
30
|
+
'route.key': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['route.key']) || 'unknown-route-key',
|
|
29
31
|
};
|
|
30
32
|
this.environment = (0, environment_1.getEnvironmentStage)();
|
|
31
33
|
}
|
|
@@ -124,6 +126,12 @@ class StandardLogger {
|
|
|
124
126
|
attributes['origin'] = data.execution.origin;
|
|
125
127
|
if (data.execution.routeKey)
|
|
126
128
|
attributes['route.key'] = data.execution.routeKey;
|
|
129
|
+
if (data.execution.loggedUser) {
|
|
130
|
+
if (data.execution.loggedUser.uid)
|
|
131
|
+
attributes['logged_user.uid'] = data.execution.loggedUser.uid;
|
|
132
|
+
if (data.execution.loggedUser.email)
|
|
133
|
+
attributes['logged_user.email'] = data.execution.loggedUser.email;
|
|
134
|
+
}
|
|
127
135
|
}
|
|
128
136
|
if (data.performance) {
|
|
129
137
|
if (data.performance.durationMs)
|
|
@@ -138,4 +146,4 @@ class StandardLogger {
|
|
|
138
146
|
}
|
|
139
147
|
}
|
|
140
148
|
exports.StandardLogger = StandardLogger;
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { SeverityNumber, Logger } from '@opentelemetry/api-logs';\nimport { IStandardLogger, StandardLogData } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\nimport { getEnvironmentStage } from './environment';\n\ninterface LogParams extends Omit<\n  StandardLogData,\n  'severity' | 'timestamp' | 'serviceName' | 'environment'\n> {\n  environment?: StandardLogData['environment'];\n}\n/**\n * Logger core que implementa o padrão de logs estruturados.\n * Recebe um LoggerProvider do OpenTelemetry para emitir os logs.\n */\nexport class StandardLogger implements IStandardLogger {\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly defaultAttributes: Record<string, any> = {};\n  private readonly spanContext: Span;\n  private readonly environment: string;\n  private defaultServiceName: string;\n\n  constructor(\n    logger: Logger,\n    tracer: IStandardTracer,\n    scopeAttributes?: Attributes\n  ) {\n    this.logger = logger;\n    this.tracer = tracer;\n    this.spanContext = this.tracer.getTracer().startSpan('init-logger');\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.defaultAttributes = {\n      'trace.id': this.spanContext.spanContext().traceId,\n      'span.id': this.spanContext.spanContext().spanId,\n      'function.name': scopeAttributes?.['function.name'] || 'unknown-function',\n      'function.invocation_id':\n        scopeAttributes?.['function.invocation_id'] || 'unknown-invocation-id',\n    };\n\n    this.environment = getEnvironmentStage();\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'DEBUG',\n    });\n  }\n\n  private async log(\n    data: Omit<StandardLogData, 'timestamp'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      serviceName: data.serviceName || this.defaultServiceName,\n      timestamp: new Date().toISOString(),\n    };\n\n    const severityMap = {\n      ERROR: SeverityNumber.ERROR,\n      WARN: SeverityNumber.WARN,\n      INFO: SeverityNumber.INFO,\n      DEBUG: SeverityNumber.DEBUG,\n    };\n\n    const logRecord = {\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.message,\n      attributes: this.buildAttributes(fullData),\n    };\n\n    this.logger.emit(logRecord);\n  }\n\n  private buildAttributes(data: StandardLogData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      timestamp: data.timestamp,\n      'service.name': data.serviceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error.type'] = data.error.name;\n      attributes['error.message'] = data.error.message;\n      attributes['error.stack'] = data.error.stack || '';\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.endpoint'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.headers)\n        attributes['http.headers'] = JSON.stringify(data.http.headers);\n      if (data.http.body)\n        attributes['http.body'] = JSON.stringify(data.http.body);\n      if (data.http.params)\n        attributes['http.params'] = JSON.stringify(data.http.params);\n      if (data.http.query)\n        attributes['http.query'] = JSON.stringify(data.http.query);\n      if (data.http.agent) attributes['http.user_agent'] = data.http.agent;\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.uid) attributes['user.uid'] = data.user.uid;\n      if (data.user.email) attributes['user.email'] = data.user.email;\n    }\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      this.defaultAttributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      this.defaultAttributes['function.invocation_id'] =\n        data.execution.invocationId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n      if (data.execution.routeKey)\n        attributes['route.key'] = data.execution.routeKey;\n    }\n\n    // Performance\n    if (data.performance) {\n      if (data.performance.durationMs)\n        attributes['duration.ms'] = data.performance.durationMs;\n      if (data.performance.success !== undefined)\n        attributes['execution.success'] = data.performance.success;\n    }\n\n    // Contexto adicional\n    if (data.context) {\n      attributes['context'] = JSON.stringify(data.context);\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries({ ...this.defaultAttributes, ...attributes }).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,sDAAiE;AAIjE,+CAAoD;AAYpD,MAAa,cAAc;IAQzB,YACE,MAAc,EACd,MAAuB,EACvB,eAA4B;QARb,sBAAiB,GAAwB,EAAE,CAAC;QAU3D,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;QACpE,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY;YAChD,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY;YAC1B,CAAC,CAAC,iBAAiB,CAAC;QAEtB,IAAI,CAAC,iBAAiB,GAAG;YACvB,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,OAAO;YAClD,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,MAAM;YAChD,eAAe,EAAE,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,eAAe,CAAC,KAAI,kBAAkB;YACzE,wBAAwB,EACtB,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,wBAAwB,CAAC,KAAI,uBAAuB;YACxE,YAAY,EAAE,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,YAAY,CAAC,KAAI,oBAAoB;YACrE,WAAW,EAAE,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAG,WAAW,CAAC,KAAI,mBAAmB;SACnE,CAAC;QAEF,IAAI,CAAC,WAAW,GAAG,IAAA,iCAAmB,GAAE,CAAC;IAC3C,CAAC;IAEK,QAAQ,CAAC,IAAe;;YAC5B,MAAM,IAAI,CAAC,GAAG,+BACZ,WAAW,EAAE,IAAI,CAAC,kBAAkB,EACpC,WAAW,EAAE,IAAI,CAAC,WAAW,IAC1B,IAAI,KACP,QAAQ,EAAE,OAAO,IACjB,CAAC;QACL,CAAC;KAAA;IAEK,OAAO,CAAC,IAAe;;YAC3B,MAAM,IAAI,CAAC,GAAG,+BACZ,WAAW,EAAE,IAAI,CAAC,kBAAkB,EACpC,WAAW,EAAE,IAAI,CAAC,WAAW,IAC1B,IAAI,KACP,QAAQ,EAAE,MAAM,IAChB,CAAC;QACL,CAAC;KAAA;IAEK,OAAO,CAAC,IAAe;;YAC3B,MAAM,IAAI,CAAC,GAAG,+BACZ,WAAW,EAAE,IAAI,CAAC,kBAAkB,EACpC,WAAW,EAAE,IAAI,CAAC,WAAW,IAC1B,IAAI,KACP,QAAQ,EAAE,MAAM,IAChB,CAAC;QACL,CAAC;KAAA;IAEK,QAAQ,CAAC,IAAe;;YAC5B,MAAM,IAAI,CAAC,GAAG,+BACZ,WAAW,EAAE,IAAI,CAAC,kBAAkB,EACpC,WAAW,EAAE,IAAI,CAAC,WAAW,IAC1B,IAAI,KACP,QAAQ,EAAE,OAAO,IACjB,CAAC;QACL,CAAC;KAAA;IAEa,GAAG,CACf,IAEC;;YAED,MAAM,QAAQ,mCACT,IAAI,KACP,WAAW,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,kBAAkB,EACxD,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GACpC,CAAC;YAEF,MAAM,WAAW,GAAG;gBAClB,KAAK,EAAE,yBAAc,CAAC,KAAK;gBAC3B,IAAI,EAAE,yBAAc,CAAC,IAAI;gBACzB,IAAI,EAAE,yBAAc,CAAC,IAAI;gBACzB,KAAK,EAAE,yBAAc,CAAC,KAAK;aAC5B,CAAC;YAEF,MAAM,SAAS,GAAG;gBAChB,cAAc,EAAE,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC;gBAC9C,YAAY,EAAE,QAAQ,CAAC,QAAQ;gBAC/B,IAAI,EAAE,QAAQ,CAAC,OAAO;gBACtB,UAAU,EAAE,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;aAC3C,CAAC;YAEF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9B,CAAC;KAAA;IAEO,eAAe,CAAC,IAAqB;QAC3C,MAAM,UAAU,GAAwB;YACtC,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,cAAc,EAAE,IAAI,CAAC,WAAW;YAChC,6BAA6B,EAAE,IAAI,CAAC,WAAW;SAChD,CAAC;QAGF,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAC3C,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;YACjD,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC;QACrD,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;YACzE,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBACtB,UAAU,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACxD,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO;gBACnB,UAAU,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACjE,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI;gBAChB,UAAU,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3D,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAClB,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC/D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBACjB,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QACvE,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAClE,CAAC;QAGD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS;gBAC1B,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;YACtD,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC7D,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC5D,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YACtE,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YACrE,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC;gBAC9C,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC9B,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU;gBAC3B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;YAC5D,IAAI,IAAI,CAAC,SAAS,CAAC,gBAAgB;gBACjC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;YACpE,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM;gBAAE,UAAU,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;YACxE,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ;gBACzB,UAAU,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;YACpD,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC;gBAC9B,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG;oBAC/B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC;gBAChE,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK;oBACjC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,KAAK,CAAC;YACtE,CAAC;QACH,CAAC;QAGD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU;gBAC7B,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAC1D,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,KAAK,SAAS;gBACxC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;QAC/D,CAAC;QAGD,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,UAAU,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACvD,CAAC;QAGD,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,iCAAM,IAAI,CAAC,iBAAiB,GAAK,UAAU,EAAG,CAAC,MAAM,CACjE,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CACrD,CACF,CAAC;IACJ,CAAC;CACF;AAvLD,wCAuLC","sourcesContent":["import { SeverityNumber, Logger } from '@opentelemetry/api-logs';\nimport { IStandardLogger, StandardLogData } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\nimport { getEnvironmentStage } from './environment';\n\ninterface LogParams extends Omit<\n  StandardLogData,\n  'severity' | 'timestamp' | 'serviceName' | 'environment'\n> {\n  environment?: StandardLogData['environment'];\n}\n/**\n * Logger core que implementa o padrão de logs estruturados.\n * Recebe um LoggerProvider do OpenTelemetry para emitir os logs.\n */\nexport class StandardLogger implements IStandardLogger {\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly defaultAttributes: Record<string, any> = {};\n  private readonly spanContext: Span;\n  private readonly environment: string;\n  private defaultServiceName: string;\n\n  constructor(\n    logger: Logger,\n    tracer: IStandardTracer,\n    scopeAttributes?: Attributes\n  ) {\n    this.logger = logger;\n    this.tracer = tracer;\n    this.spanContext = this.tracer.getTracer().startSpan('init-logger');\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.defaultAttributes = {\n      'trace.id': this.spanContext.spanContext().traceId,\n      'span.id': this.spanContext.spanContext().spanId,\n      'function.name': scopeAttributes?.['function.name'] || 'unknown-function',\n      'function.invocation_id':\n        scopeAttributes?.['function.invocation_id'] || 'unknown-invocation-id',\n      'request.id': scopeAttributes?.['request.id'] || 'unknown-request-id',\n      'route.key': scopeAttributes?.['route.key'] || 'unknown-route-key',\n    };\n\n    this.environment = getEnvironmentStage();\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'DEBUG',\n    });\n  }\n\n  private async log(\n    data: Omit<StandardLogData, 'timestamp'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      serviceName: data.serviceName || this.defaultServiceName,\n      timestamp: new Date().toISOString(),\n    };\n\n    const severityMap = {\n      ERROR: SeverityNumber.ERROR,\n      WARN: SeverityNumber.WARN,\n      INFO: SeverityNumber.INFO,\n      DEBUG: SeverityNumber.DEBUG,\n    };\n\n    const logRecord = {\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.message,\n      attributes: this.buildAttributes(fullData),\n    };\n\n    this.logger.emit(logRecord);\n  }\n\n  private buildAttributes(data: StandardLogData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      timestamp: data.timestamp,\n      'service.name': data.serviceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error.type'] = data.error.name;\n      attributes['error.message'] = data.error.message;\n      attributes['error.stack'] = data.error.stack || '';\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.endpoint'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.headers)\n        attributes['http.headers'] = JSON.stringify(data.http.headers);\n      if (data.http.body)\n        attributes['http.body'] = JSON.stringify(data.http.body);\n      if (data.http.params)\n        attributes['http.params'] = JSON.stringify(data.http.params);\n      if (data.http.query)\n        attributes['http.query'] = JSON.stringify(data.http.query);\n      if (data.http.agent) attributes['http.user_agent'] = data.http.agent;\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.uid) attributes['user.uid'] = data.user.uid;\n      if (data.user.email) attributes['user.email'] = data.user.email;\n    }\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      this.defaultAttributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      this.defaultAttributes['function.invocation_id'] =\n        data.execution.invocationId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n      if (data.execution.routeKey)\n        attributes['route.key'] = data.execution.routeKey;\n      if (data.execution.loggedUser) {\n        if (data.execution.loggedUser.uid)\n          attributes['logged_user.uid'] = data.execution.loggedUser.uid;\n        if (data.execution.loggedUser.email)\n          attributes['logged_user.email'] = data.execution.loggedUser.email;\n      }\n    }\n\n    // Performance\n    if (data.performance) {\n      if (data.performance.durationMs)\n        attributes['duration.ms'] = data.performance.durationMs;\n      if (data.performance.success !== undefined)\n        attributes['execution.success'] = data.performance.success;\n    }\n\n    // Contexto adicional\n    if (data.context) {\n      attributes['context'] = JSON.stringify(data.context);\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries({ ...this.defaultAttributes, ...attributes }).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
|
|
@@ -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
|
-
|
|
25
|
-
|
|
26
|
-
|
|
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
|
-
|
|
34
|
-
|
|
35
|
-
|
|
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
|
|
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) {
|
|
@@ -138,14 +146,20 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
138
146
|
if (!otelData)
|
|
139
147
|
return;
|
|
140
148
|
const event = request.event;
|
|
141
|
-
const
|
|
142
|
-
const origin = queryStringParameters.origin || 'unknown';
|
|
143
|
-
const loggedUser = extractLoggedUser(event);
|
|
149
|
+
const attributes = extractDefaultAttributes(event);
|
|
144
150
|
const { spanResult, successCounter, executionTimeHistogram, startTime, serviceName, environment, } = otelData;
|
|
145
151
|
spanResult.setSuccess(true);
|
|
152
|
+
const functionName = ((_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function.name']) ||
|
|
153
|
+
attributes.functionName;
|
|
154
|
+
const routeKey = ((_b = spanResult.span.attributes) === null || _b === void 0 ? void 0 : _b['route.key']) ||
|
|
155
|
+
attributes.routeKey;
|
|
156
|
+
const requestId = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['request.id']) ||
|
|
157
|
+
attributes.requestId;
|
|
146
158
|
successCounter.add(1, {
|
|
147
159
|
origin,
|
|
148
|
-
'function.name':
|
|
160
|
+
'function.name': functionName,
|
|
161
|
+
'request.id': requestId,
|
|
162
|
+
'route.key': routeKey,
|
|
149
163
|
'service.name': serviceName,
|
|
150
164
|
'deployment.environment.name': environment,
|
|
151
165
|
});
|
|
@@ -153,21 +167,41 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
153
167
|
executionTimeHistogram.record(durationMs, {
|
|
154
168
|
origin,
|
|
155
169
|
status: 'success',
|
|
156
|
-
'function.name':
|
|
170
|
+
'function.name': functionName,
|
|
171
|
+
'request.id': requestId,
|
|
172
|
+
'route.key': routeKey,
|
|
157
173
|
'service.name': serviceName,
|
|
158
174
|
'deployment.environment.name': environment,
|
|
159
175
|
});
|
|
160
|
-
const standardLogger = (0, telemetry_1.getStandardLogger)(
|
|
176
|
+
const standardLogger = (0, telemetry_1.getStandardLogger)(attributes);
|
|
161
177
|
yield standardLogger.logInfo({
|
|
162
178
|
message: 'Request completed successfully',
|
|
163
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
|
+
},
|
|
164
192
|
execution: {
|
|
165
|
-
functionName:
|
|
166
|
-
invocationId: (_d = spanResult.span.attributes) === null || _d === void 0 ? void 0 : _d['function.invocation_id']
|
|
193
|
+
functionName: functionName,
|
|
194
|
+
invocationId: ((_d = spanResult.span.attributes) === null || _d === void 0 ? void 0 : _d['function.invocation_id']) ||
|
|
195
|
+
attributes.invocationId,
|
|
167
196
|
origin,
|
|
168
|
-
routeKey:
|
|
169
|
-
requestId:
|
|
170
|
-
loggedUser
|
|
197
|
+
routeKey: routeKey,
|
|
198
|
+
requestId: requestId,
|
|
199
|
+
loggedUser: {
|
|
200
|
+
uid: (((_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['logged_user.uid']) ||
|
|
201
|
+
attributes['user.uid']),
|
|
202
|
+
email: (((_f = spanResult.span.attributes) === null || _f === void 0 ? void 0 : _f['logged_user.email']) ||
|
|
203
|
+
attributes['user.email']),
|
|
204
|
+
},
|
|
171
205
|
},
|
|
172
206
|
performance: {
|
|
173
207
|
durationMs,
|
|
@@ -182,20 +216,32 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
182
216
|
}
|
|
183
217
|
}),
|
|
184
218
|
onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
185
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
219
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
186
220
|
try {
|
|
187
221
|
const otelData = request.context.otel;
|
|
188
222
|
if (!otelData)
|
|
189
223
|
return;
|
|
224
|
+
const attributes = extractDefaultAttributes(request.event);
|
|
190
225
|
const { spanResult, failureCounter, executionTimeHistogram, startTime, serviceName, environment, origin, } = otelData;
|
|
191
226
|
const error = request.error;
|
|
192
227
|
if (error) {
|
|
193
228
|
spanResult.setError(error);
|
|
194
229
|
}
|
|
230
|
+
const functionName = ((_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function.name']) ||
|
|
231
|
+
attributes.functionName ||
|
|
232
|
+
'unknown';
|
|
233
|
+
const requestId = ((_b = spanResult.span.attributes) === null || _b === void 0 ? void 0 : _b['request.id']) ||
|
|
234
|
+
attributes.requestId ||
|
|
235
|
+
'unknown';
|
|
236
|
+
const routeKey = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['route.key']) ||
|
|
237
|
+
attributes.routeKey ||
|
|
238
|
+
'unknown';
|
|
195
239
|
failureCounter.add(1, {
|
|
196
240
|
origin,
|
|
197
|
-
error_type: ((
|
|
198
|
-
'function.name':
|
|
241
|
+
error_type: ((_d = error === null || error === void 0 ? void 0 : error.constructor) === null || _d === void 0 ? void 0 : _d.name) || 'UnknownError',
|
|
242
|
+
'function.name': functionName,
|
|
243
|
+
'request.id': requestId,
|
|
244
|
+
'route.key': routeKey,
|
|
199
245
|
'service.name': serviceName,
|
|
200
246
|
'deployment.environment.name': environment,
|
|
201
247
|
});
|
|
@@ -203,27 +249,50 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
203
249
|
executionTimeHistogram.record(durationMs, {
|
|
204
250
|
origin,
|
|
205
251
|
status: 'error',
|
|
206
|
-
'function.name':
|
|
252
|
+
'function.name': functionName,
|
|
253
|
+
'request.id': requestId,
|
|
254
|
+
'route.key': routeKey,
|
|
207
255
|
'service.name': serviceName,
|
|
208
256
|
'deployment.environment.name': environment,
|
|
209
257
|
});
|
|
210
|
-
const standardLogger = (0, telemetry_1.getStandardLogger)(
|
|
258
|
+
const standardLogger = (0, telemetry_1.getStandardLogger)(attributes);
|
|
211
259
|
yield standardLogger.logError({
|
|
212
260
|
message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
|
|
213
261
|
error: error || undefined,
|
|
214
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
|
+
},
|
|
215
275
|
execution: {
|
|
216
|
-
functionName:
|
|
217
|
-
invocationId: (_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['function.invocation_id']
|
|
218
|
-
|
|
276
|
+
functionName: functionName,
|
|
277
|
+
invocationId: ((_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['function.invocation_id']) ||
|
|
278
|
+
attributes.invocationId,
|
|
279
|
+
awsRequestId: (_f = spanResult.span.attributes) === null || _f === void 0 ? void 0 : _f['function.aws_request_id'],
|
|
219
280
|
origin,
|
|
281
|
+
routeKey: routeKey,
|
|
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
|
+
},
|
|
220
289
|
},
|
|
221
290
|
performance: {
|
|
222
291
|
durationMs,
|
|
223
292
|
success: false,
|
|
224
293
|
},
|
|
225
294
|
context: {
|
|
226
|
-
errorType: (
|
|
295
|
+
errorType: (_j = error === null || error === void 0 ? void 0 : error.constructor) === null || _j === void 0 ? void 0 : _j.name,
|
|
227
296
|
},
|
|
228
297
|
});
|
|
229
298
|
spanResult.end();
|
|
@@ -235,4 +304,4 @@ const middyTelemetryMiddleware = (options) => ({
|
|
|
235
304
|
}),
|
|
236
305
|
});
|
|
237
306
|
exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
|
|
238
|
-
//# 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 queryStringParameters = event?.queryStringParameters || {};\n      const origin = queryStringParameters.origin || 'unknown';\n      const loggedUser = extractLoggedUser(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      // Métricas\n      successCounter.add(1, {\n        origin,\n        'function.name':\n          spanResult.span.attributes?.['function.name'] || 'unknown',\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':\n          spanResult.span.attributes?.['function.name'] || 'unknown',\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: spanResult.span.attributes?.['function.name'] as string,\n          invocationId: spanResult.span.attributes?.[\n            'function.invocation_id'\n          ] as string,\n          origin,\n          routeKey: spanResult.span.attributes?.['routeKey'] as string,\n          requestId: spanResult.span.attributes?.['request.id'] as string,\n          loggedUser,\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 {\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      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        'function.name':\n          spanResult.span.attributes?.['function.name'] || 'unknown',\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':\n          spanResult.span.attributes?.['function.name'] || 'unknown',\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: spanResult.span.attributes?.['function.name'] as string,\n          invocationId: spanResult.span.attributes?.[\n            'function.invocation_id'\n          ] as string,\n          awsRequestId: spanResult.span.attributes?.[\n            'function.invocation_id'\n          ] as string,\n          origin,\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"]}
|