@mecanizou/telemetry-hub 1.3.1 → 1.3.3

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.
@@ -95,20 +95,19 @@ const api_1 = require("@opentelemetry/api");
95
95
  (0, vitest_1.expect)(attributes['http.host']).toBe('api.example.com');
96
96
  });
97
97
  (0, vitest_1.it)('deve incluir atributos de usuário', () => {
98
+ const user = {
99
+ uid: 'user-123',
100
+ email: 'user@example.com',
101
+ };
98
102
  standardTracer.startSpan({
99
103
  spanName: 'user-operation',
100
104
  serviceName: 'user-service',
101
105
  environment: 'production',
102
- user: {
103
- accountUserUid: 'user-123',
104
- accountUid: 'account-456',
105
- applicationUid: 'app-789',
106
- },
106
+ user,
107
107
  });
108
108
  const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;
109
- (0, vitest_1.expect)(attributes['accountUser.uid']).toBe('user-123');
110
- (0, vitest_1.expect)(attributes['account.uid']).toBe('account-456');
111
- (0, vitest_1.expect)(attributes['application.uid']).toBe('app-789');
109
+ (0, vitest_1.expect)(attributes['user.uid']).toBe(user.uid);
110
+ (0, vitest_1.expect)(attributes['user.email']).toBe(user.email);
112
111
  });
113
112
  (0, vitest_1.it)('deve incluir atributos de performance', () => {
114
113
  standardTracer.startSpan({
@@ -310,9 +309,6 @@ const api_1 = require("@opentelemetry/api");
310
309
  spanName: 'error-operation',
311
310
  serviceName: 'error-service',
312
311
  environment: 'production',
313
- user: {
314
- accountUserUid: 'user-123',
315
- },
316
312
  });
317
313
  const error = new Error('Operation failed');
318
314
  spanResult.setError(error);
@@ -327,4 +323,4 @@ const api_1 = require("@opentelemetry/api");
327
323
  });
328
324
  });
329
325
  });
