@mecanizou/telemetry-hub 1.3.11 → 1.3.13

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,18 @@
1
+ ## [1.3.13](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.12...v1.3.13) (2026-01-22)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * extract loggedUser ([19575c5](https://github.com/mecanizou-eco/telemetry-hub/commit/19575c5d1a85d65d2f8e118fc75107bb3c921dbb))
7
+ * extraction and logs prefix ([4393cbe](https://github.com/mecanizou-eco/telemetry-hub/commit/4393cbe24f205e0559d84d1e754228b0eca8dec5))
8
+
9
+ ## [1.3.12](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.11...v1.3.12) (2026-01-22)
10
+
11
+
12
+ ### Bug Fixes
13
+
14
+ * sonar sugestion ([106c704](https://github.com/mecanizou-eco/telemetry-hub/commit/106c7044b32a3be800b3b37e1de7565fec4a9043))
15
+
1
16
  ## [1.3.11](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.3.10...v1.3.11) (2026-01-22)
2
17
 
3
18
 
@@ -10,7 +10,8 @@ export declare class StandardLogger implements IStandardLogger {
10
10
  private readonly spanContext;
11
11
  private readonly environment;
12
12
  private readonly defaultServiceName;
13
- constructor(logger: Logger, tracer: IStandardTracer, scopeAttributes?: Attributes);
13
+ private readonly disableEmitter;
14
+ constructor(logger: Logger, tracer: IStandardTracer, scopeAttributes?: Attributes, disableEmitter?: boolean);
14
15
  defineDefaultAttributes(scopeAttributes?: any): void;
15
16
  logError(data: LogParams): Promise<void>;
16
17
  logInfo(data: LogParams): Promise<void>;
@@ -13,8 +13,9 @@ exports.StandardLogger = void 0;
13
13
  const api_logs_1 = require("@opentelemetry/api-logs");
14
14
  const environment_1 = require("./environment");
15
15
  class StandardLogger {
16
- constructor(logger, tracer, scopeAttributes) {
16
+ constructor(logger, tracer, scopeAttributes, disableEmitter) {
17
17
  this.defaultAttributes = {};
18
+ this.disableEmitter = false;
18
19
  this.logger = logger;
19
20
  this.tracer = tracer;
20
21
  this.spanContext = this.tracer.getTracer().startSpan('init-logger');
@@ -24,6 +25,8 @@ class StandardLogger {
24
25
  this.scopeAttributes = scopeAttributes;
25
26
  this.defineDefaultAttributes(scopeAttributes);
26
27
  this.environment = (0, environment_1.getEnvironmentStage)();
28
+ this.disableEmitter =
29
+ disableEmitter || this.environment === 'development' || false;
27
30
  }
28
31
  defineDefaultAttributes(scopeAttributes) {
29
32
  var _a, _b, _c;
@@ -86,7 +89,12 @@ class StandardLogger {
86
89
  body: fullData.body || fullData.message || '',
87
90
  attributes: this.buildAttributes(fullData),
88
91
  };
89
- this.logger.emit(logRecord);
92
+ if (!this.disableEmitter) {
93
+ this.logger.emit(logRecord);
94
+ }
95
+ else {
96
+ console.log('[Telemetry] Log emission disabled. Log record:', logRecord);
97
+ }
90
98
  });
91
99
  }
92
100
  buildAttributes(data) {
@@ -124,4 +132,4 @@ class StandardLogger {
124
132
  }
125
133
  }
126
134
  exports.StandardLogger = StandardLogger;
127
- //# 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, LogParams } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\nimport { getEnvironmentStage } from './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  public defaultAttributes: Record<string, any> = {};\n  public scopeAttributes?: Attributes;\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly spanContext: Span;\n  private readonly environment: string;\n  private readonly 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\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.scopeAttributes = scopeAttributes;\n    this.defineDefaultAttributes(scopeAttributes);\n    this.environment = getEnvironmentStage();\n  }\n\n  public defineDefaultAttributes(scopeAttributes?: any) {\n    this.defaultAttributes = {\n      trace: {\n        id: this.spanContext.spanContext().traceId,\n      },\n      span: {\n        id: this.spanContext.spanContext().spanId,\n      },\n      function: {\n        name:\n          scopeAttributes?.['function']?.['name'] ||\n          scopeAttributes?.functionName ||\n          'unknown',\n        invocationId:\n          scopeAttributes?.['function']?.['invocationId'] ||\n          scopeAttributes?.['execution']?.['awsRequestId'] ||\n          scopeAttributes?.invocationId ||\n          'unknown',\n      },\n      request: {\n        id:\n          scopeAttributes?.['requestId'] ||\n          scopeAttributes?.requestId ||\n          'unknown',\n      },\n    };\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'DEBUG',\n    });\n  }\n\n  async log(\n    data: Omit<LogParams, 'timestamp' | 'environment'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      serviceName: data.serviceName || this.defaultServiceName,\n      environment: this.environment,\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      message: fullData.message || '',\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.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      duration: {\n        timestamp: data.timestamp,\n      },\n      service: {\n        name: data.serviceName || this.defaultServiceName,\n      },\n      deployment: {\n        environmentName: data.environment,\n      },\n      execution: {\n        ...data.execution,\n      },\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error'] = {\n        type: data.error.name || '',\n        message: data.error.message || '',\n        stack: data.error.stack || '',\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    const entries = {\n      ...data,\n      ...this.defaultAttributes,\n      ...attributes,\n    };\n\n    delete entries.body;\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries(entries).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
135
+ //# 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, LogParams } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\nimport { getEnvironmentStage } from './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  public defaultAttributes: Record<string, any> = {};\n  public scopeAttributes?: Attributes;\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly spanContext: Span;\n  private readonly environment: string;\n  private readonly defaultServiceName: string;\n  private readonly disableEmitter: boolean = false;\n\n  constructor(\n    logger: Logger,\n    tracer: IStandardTracer,\n    scopeAttributes?: Attributes,\n    disableEmitter?: boolean\n  ) {\n    this.logger = logger;\n    this.tracer = tracer;\n    this.spanContext = this.tracer.getTracer().startSpan('init-logger');\n\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.scopeAttributes = scopeAttributes;\n    this.defineDefaultAttributes(scopeAttributes);\n    this.environment = getEnvironmentStage();\n    this.disableEmitter =\n      disableEmitter || this.environment === 'development' || false;\n  }\n\n  public defineDefaultAttributes(scopeAttributes?: any) {\n    this.defaultAttributes = {\n      trace: {\n        id: this.spanContext.spanContext().traceId,\n      },\n      span: {\n        id: this.spanContext.spanContext().spanId,\n      },\n      function: {\n        name:\n          scopeAttributes?.['function']?.['name'] ||\n          scopeAttributes?.functionName ||\n          'unknown',\n        invocationId:\n          scopeAttributes?.['function']?.['invocationId'] ||\n          scopeAttributes?.['execution']?.['awsRequestId'] ||\n          scopeAttributes?.invocationId ||\n          'unknown',\n      },\n      request: {\n        id:\n          scopeAttributes?.['requestId'] ||\n          scopeAttributes?.requestId ||\n          'unknown',\n      },\n    };\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      ...data,\n      severity: 'DEBUG',\n    });\n  }\n\n  async log(\n    data: Omit<LogParams, 'timestamp' | 'environment'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      serviceName: data.serviceName || this.defaultServiceName,\n      environment: this.environment,\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      message: fullData.message || '',\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.body || fullData.message || '',\n      attributes: this.buildAttributes(fullData),\n    };\n\n    if (!this.disableEmitter) {\n      this.logger.emit(logRecord);\n    } else {\n      console.log('[Telemetry] Log emission disabled. Log record:', logRecord);\n    }\n  }\n\n  private buildAttributes(data: StandardLogData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      duration: {\n        timestamp: data.timestamp,\n      },\n      service: {\n        name: data.serviceName || this.defaultServiceName,\n      },\n      deployment: {\n        environmentName: data.environment,\n      },\n      execution: {\n        ...data.execution,\n      },\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error'] = {\n        type: data.error.name || '',\n        message: data.error.message || '',\n        stack: data.error.stack || '',\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    const entries = {\n      ...data,\n      ...this.defaultAttributes,\n      ...attributes,\n    };\n\n    delete entries.body;\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries(entries).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
@@ -9,6 +9,7 @@ export declare function extractHttpAttributes(event: any): {
9
9
  };
10
10
  export declare function extractLoggedUser(event: any): {
11
11
  email?: string;
12
+ name?: string;
12
13
  uid?: string;
13
14
  } | undefined;
14
15
  export declare function extractDefaultAttributes(request: any): Record<string, any>;
@@ -3,10 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.extractHttpAttributes = extractHttpAttributes;
4
4
  exports.extractLoggedUser = extractLoggedUser;
5
5
  exports.extractDefaultAttributes = extractDefaultAttributes;
6
- const environment_1 = require("../core/environment");
7
6
  function extractHttpAttributes(event) {
8
7
  var _a, _b, _c, _d, _e, _f;
9
- if (event.requestContext) {
8
+ if (event === null || event === void 0 ? void 0 : event.requestContext) {
10
9
  return {
11
10
  method: ((_a = event.requestContext.http) === null || _a === void 0 ? void 0 : _a.method) || 'unknown',
12
11
  routeKey: event.routeKey || ((_b = event.requestContext) === null || _b === void 0 ? void 0 : _b.routeKey) || 'unknown',
@@ -18,27 +17,30 @@ function extractHttpAttributes(event) {
18
17
  };
19
18
  }
20
19
  return {
21
- method: event.httpMethod || 'unknown',
22
- routeKey: event.routeKey || ((_e = event.requestContext) === null || _e === void 0 ? void 0 : _e.routeKey) || 'unknown',
23
- url: event.path || 'unknown',
24
- user_agent: ((_f = event.headers) === null || _f === void 0 ? void 0 : _f['User-Agent']) || 'unknown',
25
- path_parameters: event.pathParameters || {},
26
- query_string_parameters: event.queryStringParameters || {},
27
- body: event.body || {},
20
+ method: (event === null || event === void 0 ? void 0 : event.httpMethod) || 'unknown',
21
+ routeKey: (event === null || event === void 0 ? void 0 : event.routeKey) || ((_e = event.requestContext) === null || _e === void 0 ? void 0 : _e.routeKey) || 'unknown',
22
+ url: (event === null || event === void 0 ? void 0 : event.path) || 'unknown',
23
+ user_agent: ((_f = event === null || event === void 0 ? void 0 : event.headers) === null || _f === void 0 ? void 0 : _f['User-Agent']) || 'unknown',
24
+ path_parameters: (event === null || event === void 0 ? void 0 : event.pathParameters) || {},
25
+ query_string_parameters: (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {},
26
+ body: (event === null || event === void 0 ? void 0 : event.body) || {},
28
27
  };
29
28
  }
30
29
  function extractLoggedUser(event) {
31
- var _a, _b, _c, _d, _e, _f;
32
- let loggedUser = (_c = (_b = (_a = event === null || event === void 0 ? void 0 : event.requestContext) === null || _a === void 0 ? void 0 : _a.authorizer) === null || _b === void 0 ? void 0 : _b.lambda) === null || _c === void 0 ? void 0 : _c.loggerUser;
30
+ var _a, _b, _c, _d;
31
+ let loggedUser = (_c = (_b = (_a = event === null || event === void 0 ? void 0 : event.requestContext) === null || _a === void 0 ? void 0 : _a.authorizer) === null || _b === void 0 ? void 0 : _b.lambda) === null || _c === void 0 ? void 0 : _c.loggedUser;
33
32
  if (loggedUser) {
34
33
  loggedUser =
35
34
  typeof loggedUser === 'string' ? JSON.parse(loggedUser) : loggedUser;
36
- if ((loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) &&
37
- ((_d = loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) === null || _d === void 0 ? void 0 : _d.account_user) &&
38
- ((_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)) {
35
+ const accountUser = (_d = loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) === null || _d === void 0 ? void 0 : _d.account_user;
36
+ const firstAccountUser = Array.isArray(accountUser)
37
+ ? accountUser[0]
38
+ : accountUser;
39
+ if ((loggedUser === null || loggedUser === void 0 ? void 0 : loggedUser.user) && accountUser && (firstAccountUser === null || firstAccountUser === void 0 ? void 0 : firstAccountUser.account)) {
39
40
  return {
40
41
  email: loggedUser.user.email,
41
- uid: loggedUser.user.account_user.account.uid,
42
+ uid: firstAccountUser.account.uid,
43
+ name: firstAccountUser.account.name,
42
44
  };
43
45
  }
44
46
  }
@@ -46,28 +48,46 @@ function extractLoggedUser(event) {
46
48
  }
47
49
  function extractDefaultAttributes(request) {
48
50
  var _a, _b;
49
- const lambdaContext = (request === null || request === void 0 ? void 0 : request.context) || (request === null || request === void 0 ? void 0 : request.lambdaContext);
50
- const functionName = (lambdaContext === null || lambdaContext === void 0 ? void 0 : lambdaContext.functionName) || 'unknown';
51
- const invocationId = (lambdaContext === null || lambdaContext === void 0 ? void 0 : lambdaContext.awsRequestId) || 'unknown';
52
- const serviceName = process.env.SERVICE_NAME || 'sst-service';
53
- const event = request === null || request === void 0 ? void 0 : request.event;
54
- const queryStringParameters = (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {};
55
- const origin = queryStringParameters.origin || 'unknown';
56
- const http = extractHttpAttributes(event);
57
- const routeKey = (event === null || event === void 0 ? void 0 : event.routeKey) || ((_a = event === null || event === void 0 ? void 0 : event.requestContext) === null || _a === void 0 ? void 0 : _a.routeKey) || 'unknown';
58
- 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';
59
- const loggedUser = extractLoggedUser(event);
60
- const stage = (0, environment_1.getEnvironmentStage)();
61
- return {
62
- functionName,
63
- invocationId,
64
- serviceName,
65
- origin,
66
- routeKey,
67
- requestId,
68
- stage,
69
- http,
70
- loggedUser,
71
- };
51
+ try {
52
+ const lambdaContext = (request === null || request === void 0 ? void 0 : request.context) || (request === null || request === void 0 ? void 0 : request.lambdaContext);
53
+ const functionName = (lambdaContext === null || lambdaContext === void 0 ? void 0 : lambdaContext.functionName) || 'unknown';
54
+ const invocationId = (lambdaContext === null || lambdaContext === void 0 ? void 0 : lambdaContext.awsRequestId) || 'unknown';
55
+ const serviceName = process.env.SERVICE_NAME || 'sst-service';
56
+ const event = (request === null || request === void 0 ? void 0 : request.event) || request;
57
+ const queryStringParameters = (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {};
58
+ const origin = queryStringParameters.origin || 'unknown';
59
+ const http = extractHttpAttributes(event);
60
+ const routeKey = (event === null || event === void 0 ? void 0 : event.routeKey) || ((_a = event === null || event === void 0 ? void 0 : event.requestContext) === null || _a === void 0 ? void 0 : _a.routeKey) || 'unknown';
61
+ 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';
62
+ const loggedUser = extractLoggedUser(event);
63
+ let stage = process.env.STAGE || 'development';
64
+ if (stage === 'prod')
65
+ stage = 'production';
66
+ return {
67
+ functionName,
68
+ invocationId,
69
+ serviceName,
70
+ origin,
71
+ routeKey,
72
+ requestId,
73
+ stage,
74
+ http,
75
+ loggedUser,
76
+ };
77
+ }
78
+ catch (error) {
79
+ console.error('[Telemetry] Error extracting default attributes:', error);
80
+ return {
81
+ functionName: 'unknown',
82
+ invocationId: 'unknown',
83
+ serviceName: 'unknown',
84
+ origin: 'unknown',
85
+ routeKey: 'unknown',
86
+ requestId: 'unknown',
87
+ stage: 'unknown',
88
+ http: {},
89
+ loggedUser: undefined,
90
+ };
91
+ }
72
92
  }
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0cmFjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zc3QvZXh0cmFjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUVBLHNEQThCQztBQUVELDhDQXFCQztBQUVELDREQTJCQztBQXBGRCxxREFBMEQ7QUFFMUQsU0FBZ0IscUJBQXFCLENBQUMsS0FBVTs7SUFTOUMsSUFBSSxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDekIsT0FBTztZQUNMLE1BQU0sRUFBRSxDQUFBLE1BQUEsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUFJLDBDQUFFLE1BQU0sS0FBSSxTQUFTO1lBQ3RELFFBQVEsRUFBRSxLQUFLLENBQUMsUUFBUSxLQUFJLE1BQUEsS0FBSyxDQUFDLGNBQWMsMENBQUUsUUFBUSxDQUFBLElBQUksU0FBUztZQUN2RSxHQUFHLEVBQUUsS0FBSyxDQUFDLGNBQWMsQ0FBQyxVQUFVLEtBQUksTUFBQSxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksMENBQUUsSUFBSSxDQUFBO1lBQ3ZFLFVBQVUsRUFBRSxDQUFBLE1BQUEsS0FBSyxDQUFDLE9BQU8sMENBQUcsWUFBWSxDQUFDLEtBQUksU0FBUztZQUN0RCxlQUFlLEVBQUUsS0FBSyxDQUFDLGNBQWMsSUFBSSxFQUFFO1lBQzNDLHVCQUF1QixFQUFFLEtBQUssQ0FBQyxxQkFBcUIsSUFBSSxFQUFFO1lBQzFELElBQUksRUFBRSxLQUFLLENBQUMsSUFBSSxJQUFJLEVBQUU7U0FDdkIsQ0FBQztJQUNKLENBQUM7SUFFRCxPQUFPO1FBQ0wsTUFBTSxFQUFFLEtBQUssQ0FBQyxVQUFVLElBQUksU0FBUztRQUNyQyxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsS0FBSSxNQUFBLEtBQUssQ0FBQyxjQUFjLDBDQUFFLFFBQVEsQ0FBQSxJQUFJLFNBQVM7UUFDdkUsR0FBRyxFQUFFLEtBQUssQ0FBQyxJQUFJLElBQUksU0FBUztRQUM1QixVQUFVLEVBQUUsQ0FBQSxN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bUIsR0FBRSxDQUFDO0lBRXBDLE9BQU87UUFDTCxZQUFZO1FBQ1osWUFBWTtRQUNaLFdBQVc7UUFDWCxNQUFNO1FBQ04sUUFBUTtRQUNSLFNBQVM7UUFDVCxLQUFLO1FBQ0wsSUFBSTtRQUNKLFVBQVU7S0FDWCxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEVudmlyb25tZW50U3RhZ2UgfSBmcm9tICcuLi9jb3JlL2Vudmlyb25tZW50JztcblxuZXhwb3J0IGZ1bmN0aW9uIGV4dHJhY3RIdHRwQXR0cmlidXRlcyhldmVudDogYW55KToge1xuICBtZXRob2Q6IHN0cmluZztcbiAgdXJsOiBzdHJpbmc7XG4gIHJvdXRlS2V5Pzogc3RyaW5nO1xuICB1c2VyX2FnZW50OiBzdHJpbmc7XG4gIHBhdGhfcGFyYW1ldGVyczogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgcXVlcnlfc3RyaW5nX3BhcmFtZXRlcnM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gIGJvZHk6IGFueTtcbn0ge1xuICBpZiAoZXZlbnQucmVxdWVzdENvbnRleHQpIHtcbiAgICByZXR1cm4ge1xuICAgICAgbWV0aG9kOiBldmVudC5yZXF1ZXN0Q29udGV4dC5odHRwPy5tZXRob2QgfHwgJ3Vua25vd24nLFxuICAgICAgcm91dGVLZXk6IGV2ZW50LnJvdXRlS2V5IHx8IGV2ZW50LnJlcXVlc3RDb250ZXh0Py5yb3V0ZUtleSB8fCAndW5rbm93bicsXG4gICAgICB1cmw6IGV2ZW50LnJlcXVlc3RDb250ZXh0LmRvbWFpbk5hbWUgJiYgZXZlbnQucmVxdWVzdENvbnRleHQuaHR0cD8ucGF0aCxcbiAgICAgIHVzZXJfYWdlbnQ6IGV2ZW50LmhlYWRlcnM/LlsndXNlci1hZ2VudCddIHx8ICd1bmtub3duJyxcbiAgICAgIHBhdGhfcGFyYW1ldGVyczogZXZlbnQucGF0aFBhcmFtZXRlcnMgfHwge30sXG4gICAgICBxdWVyeV9zdHJpbmdfcGFyYW1ldGVyczogZXZlbnQucXVlcnlTdHJpbmdQYXJhbWV0ZXJzIHx8IHt9LFxuICAgICAgYm9keTogZXZlbnQuYm9keSB8fCB7fSxcbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBtZXRob2Q6IGV2ZW50Lmh0dHBNZXRob2QgfHwgJ3Vua25vd24nLFxuICAgIHJvdXRlS2V5OiBldmVudC5yb3V0ZUtleSB8fCBldmVudC5yZXF1ZXN0Q29udGV4dD8ucm91dGVLZXkgfHwgJ3Vua25vd24nLFxuICAgIHVybDogZXZlbnQucGF0aCB8fCAndW5rbm93bicsXG4gICAgdXNlcl9hZ2VudDogZXZlbnQuaGVhZGVycz8uWydVc2VyLUFnZW50J10gfHwgJ3Vua25vd24nLFxuICAgIHBhdGhfcGFyYW1ldGVyczogZXZlbnQucGF0aFBhcmFtZXRlcnMgfHwge30sXG4gICAgcXVlcnlfc3RyaW5nX3BhcmFtZXRlcnM6IGV2ZW50LnF1ZXJ5U3RyaW5nUGFyYW1ldGVycyB8fCB7fSxcbiAgICBib2R5OiBldmVudC5ib2R5IHx8IHt9LFxuICB9O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXh0cmFjdExvZ2dlZFVzZXIoXG4gIGV2ZW50OiBhbnlcbik6IHsgZW1haWw/OiBzdHJpbmc7IHVpZD86IHN0cmluZyB9IHwgdW5kZWZpbmVkIHtcbiAgbGV0IGxvZ2dlZFVzZXIgPSBldmVudD8ucmVxdWVzdENvbnRleHQ/LmF1dGhvcml6ZXI/LmxhbWJkYT8ubG9nZ2VyVXNlcjtcblxuICBpZiAobG9nZ2VkVXNlcikge1xuICAgIGxvZ2dlZFVzZXIgPVxuICAgICAgdHlwZW9mIGxvZ2dlZFVzZXIgPT09ICdzdHJpbmcnID8gSlNPTi5wYXJzZShsb2dnZWRVc2VyKSA6IGxvZ2dlZFVzZXI7XG4gICAgaWYgKFxuICAgICAgbG9nZ2VkVXNlcj8udXNlciAmJlxuICAgICAgbG9nZ2VkVXNlcj8udXNlcj8uYWNjb3VudF91c2VyICYmXG4gICAgICBsb2dnZWRVc2VyPy51c2VyPy5hY2NvdW50X3VzZXI/LmFjY291bnRcbiAgICApIHtcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGVtYWlsOiBsb2dnZWRVc2VyLnVzZXIuZW1haWwsXG4gICAgICAgIHVpZDogbG9nZ2VkVXNlci51c2VyLmFjY291bnRfdXNlci5hY2NvdW50LnVpZCxcbiAgICAgIH07XG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4dHJhY3REZWZhdWx0QXR0cmlidXRlcyhyZXF1ZXN0OiBhbnkpOiBSZWNvcmQ8c3RyaW5nLCBhbnk+IHtcbiAgY29uc3QgbGFtYmRhQ29udGV4dCA9IHJlcXVlc3Q/LmNvbnRleHQgfHwgcmVxdWVzdD8ubGFtYmRhQ29udGV4dDtcbiAgY29uc3QgZnVuY3Rpb25OYW1lID0gbGFtYmRhQ29udGV4dD8uZnVuY3Rpb25OYW1lIHx8ICd1bmtub3duJztcbiAgY29uc3QgaW52b2NhdGlvbklkID0gbGFtYmRhQ29udGV4dD8uYXdzUmVxdWVzdElkIHx8ICd1bmtub3duJztcbiAgY29uc3Qgc2VydmljZU5hbWUgPSBwcm9jZXNzLmVudi5TRVJWSUNFX05BTUUgfHwgJ3NzdC1zZXJ2aWNlJztcbiAgY29uc3QgZXZlbnQgPSByZXF1ZXN0Py5ldmVudDtcbiAgY29uc3QgcXVlcnlTdHJpbmdQYXJhbWV0ZXJzID0gZXZlbnQ/LnF1ZXJ5U3RyaW5nUGFyYW1ldGVycyB8fCB7fTtcbiAgY29uc3Qgb3JpZ2luID0gcXVlcnlTdHJpbmdQYXJhbWV0ZXJzLm9yaWdpbiB8fCAndW5rbm93bic7XG4gIGNvbnN0IGh0dHAgPSBleHRyYWN0SHR0cEF0dHJpYnV0ZXMoZXZlbnQpO1xuICBjb25zdCByb3V0ZUtleSA9XG4gICAgZXZlbnQ/LnJvdXRlS2V5IHx8IGV2ZW50Py5yZXF1ZXN0Q29udGV4dD8ucm91dGVLZXkgfHwgJ3Vua25vd24nO1xuICBjb25zdCByZXF1ZXN0SWQgPVxuICAgIGV2ZW50Py5yZXF1ZXN0SWQgfHwgZXZlbnQ/LnJlcXVlc3RDb250ZXh0Py5yZXF1ZXN0SWQgfHwgJ3Vua25vd24nO1xuICBjb25zdCBsb2dnZWRVc2VyID0gZXh0cmFjdExvZ2dlZFVzZXIoZXZlbnQpO1xuICBjb25zdCBzdGFnZSA9IGdldEVudmlyb25tZW50U3RhZ2UoKTtcblxuICByZXR1cm4ge1xuICAgIGZ1bmN0aW9uTmFtZSxcbiAgICBpbnZvY2F0aW9uSWQsXG4gICAgc2VydmljZU5hbWUsXG4gICAgb3JpZ2luLFxuICAgIHJvdXRlS2V5LFxuICAgIHJlcXVlc3RJZCxcbiAgICBzdGFnZSxcbiAgICBodHRwLFxuICAgIGxvZ2dlZFVzZXIsXG4gIH07XG59XG4iXX0=
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"extraction.js","sourceRoot":"","sources":["../../src/sst/extraction.ts"],"names":[],"mappings":"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","sourcesContent":["import { getEnvironmentStage } from '../core/environment';\n\nexport function extractHttpAttributes(event: any): {\n  method: string;\n  url: string;\n  routeKey?: string;\n  user_agent: string;\n  path_parameters: Record<string, string>;\n  query_string_parameters: Record<string, string>;\n  body: any;\n} {\n  if (event?.requestContext) {\n    return {\n      method: event.requestContext.http?.method || 'unknown',\n      routeKey: event.routeKey || event.requestContext?.routeKey || 'unknown',\n      url: event.requestContext.domainName && event.requestContext.http?.path,\n      user_agent: event.headers?.['user-agent'] || 'unknown',\n      path_parameters: event.pathParameters || {},\n      query_string_parameters: event.queryStringParameters || {},\n      body: event.body || {},\n    };\n  }\n\n  return {\n    method: event?.httpMethod || 'unknown',\n    routeKey: event?.routeKey || event.requestContext?.routeKey || 'unknown',\n    url: event?.path || 'unknown',\n    user_agent: event?.headers?.['User-Agent'] || 'unknown',\n    path_parameters: event?.pathParameters || {},\n    query_string_parameters: event?.queryStringParameters || {},\n    body: event?.body || {},\n  };\n}\n\nexport function extractLoggedUser(\n  event: any\n): { email?: string; name?: string; uid?: string } | undefined {\n  let loggedUser = event?.requestContext?.authorizer?.lambda?.loggedUser;\n\n  if (loggedUser) {\n    loggedUser =\n      typeof loggedUser === 'string' ? JSON.parse(loggedUser) : loggedUser;\n\n    const accountUser = loggedUser?.user?.account_user;\n    const firstAccountUser = Array.isArray(accountUser)\n      ? accountUser[0]\n      : accountUser;\n\n    if (loggedUser?.user && accountUser && firstAccountUser?.account) {\n      return {\n        email: loggedUser.user.email,\n        uid: firstAccountUser.account.uid,\n        name: firstAccountUser.account.name,\n      };\n    }\n  }\n\n  return undefined;\n}\n\nexport function extractDefaultAttributes(request: any): Record<string, any> {\n  try {\n    const lambdaContext = request?.context || request?.lambdaContext;\n    const functionName = lambdaContext?.functionName || 'unknown';\n    const invocationId = lambdaContext?.awsRequestId || 'unknown';\n    const serviceName = process.env.SERVICE_NAME || 'sst-service';\n    const event = request?.event || request;\n    const queryStringParameters = event?.queryStringParameters || {};\n    const origin = queryStringParameters.origin || 'unknown';\n    const http = extractHttpAttributes(event);\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    let stage = process.env.STAGE || 'development';\n    if (stage === 'prod') stage = 'production';\n\n    return {\n      functionName,\n      invocationId,\n      serviceName,\n      origin,\n      routeKey,\n      requestId,\n      stage,\n      http,\n      loggedUser,\n    };\n  } catch (error) {\n    console.error('[Telemetry] Error extracting default attributes:', error);\n    return {\n      functionName: 'unknown',\n      invocationId: 'unknown',\n      serviceName: 'unknown',\n      origin: 'unknown',\n      routeKey: 'unknown',\n      requestId: 'unknown',\n      stage: 'unknown',\n      http: {},\n      loggedUser: undefined,\n    };\n  }\n}\n"]}
@@ -11,13 +11,13 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.middyTelemetryMiddleware = void 0;
13
13
  const api_1 = require("@opentelemetry/api");
14
- const perf_hooks_1 = require("perf_hooks");
14
+ const node_perf_hooks_1 = require("node:perf_hooks");
15
15
  const telemetry_1 = require("../telemetry");
16
16
  const extraction_1 = require("../extraction");
17
17
  const middyTelemetryMiddleware = (options) => ({
18
18
  before: (request) => __awaiter(void 0, void 0, void 0, function* () {
19
19
  try {
20
- const startTime = perf_hooks_1.performance.now();
20
+ const startTime = node_perf_hooks_1.performance.now();
21
21
  const attributes = (0, extraction_1.extractDefaultAttributes)(request);
22
22
  const standardTracer = (0, telemetry_1.getStandardTracer)();
23
23
  const spanResult = standardTracer.startSpan(Object.assign(Object.assign({}, attributes), { spanName: attributes.functionName, environment: attributes.stage, execution: {
@@ -53,7 +53,7 @@ const middyTelemetryMiddleware = (options) => ({
53
53
  };
54
54
  }
55
55
  catch (error) {
56
- console.error('Error in middyTelemetryMiddleware before hook:', error);
56
+ console.error('[Telemetry] Error in middyTelemetryMiddleware before hook:', error);
57
57
  }
58
58
  }),
59
59
  after: (request) => __awaiter(void 0, void 0, void 0, function* () {
@@ -77,7 +77,7 @@ const middyTelemetryMiddleware = (options) => ({
77
77
  serviceName: serviceName,
78
78
  environmentName: environment,
79
79
  });
80
- const durationMs = perf_hooks_1.performance.now() - startTime;
80
+ const durationMs = node_perf_hooks_1.performance.now() - startTime;
81
81
  executionTimeHistogram.record(durationMs, {
82
82
  origin,
83
83
  status: 'success',
@@ -87,7 +87,10 @@ const middyTelemetryMiddleware = (options) => ({
87
87
  serviceName: serviceName,
88
88
  environmentName: environment,
89
89
  });
90
- const standardLogger = (0, telemetry_1.getStandardLogger)(spanResult.span.attributes);
90
+ const standardLogger = (0, telemetry_1.getStandardLogger)({
91
+ scopeAttributes: spanResult.span.attributes,
92
+ forceNewInstance: true,
93
+ });
91
94
  yield standardLogger.logInfo(Object.assign(Object.assign({ message: 'Request completed successfully' }, attributes), { execution: {
92
95
  origin,
93
96
  routeKey: routeKey,
@@ -100,7 +103,7 @@ const middyTelemetryMiddleware = (options) => ({
100
103
  yield (0, telemetry_1.forceFlush)();
101
104
  }
102
105
  catch (error) {
103
- console.error('Error in middyTelemetryMiddleware after hook:', error);
106
+ console.error('[Telemetry] Error in middyTelemetryMiddleware after hook:', error);
104
107
  }
105
108
  }),
106
109
  onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
@@ -126,7 +129,7 @@ const middyTelemetryMiddleware = (options) => ({
126
129
  serviceName: serviceName,
127
130
  environmentName: environment,
128
131
  });
129
- const durationMs = perf_hooks_1.performance.now() - startTime;
132
+ const durationMs = node_perf_hooks_1.performance.now() - startTime;
130
133
  executionTimeHistogram.record(durationMs, {
131
134
  origin,
132
135
  status: 'error',
@@ -136,7 +139,10 @@ const middyTelemetryMiddleware = (options) => ({
136
139
  serviceName: serviceName,
137
140
  environmentName: environment,
138
141
  });
139
- const standardLogger = (0, telemetry_1.getStandardLogger)(spanResult.span.attributes);
142
+ const standardLogger = (0, telemetry_1.getStandardLogger)({
143
+ scopeAttributes: spanResult.span.attributes,
144
+ forceNewInstance: true,
145
+ });
140
146
  yield standardLogger.logError({
141
147
  message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
142
148
  error: error || undefined,
@@ -159,9 +165,9 @@ const middyTelemetryMiddleware = (options) => ({
159
165
  yield (0, telemetry_1.forceFlush)();
160
166
  }
161
167
  catch (error) {
162
- console.error('Error in middyTelemetryMiddleware onError hook:', error);
168
+ console.error('[Telemetry] Error in middyTelemetryMiddleware onError hook:', error);
163
169
  }
164
170
  }),
165
171
  });
166
172
  exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
167
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\n\ninterface MiddyMiddlewareOptions {}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error('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\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger(spanResult.span.attributes);\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error('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      const functionName =\n        spanResult.span.attributes?.['function']['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger(spanResult.span.attributes);\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        execution: {\n          awsRequestId:\n            spanResult.span.attributes?.['function']?.['aws_request_id'],\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: false,\n        },\n        context: {\n          errorType: error?.constructor?.name,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error('Error in middyTelemetryMiddleware onError hook:', error);\n    }\n  },\n});\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'node:perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\n\ninterface MiddyMiddlewareOptions {}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware before hook:',\n        error\n      );\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware after hook:',\n        error\n      );\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        failureCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n        origin,\n      } = otelData;\n      const error = request.error;\n\n      // Marcar span como erro usando StandardTracer\n      if (error) {\n        spanResult.setError(error);\n      }\n\n      const functionName =\n        spanResult.span.attributes?.['function']['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        execution: {\n          awsRequestId:\n            spanResult.span.attributes?.['function']?.['aws_request_id'],\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: false,\n        },\n        context: {\n          errorType: error?.constructor?.name,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware onError hook:',\n        error\n      );\n    }\n  },\n});\n"]}
@@ -1,5 +1,9 @@
1
1
  import { Attributes } from '@opentelemetry/api';
2
2
  import { StandardLogger, StandardTracer } from '../core';
3
- export declare const getStandardLogger: (scopeAttributes?: Attributes) => StandardLogger;
3
+ export declare const getStandardLogger: ({ scopeAttributes, forceNewInstance, disableEmitter, }: {
4
+ scopeAttributes?: Attributes;
5
+ forceNewInstance?: boolean;
6
+ disableEmitter?: boolean;
7
+ }) => StandardLogger;
4
8
  export declare const getStandardTracer: () => StandardTracer;
5
9
  export declare const forceFlush: () => Promise<void>;
@@ -96,9 +96,9 @@ const sdk = new sdk_node_1.NodeSDK({
96
96
  sdk.start();
97
97
  let standardLogger = null;
98
98
  let standardTracer = null;
99
- const getStandardLogger = (scopeAttributes) => {
99
+ const getStandardLogger = ({ scopeAttributes, forceNewInstance = false, disableEmitter = false, }) => {
100
100
  var _a, _b;
101
- if (!standardLogger) {
101
+ if (!standardLogger || forceNewInstance) {
102
102
  const tracer = (0, exports.getStandardTracer)();
103
103
  const logger = loggerProvider.getLogger('sst-middleware-logger', '1.0.0', {
104
104
  includeTraceContext: true,
@@ -129,4 +129,4 @@ const forceFlush = () => __awaiter(void 0, void 0, void 0, function* () {
129
129
  yield loggerProvider.forceFlush();
130
130
  });
131
131
  exports.forceFlush = forceFlush;
132
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVsZW1ldHJ5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NzdC90ZWxlbWV0cnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsc0RBQWtEO0FBQ2xELHNGQUE0RTtBQUM1RSwwRkFBK0U7QUFDL0Usb0ZBQXlFO0FBQ3pFLDREQUEyRTtBQUMzRSw4REFBZ0Q7QUFDaEQsb0VBQXNEO0FBQ3RELDhFQUF3RTtBQUN4RSw0Q0FBdUQ7QUFDdkQsa0NBQXlEO0FBRXpELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUM7QUFDakQsTUFBTSxRQUFRLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQztBQUVyRCxNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsSUFBSSxJQUFJLFFBQVEsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBRXhFLE1BQU0sT0FBTyxHQUFHLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsS0FBSyxDQUFDO0FBRWhFLE1BQU0sYUFBYSxHQUFHLElBQUksNENBQWlCLENBQUM7SUFDMUMsR0FBRyxFQUFFLEdBQUcsT0FBTyxTQUFTO0lBQ3hCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSwrQ0FBa0IsQ0FBQztJQUM1QyxHQUFHLEVBQUUsR0FBRyxPQUFPLFVBQVU7SUFDekIsT0FBTyxFQUFFO1FBQ1AsYUFBYSxFQUFFLFNBQVMsU0FBUyxFQUFFO1FBQ25DLGNBQWMsRUFBRSxrQkFBa0I7S0FDbkM7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLFdBQVcsR0FBRyxJQUFJLHlDQUFlLENBQUM7SUFDdEMsR0FBRyxFQUFFLEdBQUcsT0FBTyxPQUFPO0lBQ3RCLE9BQU8sRUFBRTtRQUNQLGFBQWEsRUFBRSxTQUFTLFNBQVMsRUFBRTtRQUNuQyxjQUFjLEVBQUUsa0JBQWtCO0tBQ25DO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxZQUFZLEdBQUcsSUFBSSwyQ0FBNkIsQ0FBQztJQUNyRCxRQUFRLEVBQUUsY0FBYztJQUN4QixvQkFBb0IsRUFBRSxJQUFJO0NBQzNCLENBQUMsQ0FBQztBQUdILE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsWUFBWSxJQUFJLGFBQWEsQ0FBQztBQUM5RCxNQUFNLFFBQVEsR0FBRyxJQUFJLFNBQVMsQ0FBQyxRQUFRLENBQUM7SUFDdEMsQ0FBQyx3Q0FBaUIsQ0FBQyxFQUFFLFdBQVc7Q0FDakMsQ0FBQyxDQUFDO0FBRUgsTUFBTSxjQUFjLEdBQUcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQztBQUM3RCxNQUFNLGtCQUFrQixHQUFHLElBQUksSUFBSSxDQUFDLHVCQUF1QixDQUFDLFdBQVcsQ0FBQyxDQUFDO0FBQ3pFLGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0FBRXpELE1BQU0sR0FBRyxHQUFHLElBQUksa0JBQU8sQ0FBQztJQUN0QixhQUFhO0lBQ2IsWUFBWSxFQUFFLFlBQW1CO0NBQ2xDLENBQUMsQ0FBQztBQUVILEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQztBQUdaLElBQUksY0FBYyxHQUEwQixJQUFJLENBQUM7QUFDakQsSUFBSSxjQUFjLEdBQTBCLElBQUksQ0FBQztBQUUxQyxNQUFNLGlCQUFpQixHQUFHLENBQy9CLGVBQTRCLEVBQ1osRUFBRTs7SUFDbEIsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3BCLE1BQU0sTUFBTSxHQUFHLElBQUEseUJBQWlCLEdBQUUsQ0FBQztRQUNuQyxNQUFNLE1BQU0sR0FBRyxjQUFjLENBQUMsU0FBUyxDQUFDLHVCQUF1QixFQUFFLE9BQU8sRUFBRTtZQUN4RSxtQkFBbUIsRUFBRSxJQUFJO1lBQ3pCLGVBQWU7U0FDaEIsQ0FBQyxDQUFDO1FBQ0gsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLGVBQWUsQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7U0FBTSxDQUFDO1FBQ04sTUFBTSxRQUFRLEdBQ1osQ0FBQSxNQUFBLE1BQUEsY0FBYyxDQUFDLGlCQUFpQiwwQ0FBRSxRQUFRLDBDQUFFLElBQUksTUFBSyxTQUFTLENBQUM7UUFFakUsSUFBSSxDQUFDLFFBQVEsSUFBSSxlQUFlLEVBQUUsQ0FBQztZQUNqQyxjQUFjLENBQUMsdUJBQXVCLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDMUQsQ0FBQztJQUNILENBQUM7SUFDRCxPQUFPLGNBQWMsQ0FBQztBQUN4QixDQUFDLENBQUM7QUFuQlcsUUFBQSxpQkFBaUIscUJBbUI1QjtBQUVLLE1BQU0saUJBQWlCLEdBQUcsR0FBbUIsRUFBRTtJQUNwRCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDcEIsTUFBTSxNQUFNLEdBQUcsV0FBSyxDQUFDLFNBQVMsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDckQsY0FBYyxHQUFHLElBQUkscUJBQWMsQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUMsQ0FBQztBQU5XLFFBQUEsaUJBQWlCLHFCQU01QjtBQUVLLE1BQU0sVUFBVSxHQUFHLEdBQVMsRUFBRTtJQUNuQyxNQUFNLFlBQVksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNoQyxNQUFNLGFBQWEsQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNqQyxNQUFNLGNBQWMsQ0FBQyxVQUFVLEVBQUUsQ0FBQztBQUNwQyxDQUFDLENBQUEsQ0FBQztBQUpXLFFBQUEsVUFBVSxjQUlyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5vZGVTREsgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbm9kZSc7XG5pbXBvcnQgeyBPVExQVHJhY2VFeHBvcnRlciB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L2V4cG9ydGVyLXRyYWNlLW90bHAtaHR0cCc7XG5pbXBvcnQgeyBPVExQTWV0cmljRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1tZXRyaWNzLW90bHAtaHR0cCc7XG5pbXBvcnQgeyBPVExQTG9nRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1sb2dzLW90bHAtaHR0cCc7XG5pbXBvcnQgeyBQZXJpb2RpY0V4cG9ydGluZ01ldHJpY1JlYWRlciB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Nkay1tZXRyaWNzJztcbmltcG9ydCAqIGFzIGxvZ3MgZnJvbSAnQG9wZW50ZWxlbWV0cnkvc2RrLWxvZ3MnO1xuaW1wb3J0ICogYXMgcmVzb3VyY2VzIGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Jlc291cmNlcyc7XG5pbXBvcnQgeyBBVFRSX1NFUlZJQ0VfTkFNRSB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L3NlbWFudGljLWNvbnZlbnRpb25zJztcbmltcG9ydCB7IEF0dHJpYnV0ZXMsIHRyYWNlIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvYXBpJztcbmltcG9ydCB7IFN0YW5kYXJkTG9nZ2VyLCBTdGFuZGFyZFRyYWNlciB9IGZyb20gJy4uL2NvcmUnO1xuXG5jb25zdCB1c2VyID0gcHJvY2Vzcy5lbnYuT1RFTF9FWFBPUlRFUl9PVExQX1VTRVI7XG5jb25zdCBwYXNzd29yZCA9IHByb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9QQVNTO1xuXG5jb25zdCBiYXNpY0F1dGggPSBCdWZmZXIuZnJvbShgJHt1c2VyfToke3Bhc3N3b3JkfWApLnRvU3RyaW5nKCdiYXNlNjQnKTtcblxuY29uc3QgYmFzZVVybCA9IGAke3Byb2Nlc3MuZW52Lk9URUxfRVhQT1JURVJfT1RMUF9FTkRQT0lOVH0vdjFgO1xuXG5jb25zdCB0cmFjZUV4cG9ydGVyID0gbmV3IE9UTFBUcmFjZUV4cG9ydGVyKHtcbiAgdXJsOiBgJHtiYXNlVXJsfS90cmFjZXNgLFxuICBoZWFkZXJzOiB7XG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgfSxcbn0pO1xuXG5jb25zdCBtZXRyaWNFeHBvcnRlciA9IG5ldyBPVExQTWV0cmljRXhwb3J0ZXIoe1xuICB1cmw6IGAke2Jhc2VVcmx9L21ldHJpY3NgLFxuICBoZWFkZXJzOiB7XG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgfSxcbn0pO1xuXG5jb25zdCBsb2dFeHBvcnRlciA9IG5ldyBPVExQTG9nRXhwb3J0ZXIoe1xuICB1cmw6IGAke2Jhc2VVcmx9L2xvZ3NgLFxuICBoZWFkZXJzOiB7XG4gICAgQXV0aG9yaXphdGlvbjogYEJhc2ljICR7YmFzaWNBdXRofWAsXG4gICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgfSxcbn0pO1xuXG5jb25zdCBtZXRyaWNSZWFkZXIgPSBuZXcgUGVyaW9kaWNFeHBvcnRpbmdNZXRyaWNSZWFkZXIoe1xuICBleHBvcnRlcjogbWV0cmljRXhwb3J0ZXIsXG4gIGV4cG9ydEludGVydmFsTWlsbGlzOiAxMDAwLFxufSk7XG5cbi8vIENvbmZpZ3VyYXIgTG9nZ2VyUHJvdmlkZXJcbmNvbnN0IHNlcnZpY2VOYW1lID0gcHJvY2Vzcy5lbnYuU0VSVklDRV9OQU1FIHx8ICdzc3Qtc2VydmljZSc7XG5jb25zdCByZXNvdXJjZSA9IG5ldyByZXNvdXJjZXMuUmVzb3VyY2Uoe1xuICBbQVRUUl9TRVJWSUNFX05BTUVdOiBzZXJ2aWNlTmFtZSxcbn0pO1xuXG5jb25zdCBsb2dnZXJQcm92aWRlciA9IG5ldyBsb2dzLkxvZ2dlclByb3ZpZGVyKHsgcmVzb3VyY2UgfSk7XG5jb25zdCBsb2dSZWNvcmRQcm9jZXNzb3IgPSBuZXcgbG9ncy5CYXRjaExvZ1JlY29yZFByb2Nlc3Nvcihsb2dFeHBvcnRlcik7XG5sb2dnZXJQcm92aWRlci5hZGRMb2dSZWNvcmRQcm9jZXNzb3IobG9nUmVjb3JkUHJvY2Vzc29yKTtcblxuY29uc3Qgc2RrID0gbmV3IE5vZGVTREsoe1xuICB0cmFjZUV4cG9ydGVyLFxuICBtZXRyaWNSZWFkZXI6IG1ldHJpY1JlYWRlciBhcyBhbnksIC8vIFR5cGUgY29tcGF0aWJpbGl0eSB3b3JrYXJvdW5kXG59KTtcblxuc2RrLnN0YXJ0KCk7XG5cbi8vIENyaWFyIFN0YW5kYXJkTG9nZ2VyIHBhcmEgc2VyIHVzYWRvIG5vcyBtaWRkbGV3YXJlc1xubGV0IHN0YW5kYXJkTG9nZ2VyOiBTdGFuZGFyZExvZ2dlciB8IG51bGwgPSBudWxsO1xubGV0IHN0YW5kYXJkVHJhY2VyOiBTdGFuZGFyZFRyYWNlciB8IG51bGwgPSBudWxsO1xuXG5leHBvcnQgY29uc3QgZ2V0U3RhbmRhcmRMb2dnZXIgPSAoXG4gIHNjb3BlQXR0cmlidXRlcz86IEF0dHJpYnV0ZXNcbik6IFN0YW5kYXJkTG9nZ2VyID0+IHtcbiAgaWYgKCFzdGFuZGFyZExvZ2dlcikge1xuICAgIGNvbnN0IHRyYWNlciA9IGdldFN0YW5kYXJkVHJhY2VyKCk7XG4gICAgY29uc3QgbG9nZ2VyID0gbG9nZ2VyUHJvdmlkZXIuZ2V0TG9nZ2VyKCdzc3QtbWlkZGxld2FyZS1sb2dnZXInLCAnMS4wLjAnLCB7XG4gICAgICBpbmNsdWRlVHJhY2VDb250ZXh0OiB0cnVlLFxuICAgICAgc2NvcGVBdHRyaWJ1dGVzLFxuICAgIH0pO1xuICAgIHN0YW5kYXJkTG9nZ2VyID0gbmV3IFN0YW5kYXJkTG9nZ2VyKGxvZ2dlciwgdHJhY2VyLCBzY29wZUF0dHJpYnV0ZXMpO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IGhhc1Njb3BlID1cbiAgICAgIHN0YW5kYXJkTG9nZ2VyLmRlZmF1bHRBdHRyaWJ1dGVzPy5mdW5jdGlvbj8ubmFtZSAhPT0gJ3Vua25vd24nO1xuXG4gICAgaWYgKCFoYXNTY29wZSAmJiBzY29wZUF0dHJpYnV0ZXMpIHtcbiAgICAgIHN0YW5kYXJkTG9nZ2VyLmRlZmluZURlZmF1bHRBdHRyaWJ1dGVzKHNjb3BlQXR0cmlidXRlcyk7XG4gICAgfVxuICB9XG4gIHJldHVybiBzdGFuZGFyZExvZ2dlcjtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRTdGFuZGFyZFRyYWNlciA9ICgpOiBTdGFuZGFyZFRyYWNlciA9PiB7XG4gIGlmICghc3RhbmRhcmRUcmFjZXIpIHtcbiAgICBjb25zdCB0cmFjZXIgPSB0cmFjZS5nZXRUcmFjZXIoc2VydmljZU5hbWUsICcxLjAuMCcpO1xuICAgIHN0YW5kYXJkVHJhY2VyID0gbmV3IFN0YW5kYXJkVHJhY2VyKHRyYWNlciwgc2VydmljZU5hbWUpO1xuICB9XG4gIHJldHVybiBzdGFuZGFyZFRyYWNlcjtcbn07XG5cbmV4cG9ydCBjb25zdCBmb3JjZUZsdXNoID0gYXN5bmMgKCkgPT4ge1xuICBhd2FpdCBtZXRyaWNSZWFkZXIuZm9yY2VGbHVzaCgpO1xuICBhd2FpdCB0cmFjZUV4cG9ydGVyLmZvcmNlRmx1c2goKTtcbiAgYXdhaXQgbG9nZ2VyUHJvdmlkZXIuZm9yY2VGbHVzaCgpO1xufTtcbiJdfQ==
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"telemetry.js","sourceRoot":"","sources":["../../src/sst/telemetry.ts"],"names":[],"mappings":"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","sourcesContent":["import { NodeSDK } from '@opentelemetry/sdk-node';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';\nimport { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';\nimport { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';\nimport { PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics';\nimport * as logs from '@opentelemetry/sdk-logs';\nimport * as resources from '@opentelemetry/resources';\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions';\nimport { Attributes, trace } from '@opentelemetry/api';\nimport { StandardLogger, StandardTracer } from '../core';\n\nconst user = process.env.OTEL_EXPORTER_OTLP_USER;\nconst password = process.env.OTEL_EXPORTER_OTLP_PASS;\n\nconst basicAuth = Buffer.from(`${user}:${password}`).toString('base64');\n\nconst baseUrl = `${process.env.OTEL_EXPORTER_OTLP_ENDPOINT}/v1`;\n\nconst traceExporter = new OTLPTraceExporter({\n  url: `${baseUrl}/traces`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n});\n\nconst metricExporter = new OTLPMetricExporter({\n  url: `${baseUrl}/metrics`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n});\n\nconst logExporter = new OTLPLogExporter({\n  url: `${baseUrl}/logs`,\n  headers: {\n    Authorization: `Basic ${basicAuth}`,\n    'Content-Type': 'application/json',\n  },\n});\n\nconst metricReader = new PeriodicExportingMetricReader({\n  exporter: metricExporter,\n  exportIntervalMillis: 1000,\n});\n\n// Configurar LoggerProvider\nconst serviceName = process.env.SERVICE_NAME || 'sst-service';\nconst resource = new resources.Resource({\n  [ATTR_SERVICE_NAME]: serviceName,\n});\n\nconst loggerProvider = new logs.LoggerProvider({ resource });\nconst logRecordProcessor = new logs.BatchLogRecordProcessor(logExporter);\nloggerProvider.addLogRecordProcessor(logRecordProcessor);\n\nconst sdk = new NodeSDK({\n  traceExporter,\n  metricReader: metricReader as any, // Type compatibility workaround\n});\n\nsdk.start();\n\n// Criar StandardLogger para ser usado nos middlewares\nlet standardLogger: StandardLogger | null = null;\nlet standardTracer: StandardTracer | null = null;\n\nexport const getStandardLogger = ({\n  scopeAttributes,\n  forceNewInstance = false,\n  disableEmitter = false,\n}: {\n  scopeAttributes?: Attributes;\n  forceNewInstance?: boolean;\n  disableEmitter?: boolean;\n}): StandardLogger => {\n  if (!standardLogger || forceNewInstance) {\n    const tracer = getStandardTracer();\n    const logger = loggerProvider.getLogger('sst-middleware-logger', '1.0.0', {\n      includeTraceContext: true,\n      scopeAttributes,\n    });\n    standardLogger = new StandardLogger(logger, tracer, scopeAttributes);\n  } else {\n    const hasScope =\n      standardLogger.defaultAttributes?.function?.name !== 'unknown';\n\n    if (!hasScope && scopeAttributes) {\n      standardLogger.defineDefaultAttributes(scopeAttributes);\n    }\n  }\n  return standardLogger;\n};\n\nexport const getStandardTracer = (): StandardTracer => {\n  if (!standardTracer) {\n    const tracer = trace.getTracer(serviceName, '1.0.0');\n    standardTracer = new StandardTracer(tracer, serviceName);\n  }\n  return standardTracer;\n};\n\nexport const forceFlush = async () => {\n  await metricReader.forceFlush();\n  await traceExporter.forceFlush();\n  await loggerProvider.forceFlush();\n};\n"]}
@@ -28,7 +28,7 @@ function TsedLogTelemetry() {
28
28
  controllerName = this.constructor.name;
29
29
  }
30
30
  if (!$ctx) {
31
- console.warn('[TsedLogTelemetry] Context not found, executing without telemetry');
31
+ console.warn('[Telemetry][TsedLogTelemetry] Context not found, executing without telemetry');
32
32
  return yield originalMethod.apply(this, args);
33
33
  }
34
34
  let telemetryService;
@@ -192,4 +192,4 @@ function TsedLogTelemetry() {
192
192
  return descriptor;
193
193
  };
194
194
  }
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log-telemetry.js","sourceRoot":"","sources":["../../src/tsed/log-telemetry.ts"],"names":[],"mappings":";;;;;;;;;;;AAiBA,4CAuPC;AA5PD,uCAAiD;AACjD,4CAAwD;AACxD,2CAAyC;AACzC,kCAA8C;AAE9C,SAAgB,gBAAgB;IAC9B,OAAO,UACL,OAAY,EACZ,YAAoB,EACpB,UAA8B;QAE9B,MAAM,cAAc,GAAG,UAAU,CAAC,KAAK,CAAC;QACxC,MAAM,UAAU,GAAG,YAAY,CAAC;QAEhC,UAAU,CAAC,KAAK,GAAG,UAA2B,GAAG,IAAW;;;gBAC1D,MAAM,SAAS,GAAG,wBAAW,CAAC,GAAG,EAAE,CAAC;gBAGpC,MAAM,IAAI,GAAsB,IAAI,CAAC,IAAI,CACvC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,OAAO,MAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,QAAQ,CAAA,CACvC,CAAC;gBAGF,IAAI,cAAc,GAAG,mBAAmB,CAAC;gBACzC,IAAI,CAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,WAAW,0CAAE,IAAI,KAAI,IAAI,CAAC,WAAW,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAClE,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACzC,CAAC;gBAED,IAAI,CAAC,IAAI,EAAE,CAAC;oBACV,OAAO,CAAC,IAAI,CACV,mEAAmE,CACpE,CAAC;oBACF,OAAO,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBAChD,CAAC;gBAGD,IAAI,gBAAkD,CAAC;gBACvD,IAAI,CAAC;oBACH,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;wBAClB,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAClC,8BAAoB,CACG,CAAC;oBAC5B,CAAC;gBACH,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAA,IAAI,CAAC,MAAM,0CAAE,IAAI,CAAC;wBAChB,iEAAiE,EAC/D,KAAK;qBACR,CAAC,CAAC;gBACL,CAAC;gBAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACtB,MAAA,IAAI,CAAC,MAAM,0CAAE,IAAI,CACf,gFAAgF,CACjF,CAAC;oBACF,OAAO,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;gBAChD,CAAC;gBAGD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;gBAC7B,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,cAAc,CAAC;gBAC/D,MAAM,KAAK,GAAG,IAAA,0BAAmB,GAAE,CAAC;gBAEpC,MAAM,qBAAqB,GAAG,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;gBAClD,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,IAAI,KAAK,CAAC;gBAGrD,MAAM,MAAM,GAAI,gBAAwB,CAAC,SAAS,EAAE,CAAC;gBACrD,IAAI,UAAU,GAAQ,IAAI,CAAC;gBAE3B,IAAI,MAAM,EAAE,CAAC;oBACX,UAAU,GAAG,MAAM,CAAC,SAAS,CAAC;wBAC5B,QAAQ,EAAE,GAAG,cAAc,IAAI,UAAU,EAAE;wBAC3C,WAAW;wBACX,WAAW,EAAE,KAAK;wBAClB,SAAS,EAAE;4BACT,UAAU,EAAE,cAAc;4BAC1B,gBAAgB,EAAE,UAAU;4BAC5B,SAAS,EAAE,IAAI,CAAC,EAAE;4BAClB,YAAY,EAAE,MAAA,IAAI,CAAC,OAAO,0CAAE,YAAY;4BACxC,MAAM;yBACP;wBACD,IAAI,EAAE;4BACJ,MAAM,EAAE,OAAO,CAAC,MAAM;4BACtB,GAAG,EAAE,OAAO,CAAC,GAAG;4BAChB,QAAQ,EAAE,OAAO,CAAC,GAAG;yBACtB;qBACF,CAAC,CAAC;gBACL,CAAC;gBAGD,MAAM,KAAK,GAAG,aAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;gBACvC,MAAM,sBAAsB,GAAG,KAAK,CAAC,eAAe,CAClD,yBAAyB,EACzB;oBACE,WAAW,EAAE,8CAA8C;oBAC3D,IAAI,EAAE,IAAI;oBACV,SAAS,EAAE,eAAS,CAAC,MAAM;iBAC5B,CACF,CAAC;gBACF,MAAM,cAAc,GAAG,KAAK,CAAC,aAAa,CAAC,0BAA0B,EAAE;oBACrE,WAAW,EAAE,oCAAoC;iBAClD,CAAC,CAAC;gBACH,MAAM,cAAc,GAAG,KAAK,CAAC,aAAa,CAAC,sBAAsB,EAAE;oBACjE,WAAW,EAAE,gCAAgC;iBAC9C,CAAC,CAAC;gBAEH,IAAI,CAAC;oBACH,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;oBAGtD,MAAM,UAAU,GAAG,wBAAW,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;oBAGjD,IAAI,UAAU,EAAE,CAAC;wBACf,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;oBAC9B,CAAC;oBAGD,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE;wBACpB,MAAM;wBACN,UAAU,EAAE,cAAc;wBAC1B,MAAM,EAAE,UAAU;wBAClB,WAAW,EAAE,WAAW;wBACxB,eAAe,EAAE,KAAK;qBACvB,CAAC,CAAC;oBAEH,sBAAsB,CAAC,MAAM,CAAC,UAAU,EAAE;wBACxC,MAAM;wBACN,MAAM,EAAE,SAAS;wBACjB,UAAU,EAAE,cAAc;wBAC1B,MAAM,EAAE,UAAU;wBAClB,WAAW,EAAE,WAAW;wBACxB,eAAe,EAAE,KAAK;qBACvB,CAAC,CAAC;oBAGH,MAAM,MAAM,GAAI,gBAAwB,CAAC,SAAS,EAAE,CAAC;oBACrD,IAAI,MAAM,EAAE,CAAC;wBACX,MAAM,MAAM,CAAC,OAAO,CAAC;4BACnB,OAAO,EAAE,gCAAgC;4BACzC,WAAW;4BACX,WAAW,EAAE,KAAK;4BAClB,SAAS,EAAE;gCACT,UAAU,EAAE,cAAc;gCAC1B,gBAAgB,EAAE,UAAU;gCAC5B,SAAS,EAAE,IAAI,CAAC,EAAE;gCAClB,YAAY,EAAE,MAAA,IAAI,CAAC,OAAO,0CAAE,YAAY;gCACxC,MAAM;6BACP;4BACD,IAAI,EAAE;gCACJ,MAAM,EAAE,OAAO,CAAC,MAAM;gCACtB,GAAG,EAAE,OAAO,CAAC,GAAG;gCAChB,QAAQ,EAAE,OAAO,CAAC,GAAG;gCACrB,UAAU,EAAE,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,UAAU,KAAI,GAAG;6BAC7C;4BACD,WAAW,EAAE;gCACX,UAAU;gCACV,OAAO,EAAE,IAAI;6BACd;yBACF,CAAC,CAAC;oBACL,CAAC;oBAGD,IAAI,UAAU,EAAE,CAAC;wBACf,UAAU,CAAC,GAAG,EAAE,CAAC;oBACnB,CAAC;oBACD,MAAO,gBAAwB,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;oBAE/D,OAAO,MAAM,CAAC;gBAChB,CAAC;gBAAC,OAAO,KAAU,EAAE,CAAC;oBAEpB,MAAM,UAAU,GAAG,wBAAW,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC;oBAEjD,MAAA,IAAI,CAAC,MAAM,0CAAE,IAAI,CAAC,oCAAoC,CAAC,CAAC;oBAGxD,IAAI,UAAU,EAAE,CAAC;wBACf,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBAC7B,CAAC;oBAGD,cAAc,CAAC,GAAG,CAAC,CAAC,EAAE;wBACpB,MAAM;wBACN,UAAU,EAAE,CAAA,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW,0CAAE,IAAI,KAAI,cAAc;wBACtD,UAAU,EAAE,cAAc;wBAC1B,MAAM,EAAE,UAAU;wBAClB,WAAW,EAAE,WAAW;wBACxB,eAAe,EAAE,KAAK;qBACvB,CAAC,CAAC;oBAEH,sBAAsB,CAAC,MAAM,CAAC,UAAU,EAAE;wBACxC,MAAM;wBACN,MAAM,EAAE,OAAO;wBACf,UAAU,EAAE,cAAc;wBAC1B,MAAM,EAAE,UAAU;wBAClB,WAAW,EAAE,WAAW;wBACxB,eAAe,EAAE,KAAK;qBACvB,CAAC,CAAC;oBAGH,IAAI,QAAQ,GAAQ,EAAE,CAAC;oBACvB,IAAI,CAAC;wBAEH,IAAI,OAAO,oBAAoB,KAAK,WAAW,EAAE,CAAC;4BAEhD,MAAM,EAAE,UAAU,EAAE,GAAG,oBAAoB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;4BACtD,QAAQ,GAAG;gCACT,cAAc,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,GAAG;gCAC/B,UAAU,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,OAAO,0CAAE,GAAG;gCACpC,cAAc,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,WAAW,0CAAE,GAAG;6BAC7C,CAAC;wBACJ,CAAC;oBACH,CAAC;oBAAC,OAAO,CAAC,EAAE,CAAC;oBAEb,CAAC;oBAGD,MAAM,gBAAgB,CAAC,QAAQ,+BAC7B,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE;4BACP,UAAU,EAAE,KAAK,CAAC,MAAM,IAAI,GAAG;4BAC/B,GAAG,EAAE,OAAO,CAAC,GAAG;4BAChB,OAAO,EAAE,OAAO,CAAC,OAAO;4BACxB,IAAI,EAAE,OAAO,CAAC,IAAI;4BAClB,MAAM,EAAE,OAAO,CAAC,MAAM;4BACtB,KAAK,EAAE,OAAO,CAAC,KAAK;4BACpB,SAAS,EAAE,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,WAAW,0CAAE,IAAI;yBACpC,IACE,QAAQ,KACX,SAAS,EAAE,IAAI,CAAC,EAAE,EAClB,YAAY,EAAE,MAAA,IAAI,CAAC,OAAO,0CAAE,YAAY,EACxC,QAAQ,EAAE,OAAO,CAAC,GAAG,EACrB,MAAM,EAAE,OAAO,CAAC,MAAM,EACtB,UAAU,EAAE,cAAc,EAC1B,gBAAgB,EAAE,UAAU,IAC5B,CAAC;oBAGH,IAAI,UAAU,EAAE,CAAC;wBACf,UAAU,CAAC,GAAG,EAAE,CAAC;oBACnB,CAAC;oBACD,MAAO,gBAAwB,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC;oBAE/D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;oBAG5C,MAAM,KAAK,CAAC;gBACd,CAAC;YACH,CAAC;SAAA,CAAC;QAEF,OAAO,UAAU,CAAC;IACpB,CAAC,CAAC;AACJ,CAAC","sourcesContent":["/**\n * Decorator que captura erros automaticamente, cria spans e envia para telemetria\n * Alinhado com a implementação do SST middleware para garantir consistência\n *\n * Uso no controller:\n *\n * @TsedLogTelemetry()\n * async getCheckout(@Context() $ctx: ServerlessContext, ...) {\n *   return await this.service.execute(params);\n * }\n */\nimport { ServerlessContext } from '@tsed/platform-serverless';\nimport { TsedTelemetryService } from './service';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'perf_hooks';\nimport { getEnvironmentStage } from '../core';\n\nexport function TsedLogTelemetry() {\n  return function (\n    _target: any,\n    _propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const originalMethod = descriptor.value;\n    const methodName = _propertyKey;\n\n    descriptor.value = async function (this: any, ...args: any[]) {\n      const startTime = performance.now();\n\n      // Encontrar o contexto\n      const $ctx: ServerlessContext = args.find(\n        (arg) => arg?.request && arg?.response\n      );\n\n      // Capturar o nome do controller\n      let controllerName = 'UnknownController';\n      if (this?.constructor?.name && this.constructor.name !== 'Object') {\n        controllerName = this.constructor.name;\n      }\n\n      if (!$ctx) {\n        console.warn(\n          '[TsedLogTelemetry] Context not found, executing without telemetry'\n        );\n        return await originalMethod.apply(this, args);\n      }\n\n      // Buscar o TelemetryService do injector\n      let telemetryService: TsedTelemetryService | undefined;\n      try {\n        if ($ctx.injector) {\n          telemetryService = $ctx.injector.get(\n            TsedTelemetryService\n          ) as TsedTelemetryService;\n        }\n      } catch (error) {\n        $ctx.logger?.warn({\n          'TsedLogTelemetry - Failed to get TelemetryService from injector':\n            error,\n        });\n      }\n\n      if (!telemetryService) {\n        $ctx.logger?.warn(\n          '[TsedLogTelemetry] TelemetryService not available, executing without telemetry'\n        );\n        return await originalMethod.apply(this, args);\n      }\n\n      // Extrair informações básicas\n      const request = $ctx.request;\n      const serviceName = process.env.SERVICE_NAME || 'tsed-service';\n      const stage = getEnvironmentStage();\n\n      const queryStringParameters = request.query || {};\n      const origin = queryStringParameters.origin || 'web';\n\n      // Criar span usando StandardTracer (similar ao SST middleware)\n      const tracer = (telemetryService as any).getTracer();\n      let spanResult: any = null;\n\n      if (tracer) {\n        spanResult = tracer.startSpan({\n          spanName: `${controllerName}.${methodName}`,\n          serviceName,\n          environment: stage,\n          execution: {\n            controller: controllerName,\n            controllerMethod: methodName,\n            requestId: $ctx.id,\n            awsRequestId: $ctx.context?.awsRequestId,\n            origin,\n          },\n          http: {\n            method: request.method,\n            url: request.url,\n            endpoint: request.url,\n          },\n        });\n      }\n\n      // Criar métricas (similar ao SST middleware)\n      const meter = metrics.getMeter(origin);\n      const executionTimeHistogram = meter.createHistogram(\n        'tsed_execution_duration',\n        {\n          description: 'Tempo total de execução do método Tsed em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('tsed_successful_requests', {\n        description: 'Total de requisições bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('tsed_failed_requests', {\n        description: 'Total de requisições com falha',\n      });\n\n      try {\n        const result = await originalMethod.apply(this, args);\n\n        // SUCESSO - Similar ao 'after' do SST middleware\n        const durationMs = performance.now() - startTime;\n\n        // Marcar span como sucesso\n        if (spanResult) {\n          spanResult.setSuccess(true);\n        }\n\n        // Métricas de sucesso\n        successCounter.add(1, {\n          origin,\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        executionTimeHistogram.record(durationMs, {\n          origin,\n          status: 'success',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        // Log de sucesso (similar ao SST)\n        const logger = (telemetryService as any).getLogger();\n        if (logger) {\n          await logger.logInfo({\n            message: 'Request completed successfully',\n            serviceName,\n            environment: stage,\n            execution: {\n              controller: controllerName,\n              controllerMethod: methodName,\n              requestId: $ctx.id,\n              awsRequestId: $ctx.context?.awsRequestId,\n              origin,\n            },\n            http: {\n              method: request.method,\n              url: request.url,\n              endpoint: request.url,\n              statusCode: $ctx.response?.statusCode || 200,\n            },\n            performance: {\n              durationMs,\n              success: true,\n            },\n          });\n        }\n\n        // Finalizar span e force flush\n        if (spanResult) {\n          spanResult.end();\n        }\n        await (telemetryService as any).telemetryProvider.forceFlush();\n\n        return result;\n      } catch (error: any) {\n        // ERRO - Similar ao 'onError' do SST middleware\n        const durationMs = performance.now() - startTime;\n\n        $ctx.logger?.info('Error caught, sending to telemetry');\n\n        // Marcar span como erro\n        if (spanResult) {\n          spanResult.setError(error);\n        }\n\n        // Métricas de erro\n        failureCounter.add(1, {\n          origin,\n          error_type: error?.constructor?.name || 'UnknownError',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        executionTimeHistogram.record(durationMs, {\n          origin,\n          status: 'error',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        // Extrair informações do usuário\n        let userInfo: any = {};\n        try {\n          // @ts-ignore - LoggedUserIdentifier é específico da aplicação\n          if (typeof LoggedUserIdentifier !== 'undefined') {\n            // @ts-ignore\n            const { loggedUser } = LoggedUserIdentifier.use($ctx);\n            userInfo = {\n              accountUserUid: loggedUser?.uid,\n              accountUid: loggedUser?.account?.uid,\n              applicationUid: loggedUser?.application?.uid,\n            };\n          }\n        } catch (e) {\n          // LoggedUserIdentifier não está disponível\n        }\n\n        // Log de erro (similar ao SST)\n        await telemetryService.logError({\n          error: error,\n          context: {\n            statusCode: error.status || 500,\n            url: request.url,\n            headers: request.headers,\n            body: request.body,\n            params: request.params,\n            query: request.query,\n            errorType: error?.constructor?.name,\n          },\n          ...userInfo,\n          requestId: $ctx.id,\n          awsRequestId: $ctx.context?.awsRequestId,\n          endpoint: request.url,\n          method: request.method,\n          controller: controllerName,\n          controllerMethod: methodName,\n        });\n\n        // Finalizar span e force flush\n        if (spanResult) {\n          spanResult.end();\n        }\n        await (telemetryService as any).telemetryProvider.forceFlush();\n\n        $ctx.logger.info('Error sent to telemetry');\n\n        // Re-throw para manter o comportamento normal de erro\n        throw error;\n      }\n    };\n\n    return descriptor;\n  };\n}\n"]}
195
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log-telemetry.js","sourceRoot":"","sources":["../../src/tsed/log-telemetry.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Decorator que captura erros automaticamente, cria spans e envia para telemetria\n * Alinhado com a implementação do SST middleware para garantir consistência\n *\n * Uso no controller:\n *\n * @TsedLogTelemetry()\n * async getCheckout(@Context() $ctx: ServerlessContext, ...) {\n *   return await this.service.execute(params);\n * }\n */\nimport { ServerlessContext } from '@tsed/platform-serverless';\nimport { TsedTelemetryService } from './service';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'perf_hooks';\nimport { getEnvironmentStage } from '../core';\n\nexport function TsedLogTelemetry() {\n  return function (\n    _target: any,\n    _propertyKey: string,\n    descriptor: PropertyDescriptor\n  ) {\n    const originalMethod = descriptor.value;\n    const methodName = _propertyKey;\n\n    descriptor.value = async function (this: any, ...args: any[]) {\n      const startTime = performance.now();\n\n      // Encontrar o contexto\n      const $ctx: ServerlessContext = args.find(\n        (arg) => arg?.request && arg?.response\n      );\n\n      // Capturar o nome do controller\n      let controllerName = 'UnknownController';\n      if (this?.constructor?.name && this.constructor.name !== 'Object') {\n        controllerName = this.constructor.name;\n      }\n\n      if (!$ctx) {\n        console.warn(\n          '[Telemetry][TsedLogTelemetry] Context not found, executing without telemetry'\n        );\n        return await originalMethod.apply(this, args);\n      }\n\n      // Buscar o TelemetryService do injector\n      let telemetryService: TsedTelemetryService | undefined;\n      try {\n        if ($ctx.injector) {\n          telemetryService = $ctx.injector.get(\n            TsedTelemetryService\n          ) as TsedTelemetryService;\n        }\n      } catch (error) {\n        $ctx.logger?.warn({\n          'TsedLogTelemetry - Failed to get TelemetryService from injector':\n            error,\n        });\n      }\n\n      if (!telemetryService) {\n        $ctx.logger?.warn(\n          '[TsedLogTelemetry] TelemetryService not available, executing without telemetry'\n        );\n        return await originalMethod.apply(this, args);\n      }\n\n      // Extrair informações básicas\n      const request = $ctx.request;\n      const serviceName = process.env.SERVICE_NAME || 'tsed-service';\n      const stage = getEnvironmentStage();\n\n      const queryStringParameters = request.query || {};\n      const origin = queryStringParameters.origin || 'web';\n\n      // Criar span usando StandardTracer (similar ao SST middleware)\n      const tracer = (telemetryService as any).getTracer();\n      let spanResult: any = null;\n\n      if (tracer) {\n        spanResult = tracer.startSpan({\n          spanName: `${controllerName}.${methodName}`,\n          serviceName,\n          environment: stage,\n          execution: {\n            controller: controllerName,\n            controllerMethod: methodName,\n            requestId: $ctx.id,\n            awsRequestId: $ctx.context?.awsRequestId,\n            origin,\n          },\n          http: {\n            method: request.method,\n            url: request.url,\n            endpoint: request.url,\n          },\n        });\n      }\n\n      // Criar métricas (similar ao SST middleware)\n      const meter = metrics.getMeter(origin);\n      const executionTimeHistogram = meter.createHistogram(\n        'tsed_execution_duration',\n        {\n          description: 'Tempo total de execução do método Tsed em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('tsed_successful_requests', {\n        description: 'Total de requisições bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('tsed_failed_requests', {\n        description: 'Total de requisições com falha',\n      });\n\n      try {\n        const result = await originalMethod.apply(this, args);\n\n        // SUCESSO - Similar ao 'after' do SST middleware\n        const durationMs = performance.now() - startTime;\n\n        // Marcar span como sucesso\n        if (spanResult) {\n          spanResult.setSuccess(true);\n        }\n\n        // Métricas de sucesso\n        successCounter.add(1, {\n          origin,\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        executionTimeHistogram.record(durationMs, {\n          origin,\n          status: 'success',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        // Log de sucesso (similar ao SST)\n        const logger = (telemetryService as any).getLogger();\n        if (logger) {\n          await logger.logInfo({\n            message: 'Request completed successfully',\n            serviceName,\n            environment: stage,\n            execution: {\n              controller: controllerName,\n              controllerMethod: methodName,\n              requestId: $ctx.id,\n              awsRequestId: $ctx.context?.awsRequestId,\n              origin,\n            },\n            http: {\n              method: request.method,\n              url: request.url,\n              endpoint: request.url,\n              statusCode: $ctx.response?.statusCode || 200,\n            },\n            performance: {\n              durationMs,\n              success: true,\n            },\n          });\n        }\n\n        // Finalizar span e force flush\n        if (spanResult) {\n          spanResult.end();\n        }\n        await (telemetryService as any).telemetryProvider.forceFlush();\n\n        return result;\n      } catch (error: any) {\n        // ERRO - Similar ao 'onError' do SST middleware\n        const durationMs = performance.now() - startTime;\n\n        $ctx.logger?.info('Error caught, sending to telemetry');\n\n        // Marcar span como erro\n        if (spanResult) {\n          spanResult.setError(error);\n        }\n\n        // Métricas de erro\n        failureCounter.add(1, {\n          origin,\n          error_type: error?.constructor?.name || 'UnknownError',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        executionTimeHistogram.record(durationMs, {\n          origin,\n          status: 'error',\n          controller: controllerName,\n          method: methodName,\n          serviceName: serviceName,\n          environmentName: stage,\n        });\n\n        // Extrair informações do usuário\n        let userInfo: any = {};\n        try {\n          // @ts-ignore - LoggedUserIdentifier é específico da aplicação\n          if (typeof LoggedUserIdentifier !== 'undefined') {\n            // @ts-ignore\n            const { loggedUser } = LoggedUserIdentifier.use($ctx);\n            userInfo = {\n              accountUserUid: loggedUser?.uid,\n              accountUid: loggedUser?.account?.uid,\n              applicationUid: loggedUser?.application?.uid,\n            };\n          }\n        } catch (e) {\n          // LoggedUserIdentifier não está disponível\n        }\n\n        // Log de erro (similar ao SST)\n        await telemetryService.logError({\n          error: error,\n          context: {\n            statusCode: error.status || 500,\n            url: request.url,\n            headers: request.headers,\n            body: request.body,\n            params: request.params,\n            query: request.query,\n            errorType: error?.constructor?.name,\n          },\n          ...userInfo,\n          requestId: $ctx.id,\n          awsRequestId: $ctx.context?.awsRequestId,\n          endpoint: request.url,\n          method: request.method,\n          controller: controllerName,\n          controllerMethod: methodName,\n        });\n\n        // Finalizar span e force flush\n        if (spanResult) {\n          spanResult.end();\n        }\n        await (telemetryService as any).telemetryProvider.forceFlush();\n\n        $ctx.logger.info('Error sent to telemetry');\n\n        // Re-throw para manter o comportamento normal de erro\n        throw error;\n      }\n    };\n\n    return descriptor;\n  };\n}\n"]}
@@ -22,7 +22,7 @@ class TsedSyncLogRecordProcessor {
22
22
  resolve();
23
23
  }
24
24
  else {
25
- console.error('[SyncLogRecordProcessor] Export failed:', result.error);
25
+ console.error('[Telemetry][SyncLogRecordProcessor] Export failed:', result.error);
26
26
  reject(result.error instanceof Error
27
27
  ? result.error
28
28
  : new Error(String(result.error)));
@@ -36,7 +36,7 @@ class TsedSyncLogRecordProcessor {
36
36
  }
37
37
  })
38
38
  .catch((error) => {
39
- console.error('[SyncLogRecordProcessor] Export error:', error);
39
+ console.error('[Telemetry][SyncLogRecordProcessor] Export error:', error);
40
40
  const index = this.pendingExports.indexOf(exportPromise);
41
41
  if (index > -1) {
42
42
  this.pendingExports.splice(index, 1);
@@ -46,29 +46,29 @@ class TsedSyncLogRecordProcessor {
46
46
  }
47
47
  forceFlush() {
48
48
  return __awaiter(this, void 0, void 0, function* () {
49
- console.log(`[SyncLogRecordProcessor] forceFlush called with ${this.pendingExports.length} pending exports`);
49
+ console.log(`[Telemetry][SyncLogRecordProcessor] forceFlush called with ${this.pendingExports.length} pending exports`);
50
50
  if (this.pendingExports.length === 0) {
51
- console.log('[SyncLogRecordProcessor] No pending exports to flush');
51
+ console.log('[Telemetry][SyncLogRecordProcessor] No pending exports to flush');
52
52
  return;
53
53
  }
54
54
  try {
55
55
  yield Promise.all(this.pendingExports);
56
- console.log('[SyncLogRecordProcessor] All pending exports completed');
56
+ console.log('[Telemetry][SyncLogRecordProcessor] All pending exports completed');
57
57
  }
58
58
  catch (error) {
59
- console.error('[SyncLogRecordProcessor] Error during forceFlush:', error);
59
+ console.error('[Telemetry][SyncLogRecordProcessor] Error during forceFlush:', error);
60
60
  throw error;
61
61
  }
62
62
  });
63
63
  }
64
64
  shutdown() {
65
65
  return __awaiter(this, void 0, void 0, function* () {
66
- console.log('[SyncLogRecordProcessor] Shutting down...');
66
+ console.log('[Telemetry][SyncLogRecordProcessor] Shutting down...');
67
67
  yield this.forceFlush();
68
68
  yield this.exporter.shutdown();
69
- console.log('[SyncLogRecordProcessor] Shutdown complete');
69
+ console.log('[Telemetry][SyncLogRecordProcessor] Shutdown complete');
70
70
  });
71
71
  }
72
72
  }
73
73
  exports.TsedSyncLogRecordProcessor = TsedSyncLogRecordProcessor;
74
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3luYy1sb2ctcmVjb3JkLXByb2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90c2VkL3N5bmMtbG9nLXJlY29yZC1wcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBWUEsTUFBYSwwQkFBMEI7SUFJckMsWUFBWSxRQUF5QjtRQUZwQixtQkFBYyxHQUFvQixFQUFFLENBQUM7UUFHcEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDM0IsQ0FBQztJQUVELE1BQU0sQ0FBQyxTQUE0QixFQUFFLFFBQWtCO1FBSXJELE1BQU0sYUFBYSxHQUFHLElBQUksT0FBTyxDQUFPLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQzFELElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRTtnQkFDM0MsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUN0QixPQUFPLEVBQUUsQ0FBQztnQkFDWixDQUFDO3FCQUFNLENBQUM7b0JBQ04sT0FBTyxDQUFDLEtBQUssQ0FDWCx5Q0FBeUMsRUFDekMsTUFBTSxDQUFDLEtBQUssQ0FDYixDQUFDO29CQUNGLE1BQU0sQ0FDSixNQUFNLENBQUMsS0FBSyxZQUFZLEtBQUs7d0JBQzNCLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSzt3QkFDZCxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUNwQyxDQUFDO2dCQUNKLENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQzthQUNDLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDVCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUN6RCxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNmLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQyxDQUFDO2FBQ0QsS0FBSyxDQUFDLENBQUMsS0FBYyxFQUFFLEVBQUU7WUFDeEIsT0FBTyxDQUFDLEtBQUssQ0FBQyx3Q0FBd0MsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUMvRCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUN6RCxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNmLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFTCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUssVUFBVTs7WUFDZCxPQUFPLENBQUMsR0FBRyxDQUNULG1EQUFtRCxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sa0JBQWtCLENBQ2hHLENBQUM7WUFFRixJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUNyQyxPQUFPLENBQUMsR0FBRyxDQUFDLHNEQUFzRCxDQUFDLENBQUM7Z0JBQ3BFLE9BQU87WUFDVCxDQUFDO1lBRUQsSUFBSSxDQUFDO2dCQUVILE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7Z0JBQ3ZDLE9BQU8sQ0FBQyxHQUFHLENBQUMsd0RBQXdELENBQUMsQ0FBQztZQUN4RSxDQUFDO1lBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztnQkFDZixPQUFPLENBQUMsS0FBSyxDQUFDLG1EQUFtRCxFQUFFLEtBQUssQ0FBQyxDQUFDO2dCQUMxRSxNQUFNLEtBQUssQ0FBQztZQUNkLENBQUM7UUFDSCxDQUFDO0tBQUE7SUFFSyxRQUFROztZQUNaLE9BQU8sQ0FBQyxHQUFHLENBQUMsMkNBQTJDLENBQUMsQ0FBQztZQUN6RCxNQUFNLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUN4QixNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDL0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyw0Q0FBNEMsQ0FBQyxDQUFDO1FBQzVELENBQUM7S0FBQTtDQUNGO0FBeEVELGdFQXdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ1JlY29yZFByb2Nlc3NvciwgUmVhZGFibGVMb2dSZWNvcmQgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbG9ncyc7XG5pbXBvcnQgeyBPVExQTG9nRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1sb2dzLW90bHAtaHR0cCc7XG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvYXBpJztcblxuLyoqXG4gKiBDdXN0b20gTG9nUmVjb3JkUHJvY2Vzc29yIHRoYXQgZW5zdXJlcyBzeW5jaHJvbm91cyBleHBvcnQgZm9yIEFXUyBMYW1iZGFcbiAqXG4gKiBUaGlzIHByb2Nlc3NvciB3cmFwcyB0aGUgT1RMUCBleHBvcnRlciBhbmQgZW5zdXJlcyB0aGF0IGxvZ3MgYXJlIGFjdHVhbGx5XG4gKiBleHBvcnRlZCBzeW5jaHJvbm91c2x5IGJ5IGltbWVkaWF0ZWx5IGNhbGxpbmcgZXhwb3J0KCkgYW5kIHdhaXRpbmcgZm9yIGl0XG4gKiB0byBjb21wbGV0ZSwgcmF0aGVyIHRoYW4gcmVseWluZyBvbiBTaW1wbGVMb2dSZWNvcmRQcm9jZXNzb3Igd2hpY2ggbWF5IG5vdFxuICogcHJvcGVybHkgYXdhaXQgdGhlIGFzeW5jIEhUVFAgcmVxdWVzdCBpbiBMYW1iZGEgZW52aXJvbm1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgVHNlZFN5bmNMb2dSZWNvcmRQcm9jZXNzb3IgaW1wbGVtZW50cyBMb2dSZWNvcmRQcm9jZXNzb3Ige1xuICBwcml2YXRlIHJlYWRvbmx5IGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXI7XG4gIHByaXZhdGUgcmVhZG9ubHkgcGVuZGluZ0V4cG9ydHM6IFByb21pc2U8dm9pZD5bXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXIpIHtcbiAgICB0aGlzLmV4cG9ydGVyID0gZXhwb3J0ZXI7XG4gIH1cblxuICBvbkVtaXQobG9nUmVjb3JkOiBSZWFkYWJsZUxvZ1JlY29yZCwgX2NvbnRleHQ/OiBDb250ZXh0KTogdm9pZCB7XG4gICAgLy8gRXhwb3J0IGltbWVkaWF0ZWx5IGFuZCB0cmFjayB0aGUgcHJvbWlzZVxuICAgIC8vIFRoZSBleHBvcnQgbWV0aG9kIHJldHVybnMgdm9pZCwgYnV0IGludGVybmFsbHkgdHJpZ2dlcnMgYXN5bmMgSFRUUCByZXF1ZXN0XG4gICAgLy8gV2UgbmVlZCB0byB3cmFwIGl0IHRvIHRyYWNrIGNvbXBsZXRpb25cbiAgICBjb25zdCBleHBvcnRQcm9taXNlID0gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5leHBvcnRlci5leHBvcnQoW2xvZ1JlY29yZF0sIChyZXN1bHQpID0+IHtcbiAgICAgICAgaWYgKHJlc3VsdC5jb2RlID09PSAwKSB7XG4gICAgICAgICAgcmVzb2x2ZSgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAnW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEV4cG9ydCBmYWlsZWQ6JyxcbiAgICAgICAgICAgIHJlc3VsdC5lcnJvclxuICAgICAgICAgICk7XG4gICAgICAgICAgcmVqZWN0KFxuICAgICAgICAgICAgcmVzdWx0LmVycm9yIGluc3RhbmNlb2YgRXJyb3JcbiAgICAgICAgICAgICAgPyByZXN1bHQuZXJyb3JcbiAgICAgICAgICAgICAgOiBuZXcgRXJyb3IoU3RyaW5nKHJlc3VsdC5lcnJvcikpXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSlcbiAgICAgIC50aGVuKCgpID0+IHtcbiAgICAgICAgY29uc3QgaW5kZXggPSB0aGlzLnBlbmRpbmdFeHBvcnRzLmluZGV4T2YoZXhwb3J0UHJvbWlzZSk7XG4gICAgICAgIGlmIChpbmRleCA+IC0xKSB7XG4gICAgICAgICAgdGhpcy5wZW5kaW5nRXhwb3J0cy5zcGxpY2UoaW5kZXgsIDEpO1xuICAgICAgICB9XG4gICAgICB9KVxuICAgICAgLmNhdGNoKChlcnJvcjogdW5rbm93bikgPT4ge1xuICAgICAgICBjb25zb2xlLmVycm9yKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gRXhwb3J0IGVycm9yOicsIGVycm9yKTtcbiAgICAgICAgY29uc3QgaW5kZXggPSB0aGlzLnBlbmRpbmdFeHBvcnRzLmluZGV4T2YoZXhwb3J0UHJvbWlzZSk7XG4gICAgICAgIGlmIChpbmRleCA+IC0xKSB7XG4gICAgICAgICAgdGhpcy5wZW5kaW5nRXhwb3J0cy5zcGxpY2UoaW5kZXgsIDEpO1xuICAgICAgICB9XG4gICAgICB9KTtcblxuICAgIHRoaXMucGVuZGluZ0V4cG9ydHMucHVzaChleHBvcnRQcm9taXNlKTtcbiAgfVxuXG4gIGFzeW5jIGZvcmNlRmx1c2goKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc29sZS5sb2coXG4gICAgICBgW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIGZvcmNlRmx1c2ggY2FsbGVkIHdpdGggJHt0aGlzLnBlbmRpbmdFeHBvcnRzLmxlbmd0aH0gcGVuZGluZyBleHBvcnRzYFxuICAgICk7XG5cbiAgICBpZiAodGhpcy5wZW5kaW5nRXhwb3J0cy5sZW5ndGggPT09IDApIHtcbiAgICAgIGNvbnNvbGUubG9nKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gTm8gcGVuZGluZyBleHBvcnRzIHRvIGZsdXNoJyk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdHJ5IHtcbiAgICAgIC8vIFdhaXQgZm9yIGFsbCBwZW5kaW5nIGV4cG9ydHMgdG8gY29tcGxldGVcbiAgICAgIGF3YWl0IFByb21pc2UuYWxsKHRoaXMucGVuZGluZ0V4cG9ydHMpO1xuICAgICAgY29uc29sZS5sb2coJ1tTeW5jTG9nUmVjb3JkUHJvY2Vzc29yXSBBbGwgcGVuZGluZyBleHBvcnRzIGNvbXBsZXRlZCcpO1xuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLmVycm9yKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gRXJyb3IgZHVyaW5nIGZvcmNlRmx1c2g6JywgZXJyb3IpO1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgc2h1dGRvd24oKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc29sZS5sb2coJ1tTeW5jTG9nUmVjb3JkUHJvY2Vzc29yXSBTaHV0dGluZyBkb3duLi4uJyk7XG4gICAgYXdhaXQgdGhpcy5mb3JjZUZsdXNoKCk7XG4gICAgYXdhaXQgdGhpcy5leHBvcnRlci5zaHV0ZG93bigpO1xuICAgIGNvbnNvbGUubG9nKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gU2h1dGRvd24gY29tcGxldGUnKTtcbiAgfVxufVxuIl19
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3luYy1sb2ctcmVjb3JkLXByb2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90c2VkL3N5bmMtbG9nLXJlY29yZC1wcm9jZXNzb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0FBWUEsTUFBYSwwQkFBMEI7SUFJckMsWUFBWSxRQUF5QjtRQUZwQixtQkFBYyxHQUFvQixFQUFFLENBQUM7UUFHcEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDM0IsQ0FBQztJQUVELE1BQU0sQ0FBQyxTQUE0QixFQUFFLFFBQWtCO1FBSXJELE1BQU0sYUFBYSxHQUFHLElBQUksT0FBTyxDQUFPLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQzFELElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEVBQUUsRUFBRTtnQkFDM0MsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUN0QixPQUFPLEVBQUUsQ0FBQztnQkFDWixDQUFDO3FCQUFNLENBQUM7b0JBQ04sT0FBTyxDQUFDLEtBQUssQ0FDWCxvREFBb0QsRUFDcEQsTUFBTSxDQUFDLEtBQUssQ0FDYixDQUFDO29CQUNGLE1BQU0sQ0FDSixNQUFNLENBQUMsS0FBSyxZQUFZLEtBQUs7d0JBQzNCLENBQUMsQ0FBQyxNQUFNLENBQUMsS0FBSzt3QkFDZCxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUNwQyxDQUFDO2dCQUNKLENBQUM7WUFDSCxDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQzthQUNDLElBQUksQ0FBQyxHQUFHLEVBQUU7WUFDVCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUN6RCxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNmLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQyxDQUFDO2FBQ0QsS0FBSyxDQUFDLENBQUMsS0FBYyxFQUFFLEVBQUU7WUFDeEIsT0FBTyxDQUFDLEtBQUssQ0FDWCxtREFBbUQsRUFDbkQsS0FBSyxDQUNOLENBQUM7WUFDRixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUN6RCxJQUFJLEtBQUssR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDO2dCQUNmLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2QyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFTCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUssVUFBVTs7WUFDZCxPQUFPLENBQUMsR0FBRyxDQUNULDhEQUE4RCxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sa0JBQWtCLENBQzNHLENBQUM7WUFFRixJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUNyQyxPQUFPLENBQUMsR0FBRyxDQUNULGlFQUFpRSxDQUNsRSxDQUFDO2dCQUNGLE9BQU87WUFDVCxDQUFDO1lBRUQsSUFBSSxDQUFDO2dCQUVILE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7Z0JBQ3ZDLE9BQU8sQ0FBQyxHQUFHLENBQ1QsbUVBQW1FLENBQ3BFLENBQUM7WUFDSixDQUFDO1lBQUMsT0FBTyxLQUFLLEVBQUUsQ0FBQztnQkFDZixPQUFPLENBQUMsS0FBSyxDQUNYLDhEQUE4RCxFQUM5RCxLQUFLLENBQ04sQ0FBQztnQkFDRixNQUFNLEtBQUssQ0FBQztZQUNkLENBQUM7UUFDSCxDQUFDO0tBQUE7SUFFSyxRQUFROztZQUNaLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0RBQXNELENBQUMsQ0FBQztZQUNwRSxNQUFNLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUN4QixNQUFNLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDL0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1FBQ3ZFLENBQUM7S0FBQTtDQUNGO0FBbEZELGdFQWtGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ1JlY29yZFByb2Nlc3NvciwgUmVhZGFibGVMb2dSZWNvcmQgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9zZGstbG9ncyc7XG5pbXBvcnQgeyBPVExQTG9nRXhwb3J0ZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9leHBvcnRlci1sb2dzLW90bHAtaHR0cCc7XG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvYXBpJztcblxuLyoqXG4gKiBDdXN0b20gTG9nUmVjb3JkUHJvY2Vzc29yIHRoYXQgZW5zdXJlcyBzeW5jaHJvbm91cyBleHBvcnQgZm9yIEFXUyBMYW1iZGFcbiAqXG4gKiBUaGlzIHByb2Nlc3NvciB3cmFwcyB0aGUgT1RMUCBleHBvcnRlciBhbmQgZW5zdXJlcyB0aGF0IGxvZ3MgYXJlIGFjdHVhbGx5XG4gKiBleHBvcnRlZCBzeW5jaHJvbm91c2x5IGJ5IGltbWVkaWF0ZWx5IGNhbGxpbmcgZXhwb3J0KCkgYW5kIHdhaXRpbmcgZm9yIGl0XG4gKiB0byBjb21wbGV0ZSwgcmF0aGVyIHRoYW4gcmVseWluZyBvbiBTaW1wbGVMb2dSZWNvcmRQcm9jZXNzb3Igd2hpY2ggbWF5IG5vdFxuICogcHJvcGVybHkgYXdhaXQgdGhlIGFzeW5jIEhUVFAgcmVxdWVzdCBpbiBMYW1iZGEgZW52aXJvbm1lbnRzLlxuICovXG5leHBvcnQgY2xhc3MgVHNlZFN5bmNMb2dSZWNvcmRQcm9jZXNzb3IgaW1wbGVtZW50cyBMb2dSZWNvcmRQcm9jZXNzb3Ige1xuICBwcml2YXRlIHJlYWRvbmx5IGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXI7XG4gIHByaXZhdGUgcmVhZG9ubHkgcGVuZGluZ0V4cG9ydHM6IFByb21pc2U8dm9pZD5bXSA9IFtdO1xuXG4gIGNvbnN0cnVjdG9yKGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXIpIHtcbiAgICB0aGlzLmV4cG9ydGVyID0gZXhwb3J0ZXI7XG4gIH1cblxuICBvbkVtaXQobG9nUmVjb3JkOiBSZWFkYWJsZUxvZ1JlY29yZCwgX2NvbnRleHQ/OiBDb250ZXh0KTogdm9pZCB7XG4gICAgLy8gRXhwb3J0IGltbWVkaWF0ZWx5IGFuZCB0cmFjayB0aGUgcHJvbWlzZVxuICAgIC8vIFRoZSBleHBvcnQgbWV0aG9kIHJldHVybnMgdm9pZCwgYnV0IGludGVybmFsbHkgdHJpZ2dlcnMgYXN5bmMgSFRUUCByZXF1ZXN0XG4gICAgLy8gV2UgbmVlZCB0byB3cmFwIGl0IHRvIHRyYWNrIGNvbXBsZXRpb25cbiAgICBjb25zdCBleHBvcnRQcm9taXNlID0gbmV3IFByb21pc2U8dm9pZD4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgdGhpcy5leHBvcnRlci5leHBvcnQoW2xvZ1JlY29yZF0sIChyZXN1bHQpID0+IHtcbiAgICAgICAgaWYgKHJlc3VsdC5jb2RlID09PSAwKSB7XG4gICAgICAgICAgcmVzb2x2ZSgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgICAnW1RlbGVtZXRyeV1bU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gRXhwb3J0IGZhaWxlZDonLFxuICAgICAgICAgICAgcmVzdWx0LmVycm9yXG4gICAgICAgICAgKTtcbiAgICAgICAgICByZWplY3QoXG4gICAgICAgICAgICByZXN1bHQuZXJyb3IgaW5zdGFuY2VvZiBFcnJvclxuICAgICAgICAgICAgICA/IHJlc3VsdC5lcnJvclxuICAgICAgICAgICAgICA6IG5ldyBFcnJvcihTdHJpbmcocmVzdWx0LmVycm9yKSlcbiAgICAgICAgICApO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KVxuICAgICAgLnRoZW4oKCkgPT4ge1xuICAgICAgICBjb25zdCBpbmRleCA9IHRoaXMucGVuZGluZ0V4cG9ydHMuaW5kZXhPZihleHBvcnRQcm9taXNlKTtcbiAgICAgICAgaWYgKGluZGV4ID4gLTEpIHtcbiAgICAgICAgICB0aGlzLnBlbmRpbmdFeHBvcnRzLnNwbGljZShpbmRleCwgMSk7XG4gICAgICAgIH1cbiAgICAgIH0pXG4gICAgICAuY2F0Y2goKGVycm9yOiB1bmtub3duKSA9PiB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoXG4gICAgICAgICAgJ1tUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEV4cG9ydCBlcnJvcjonLFxuICAgICAgICAgIGVycm9yXG4gICAgICAgICk7XG4gICAgICAgIGNvbnN0IGluZGV4ID0gdGhpcy5wZW5kaW5nRXhwb3J0cy5pbmRleE9mKGV4cG9ydFByb21pc2UpO1xuICAgICAgICBpZiAoaW5kZXggPiAtMSkge1xuICAgICAgICAgIHRoaXMucGVuZGluZ0V4cG9ydHMuc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG5cbiAgICB0aGlzLnBlbmRpbmdFeHBvcnRzLnB1c2goZXhwb3J0UHJvbWlzZSk7XG4gIH1cblxuICBhc3luYyBmb3JjZUZsdXNoKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnNvbGUubG9nKFxuICAgICAgYFtUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIGZvcmNlRmx1c2ggY2FsbGVkIHdpdGggJHt0aGlzLnBlbmRpbmdFeHBvcnRzLmxlbmd0aH0gcGVuZGluZyBleHBvcnRzYFxuICAgICk7XG5cbiAgICBpZiAodGhpcy5wZW5kaW5nRXhwb3J0cy5sZW5ndGggPT09IDApIHtcbiAgICAgIGNvbnNvbGUubG9nKFxuICAgICAgICAnW1RlbGVtZXRyeV1bU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gTm8gcGVuZGluZyBleHBvcnRzIHRvIGZsdXNoJ1xuICAgICAgKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0cnkge1xuICAgICAgLy8gV2FpdCBmb3IgYWxsIHBlbmRpbmcgZXhwb3J0cyB0byBjb21wbGV0ZVxuICAgICAgYXdhaXQgUHJvbWlzZS5hbGwodGhpcy5wZW5kaW5nRXhwb3J0cyk7XG4gICAgICBjb25zb2xlLmxvZyhcbiAgICAgICAgJ1tUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEFsbCBwZW5kaW5nIGV4cG9ydHMgY29tcGxldGVkJ1xuICAgICAgKTtcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgJ1tUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEVycm9yIGR1cmluZyBmb3JjZUZsdXNoOicsXG4gICAgICAgIGVycm9yXG4gICAgICApO1xuICAgICAgdGhyb3cgZXJyb3I7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgc2h1dGRvd24oKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgY29uc29sZS5sb2coJ1tUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIFNodXR0aW5nIGRvd24uLi4nKTtcbiAgICBhd2FpdCB0aGlzLmZvcmNlRmx1c2goKTtcbiAgICBhd2FpdCB0aGlzLmV4cG9ydGVyLnNodXRkb3duKCk7XG4gICAgY29uc29sZS5sb2coJ1tUZWxlbWV0cnldW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIFNodXRkb3duIGNvbXBsZXRlJyk7XG4gIH1cbn1cbiJdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mecanizou/telemetry-hub",
3
- "version": "1.3.11",
3
+ "version": "1.3.13",
4
4
  "description": "Mecanizou telemetry lib",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",