330
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracer.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/tracer.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, vi, beforeEach } from 'vitest';\nimport { StandardTracer } from '../tracer';\nimport { SpanStatusCode, SpanKind } from '@opentelemetry/api';\n\ndescribe('StandardTracer', () => {\n  let mockTracer: any;\n  let mockSpan: any;\n  let standardTracer: StandardTracer;\n\n  beforeEach(() => {\n    mockSpan = {\n      end: vi.fn(),\n      setAttribute: vi.fn(),\n      setStatus: vi.fn(),\n      recordException: vi.fn(),\n    };\n\n    mockTracer = {\n      startSpan: vi.fn().mockReturnValue(mockSpan),\n    };\n\n    standardTracer = new StandardTracer(mockTracer, 'test-service');\n  });\n\n  describe('startSpan', () => {\n    it('deve criar span com nome e atributos básicos', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'test-operation',\n        serviceName: 'my-service',\n        environment: 'production',\n      });\n\n      expect(mockTracer.startSpan).toHaveBeenCalledWith('test-operation', {\n        kind: SpanKind.SERVER,\n        attributes: {\n          'service.name': 'my-service',\n          'deployment.environment.name': 'production',\n        },\n      });\n\n      expect(spanResult.span).toBe(mockSpan);\n      expect(spanResult.end).toBeDefined();\n      expect(spanResult.setSuccess).toBeDefined();\n      expect(spanResult.setError).toBeDefined();\n      expect(spanResult.setAttribute).toBeDefined();\n    });\n\n    it('deve usar defaultServiceName quando serviceName não fornecido', () => {\n      standardTracer.startSpan({\n        spanName: 'test-operation',\n        serviceName: '',\n        environment: 'test',\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['service.name']).toBe('test-service');\n    });\n\n    it('deve incluir atributos de execução', () => {\n      standardTracer.startSpan({\n        spanName: 'process-request',\n        serviceName: 'api-service',\n        environment: 'production',\n        execution: {\n          functionName: 'processPayment',\n          invocationId: 'inv-123',\n          awsRequestId: 'aws-456',\n          requestId: 'req-789',\n          controller: 'PaymentController',\n          controllerMethod: 'process',\n          origin: 'mobile',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['function.name']).toBe('processPayment');\n      expect(attributes['function.invocation_id']).toBe('inv-123');\n      expect(attributes['aws.request.id']).toBe('aws-456');\n      expect(attributes['request.id']).toBe('req-789');\n      expect(attributes['controller.name']).toBe('PaymentController');\n      expect(attributes['controller.method']).toBe('process');\n      expect(attributes['origin']).toBe('mobile');\n    });\n\n    it('deve incluir atributos HTTP', () => {\n      standardTracer.startSpan({\n        spanName: 'http-request',\n        serviceName: 'web-service',\n        environment: 'production',\n        http: {\n          method: 'POST',\n          url: 'https://api.example.com/orders',\n          endpoint: '/orders',\n          statusCode: 201,\n          scheme: 'https',\n          host: 'api.example.com',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['http.method']).toBe('POST');\n      expect(attributes['http.url']).toBe('https://api.example.com/orders');\n      expect(attributes['http.target']).toBe('/orders');\n      expect(attributes['http.status_code']).toBe(201);\n      expect(attributes['http.scheme']).toBe('https');\n      expect(attributes['http.host']).toBe('api.example.com');\n    });\n\n    it('deve incluir atributos de usuário', () => {\n      standardTracer.startSpan({\n        spanName: 'user-operation',\n        serviceName: 'user-service',\n        environment: 'production',\n        user: {\n          accountUserUid: 'user-123',\n          accountUid: 'account-456',\n          applicationUid: 'app-789',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['accountUser.uid']).toBe('user-123');\n      expect(attributes['account.uid']).toBe('account-456');\n      expect(attributes['application.uid']).toBe('app-789');\n    });\n\n    it('deve incluir atributos de performance', () => {\n      standardTracer.startSpan({\n        spanName: 'performance-test',\n        serviceName: 'perf-service',\n        environment: 'test',\n        performance: {\n          durationMs: 250,\n          success: true,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['duration.ms']).toBe(250);\n      expect(attributes['execution.success']).toBe(true);\n    });\n\n    it('deve incluir atributos de erro', () => {\n      standardTracer.startSpan({\n        spanName: 'error-operation',\n        serviceName: 'error-service',\n        environment: 'production',\n        error: {\n          type: 'ValidationError',\n          message: 'Invalid input',\n          stack: 'Error stack trace',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['error.type']).toBe('ValidationError');\n      expect(attributes['error.message']).toBe('Invalid input');\n      expect(attributes['error.stack']).toBe('Error stack trace');\n    });\n\n    it('deve incluir atributos customizados', () => {\n      standardTracer.startSpan({\n        spanName: 'custom-operation',\n        serviceName: 'custom-service',\n        environment: 'production',\n        attributes: {\n          'custom.field': 'value',\n          'custom.count': 42,\n          'custom.enabled': true,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['custom.field']).toBe('value');\n      expect(attributes['custom.count']).toBe(42);\n      expect(attributes['custom.enabled']).toBe(true);\n    });\n\n    it('deve filtrar valores undefined e null', () => {\n      standardTracer.startSpan({\n        spanName: 'filter-test',\n        serviceName: 'filter-service',\n        environment: 'production',\n        execution: {\n          functionName: 'test',\n          invocationId: undefined,\n          awsRequestId: null as any,\n        },\n        attributes: {\n          valid: 'value',\n          invalid: undefined as any,\n          nullValue: null as any,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['function.name']).toBe('test');\n      expect(attributes['function.invocation_id']).toBeUndefined();\n      expect(attributes['aws.request.id']).toBeUndefined();\n      expect(attributes['valid']).toBe('value');\n      expect(attributes['invalid']).toBeUndefined();\n      expect(attributes['nullValue']).toBeUndefined();\n    });\n  });\n\n  describe('StandardSpanResult', () => {\n    let spanResult: any;\n\n    beforeEach(() => {\n      spanResult = standardTracer.startSpan({\n        spanName: 'test-span',\n        serviceName: 'test-service',\n        environment: 'test',\n      });\n    });\n\n    describe('end', () => {\n      it('deve finalizar o span', () => {\n        spanResult.end();\n\n        expect(mockSpan.end).toHaveBeenCalledTimes(1);\n      });\n    });\n\n    describe('setSuccess', () => {\n      it('deve marcar span como sucesso', () => {\n        spanResult.setSuccess(true);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          true\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.OK,\n        });\n      });\n\n      it('deve marcar span como falha', () => {\n        spanResult.setSuccess(false);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          false\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.ERROR,\n        });\n      });\n    });\n\n    describe('setError', () => {\n      it('deve registrar erro no span', () => {\n        const error = new Error('Test error');\n\n        spanResult.setError(error);\n\n        expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.type',\n          'Error'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.message',\n          'Test error'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          false\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.ERROR,\n          message: 'Test error',\n        });\n      });\n\n      it('deve incluir stack trace quando disponível', () => {\n        const error = new Error('Error with stack');\n        error.stack = 'Error: Error with stack\\n  at test.ts:1:1';\n\n        spanResult.setError(error);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.stack',\n          error.stack\n        );\n      });\n\n      it('deve funcionar com erro customizado', () => {\n        class CustomError extends Error {\n          constructor(message: string) {\n            super(message);\n            this.name = 'CustomError';\n          }\n        }\n\n        const error = new CustomError('Custom error message');\n\n        spanResult.setError(error);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.type',\n          'CustomError'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.message',\n          'Custom error message'\n        );\n      });\n    });\n\n    describe('setAttribute', () => {\n      it('deve adicionar atributo string', () => {\n        spanResult.setAttribute('custom.key', 'custom value');\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'custom.key',\n          'custom value'\n        );\n      });\n\n      it('deve adicionar atributo numérico', () => {\n        spanResult.setAttribute('custom.count', 123);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith('custom.count', 123);\n      });\n\n      it('deve adicionar atributo booleano', () => {\n        spanResult.setAttribute('custom.enabled', true);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'custom.enabled',\n          true\n        );\n      });\n    });\n  });\n\n  describe('recordException', () => {\n    it('deve registrar exceção com todos os atributos', () => {\n      const error = new Error('Exception test');\n      error.stack = 'Error stack trace here';\n\n      standardTracer.recordException(mockSpan, error);\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith('error.type', 'Error');\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.message',\n        'Exception test'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.stack',\n        'Error stack trace here'\n      );\n    });\n\n    it('deve funcionar sem stack trace', () => {\n      const error = new Error('No stack');\n      delete error.stack;\n\n      standardTracer.recordException(mockSpan, error);\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith('error.type', 'Error');\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.message',\n        'No stack'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledTimes(2); // Apenas type e message\n    });\n  });\n\n  describe('cenários de uso completos', () => {\n    it('deve gerenciar fluxo de sucesso completo', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'complete-operation',\n        serviceName: 'complete-service',\n        environment: 'production',\n        execution: {\n          functionName: 'processData',\n          requestId: 'req-123',\n        },\n        http: {\n          method: 'POST',\n          endpoint: '/api/data',\n        },\n      });\n\n      spanResult.setAttribute('custom.step', 'processing');\n      spanResult.setSuccess(true);\n      spanResult.end();\n\n      expect(mockTracer.startSpan).toHaveBeenCalled();\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'custom.step',\n        'processing'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'execution.success',\n        true\n      );\n      expect(mockSpan.setStatus).toHaveBeenCalledWith({\n        code: SpanStatusCode.OK,\n      });\n      expect(mockSpan.end).toHaveBeenCalled();\n    });\n\n    it('deve gerenciar fluxo de erro completo', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'error-operation',\n        serviceName: 'error-service',\n        environment: 'production',\n        user: {\n          accountUserUid: 'user-123',\n        },\n      });\n\n      const error = new Error('Operation failed');\n\n      spanResult.setError(error);\n      spanResult.end();\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'execution.success',\n        false\n      );\n      expect(mockSpan.setStatus).toHaveBeenCalledWith({\n        code: SpanStatusCode.ERROR,\n        message: 'Operation failed',\n      });\n      expect(mockSpan.end).toHaveBeenCalled();\n    });\n  });\n});\n"]}
326
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracer.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/tracer.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect, vi, beforeEach } from 'vitest';\nimport { StandardTracer } from '../tracer';\nimport { SpanStatusCode, SpanKind } from '@opentelemetry/api';\n\ndescribe('StandardTracer', () => {\n  let mockTracer: any;\n  let mockSpan: any;\n  let standardTracer: StandardTracer;\n\n  beforeEach(() => {\n    mockSpan = {\n      end: vi.fn(),\n      setAttribute: vi.fn(),\n      setStatus: vi.fn(),\n      recordException: vi.fn(),\n    };\n\n    mockTracer = {\n      startSpan: vi.fn().mockReturnValue(mockSpan),\n    };\n\n    standardTracer = new StandardTracer(mockTracer, 'test-service');\n  });\n\n  describe('startSpan', () => {\n    it('deve criar span com nome e atributos básicos', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'test-operation',\n        serviceName: 'my-service',\n        environment: 'production',\n      });\n\n      expect(mockTracer.startSpan).toHaveBeenCalledWith('test-operation', {\n        kind: SpanKind.SERVER,\n        attributes: {\n          'service.name': 'my-service',\n          'deployment.environment.name': 'production',\n        },\n      });\n\n      expect(spanResult.span).toBe(mockSpan);\n      expect(spanResult.end).toBeDefined();\n      expect(spanResult.setSuccess).toBeDefined();\n      expect(spanResult.setError).toBeDefined();\n      expect(spanResult.setAttribute).toBeDefined();\n    });\n\n    it('deve usar defaultServiceName quando serviceName não fornecido', () => {\n      standardTracer.startSpan({\n        spanName: 'test-operation',\n        serviceName: '',\n        environment: 'test',\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['service.name']).toBe('test-service');\n    });\n\n    it('deve incluir atributos de execução', () => {\n      standardTracer.startSpan({\n        spanName: 'process-request',\n        serviceName: 'api-service',\n        environment: 'production',\n        execution: {\n          functionName: 'processPayment',\n          invocationId: 'inv-123',\n          awsRequestId: 'aws-456',\n          requestId: 'req-789',\n          controller: 'PaymentController',\n          controllerMethod: 'process',\n          origin: 'mobile',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['function.name']).toBe('processPayment');\n      expect(attributes['function.invocation_id']).toBe('inv-123');\n      expect(attributes['aws.request.id']).toBe('aws-456');\n      expect(attributes['request.id']).toBe('req-789');\n      expect(attributes['controller.name']).toBe('PaymentController');\n      expect(attributes['controller.method']).toBe('process');\n      expect(attributes['origin']).toBe('mobile');\n    });\n\n    it('deve incluir atributos HTTP', () => {\n      standardTracer.startSpan({\n        spanName: 'http-request',\n        serviceName: 'web-service',\n        environment: 'production',\n        http: {\n          method: 'POST',\n          url: 'https://api.example.com/orders',\n          endpoint: '/orders',\n          statusCode: 201,\n          scheme: 'https',\n          host: 'api.example.com',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['http.method']).toBe('POST');\n      expect(attributes['http.url']).toBe('https://api.example.com/orders');\n      expect(attributes['http.target']).toBe('/orders');\n      expect(attributes['http.status_code']).toBe(201);\n      expect(attributes['http.scheme']).toBe('https');\n      expect(attributes['http.host']).toBe('api.example.com');\n    });\n\n    it('deve incluir atributos de usuário', () => {\n      const user = {\n        uid: 'user-123',\n        email: 'user@example.com',\n      };\n      standardTracer.startSpan({\n        spanName: 'user-operation',\n        serviceName: 'user-service',\n        environment: 'production',\n        user,\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['user.uid']).toBe(user.uid);\n      expect(attributes['user.email']).toBe(user.email);\n    });\n\n    it('deve incluir atributos de performance', () => {\n      standardTracer.startSpan({\n        spanName: 'performance-test',\n        serviceName: 'perf-service',\n        environment: 'test',\n        performance: {\n          durationMs: 250,\n          success: true,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['duration.ms']).toBe(250);\n      expect(attributes['execution.success']).toBe(true);\n    });\n\n    it('deve incluir atributos de erro', () => {\n      standardTracer.startSpan({\n        spanName: 'error-operation',\n        serviceName: 'error-service',\n        environment: 'production',\n        error: {\n          type: 'ValidationError',\n          message: 'Invalid input',\n          stack: 'Error stack trace',\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['error.type']).toBe('ValidationError');\n      expect(attributes['error.message']).toBe('Invalid input');\n      expect(attributes['error.stack']).toBe('Error stack trace');\n    });\n\n    it('deve incluir atributos customizados', () => {\n      standardTracer.startSpan({\n        spanName: 'custom-operation',\n        serviceName: 'custom-service',\n        environment: 'production',\n        attributes: {\n          'custom.field': 'value',\n          'custom.count': 42,\n          'custom.enabled': true,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['custom.field']).toBe('value');\n      expect(attributes['custom.count']).toBe(42);\n      expect(attributes['custom.enabled']).toBe(true);\n    });\n\n    it('deve filtrar valores undefined e null', () => {\n      standardTracer.startSpan({\n        spanName: 'filter-test',\n        serviceName: 'filter-service',\n        environment: 'production',\n        execution: {\n          functionName: 'test',\n          invocationId: undefined,\n          awsRequestId: null as any,\n        },\n        attributes: {\n          valid: 'value',\n          invalid: undefined as any,\n          nullValue: null as any,\n        },\n      });\n\n      const attributes = mockTracer.startSpan.mock.calls[0][1].attributes;\n      expect(attributes['function.name']).toBe('test');\n      expect(attributes['function.invocation_id']).toBeUndefined();\n      expect(attributes['aws.request.id']).toBeUndefined();\n      expect(attributes['valid']).toBe('value');\n      expect(attributes['invalid']).toBeUndefined();\n      expect(attributes['nullValue']).toBeUndefined();\n    });\n  });\n\n  describe('StandardSpanResult', () => {\n    let spanResult: any;\n\n    beforeEach(() => {\n      spanResult = standardTracer.startSpan({\n        spanName: 'test-span',\n        serviceName: 'test-service',\n        environment: 'test',\n      });\n    });\n\n    describe('end', () => {\n      it('deve finalizar o span', () => {\n        spanResult.end();\n\n        expect(mockSpan.end).toHaveBeenCalledTimes(1);\n      });\n    });\n\n    describe('setSuccess', () => {\n      it('deve marcar span como sucesso', () => {\n        spanResult.setSuccess(true);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          true\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.OK,\n        });\n      });\n\n      it('deve marcar span como falha', () => {\n        spanResult.setSuccess(false);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          false\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.ERROR,\n        });\n      });\n    });\n\n    describe('setError', () => {\n      it('deve registrar erro no span', () => {\n        const error = new Error('Test error');\n\n        spanResult.setError(error);\n\n        expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.type',\n          'Error'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.message',\n          'Test error'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'execution.success',\n          false\n        );\n        expect(mockSpan.setStatus).toHaveBeenCalledWith({\n          code: SpanStatusCode.ERROR,\n          message: 'Test error',\n        });\n      });\n\n      it('deve incluir stack trace quando disponível', () => {\n        const error = new Error('Error with stack');\n        error.stack = 'Error: Error with stack\\n  at test.ts:1:1';\n\n        spanResult.setError(error);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.stack',\n          error.stack\n        );\n      });\n\n      it('deve funcionar com erro customizado', () => {\n        class CustomError extends Error {\n          constructor(message: string) {\n            super(message);\n            this.name = 'CustomError';\n          }\n        }\n\n        const error = new CustomError('Custom error message');\n\n        spanResult.setError(error);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.type',\n          'CustomError'\n        );\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'error.message',\n          'Custom error message'\n        );\n      });\n    });\n\n    describe('setAttribute', () => {\n      it('deve adicionar atributo string', () => {\n        spanResult.setAttribute('custom.key', 'custom value');\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'custom.key',\n          'custom value'\n        );\n      });\n\n      it('deve adicionar atributo numérico', () => {\n        spanResult.setAttribute('custom.count', 123);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith('custom.count', 123);\n      });\n\n      it('deve adicionar atributo booleano', () => {\n        spanResult.setAttribute('custom.enabled', true);\n\n        expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n          'custom.enabled',\n          true\n        );\n      });\n    });\n  });\n\n  describe('recordException', () => {\n    it('deve registrar exceção com todos os atributos', () => {\n      const error = new Error('Exception test');\n      error.stack = 'Error stack trace here';\n\n      standardTracer.recordException(mockSpan, error);\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith('error.type', 'Error');\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.message',\n        'Exception test'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.stack',\n        'Error stack trace here'\n      );\n    });\n\n    it('deve funcionar sem stack trace', () => {\n      const error = new Error('No stack');\n      delete error.stack;\n\n      standardTracer.recordException(mockSpan, error);\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith('error.type', 'Error');\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'error.message',\n        'No stack'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledTimes(2); // Apenas type e message\n    });\n  });\n\n  describe('cenários de uso completos', () => {\n    it('deve gerenciar fluxo de sucesso completo', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'complete-operation',\n        serviceName: 'complete-service',\n        environment: 'production',\n        execution: {\n          functionName: 'processData',\n          requestId: 'req-123',\n        },\n        http: {\n          method: 'POST',\n          endpoint: '/api/data',\n        },\n      });\n\n      spanResult.setAttribute('custom.step', 'processing');\n      spanResult.setSuccess(true);\n      spanResult.end();\n\n      expect(mockTracer.startSpan).toHaveBeenCalled();\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'custom.step',\n        'processing'\n      );\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'execution.success',\n        true\n      );\n      expect(mockSpan.setStatus).toHaveBeenCalledWith({\n        code: SpanStatusCode.OK,\n      });\n      expect(mockSpan.end).toHaveBeenCalled();\n    });\n\n    it('deve gerenciar fluxo de erro completo', () => {\n      const spanResult = standardTracer.startSpan({\n        spanName: 'error-operation',\n        serviceName: 'error-service',\n        environment: 'production',\n      });\n\n      const error = new Error('Operation failed');\n\n      spanResult.setError(error);\n      spanResult.end();\n\n      expect(mockSpan.recordException).toHaveBeenCalledWith(error);\n      expect(mockSpan.setAttribute).toHaveBeenCalledWith(\n        'execution.success',\n        false\n      );\n      expect(mockSpan.setStatus).toHaveBeenCalledWith({\n        code: SpanStatusCode.ERROR,\n        message: 'Operation failed',\n      });\n      expect(mockSpan.end).toHaveBeenCalled();\n    });\n  });\n});\n"]}
@@ -0,0 +1 @@
1
+ export declare function getEnvironmentStage(): string;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getEnvironmentStage = getEnvironmentStage;
4
+ function getEnvironmentStage() {
5
+ let stage = process.env.STAGE || 'development';
6
+ if (stage === 'prod')
7
+ stage = 'production';
8
+ return stage;
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW52aXJvbm1lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29yZS9lbnZpcm9ubWVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLGtEQUlDO0FBSkQsU0FBZ0IsbUJBQW1CO0lBQ2pDLElBQUksS0FBSyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxJQUFJLGFBQWEsQ0FBQztJQUMvQyxJQUFJLEtBQUssS0FBSyxNQUFNO1FBQUUsS0FBSyxHQUFHLFlBQVksQ0FBQztJQUMzQyxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gZ2V0RW52aXJvbm1lbnRTdGFnZSgpOiBzdHJpbmcge1xuICBsZXQgc3RhZ2UgPSBwcm9jZXNzLmVudi5TVEFHRSB8fCAnZGV2ZWxvcG1lbnQnO1xuICBpZiAoc3RhZ2UgPT09ICdwcm9kJykgc3RhZ2UgPSAncHJvZHVjdGlvbic7XG4gIHJldHVybiBzdGFnZTtcbn1cbiJdfQ==
@@ -2,3 +2,4 @@ export { StandardLogger } from './logger';
2
2
  export { IStandardLogger, StandardLogData } from './logger-types';
3
3
  export { StandardTracer } from './tracer';
4
4
  export { IStandardTracer, StandardTraceData, StandardSpanResult, } from './tracer-types';
5
+ export { getEnvironmentStage } from './environment';
@@ -1,8 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.StandardTracer = exports.StandardLogger = void 0;
3
+ exports.getEnvironmentStage = exports.StandardTracer = exports.StandardLogger = void 0;
4
4
  var logger_1 = require("./logger");
5
5
  Object.defineProperty(exports, "StandardLogger", { enumerable: true, get: function () { return logger_1.StandardLogger; } });
6
6
  var tracer_1 = require("./tracer");
7
7
  Object.defineProperty(exports, "StandardTracer", { enumerable: true, get: function () { return tracer_1.StandardTracer; } });
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBMEM7QUFBakMsd0dBQUEsY0FBYyxPQUFBO0FBRXZCLG1DQUEwQztBQUFqQyx3R0FBQSxjQUFjLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBTdGFuZGFyZExvZ2dlciB9IGZyb20gJy4vbG9nZ2VyJztcbmV4cG9ydCB7IElTdGFuZGFyZExvZ2dlciwgU3RhbmRhcmRMb2dEYXRhIH0gZnJvbSAnLi9sb2dnZXItdHlwZXMnO1xuZXhwb3J0IHsgU3RhbmRhcmRUcmFjZXIgfSBmcm9tICcuL3RyYWNlcic7XG5leHBvcnQge1xuICBJU3RhbmRhcmRUcmFjZXIsXG4gIFN0YW5kYXJkVHJhY2VEYXRhLFxuICBTdGFuZGFyZFNwYW5SZXN1bHQsXG59IGZyb20gJy4vdHJhY2VyLXR5cGVzJztcbiJdfQ==
8
+ var environment_1 = require("./environment");
9
+ Object.defineProperty(exports, "getEnvironmentStage", { enumerable: true, get: function () { return environment_1.getEnvironmentStage; } });
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29yZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBMEM7QUFBakMsd0dBQUEsY0FBYyxPQUFBO0FBRXZCLG1DQUEwQztBQUFqQyx3R0FBQSxjQUFjLE9BQUE7QUFPdkIsNkNBQW9EO0FBQTNDLGtIQUFBLG1CQUFtQixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgU3RhbmRhcmRMb2dnZXIgfSBmcm9tICcuL2xvZ2dlcic7XG5leHBvcnQgeyBJU3RhbmRhcmRMb2dnZXIsIFN0YW5kYXJkTG9nRGF0YSB9IGZyb20gJy4vbG9nZ2VyLXR5cGVzJztcbmV4cG9ydCB7IFN0YW5kYXJkVHJhY2VyIH0gZnJvbSAnLi90cmFjZXInO1xuZXhwb3J0IHtcbiAgSVN0YW5kYXJkVHJhY2VyLFxuICBTdGFuZGFyZFRyYWNlRGF0YSxcbiAgU3RhbmRhcmRTcGFuUmVzdWx0LFxufSBmcm9tICcuL3RyYWNlci10eXBlcyc7XG5cbmV4cG9ydCB7IGdldEVudmlyb25tZW50U3RhZ2UgfSBmcm9tICcuL2Vudmlyb25tZW50JztcbiJdfQ==
@@ -13,11 +13,11 @@ export interface StandardLogData {
13
13
  body?: any;
14
14
  params?: Record<string, any>;
15
15
  query?: Record<string, any>;
16
+ agent?: string;
16
17
  };
17
18
  user?: {
18
- accountUserUid?: string;
19
- accountUid?: string;
20
- applicationUid?: string;
19
+ uid?: string;
20
+ email?: string;
21
21
  };
22
22
  execution?: {
23
23
  requestId?: string;
@@ -27,6 +27,11 @@ export interface StandardLogData {
27
27
  controller?: string;
28
28
  controllerMethod?: string;
29
29
  origin?: string;
30
+ routeKey?: string;
31
+ loggedUser?: {
32
+ uid?: string;
33
+ email?: string;
34
+ };
30
35
  };
31
36
  performance?: {
32
37
  durationMs?: number;
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvbG9nZ2VyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVyZmFjZSBwYWRyw6NvIHBhcmEgbG9ncyBlc3RydXR1cmFkb3MgZW0gdG9kYSBhIGFwbGljYcOnw6NvLlxuICogQ29tYmluYSBjYW1wb3MgaW1wb3J0YW50ZXMgZGUgYW1iYXMgaW1wbGVtZW50YcOnw7VlcyAoVHNlZCBlIFNTVCkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3RhbmRhcmRMb2dEYXRhIHtcbiAgLy8gSW5mb3JtYcOnw7VlcyBkbyBlcnJvL2V2ZW50b1xuICBzZXZlcml0eTogJ0VSUk9SJyB8ICdXQVJOJyB8ICdJTkZPJyB8ICdERUJVRyc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgZXJyb3I/OiBFcnJvcjtcblxuICAvLyBJZGVudGlmaWNhw6fDo28gZG8gc2VydmnDp29cbiAgc2VydmljZU5hbWU6IHN0cmluZztcbiAgZW52aXJvbm1lbnQ6IHN0cmluZzsgLy8gZGV2ZWxvcG1lbnQsIHN0YWdpbmcsIHByb2R1Y3Rpb25cblxuICAvLyBDb250ZXh0byBkYSByZXF1aXNpw6fDo28gSFRUUFxuICBodHRwPzoge1xuICAgIG1ldGhvZD86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgZW5kcG9pbnQ/OiBzdHJpbmc7XG4gICAgc3RhdHVzQ29kZT86IG51bWJlcjtcbiAgICBoZWFkZXJzPzogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgICBib2R5PzogYW55O1xuICAgIHBhcmFtcz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gICAgcXVlcnk/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICB9O1xuXG4gIC8vIElkZW50aWZpY2HDp8OjbyBkbyB1c3XDoXJpby9jb250YVxuICB1c2VyPzoge1xuICAgIGFjY291bnRVc2VyVWlkPzogc3RyaW5nO1xuICAgIGFjY291bnRVaWQ/OiBzdHJpbmc7XG4gICAgYXBwbGljYXRpb25VaWQ/OiBzdHJpbmc7XG4gIH07XG5cbiAgLy8gQ29udGV4dG8gZGEgZXhlY3XDp8Ojb1xuICBleGVjdXRpb24/OiB7XG4gICAgcmVxdWVzdElkPzogc3RyaW5nO1xuICAgIGF3c1JlcXVlc3RJZD86IHN0cmluZztcbiAgICBmdW5jdGlvbk5hbWU/OiBzdHJpbmc7XG4gICAgaW52b2NhdGlvbklkPzogc3RyaW5nO1xuICAgIGNvbnRyb2xsZXI/OiBzdHJpbmc7XG4gICAgY29udHJvbGxlck1ldGhvZD86IHN0cmluZztcbiAgICBvcmlnaW4/OiBzdHJpbmc7IC8vIG9yaWdlbSBkYSByZXF1aXNpw6fDo28gKGV4OiB3ZWIsIG1vYmlsZSlcbiAgfTtcblxuICAvLyBQZXJmb3JtYW5jZVxuICBwZXJmb3JtYW5jZT86IHtcbiAgICBkdXJhdGlvbk1zPzogbnVtYmVyO1xuICAgIHN1Y2Nlc3M/OiBib29sZWFuO1xuICB9O1xuXG4gIC8vIENvbnRleHRvIGFkaWNpb25hbCBsaXZyZVxuICBjb250ZXh0PzogUmVjb3JkPHN0cmluZywgYW55PjtcblxuICAvLyBUaW1lc3RhbXBcbiAgdGltZXN0YW1wOiBzdHJpbmc7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHBhcmEgbyBsb2dnZXIgY29yZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIElTdGFuZGFyZExvZ2dlciB7XG4gIGxvZ0Vycm9yKFxuICAgIGRhdGE6IE9taXQ8U3RhbmRhcmRMb2dEYXRhLCAnc2V2ZXJpdHknIHwgJ3RpbWVzdGFtcCc+XG4gICk6IFByb21pc2U8dm9pZD47XG4gIGxvZ0luZm8oZGF0YTogT21pdDxTdGFuZGFyZExvZ0RhdGEsICdzZXZlcml0eScgfCAndGltZXN0YW1wJz4pOiBQcm9taXNlPHZvaWQ+O1xuICBsb2dXYXJuKGRhdGE6IE9taXQ8U3RhbmRhcmRMb2dEYXRhLCAnc2V2ZXJpdHknIHwgJ3RpbWVzdGFtcCc+KTogUHJvbWlzZTx2b2lkPjtcbiAgbG9nRGVidWcoXG4gICAgZGF0YTogT21pdDxTdGFuZGFyZExvZ0RhdGEsICdzZXZlcml0eScgfCAndGltZXN0YW1wJz5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvbG9nZ2VyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVyZmFjZSBwYWRyw6NvIHBhcmEgbG9ncyBlc3RydXR1cmFkb3MgZW0gdG9kYSBhIGFwbGljYcOnw6NvLlxuICogQ29tYmluYSBjYW1wb3MgaW1wb3J0YW50ZXMgZGUgYW1iYXMgaW1wbGVtZW50YcOnw7VlcyAoVHNlZCBlIFNTVCkuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3RhbmRhcmRMb2dEYXRhIHtcbiAgLy8gSW5mb3JtYcOnw7VlcyBkbyBlcnJvL2V2ZW50b1xuICBzZXZlcml0eTogJ0VSUk9SJyB8ICdXQVJOJyB8ICdJTkZPJyB8ICdERUJVRyc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgZXJyb3I/OiBFcnJvcjtcblxuICAvLyBJZGVudGlmaWNhw6fDo28gZG8gc2VydmnDp29cbiAgc2VydmljZU5hbWU6IHN0cmluZztcbiAgZW52aXJvbm1lbnQ6IHN0cmluZzsgLy8gZGV2ZWxvcG1lbnQsIHN0YWdpbmcsIHByb2R1Y3Rpb25cblxuICAvLyBDb250ZXh0byBkYSByZXF1aXNpw6fDo28gSFRUUFxuICBodHRwPzoge1xuICAgIG1ldGhvZD86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgZW5kcG9pbnQ/OiBzdHJpbmc7XG4gICAgc3RhdHVzQ29kZT86IG51bWJlcjtcbiAgICBoZWFkZXJzPzogUmVjb3JkPHN0cmluZywgYW55PjtcbiAgICBib2R5PzogYW55O1xuICAgIHBhcmFtcz86IFJlY29yZDxzdHJpbmcsIGFueT47XG4gICAgcXVlcnk/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuICAgIGFnZW50Pzogc3RyaW5nO1xuICB9O1xuXG4gIC8vIElkZW50aWZpY2HDp8OjbyBkbyB1c3XDoXJpby9jb250YVxuICB1c2VyPzoge1xuICAgIHVpZD86IHN0cmluZztcbiAgICBlbWFpbD86IHN0cmluZztcbiAgfTtcblxuICAvLyBDb250ZXh0byBkYSBleGVjdcOnw6NvXG4gIGV4ZWN1dGlvbj86IHtcbiAgICByZXF1ZXN0SWQ/OiBzdHJpbmc7XG4gICAgYXdzUmVxdWVzdElkPzogc3RyaW5nO1xuICAgIGZ1bmN0aW9uTmFtZT86IHN0cmluZztcbiAgICBpbnZvY2F0aW9uSWQ/OiBzdHJpbmc7XG4gICAgY29udHJvbGxlcj86IHN0cmluZztcbiAgICBjb250cm9sbGVyTWV0aG9kPzogc3RyaW5nO1xuICAgIG9yaWdpbj86IHN0cmluZzsgLy8gb3JpZ2VtIGRhIHJlcXVpc2nDp8OjbyAoZXg6IHdlYiwgbW9iaWxlKVxuICAgIHJvdXRlS2V5Pzogc3RyaW5nO1xuICAgIGxvZ2dlZFVzZXI/OiB7XG4gICAgICB1aWQ/OiBzdHJpbmc7XG4gICAgICBlbWFpbD86IHN0cmluZztcbiAgICB9O1xuICB9O1xuXG4gIC8vIFBlcmZvcm1hbmNlXG4gIHBlcmZvcm1hbmNlPzoge1xuICAgIGR1cmF0aW9uTXM/OiBudW1iZXI7XG4gICAgc3VjY2Vzcz86IGJvb2xlYW47XG4gIH07XG5cbiAgLy8gQ29udGV4dG8gYWRpY2lvbmFsIGxpdnJlXG4gIGNvbnRleHQ/OiBSZWNvcmQ8c3RyaW5nLCBhbnk+O1xuXG4gIC8vIFRpbWVzdGFtcFxuICB0aW1lc3RhbXA6IHN0cmluZztcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgcGFyYSBvIGxvZ2dlciBjb3JlXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVN0YW5kYXJkTG9nZ2VyIHtcbiAgbG9nRXJyb3IoXG4gICAgZGF0YTogT21pdDxTdGFuZGFyZExvZ0RhdGEsICdzZXZlcml0eScgfCAndGltZXN0YW1wJz5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbiAgbG9nSW5mbyhkYXRhOiBPbWl0PFN0YW5kYXJkTG9nRGF0YSwgJ3NldmVyaXR5JyB8ICd0aW1lc3RhbXAnPik6IFByb21pc2U8dm9pZD47XG4gIGxvZ1dhcm4oZGF0YTogT21pdDxTdGFuZGFyZExvZ0RhdGEsICdzZXZlcml0eScgfCAndGltZXN0YW1wJz4pOiBQcm9taXNlPHZvaWQ+O1xuICBsb2dEZWJ1ZyhcbiAgICBkYXRhOiBPbWl0PFN0YW5kYXJkTG9nRGF0YSwgJ3NldmVyaXR5JyB8ICd0aW1lc3RhbXAnPlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuIl19
@@ -10,8 +10,8 @@ export declare class StandardLogger implements IStandardLogger {
10
10
  private readonly tracer;
11
11
  private readonly defaultAttributes;
12
12
  private readonly spanContext;
13
- private readonly defaultServiceName;
14
13
  private readonly environment;
14
+ private defaultServiceName;
15
15
  constructor(logger: Logger, tracer: IStandardTracer, scopeAttributes?: Attributes);
16
16
  logError(data: LogParams): Promise<void>;
17
17
  logInfo(data: LogParams): Promise<void>;
@@ -11,6 +11,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.StandardLogger = void 0;
13
13
  const api_logs_1 = require("@opentelemetry/api-logs");
14
+ const environment_1 = require("./environment");
14
15
  class StandardLogger {
15
16
  constructor(logger, tracer, scopeAttributes) {
16
17
  this.defaultAttributes = {};
@@ -26,34 +27,31 @@ class StandardLogger {
26
27
  'function.name': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['function.name']) || 'unknown-function',
27
28
  'function.invocation_id': (scopeAttributes === null || scopeAttributes === void 0 ? void 0 : scopeAttributes['function.invocation_id']) || 'unknown-invocation-id',
28
29
  };
29
- let stage = process.env.STAGE || 'development';
30
- if (stage === 'prod')
31
- stage = 'production';
32
- this.environment = stage;
30
+ this.environment = (0, environment_1.getEnvironmentStage)();
33
31
  }
34
32
  logError(data) {
35
33
  return __awaiter(this, void 0, void 0, function* () {
36
- yield this.log(Object.assign(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), this.defaultAttributes), { severity: 'ERROR' }));
34
+ yield this.log(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), { severity: 'ERROR' }));
37
35
  });
38
36
  }
39
37
  logInfo(data) {
40
38
  return __awaiter(this, void 0, void 0, function* () {
41
- yield this.log(Object.assign(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), this.defaultAttributes), { severity: 'INFO' }));
39
+ yield this.log(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), { severity: 'INFO' }));
42
40
  });
43
41
  }
44
42
  logWarn(data) {
45
43
  return __awaiter(this, void 0, void 0, function* () {
46
- yield this.log(Object.assign(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), this.defaultAttributes), { severity: 'WARN' }));
44
+ yield this.log(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), { severity: 'WARN' }));
47
45
  });
48
46
  }
49
47
  logDebug(data) {
50
48
  return __awaiter(this, void 0, void 0, function* () {
51
- yield this.log(Object.assign(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), this.defaultAttributes), { severity: 'DEBUG' }));
49
+ yield this.log(Object.assign(Object.assign({ serviceName: this.defaultServiceName, environment: this.environment }, data), { severity: 'DEBUG' }));
52
50
  });
53
51
  }
54
52
  log(data) {
55
53
  return __awaiter(this, void 0, void 0, function* () {
56
- const fullData = Object.assign(Object.assign(Object.assign({}, data), this.defaultAttributes), { serviceName: data.serviceName || this.defaultServiceName, timestamp: new Date().toISOString() });
54
+ const fullData = Object.assign(Object.assign({}, data), { serviceName: data.serviceName || this.defaultServiceName, timestamp: new Date().toISOString() });
57
55
  const severityMap = {
58
56
  ERROR: api_logs_1.SeverityNumber.ERROR,
59
57
  WARN: api_logs_1.SeverityNumber.WARN,
@@ -97,14 +95,14 @@ class StandardLogger {
97
95
  attributes['http.params'] = JSON.stringify(data.http.params);
98
96
  if (data.http.query)
99
97
  attributes['http.query'] = JSON.stringify(data.http.query);
98
+ if (data.http.agent)
99
+ attributes['http.user_agent'] = data.http.agent;
100
100
  }
101
101
  if (data.user) {
102
- if (data.user.accountUserUid)
103
- attributes['accountUser.uid'] = data.user.accountUserUid;
104
- if (data.user.accountUid)
105
- attributes['account.uid'] = data.user.accountUid;
106
- if (data.user.applicationUid)
107
- attributes['application.uid'] = data.user.applicationUid;
102
+ if (data.user.uid)
103
+ attributes['user.uid'] = data.user.uid;
104
+ if (data.user.email)
105
+ attributes['user.email'] = data.user.email;
108
106
  }
109
107
  if (data.execution) {
110
108
  if (data.execution.requestId)
@@ -113,14 +111,19 @@ class StandardLogger {
113
111
  attributes['aws.request.id'] = data.execution.awsRequestId;
114
112
  if (data.execution.functionName)
115
113
  attributes['function.name'] = data.execution.functionName;
114
+ this.defaultAttributes['function.name'] = data.execution.functionName;
116
115
  if (data.execution.invocationId)
117
116
  attributes['function.invocation_id'] = data.execution.invocationId;
117
+ this.defaultAttributes['function.invocation_id'] =
118
+ data.execution.invocationId;
118
119
  if (data.execution.controller)
119
120
  attributes['controller.name'] = data.execution.controller;
120
121
  if (data.execution.controllerMethod)
121
122
  attributes['controller.method'] = data.execution.controllerMethod;
122
123
  if (data.execution.origin)
123
124
  attributes['origin'] = data.execution.origin;
125
+ if (data.execution.routeKey)
126
+ attributes['route.key'] = data.execution.routeKey;
124
127
  }
125
128
  if (data.performance) {
126
129
  if (data.performance.durationMs)
@@ -131,8 +134,8 @@ class StandardLogger {
131
134
  if (data.context) {
132
135
  attributes['context'] = JSON.stringify(data.context);
133
136
  }
134
- return Object.fromEntries(Object.entries(Object.assign(Object.assign({}, attributes), this.defaultAttributes)).filter(([, value]) => value !== undefined && value !== null));
137
+ return Object.fromEntries(Object.entries(Object.assign(Object.assign({}, this.defaultAttributes), attributes)).filter(([, value]) => value !== undefined && value !== null));
135
138
  }
136
139
  }
137
140
  exports.StandardLogger = StandardLogger;
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { SeverityNumber, Logger } from '@opentelemetry/api-logs';\nimport { IStandardLogger, StandardLogData } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\n\ninterface LogParams extends Omit<\n  StandardLogData,\n  'severity' | 'timestamp' | 'serviceName' | 'environment'\n> {\n  environment?: StandardLogData['environment'];\n}\n/**\n * Logger core que implementa o padrão de logs estruturados.\n * Recebe um LoggerProvider do OpenTelemetry para emitir os logs.\n */\nexport class StandardLogger implements IStandardLogger {\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly defaultAttributes: Record<string, any> = {};\n  private readonly spanContext: Span;\n  private readonly defaultServiceName: string;\n  private readonly environment: string;\n\n  constructor(\n    logger: Logger,\n    tracer: IStandardTracer,\n    scopeAttributes?: Attributes\n  ) {\n    this.logger = logger;\n    this.tracer = tracer;\n    this.spanContext = this.tracer.getTracer().startSpan('init-logger');\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.defaultAttributes = {\n      'trace.id': this.spanContext.spanContext().traceId,\n      'span.id': this.spanContext.spanContext().spanId,\n      'function.name': scopeAttributes?.['function.name'] || 'unknown-function',\n      'function.invocation_id':\n        scopeAttributes?.['function.invocation_id'] || 'unknown-invocation-id',\n    };\n\n    let stage = process.env.STAGE || 'development';\n    if (stage === 'prod') stage = 'production';\n\n    this.environment = stage;\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      ...this.defaultAttributes,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      ...this.defaultAttributes,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      ...this.defaultAttributes,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      ...this.defaultAttributes,\n      severity: 'DEBUG',\n    });\n  }\n\n  private async log(\n    data: Omit<StandardLogData, 'timestamp'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      ...this.defaultAttributes,\n      serviceName: data.serviceName || this.defaultServiceName,\n      timestamp: new Date().toISOString(),\n    };\n\n    const severityMap = {\n      ERROR: SeverityNumber.ERROR,\n      WARN: SeverityNumber.WARN,\n      INFO: SeverityNumber.INFO,\n      DEBUG: SeverityNumber.DEBUG,\n    };\n\n    const logRecord = {\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.message,\n      attributes: this.buildAttributes(fullData),\n    };\n\n    this.logger.emit(logRecord);\n  }\n\n  private buildAttributes(data: StandardLogData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      timestamp: data.timestamp,\n      'service.name': data.serviceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error.type'] = data.error.name;\n      attributes['error.message'] = data.error.message;\n      attributes['error.stack'] = data.error.stack || '';\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.endpoint'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.headers)\n        attributes['http.headers'] = JSON.stringify(data.http.headers);\n      if (data.http.body)\n        attributes['http.body'] = JSON.stringify(data.http.body);\n      if (data.http.params)\n        attributes['http.params'] = JSON.stringify(data.http.params);\n      if (data.http.query)\n        attributes['http.query'] = JSON.stringify(data.http.query);\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.accountUserUid)\n        attributes['accountUser.uid'] = data.user.accountUserUid;\n      if (data.user.accountUid)\n        attributes['account.uid'] = data.user.accountUid;\n      if (data.user.applicationUid)\n        attributes['application.uid'] = data.user.applicationUid;\n    }\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n    }\n\n    // Performance\n    if (data.performance) {\n      if (data.performance.durationMs)\n        attributes['duration.ms'] = data.performance.durationMs;\n      if (data.performance.success !== undefined)\n        attributes['execution.success'] = data.performance.success;\n    }\n\n    // Contexto adicional\n    if (data.context) {\n      attributes['context'] = JSON.stringify(data.context);\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries({ ...attributes, ...this.defaultAttributes }).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/core/logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { SeverityNumber, Logger } from '@opentelemetry/api-logs';\nimport { IStandardLogger, StandardLogData } from './logger-types';\nimport { IStandardTracer } from './tracer-types';\nimport { Attributes, Span } from '@opentelemetry/api';\nimport { getEnvironmentStage } from './environment';\n\ninterface LogParams extends Omit<\n  StandardLogData,\n  'severity' | 'timestamp' | 'serviceName' | 'environment'\n> {\n  environment?: StandardLogData['environment'];\n}\n/**\n * Logger core que implementa o padrão de logs estruturados.\n * Recebe um LoggerProvider do OpenTelemetry para emitir os logs.\n */\nexport class StandardLogger implements IStandardLogger {\n  private readonly logger: Logger;\n  private readonly tracer: IStandardTracer;\n  private readonly defaultAttributes: Record<string, any> = {};\n  private readonly spanContext: Span;\n  private readonly environment: string;\n  private defaultServiceName: string;\n\n  constructor(\n    logger: Logger,\n    tracer: IStandardTracer,\n    scopeAttributes?: Attributes\n  ) {\n    this.logger = logger;\n    this.tracer = tracer;\n    this.spanContext = this.tracer.getTracer().startSpan('init-logger');\n    this.defaultServiceName = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service';\n\n    this.defaultAttributes = {\n      'trace.id': this.spanContext.spanContext().traceId,\n      'span.id': this.spanContext.spanContext().spanId,\n      'function.name': scopeAttributes?.['function.name'] || 'unknown-function',\n      'function.invocation_id':\n        scopeAttributes?.['function.invocation_id'] || 'unknown-invocation-id',\n    };\n\n    this.environment = getEnvironmentStage();\n  }\n\n  async logError(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'ERROR',\n    });\n  }\n\n  async logInfo(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'INFO',\n    });\n  }\n\n  async logWarn(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'WARN',\n    });\n  }\n\n  async logDebug(data: LogParams): Promise<void> {\n    await this.log({\n      serviceName: this.defaultServiceName,\n      environment: this.environment,\n      ...data,\n      severity: 'DEBUG',\n    });\n  }\n\n  private async log(\n    data: Omit<StandardLogData, 'timestamp'> & {\n      severity: StandardLogData['severity'];\n    }\n  ): Promise<void> {\n    const fullData: StandardLogData = {\n      ...data,\n      serviceName: data.serviceName || this.defaultServiceName,\n      timestamp: new Date().toISOString(),\n    };\n\n    const severityMap = {\n      ERROR: SeverityNumber.ERROR,\n      WARN: SeverityNumber.WARN,\n      INFO: SeverityNumber.INFO,\n      DEBUG: SeverityNumber.DEBUG,\n    };\n\n    const logRecord = {\n      severityNumber: severityMap[fullData.severity],\n      severityText: fullData.severity,\n      body: fullData.message,\n      attributes: this.buildAttributes(fullData),\n    };\n\n    this.logger.emit(logRecord);\n  }\n\n  private buildAttributes(data: StandardLogData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      timestamp: data.timestamp,\n      'service.name': data.serviceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Informações do erro\n    if (data.error) {\n      attributes['error.type'] = data.error.name;\n      attributes['error.message'] = data.error.message;\n      attributes['error.stack'] = data.error.stack || '';\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.endpoint'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.headers)\n        attributes['http.headers'] = JSON.stringify(data.http.headers);\n      if (data.http.body)\n        attributes['http.body'] = JSON.stringify(data.http.body);\n      if (data.http.params)\n        attributes['http.params'] = JSON.stringify(data.http.params);\n      if (data.http.query)\n        attributes['http.query'] = JSON.stringify(data.http.query);\n      if (data.http.agent) attributes['http.user_agent'] = data.http.agent;\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.uid) attributes['user.uid'] = data.user.uid;\n      if (data.user.email) attributes['user.email'] = data.user.email;\n    }\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      this.defaultAttributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      this.defaultAttributes['function.invocation_id'] =\n        data.execution.invocationId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n      if (data.execution.routeKey)\n        attributes['route.key'] = data.execution.routeKey;\n    }\n\n    // Performance\n    if (data.performance) {\n      if (data.performance.durationMs)\n        attributes['duration.ms'] = data.performance.durationMs;\n      if (data.performance.success !== undefined)\n        attributes['execution.success'] = data.performance.success;\n    }\n\n    // Contexto adicional\n    if (data.context) {\n      attributes['context'] = JSON.stringify(data.context);\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries({ ...this.defaultAttributes, ...attributes }).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
@@ -11,6 +11,11 @@ export interface StandardTraceData {
11
11
  controller?: string;
12
12
  controllerMethod?: string;
13
13
  origin?: string;
14
+ routeKey?: string;
15
+ loggedUser?: {
16
+ email?: string;
17
+ uid?: string;
18
+ };
14
19
  };
15
20
  http?: {
16
21
  method?: string;
@@ -20,11 +25,13 @@ export interface StandardTraceData {
20
25
  target?: string;
21
26
  scheme?: string;
22
27
  host?: string;
28
+ agent?: string;
29
+ params?: Record<string, string>;
30
+ query?: Record<string, string>;
23
31
  };
24
32
  user?: {
25
- accountUserUid?: string;
26
- accountUid?: string;
27
- applicationUid?: string;
33
+ email?: string;
34
+ uid?: string;
28
35
  };
29
36
  performance?: {
30
37
  durationMs?: number;
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhY2VyLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvdHJhY2VyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTcGFuLCBUcmFjZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9hcGknO1xuXG4vKipcbiAqIEludGVyZmFjZSBwYWRyw6NvIHBhcmEgZGFkb3MgZGUgdHJhY2VzIGVtIHRvZGEgYSBhcGxpY2HDp8Ojby5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdGFuZGFyZFRyYWNlRGF0YSB7XG4gIC8vIElkZW50aWZpY2HDp8OjbyBkbyBzcGFuXG4gIHNwYW5OYW1lOiBzdHJpbmc7XG4gIHNlcnZpY2VOYW1lOiBzdHJpbmc7XG4gIGVudmlyb25tZW50OiBzdHJpbmc7XG5cbiAgLy8gQ29udGV4dG8gZGEgZXhlY3XDp8Ojb1xuICBleGVjdXRpb24/OiB7XG4gICAgZnVuY3Rpb25OYW1lPzogc3RyaW5nO1xuICAgIGludm9jYXRpb25JZD86IHN0cmluZztcbiAgICBhd3NSZXF1ZXN0SWQ/OiBzdHJpbmc7XG4gICAgcmVxdWVzdElkPzogc3RyaW5nO1xuICAgIGNvbnRyb2xsZXI/OiBzdHJpbmc7XG4gICAgY29udHJvbGxlck1ldGhvZD86IHN0cmluZztcbiAgICBvcmlnaW4/OiBzdHJpbmc7XG4gIH07XG5cbiAgLy8gQ29udGV4dG8gSFRUUFxuICBodHRwPzoge1xuICAgIG1ldGhvZD86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgZW5kcG9pbnQ/OiBzdHJpbmc7XG4gICAgc3RhdHVzQ29kZT86IG51bWJlcjtcbiAgICB0YXJnZXQ/OiBzdHJpbmc7XG4gICAgc2NoZW1lPzogc3RyaW5nO1xuICAgIGhvc3Q/OiBzdHJpbmc7XG4gIH07XG5cbiAgLy8gSWRlbnRpZmljYcOnw6NvIGRvIHVzdcOhcmlvXG4gIHVzZXI/OiB7XG4gICAgYWNjb3VudFVzZXJVaWQ/OiBzdHJpbmc7XG4gICAgYWNjb3VudFVpZD86IHN0cmluZztcbiAgICBhcHBsaWNhdGlvblVpZD86IHN0cmluZztcbiAgfTtcblxuICAvLyBQZXJmb3JtYW5jZVxuICBwZXJmb3JtYW5jZT86IHtcbiAgICBkdXJhdGlvbk1zPzogbnVtYmVyO1xuICAgIHN1Y2Nlc3M/OiBib29sZWFuO1xuICB9O1xuXG4gIC8vIEluZm9ybWHDp8O1ZXMgZGUgZXJyb1xuICBlcnJvcj86IHtcbiAgICB0eXBlPzogc3RyaW5nO1xuICAgIG1lc3NhZ2U/OiBzdHJpbmc7XG4gICAgc3RhY2s/OiBzdHJpbmc7XG4gIH07XG5cbiAgLy8gQXRyaWJ1dG9zIGN1c3RvbWl6YWRvcyBhZGljaW9uYWlzXG4gIGF0dHJpYnV0ZXM/OiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCBudW1iZXIgfCBib29sZWFuPjtcbn1cblxuLyoqXG4gKiBJbnRlcmZhY2UgcGFyYSByZXN1bHRhZG8gZGUgc3BhbiBjcmlhZG9cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdGFuZGFyZFNwYW5SZXN1bHQge1xuICBzcGFuOiBTcGFuO1xuICBlbmQ6ICgpID0+IHZvaWQ7XG4gIHNldFN1Y2Nlc3M6IChzdWNjZXNzOiBib29sZWFuKSA9PiB2b2lkO1xuICBzZXRFcnJvcjogKGVycm9yOiBFcnJvcikgPT4gdm9pZDtcbiAgc2V0QXR0cmlidXRlOiAoa2V5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcgfCBudW1iZXIgfCBib29sZWFuKSA9PiB2b2lkO1xufVxuXG4vKipcbiAqIEludGVyZmFjZSBwYXJhIG8gdHJhY2VyIHBhZHJvbml6YWRvXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVN0YW5kYXJkVHJhY2VyIHtcbiAgc3RhcnRTcGFuKGRhdGE6IFN0YW5kYXJkVHJhY2VEYXRhKTogU3RhbmRhcmRTcGFuUmVzdWx0O1xuICByZWNvcmRFeGNlcHRpb24oc3BhbjogU3BhbiwgZXJyb3I6IEVycm9yKTogdm9pZDtcbiAgZ2V0VHJhY2VyKCk6IFRyYWNlcjtcbn1cbiJdfQ==
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhY2VyLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvcmUvdHJhY2VyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTcGFuLCBUcmFjZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9hcGknO1xuXG4vKipcbiAqIEludGVyZmFjZSBwYWRyw6NvIHBhcmEgZGFkb3MgZGUgdHJhY2VzIGVtIHRvZGEgYSBhcGxpY2HDp8Ojby5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdGFuZGFyZFRyYWNlRGF0YSB7XG4gIC8vIElkZW50aWZpY2HDp8OjbyBkbyBzcGFuXG4gIHNwYW5OYW1lOiBzdHJpbmc7XG4gIHNlcnZpY2VOYW1lOiBzdHJpbmc7XG4gIGVudmlyb25tZW50OiBzdHJpbmc7XG5cbiAgLy8gQ29udGV4dG8gZGEgZXhlY3XDp8Ojb1xuICBleGVjdXRpb24/OiB7XG4gICAgZnVuY3Rpb25OYW1lPzogc3RyaW5nO1xuICAgIGludm9jYXRpb25JZD86IHN0cmluZztcbiAgICBhd3NSZXF1ZXN0SWQ/OiBzdHJpbmc7XG4gICAgcmVxdWVzdElkPzogc3RyaW5nO1xuICAgIGNvbnRyb2xsZXI/OiBzdHJpbmc7XG4gICAgY29udHJvbGxlck1ldGhvZD86IHN0cmluZztcbiAgICBvcmlnaW4/OiBzdHJpbmc7XG4gICAgcm91dGVLZXk/OiBzdHJpbmc7XG4gICAgbG9nZ2VkVXNlcj86IHtcbiAgICAgIGVtYWlsPzogc3RyaW5nO1xuICAgICAgdWlkPzogc3RyaW5nO1xuICAgIH07XG4gIH07XG5cbiAgLy8gQ29udGV4dG8gSFRUUFxuICBodHRwPzoge1xuICAgIG1ldGhvZD86IHN0cmluZztcbiAgICB1cmw/OiBzdHJpbmc7XG4gICAgZW5kcG9pbnQ/OiBzdHJpbmc7XG4gICAgc3RhdHVzQ29kZT86IG51bWJlcjtcbiAgICB0YXJnZXQ/OiBzdHJpbmc7XG4gICAgc2NoZW1lPzogc3RyaW5nO1xuICAgIGhvc3Q/OiBzdHJpbmc7XG4gICAgYWdlbnQ/OiBzdHJpbmc7XG4gICAgcGFyYW1zPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgICBxdWVyeT86IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG4gIH07XG5cbiAgLy8gSWRlbnRpZmljYcOnw6NvIGRvIHVzdcOhcmlvXG4gIHVzZXI/OiB7XG4gICAgZW1haWw/OiBzdHJpbmc7XG4gICAgdWlkPzogc3RyaW5nO1xuICB9O1xuXG4gIC8vIFBlcmZvcm1hbmNlXG4gIHBlcmZvcm1hbmNlPzoge1xuICAgIGR1cmF0aW9uTXM/OiBudW1iZXI7XG4gICAgc3VjY2Vzcz86IGJvb2xlYW47XG4gIH07XG5cbiAgLy8gSW5mb3JtYcOnw7VlcyBkZSBlcnJvXG4gIGVycm9yPzoge1xuICAgIHR5cGU/OiBzdHJpbmc7XG4gICAgbWVzc2FnZT86IHN0cmluZztcbiAgICBzdGFjaz86IHN0cmluZztcbiAgfTtcblxuICAvLyBBdHJpYnV0b3MgY3VzdG9taXphZG9zIGFkaWNpb25haXNcbiAgYXR0cmlidXRlcz86IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4+O1xufVxuXG4vKipcbiAqIEludGVyZmFjZSBwYXJhIHJlc3VsdGFkbyBkZSBzcGFuIGNyaWFkb1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFN0YW5kYXJkU3BhblJlc3VsdCB7XG4gIHNwYW46IFNwYW47XG4gIGVuZDogKCkgPT4gdm9pZDtcbiAgc2V0U3VjY2VzczogKHN1Y2Nlc3M6IGJvb2xlYW4pID0+IHZvaWQ7XG4gIHNldEVycm9yOiAoZXJyb3I6IEVycm9yKSA9PiB2b2lkO1xuICBzZXRBdHRyaWJ1dGU6IChrZXk6IHN0cmluZywgdmFsdWU6IHN0cmluZyB8IG51bWJlciB8IGJvb2xlYW4pID0+IHZvaWQ7XG59XG5cbi8qKlxuICogSW50ZXJmYWNlIHBhcmEgbyB0cmFjZXIgcGFkcm9uaXphZG9cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJU3RhbmRhcmRUcmFjZXIge1xuICBzdGFydFNwYW4oZGF0YTogU3RhbmRhcmRUcmFjZURhdGEpOiBTdGFuZGFyZFNwYW5SZXN1bHQ7XG4gIHJlY29yZEV4Y2VwdGlvbihzcGFuOiBTcGFuLCBlcnJvcjogRXJyb3IpOiB2b2lkO1xuICBnZXRUcmFjZXIoKTogVHJhY2VyO1xufVxuIl19
@@ -82,14 +82,18 @@ class StandardTracer {
82
82
  attributes['http.scheme'] = data.http.scheme;
83
83
  if (data.http.host)
84
84
  attributes['http.host'] = data.http.host;
85
+ if (data.http.agent)
86
+ attributes['http.user_agent'] = data.http.agent;
87
+ if (data.http.params)
88
+ attributes['http.path_parameters'] = data.http.params;
89
+ if (data.http.query)
90
+ attributes['http.query_string_parameters'] = data.http.query;
85
91
  }
86
92
  if (data.user) {
87
- if (data.user.accountUserUid)
88
- attributes['accountUser.uid'] = data.user.accountUserUid;
89
- if (data.user.accountUid)
90
- attributes['account.uid'] = data.user.accountUid;
91
- if (data.user.applicationUid)
92
- attributes['application.uid'] = data.user.applicationUid;
93
+ if (data.user.uid)
94
+ attributes['user.uid'] = data.user.uid;
95
+ if (data.user.email)
96
+ attributes['user.email'] = data.user.email;
93
97
  }
94
98
  if (data.performance) {
95
99
  if (data.performance.durationMs)
@@ -116,4 +120,4 @@ class StandardTracer {
116
120
  }
117
121
  }
118
122
  exports.StandardTracer = StandardTracer;
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracer.js","sourceRoot":"","sources":["../../src/core/tracer.ts"],"names":[],"mappings":";;;AAAA,4CAA4E;AAW5E,MAAa,cAAc;IACzB,YACmB,MAAc,EACd,qBAA6B,OAAO,CAAC,GAAG,CAAC,YAAY;QACpE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY;QAC1B,CAAC,CAAC,iBAAiB;QAHJ,WAAM,GAAN,MAAM,CAAQ;QACd,uBAAkB,GAAlB,kBAAkB,CAEd;IACpB,CAAC;IAEJ,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAKD,SAAS,CAAC,IAAuB;QAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChD,IAAI,EAAE,cAAQ,CAAC,MAAM;YACrB,UAAU;SACX,CAAC,CAAC;QAEH,OAAO;YACL,IAAI;YACJ,GAAG,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACrB,UAAU,EAAE,CAAC,OAAgB,EAAE,EAAE;gBAC/B,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;gBAChD,IAAI,CAAC,SAAS,CAAC;oBACb,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,oBAAc,CAAC,EAAE,CAAC,CAAC,CAAC,oBAAc,CAAC,KAAK;iBACzD,CAAC,CAAC;YACL,CAAC;YACD,QAAQ,EAAE,CAAC,KAAY,EAAE,EAAE;gBACzB,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;gBAC9C,IAAI,CAAC,SAAS,CAAC;oBACb,IAAI,EAAE,oBAAc,CAAC,KAAK;oBAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;iBACvB,CAAC,CAAC;YACL,CAAC;YACD,YAAY,EAAE,CAAC,GAAW,EAAE,KAAgC,EAAE,EAAE;gBAC9D,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAChC,CAAC;SACF,CAAC;IACJ,CAAC;IAKD,eAAe,CAAC,IAAU,EAAE,KAAY;QACtC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAKO,eAAe,CAAC,IAAuB;QAC7C,MAAM,UAAU,GAAwB;YACtC,cAAc,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,kBAAkB;YAC3D,6BAA6B,EAAE,IAAI,CAAC,WAAW;SAChD,CAAC;QAGF,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC5D,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YACrE,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC7D,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS;gBAC1B,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;YACtD,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU;gBAC3B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;YAC5D,IAAI,IAAI,CAAC,SAAS,CAAC,gBAAgB;gBACjC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;YACpE,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM;gBAAE,UAAU,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QAC1E,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;YACvE,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBACtB,UAAU,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACxD,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,UAAU,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;QAC/D,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,cAAc;gBAC1B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;YAC3D,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBACtB,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACnD,IAAI,IAAI,CAAC,IAAI,CAAC,cAAc;gBAC1B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC;QAC7D,CAAC;QAGD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU;gBAC7B,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAC1D,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,KAAK,SAAS;gBACxC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;QAC/D,CAAC;QAGD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI;gBAAE,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAChE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO;gBAAE,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;YACzE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;QACrE,CAAC;QAGD,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;gBACvD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;oBAC1C,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAGD,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,MAAM,CAC/B,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CACrD,CACF,CAAC;IACJ,CAAC;CACF;AAxID,wCAwIC","sourcesContent":["import { Span, SpanStatusCode, Tracer, SpanKind } from '@opentelemetry/api';\nimport {\n  IStandardTracer,\n  StandardTraceData,\n  StandardSpanResult,\n} from './tracer-types';\n\n/**\n * Tracer padronizado que garante consistência nos traces.\n * Complementa o StandardLogger para observabilidade completa.\n */\nexport class StandardTracer implements IStandardTracer {\n  constructor(\n    private readonly tracer: Tracer,\n    private readonly defaultServiceName: string = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service'\n  ) {}\n\n  getTracer(): Tracer {\n    return this.tracer;\n  }\n\n  /**\n   * Inicia um novo span com atributos padronizados\n   */\n  startSpan(data: StandardTraceData): StandardSpanResult {\n    const attributes = this.buildAttributes(data);\n\n    const span = this.tracer.startSpan(data.spanName, {\n      kind: SpanKind.SERVER,\n      attributes,\n    });\n\n    return {\n      span,\n      end: () => span.end(),\n      setSuccess: (success: boolean) => {\n        span.setAttribute('execution.success', success);\n        span.setStatus({\n          code: success ? SpanStatusCode.OK : SpanStatusCode.ERROR,\n        });\n      },\n      setError: (error: Error) => {\n        this.recordException(span, error);\n        span.setAttribute('execution.success', false);\n        span.setStatus({\n          code: SpanStatusCode.ERROR,\n          message: error.message,\n        });\n      },\n      setAttribute: (key: string, value: string | number | boolean) => {\n        span.setAttribute(key, value);\n      },\n    };\n  }\n\n  /**\n   * Registra uma exceção no span\n   */\n  recordException(span: Span, error: Error): void {\n    span.recordException(error);\n    span.setAttribute('error.type', error.name);\n    span.setAttribute('error.message', error.message);\n    if (error.stack) {\n      span.setAttribute('error.stack', error.stack);\n    }\n  }\n\n  /**\n   * Constrói atributos padronizados para o span\n   */\n  private buildAttributes(data: StandardTraceData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      'service.name': data.serviceName || this.defaultServiceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.target'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.scheme) attributes['http.scheme'] = data.http.scheme;\n      if (data.http.host) attributes['http.host'] = data.http.host;\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.accountUserUid)\n        attributes['accountUser.uid'] = data.user.accountUserUid;\n      if (data.user.accountUid)\n        attributes['account.uid'] = data.user.accountUid;\n      if (data.user.applicationUid)\n        attributes['application.uid'] = data.user.applicationUid;\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    // Erro\n    if (data.error) {\n      if (data.error.type) attributes['error.type'] = data.error.type;\n      if (data.error.message) attributes['error.message'] = data.error.message;\n      if (data.error.stack) attributes['error.stack'] = data.error.stack;\n    }\n\n    // Atributos customizados\n    if (data.attributes) {\n      Object.entries(data.attributes).forEach(([key, value]) => {\n        if (value !== undefined && value !== null) {\n          attributes[key] = value;\n        }\n      });\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries(attributes).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tracer.js","sourceRoot":"","sources":["../../src/core/tracer.ts"],"names":[],"mappings":";;;AAAA,4CAA4E;AAW5E,MAAa,cAAc;IACzB,YACmB,MAAc,EACd,qBAA6B,OAAO,CAAC,GAAG,CAAC,YAAY;QACpE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY;QAC1B,CAAC,CAAC,iBAAiB;QAHJ,WAAM,GAAN,MAAM,CAAQ;QACd,uBAAkB,GAAlB,kBAAkB,CAEd;IACpB,CAAC;IAEJ,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAKD,SAAS,CAAC,IAAuB;QAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;QAE9C,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChD,IAAI,EAAE,cAAQ,CAAC,MAAM;YACrB,UAAU;SACX,CAAC,CAAC;QAEH,OAAO;YACL,IAAI;YACJ,GAAG,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YACrB,UAAU,EAAE,CAAC,OAAgB,EAAE,EAAE;gBAC/B,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,OAAO,CAAC,CAAC;gBAChD,IAAI,CAAC,SAAS,CAAC;oBACb,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,oBAAc,CAAC,EAAE,CAAC,CAAC,CAAC,oBAAc,CAAC,KAAK;iBACzD,CAAC,CAAC;YACL,CAAC;YACD,QAAQ,EAAE,CAAC,KAAY,EAAE,EAAE;gBACzB,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAClC,IAAI,CAAC,YAAY,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;gBAC9C,IAAI,CAAC,SAAS,CAAC;oBACb,IAAI,EAAE,oBAAc,CAAC,KAAK;oBAC1B,OAAO,EAAE,KAAK,CAAC,OAAO;iBACvB,CAAC,CAAC;YACL,CAAC;YACD,YAAY,EAAE,CAAC,GAAW,EAAE,KAAgC,EAAE,EAAE;gBAC9D,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YAChC,CAAC;SACF,CAAC;IACJ,CAAC;IAKD,eAAe,CAAC,IAAU,EAAE,KAAY;QACtC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;QAClD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;IAKO,eAAe,CAAC,IAAuB;QAC7C,MAAM,UAAU,GAAwB;YACtC,cAAc,EAAE,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,kBAAkB;YAC3D,6BAA6B,EAAE,IAAI,CAAC,WAAW;SAChD,CAAC;QAGF,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC5D,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,wBAAwB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YACrE,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY;gBAC7B,UAAU,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;YAC7D,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS;gBAC1B,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC;YACtD,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU;gBAC3B,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;YAC5D,IAAI,IAAI,CAAC,SAAS,CAAC,gBAAgB;gBACjC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,gBAAgB,CAAC;YACpE,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM;gBAAE,UAAU,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QAC1E,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;YACvE,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU;gBACtB,UAAU,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACxD,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACnE,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,UAAU,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;YAC7D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;YACrE,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM;gBAClB,UAAU,CAAC,sBAAsB,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YACxD,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBACjB,UAAU,CAAC,8BAA8B,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QACjE,CAAC;QAGD,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,UAAU,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK;gBAAE,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;QAClE,CAAC;QAGD,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU;gBAC7B,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAC1D,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,KAAK,SAAS;gBACxC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;QAC/D,CAAC;QAGD,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI;gBAAE,UAAU,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;YAChE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO;gBAAE,UAAU,CAAC,eAAe,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;YACzE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK;gBAAE,UAAU,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;QACrE,CAAC;QAGD,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;gBACvD,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;oBAC1C,UAAU,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;gBAC1B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAGD,OAAO,MAAM,CAAC,WAAW,CACvB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,MAAM,CAC/B,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CACrD,CACF,CAAC;IACJ,CAAC;CACF;AAzID,wCAyIC","sourcesContent":["import { Span, SpanStatusCode, Tracer, SpanKind } from '@opentelemetry/api';\nimport {\n  IStandardTracer,\n  StandardTraceData,\n  StandardSpanResult,\n} from './tracer-types';\n\n/**\n * Tracer padronizado que garante consistência nos traces.\n * Complementa o StandardLogger para observabilidade completa.\n */\nexport class StandardTracer implements IStandardTracer {\n  constructor(\n    private readonly tracer: Tracer,\n    private readonly defaultServiceName: string = process.env.SERVICE_NAME\n      ? process.env.SERVICE_NAME\n      : 'unknown-service'\n  ) {}\n\n  getTracer(): Tracer {\n    return this.tracer;\n  }\n\n  /**\n   * Inicia um novo span com atributos padronizados\n   */\n  startSpan(data: StandardTraceData): StandardSpanResult {\n    const attributes = this.buildAttributes(data);\n\n    const span = this.tracer.startSpan(data.spanName, {\n      kind: SpanKind.SERVER,\n      attributes,\n    });\n\n    return {\n      span,\n      end: () => span.end(),\n      setSuccess: (success: boolean) => {\n        span.setAttribute('execution.success', success);\n        span.setStatus({\n          code: success ? SpanStatusCode.OK : SpanStatusCode.ERROR,\n        });\n      },\n      setError: (error: Error) => {\n        this.recordException(span, error);\n        span.setAttribute('execution.success', false);\n        span.setStatus({\n          code: SpanStatusCode.ERROR,\n          message: error.message,\n        });\n      },\n      setAttribute: (key: string, value: string | number | boolean) => {\n        span.setAttribute(key, value);\n      },\n    };\n  }\n\n  /**\n   * Registra uma exceção no span\n   */\n  recordException(span: Span, error: Error): void {\n    span.recordException(error);\n    span.setAttribute('error.type', error.name);\n    span.setAttribute('error.message', error.message);\n    if (error.stack) {\n      span.setAttribute('error.stack', error.stack);\n    }\n  }\n\n  /**\n   * Constrói atributos padronizados para o span\n   */\n  private buildAttributes(data: StandardTraceData): Record<string, any> {\n    const attributes: Record<string, any> = {\n      'service.name': data.serviceName || this.defaultServiceName,\n      'deployment.environment.name': data.environment,\n    };\n\n    // Execução\n    if (data.execution) {\n      if (data.execution.functionName)\n        attributes['function.name'] = data.execution.functionName;\n      if (data.execution.invocationId)\n        attributes['function.invocation_id'] = data.execution.invocationId;\n      if (data.execution.awsRequestId)\n        attributes['aws.request.id'] = data.execution.awsRequestId;\n      if (data.execution.requestId)\n        attributes['request.id'] = data.execution.requestId;\n      if (data.execution.controller)\n        attributes['controller.name'] = data.execution.controller;\n      if (data.execution.controllerMethod)\n        attributes['controller.method'] = data.execution.controllerMethod;\n      if (data.execution.origin) attributes['origin'] = data.execution.origin;\n    }\n\n    // HTTP\n    if (data.http) {\n      if (data.http.method) attributes['http.method'] = data.http.method;\n      if (data.http.url) attributes['http.url'] = data.http.url;\n      if (data.http.endpoint) attributes['http.target'] = data.http.endpoint;\n      if (data.http.statusCode)\n        attributes['http.status_code'] = data.http.statusCode;\n      if (data.http.scheme) attributes['http.scheme'] = data.http.scheme;\n      if (data.http.host) attributes['http.host'] = data.http.host;\n      if (data.http.agent) attributes['http.user_agent'] = data.http.agent;\n      if (data.http.params)\n        attributes['http.path_parameters'] = data.http.params;\n      if (data.http.query)\n        attributes['http.query_string_parameters'] = data.http.query;\n    }\n\n    // Usuário\n    if (data.user) {\n      if (data.user.uid) attributes['user.uid'] = data.user.uid;\n      if (data.user.email) attributes['user.email'] = data.user.email;\n    }\n\n    // 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    // Erro\n    if (data.error) {\n      if (data.error.type) attributes['error.type'] = data.error.type;\n      if (data.error.message) attributes['error.message'] = data.error.message;\n      if (data.error.stack) attributes['error.stack'] = data.error.stack;\n    }\n\n    // Atributos customizados\n    if (data.attributes) {\n      Object.entries(data.attributes).forEach(([key, value]) => {\n        if (value !== undefined && value !== null) {\n          attributes[key] = value;\n        }\n      });\n    }\n\n    // Filtrar valores undefined/null\n    return Object.fromEntries(\n      Object.entries(attributes).filter(\n        ([, value]) => value !== undefined && value !== null\n      )\n    );\n  }\n}\n"]}