@mecanizou/telemetry-hub 1.0.2 → 1.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/.github/workflows/pull_request.yml +32 -32
  2. package/.github/workflows/release.yml +129 -129
  3. package/.prettierignore +4 -4
  4. package/CHANGELOG.md +36 -14
  5. package/DOCS_GUIDE.md +151 -151
  6. package/README.md +248 -248
  7. package/dist/core/__tests__/logger-types.test.js +1 -1
  8. package/dist/core/__tests__/logger.test.js +1 -1
  9. package/dist/core/__tests__/tracer.test.js +1 -1
  10. package/dist/core/index.js +1 -1
  11. package/dist/core/logger-types.js +1 -1
  12. package/dist/core/logger.js +1 -1
  13. package/dist/core/tracer-types.js +1 -1
  14. package/dist/core/tracer.js +1 -1
  15. package/dist/index.js +1 -1
  16. package/dist/sst/__tests__/telemetry.test.js +1 -1
  17. package/dist/sst/index.js +1 -1
  18. package/dist/sst/middy/index.js +1 -1
  19. package/dist/sst/middy/middleware.js +1 -1
  20. package/dist/sst/telemetry.js +1 -1
  21. package/dist/tsed/__tests__/config.test.js +1 -1
  22. package/dist/tsed/__tests__/service.test.js +1 -1
  23. package/dist/tsed/config.js +1 -1
  24. package/dist/tsed/index.js +1 -1
  25. package/dist/tsed/log-telemetry.js +1 -1
  26. package/dist/tsed/service.js +1 -1
  27. package/dist/tsed/sync-log-record-processor.js +1 -1
  28. package/package.json +72 -72
  29. package/release.config.js +23 -23
  30. package/vitest.config.ts +22 -22
  31. package/dist/telemetry/core/__tests__/logger-types.test.d.ts +0 -1
  32. package/dist/telemetry/core/__tests__/logger-types.test.js +0 -325
  33. package/dist/telemetry/core/__tests__/logger.test.d.ts +0 -1
  34. package/dist/telemetry/core/__tests__/logger.test.js +0 -337
  35. package/dist/telemetry/core/__tests__/tracer.test.d.ts +0 -1
  36. package/dist/telemetry/core/__tests__/tracer.test.js +0 -330
  37. package/dist/telemetry/core/index.d.ts +0 -4
  38. package/dist/telemetry/core/index.js +0 -8
  39. package/dist/telemetry/core/logger-types.d.ts +0 -43
  40. package/dist/telemetry/core/logger-types.js +0 -3
  41. package/dist/telemetry/core/logger.d.ts +0 -13
  42. package/dist/telemetry/core/logger.js +0 -123
  43. package/dist/telemetry/core/tracer-types.d.ts +0 -50
  44. package/dist/telemetry/core/tracer-types.js +0 -3
  45. package/dist/telemetry/core/tracer.d.ts +0 -10
  46. package/dist/telemetry/core/tracer.js +0 -114
  47. package/dist/telemetry/index.d.ts +0 -3
  48. package/dist/telemetry/index.js +0 -20
  49. package/dist/telemetry/sst/__tests__/telemetry.test.d.ts +0 -1
  50. package/dist/telemetry/sst/__tests__/telemetry.test.js +0 -138
  51. package/dist/telemetry/sst/index.d.ts +0 -1
  52. package/dist/telemetry/sst/index.js +0 -18
  53. package/dist/telemetry/sst/middy/index.d.ts +0 -1
  54. package/dist/telemetry/sst/middy/index.js +0 -18
  55. package/dist/telemetry/sst/middy/middleware.d.ts +0 -5
  56. package/dist/telemetry/sst/middy/middleware.js +0 -157
  57. package/dist/telemetry/sst/telemetry.d.ts +0 -4
  58. package/dist/telemetry/sst/telemetry.js +0 -121
  59. package/dist/telemetry/tsed/__tests__/config.test.d.ts +0 -1
  60. package/dist/telemetry/tsed/__tests__/config.test.js +0 -146
  61. package/dist/telemetry/tsed/__tests__/service.test.d.ts +0 -1
  62. package/dist/telemetry/tsed/__tests__/service.test.js +0 -63
  63. package/dist/telemetry/tsed/config.d.ts +0 -26
  64. package/dist/telemetry/tsed/config.js +0 -166
  65. package/dist/telemetry/tsed/index.d.ts +0 -4
  66. package/dist/telemetry/tsed/index.js +0 -21
  67. package/dist/telemetry/tsed/log-telemetry.d.ts +0 -1
  68. package/dist/telemetry/tsed/log-telemetry.js +0 -196
  69. package/dist/telemetry/tsed/service.d.ts +0 -26
  70. package/dist/telemetry/tsed/service.js +0 -150
  71. package/dist/telemetry/tsed/sync-log-record-processor.d.ts +0 -11
  72. package/dist/telemetry/tsed/sync-log-record-processor.js +0 -74
package/README.md CHANGED
@@ -1,248 +1,248 @@
1
- # 📊 Telemetry Hub
2
-
3
- Biblioteca centralizada para telemetria e logging estruturado padronizado, compatível com múltiplos frameworks (Tsed, SST/Middy).
4
-
5
- ## 🔗 Quick Links
6
-
7
- - **📘 Guias por Framework:**
8
- - [Tsed](./src/telemetry/tsed/README.md)
9
- - [SST/Middy](./src/telemetry/sst/README.md)
10
- - **📖 Conceitos Core:**
11
- - [Logging Padronizado](./src/telemetry/core/LOGGING.md)
12
- - [Tracing Padronizado](./src/telemetry/core/TRACING.md)
13
- - [Testes](./src/telemetry/core/__tests__/README.md)
14
-
15
- ## 🎯 Objetivo
16
-
17
- Padronizar a forma como logs são gerados em diferentes tipos de projetos, garantindo:
18
- - **Consistência** nos campos de log entre diferentes implementações
19
- - **Observabilidade** através do OpenTelemetry
20
- - **Facilidade de manutenção** com uma única fonte de verdade
21
-
22
- ## 📦 Instalação
23
-
24
- ```bash
25
- npm install @mecanizou/telemetry-hub
26
- ```
27
-
28
- ## 🏗️ Arquitetura
29
-
30
- ```
31
- src/telemetry/
32
- ├── core/ # 🎯 Implementação base (StandardLogger, StandardTracer)
33
- │ ├── types.ts # Interface StandardLogData
34
- │ ├── logger.ts # StandardLogger
35
- │ ├── tracer-types.ts # Interface StandardTraceData
36
- │ ├── tracer.ts # StandardTracer
37
- │ ├── index.ts # Exports
38
- │ ├── README.md # 📚 Visão geral do Core
39
- │ ├── LOGGING.md # 📝 Guia de logging
40
- │ ├── TRACING.md # 🔍 Guia de tracing
41
- │ └── __tests__/ # Testes (57 testes, 100% cobertura)
42
- │ ├── logger.test.ts
43
- │ ├── tracer.test.ts
44
- │ ├── logger-types.test.ts
45
- │ └── README.md # 📚 Documentação dos testes
46
-
47
- ├── tsed/ # 🔷 Implementação para Tsed
48
- │ ├── config.ts # TsedTelemetryProvider (logs + traces + métricas)
49
- │ ├── service.ts # TsedTelemetryService
50
- │ ├── log-telemetry.ts # Decorator @TsedLogTelemetry
51
- │ ├── sync-log-record-processor.ts
52
- │ ├── index.ts
53
- │ ├── README.md # 📚 Guia de uso Tsed
54
- │ ├── IMPLEMENTATION_SUMMARY.md # 📝 Resumo da implementação
55
- │ └── SST_COMPARISON.md # 🔄 Comparação Tsed vs SST
56
-
57
- └── sst/ # 🟦 Implementação para SST/Middy
58
- ├── telemetry.ts # Configuração OpenTelemetry + getStandardLogger/Tracer
59
- ├── index.ts
60
- ├── README.md # 📚 Guia de uso SST
61
- └── middy/
62
- ├── middleware.ts # Middleware Middy (usa StandardLogger + StandardTracer)
63
- └── index.ts
64
- ```
65
-
66
- ### Componentes Principais
67
-
68
- #### 1. **StandardLogger** (Core)
69
- - Classe base que formata logs no padrão OpenTelemetry
70
- - Garante que todos os campos seguem a mesma estrutura
71
- - Implementa os métodos: `logError`, `logInfo`, `logWarn`, `logDebug`
72
-
73
- #### 2. **StandardLogData** (Interface)
74
- Define o contrato padrão de log com campos:
75
- - **severity**, **message**, **error**
76
- - **serviceName**, **environment**
77
- - **http** (method, url, endpoint, statusCode, etc.)
78
- - **user** (accountUserUid, accountUid, applicationUid)
79
- - **execution** (requestId, awsRequestId, functionName, controller, etc.)
80
- - **performance** (durationMs, success)
81
- - **context** (dados adicionais)
82
-
83
- ## 🚀 Uso
84
-
85
- ### Para Projetos Tsed
86
-
87
- ```typescript
88
- import {
89
- TsedTelemetryProvider,
90
- TsedTelemetryService,
91
- TsedLogTelemetry
92
- } from '@mecanizou/telemetry-hub';
93
-
94
- // 1. Configurar provider (no módulo principal)
95
- @Configuration({
96
- // ...
97
- })
98
- export class Server {
99
- @Inject()
100
- protected telemetryProvider: TsedTelemetryProvider;
101
-
102
- async $afterInit() {
103
- await this.telemetryProvider.initialize();
104
- }
105
- }
106
-
107
- // 2. Usar decorator nos controllers
108
- export class CheckoutController {
109
- @TsedLogTelemetry()
110
- async getCheckout(@Context() $ctx: ServerlessContext) {
111
- // Erros são capturados e logados automaticamente
112
- return await this.service.execute();
113
- }
114
- }
115
- ```
116
-
117
- ### Para Projetos SST (Lambdas com Middy)
118
-
119
- ```typescript
120
- import { middyMiddleware } from '@mecanizou/telemetry-hub';
121
- import middy from '@middy/core';
122
-
123
- export const handler = middy(async (event, context) => {
124
- // Sua lógica aqui
125
- return { statusCode: 200, body: 'OK' };
126
- }).use(middyMiddleware());
127
- ```
128
-
129
- O middleware automaticamente:
130
- - Registra logs de INFO em caso de sucesso
131
- - Registra logs de ERROR em caso de falha
132
- - Mantém traces e métricas do OpenTelemetry
133
-
134
- ## ⚙️ Configuração
135
-
136
- ### Variáveis de Ambiente Obrigatórias
137
-
138
- ```bash
139
- OTEL_EXPORTER_OTLP_ENDPOINT=https://seu-endpoint-otel.com
140
- OTEL_EXPORTER_OTLP_USER=seu-usuario
141
- OTEL_EXPORTER_OTLP_PASS=sua-senha
142
- ```
143
-
144
- ### Variáveis de Ambiente Opcionais
145
-
146
- ```bash
147
- SERVICE_NAME=my-service # Default: 'unknown-service' (Tsed) ou 'sst-service' (SST)
148
- STAGE=production # Default: 'development'
149
- ```
150
-
151
- ## ✅ Testes
152
-
153
- O projeto possui **79 testes** com 100% de cobertura:
154
-
155
- - **Core**: 57 testes (logger, tracer, tipos)
156
- - **SST**: 9 testes (integração, singleton, forceFlush)
157
- - **Tsed**: 13 testes (provider, service, integração)
158
-
159
- Para executar:
160
- ```bash
161
- npm test # Executar todos os testes
162
- npm run test:watch # Modo watch
163
- npm run test:ui # UI interativa
164
- npm run test:coverage # Relatório de cobertura
165
- ```
166
-
167
- ## 📝 Campos Padronizados de Log
168
-
169
- Todos os logs exportam os seguintes atributos OpenTelemetry:
170
-
171
- ```typescript
172
- {
173
- // Identificação
174
- timestamp: "2024-12-05T10:30:00.000Z",
175
- "service.name": "cart-service",
176
- "deployment.environment.name": "production",
177
-
178
- // Erro (quando aplicável)
179
- "error.type": "ValidationError",
180
- "error.message": "Invalid cart item",
181
- "error.stack": "...",
182
-
183
- // HTTP
184
- "http.method": "POST",
185
- "http.url": "/api/cart/checkout",
186
- "http.endpoint": "/api/cart/checkout",
187
- "http.status_code": 400,
188
-
189
- // Usuário
190
- "accountUser.uid": "user-123",
191
- "account.uid": "account-456",
192
- "application.uid": "app-789",
193
-
194
- // Execução
195
- "request.id": "req-abc",
196
- "aws.request.id": "aws-xyz",
197
- "faas.name": "checkoutHandler",
198
- "faas.invocation_id": "inv-123",
199
- "controller.name": "CheckoutController",
200
- "controller.method": "getCheckout",
201
- "origin": "mobile",
202
-
203
- // Performance
204
- "duration.ms": 234,
205
- "execution.success": true,
206
-
207
- // Contexto adicional
208
- "context": "{...}"
209
- }
210
- ```
211
-
212
- ## 🔄 Compatibilidade
213
-
214
- | Framework | Versão Testada | Status |
215
- |-----------|---------------|--------|
216
- | Tsed | ^8.19.4 | ✅ |
217
- | SST/Middy | ^6.4.5 | ✅ |
218
- | OpenTelemetry | ^0.56.0 | ✅ |
219
-
220
- ## 📚 Documentação Adicional
221
-
222
- > 📖 **[Guia de Navegação da Documentação](./DOCS_GUIDE.md)** - Mapa completo de toda documentação disponível
223
-
224
- ### Core (Conceitos e Implementação Base)
225
- - [Core README](./src/telemetry/core/README.md) - Visão geral do StandardLogger e StandardTracer
226
- - [LOGGING.md](./src/telemetry/core/LOGGING.md) - Guia detalhado de logging estruturado
227
- - [TRACING.md](./src/telemetry/core/TRACING.md) - Guia detalhado de traces padronizados
228
- - [Testes](./src/telemetry/core/__tests__/README.md) - Documentação dos testes (57 tests, 100% coverage)
229
-
230
- ### Por Framework
231
- - **Tsed:** [src/telemetry/tsed/README.md](./src/telemetry/tsed/README.md)
232
- - [Resumo da Implementação](./src/telemetry/tsed/IMPLEMENTATION_SUMMARY.md)
233
- - [Comparação Tsed vs SST](./src/telemetry/tsed/SST_COMPARISON.md)
234
- - **SST:** [src/telemetry/sst/README.md](./src/telemetry/sst/README.md)
235
-
236
- ## 🤝 Contribuindo
237
-
238
- Esta é uma lib interna da Mecanizou. Para contribuir:
239
-
240
- 1. Clone o repositório
241
- 2. Instale dependências: `npm install`
242
- 3. Execute testes: `npm test`
243
- 4. Execute verificação de tipo: `npm run test:tsc`
244
- 5. Formate código: `npm run fix`
245
-
246
- ## 📄 Licença
247
-
248
- ISC
1
+ # 📊 Telemetry Hub
2
+
3
+ Biblioteca centralizada para telemetria e logging estruturado padronizado, compatível com múltiplos frameworks (Tsed, SST/Middy).
4
+
5
+ ## 🔗 Quick Links
6
+
7
+ - **📘 Guias por Framework:**
8
+ - [Tsed](./src/telemetry/tsed/README.md)
9
+ - [SST/Middy](./src/telemetry/sst/README.md)
10
+ - **📖 Conceitos Core:**
11
+ - [Logging Padronizado](./src/telemetry/core/LOGGING.md)
12
+ - [Tracing Padronizado](./src/telemetry/core/TRACING.md)
13
+ - [Testes](./src/telemetry/core/__tests__/README.md)
14
+
15
+ ## 🎯 Objetivo
16
+
17
+ Padronizar a forma como logs são gerados em diferentes tipos de projetos, garantindo:
18
+ - **Consistência** nos campos de log entre diferentes implementações
19
+ - **Observabilidade** através do OpenTelemetry
20
+ - **Facilidade de manutenção** com uma única fonte de verdade
21
+
22
+ ## 📦 Instalação
23
+
24
+ ```bash
25
+ npm install @mecanizou/telemetry-hub
26
+ ```
27
+
28
+ ## 🏗️ Arquitetura
29
+
30
+ ```
31
+ src/telemetry/
32
+ ├── core/ # 🎯 Implementação base (StandardLogger, StandardTracer)
33
+ │ ├── types.ts # Interface StandardLogData
34
+ │ ├── logger.ts # StandardLogger
35
+ │ ├── tracer-types.ts # Interface StandardTraceData
36
+ │ ├── tracer.ts # StandardTracer
37
+ │ ├── index.ts # Exports
38
+ │ ├── README.md # 📚 Visão geral do Core
39
+ │ ├── LOGGING.md # 📝 Guia de logging
40
+ │ ├── TRACING.md # 🔍 Guia de tracing
41
+ │ └── __tests__/ # Testes (57 testes, 100% cobertura)
42
+ │ ├── logger.test.ts
43
+ │ ├── tracer.test.ts
44
+ │ ├── logger-types.test.ts
45
+ │ └── README.md # 📚 Documentação dos testes
46
+
47
+ ├── tsed/ # 🔷 Implementação para Tsed
48
+ │ ├── config.ts # TsedTelemetryProvider (logs + traces + métricas)
49
+ │ ├── service.ts # TsedTelemetryService
50
+ │ ├── log-telemetry.ts # Decorator @TsedLogTelemetry
51
+ │ ├── sync-log-record-processor.ts
52
+ │ ├── index.ts
53
+ │ ├── README.md # 📚 Guia de uso Tsed
54
+ │ ├── IMPLEMENTATION_SUMMARY.md # 📝 Resumo da implementação
55
+ │ └── SST_COMPARISON.md # 🔄 Comparação Tsed vs SST
56
+
57
+ └── sst/ # 🟦 Implementação para SST/Middy
58
+ ├── telemetry.ts # Configuração OpenTelemetry + getStandardLogger/Tracer
59
+ ├── index.ts
60
+ ├── README.md # 📚 Guia de uso SST
61
+ └── middy/
62
+ ├── middleware.ts # Middleware Middy (usa StandardLogger + StandardTracer)
63
+ └── index.ts
64
+ ```
65
+
66
+ ### Componentes Principais
67
+
68
+ #### 1. **StandardLogger** (Core)
69
+ - Classe base que formata logs no padrão OpenTelemetry
70
+ - Garante que todos os campos seguem a mesma estrutura
71
+ - Implementa os métodos: `logError`, `logInfo`, `logWarn`, `logDebug`
72
+
73
+ #### 2. **StandardLogData** (Interface)
74
+ Define o contrato padrão de log com campos:
75
+ - **severity**, **message**, **error**
76
+ - **serviceName**, **environment**
77
+ - **http** (method, url, endpoint, statusCode, etc.)
78
+ - **user** (accountUserUid, accountUid, applicationUid)
79
+ - **execution** (requestId, awsRequestId, functionName, controller, etc.)
80
+ - **performance** (durationMs, success)
81
+ - **context** (dados adicionais)
82
+
83
+ ## 🚀 Uso
84
+
85
+ ### Para Projetos Tsed
86
+
87
+ ```typescript
88
+ import {
89
+ TsedTelemetryProvider,
90
+ TsedTelemetryService,
91
+ TsedLogTelemetry
92
+ } from '@mecanizou/telemetry-hub';
93
+
94
+ // 1. Configurar provider (no módulo principal)
95
+ @Configuration({
96
+ // ...
97
+ })
98
+ export class Server {
99
+ @Inject()
100
+ protected telemetryProvider: TsedTelemetryProvider;
101
+
102
+ async $afterInit() {
103
+ await this.telemetryProvider.initialize();
104
+ }
105
+ }
106
+
107
+ // 2. Usar decorator nos controllers
108
+ export class CheckoutController {
109
+ @TsedLogTelemetry()
110
+ async getCheckout(@Context() $ctx: ServerlessContext) {
111
+ // Erros são capturados e logados automaticamente
112
+ return await this.service.execute();
113
+ }
114
+ }
115
+ ```
116
+
117
+ ### Para Projetos SST (Lambdas com Middy)
118
+
119
+ ```typescript
120
+ import { middyMiddleware } from '@mecanizou/telemetry-hub';
121
+ import middy from '@middy/core';
122
+
123
+ export const handler = middy(async (event, context) => {
124
+ // Sua lógica aqui
125
+ return { statusCode: 200, body: 'OK' };
126
+ }).use(middyMiddleware());
127
+ ```
128
+
129
+ O middleware automaticamente:
130
+ - Registra logs de INFO em caso de sucesso
131
+ - Registra logs de ERROR em caso de falha
132
+ - Mantém traces e métricas do OpenTelemetry
133
+
134
+ ## ⚙️ Configuração
135
+
136
+ ### Variáveis de Ambiente Obrigatórias
137
+
138
+ ```bash
139
+ OTEL_EXPORTER_OTLP_ENDPOINT=https://seu-endpoint-otel.com
140
+ OTEL_EXPORTER_OTLP_USER=seu-usuario
141
+ OTEL_EXPORTER_OTLP_PASS=sua-senha
142
+ ```
143
+
144
+ ### Variáveis de Ambiente Opcionais
145
+
146
+ ```bash
147
+ SERVICE_NAME=my-service # Default: 'unknown-service' (Tsed) ou 'sst-service' (SST)
148
+ STAGE=production # Default: 'development'
149
+ ```
150
+
151
+ ## ✅ Testes
152
+
153
+ O projeto possui **79 testes** com 100% de cobertura:
154
+
155
+ - **Core**: 57 testes (logger, tracer, tipos)
156
+ - **SST**: 9 testes (integração, singleton, forceFlush)
157
+ - **Tsed**: 13 testes (provider, service, integração)
158
+
159
+ Para executar:
160
+ ```bash
161
+ npm test # Executar todos os testes
162
+ npm run test:watch # Modo watch
163
+ npm run test:ui # UI interativa
164
+ npm run test:coverage # Relatório de cobertura
165
+ ```
166
+
167
+ ## 📝 Campos Padronizados de Log
168
+
169
+ Todos os logs exportam os seguintes atributos OpenTelemetry:
170
+
171
+ ```typescript
172
+ {
173
+ // Identificação
174
+ timestamp: "2024-12-05T10:30:00.000Z",
175
+ "service.name": "cart-service",
176
+ "deployment.environment.name": "production",
177
+
178
+ // Erro (quando aplicável)
179
+ "error.type": "ValidationError",
180
+ "error.message": "Invalid cart item",
181
+ "error.stack": "...",
182
+
183
+ // HTTP
184
+ "http.method": "POST",
185
+ "http.url": "/api/cart/checkout",
186
+ "http.endpoint": "/api/cart/checkout",
187
+ "http.status_code": 400,
188
+
189
+ // Usuário
190
+ "accountUser.uid": "user-123",
191
+ "account.uid": "account-456",
192
+ "application.uid": "app-789",
193
+
194
+ // Execução
195
+ "request.id": "req-abc",
196
+ "aws.request.id": "aws-xyz",
197
+ "faas.name": "checkoutHandler",
198
+ "faas.invocation_id": "inv-123",
199
+ "controller.name": "CheckoutController",
200
+ "controller.method": "getCheckout",
201
+ "origin": "mobile",
202
+
203
+ // Performance
204
+ "duration.ms": 234,
205
+ "execution.success": true,
206
+
207
+ // Contexto adicional
208
+ "context": "{...}"
209
+ }
210
+ ```
211
+
212
+ ## 🔄 Compatibilidade
213
+
214
+ | Framework | Versão Testada | Status |
215
+ |-----------|---------------|--------|
216
+ | Tsed | ^8.19.4 | ✅ |
217
+ | SST/Middy | ^6.4.5 | ✅ |
218
+ | OpenTelemetry | ^0.56.0 | ✅ |
219
+
220
+ ## 📚 Documentação Adicional
221
+
222
+ > 📖 **[Guia de Navegação da Documentação](./DOCS_GUIDE.md)** - Mapa completo de toda documentação disponível
223
+
224
+ ### Core (Conceitos e Implementação Base)
225
+ - [Core README](./src/telemetry/core/README.md) - Visão geral do StandardLogger e StandardTracer
226
+ - [LOGGING.md](./src/telemetry/core/LOGGING.md) - Guia detalhado de logging estruturado
227
+ - [TRACING.md](./src/telemetry/core/TRACING.md) - Guia detalhado de traces padronizados
228
+ - [Testes](./src/telemetry/core/__tests__/README.md) - Documentação dos testes (57 tests, 100% coverage)
229
+
230
+ ### Por Framework
231
+ - **Tsed:** [src/telemetry/tsed/README.md](./src/telemetry/tsed/README.md)
232
+ - [Resumo da Implementação](./src/telemetry/tsed/IMPLEMENTATION_SUMMARY.md)
233
+ - [Comparação Tsed vs SST](./src/telemetry/tsed/SST_COMPARISON.md)
234
+ - **SST:** [src/telemetry/sst/README.md](./src/telemetry/sst/README.md)
235
+
236
+ ## 🤝 Contribuindo
237
+
238
+ Esta é uma lib interna da Mecanizou. Para contribuir:
239
+
240
+ 1. Clone o repositório
241
+ 2. Instale dependências: `npm install`
242
+ 3. Execute testes: `npm test`
243
+ 4. Execute verificação de tipo: `npm run test:tsc`
244
+ 5. Formate código: `npm run fix`
245
+
246
+ ## 📄 Licença
247
+
248
+ ISC
@@ -322,4 +322,4 @@ const vitest_1 = require("vitest");
322
322
  });
323
323
  });
324
324
  });
325
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger-types.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/logger-types.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect } from 'vitest';\r\nimport type { StandardLogData, IStandardLogger } from '../logger-types';\r\n\r\ndescribe('Types - StandardLogData', () => {\r\n  it('deve aceitar log mínimo válido', () => {\r\n    const minimalLog: StandardLogData = {\r\n      severity: 'INFO',\r\n      message: 'Test message',\r\n      serviceName: 'test-service',\r\n      environment: 'test',\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(minimalLog).toBeDefined();\r\n    expect(minimalLog.severity).toBe('INFO');\r\n  });\r\n\r\n  it('deve aceitar todos os níveis de severity', () => {\r\n    const severities: StandardLogData['severity'][] = [\r\n      'ERROR',\r\n      'WARN',\r\n      'INFO',\r\n      'DEBUG',\r\n    ];\r\n\r\n    severities.forEach((severity) => {\r\n      const log: StandardLogData = {\r\n        severity,\r\n        message: 'Test',\r\n        serviceName: 'test',\r\n        environment: 'test',\r\n        timestamp: new Date().toISOString(),\r\n      };\r\n      expect(log.severity).toBe(severity);\r\n    });\r\n  });\r\n\r\n  it('deve aceitar log completo com todos os campos opcionais', () => {\r\n    const completeLog: StandardLogData = {\r\n      severity: 'ERROR',\r\n      message: 'Complete log message',\r\n      error: new Error('Test error'),\r\n      serviceName: 'complete-service',\r\n      environment: 'production',\r\n      http: {\r\n        method: 'POST',\r\n        url: 'https://api.example.com/test',\r\n        endpoint: '/test',\r\n        statusCode: 500,\r\n        headers: { 'content-type': 'application/json' },\r\n        body: { test: 'data' },\r\n        params: { id: '123' },\r\n        query: { filter: 'active' },\r\n      },\r\n      user: {\r\n        accountUserUid: 'user-123',\r\n        accountUid: 'account-456',\r\n        applicationUid: 'app-789',\r\n      },\r\n      execution: {\r\n        requestId: 'req-abc',\r\n        awsRequestId: 'aws-xyz',\r\n        functionName: 'testFunction',\r\n        invocationId: 'inv-123',\r\n        controller: 'TestController',\r\n        controllerMethod: 'testMethod',\r\n        origin: 'mobile',\r\n      },\r\n      performance: {\r\n        durationMs: 1500,\r\n        success: false,\r\n      },\r\n      context: {\r\n        customField: 'customValue',\r\n        nested: {\r\n          data: 123,\r\n        },\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(completeLog).toBeDefined();\r\n    expect(completeLog.http).toBeDefined();\r\n    expect(completeLog.user).toBeDefined();\r\n    expect(completeLog.execution).toBeDefined();\r\n    expect(completeLog.performance).toBeDefined();\r\n    expect(completeLog.context).toBeDefined();\r\n  });\r\n\r\n  it('deve aceitar campos HTTP parciais', () => {\r\n    const partialHttpLog: StandardLogData = {\r\n      severity: 'INFO',\r\n      message: 'Partial HTTP',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      http: {\r\n        method: 'GET',\r\n        endpoint: '/api/users',\r\n        // outros campos opcionais omitidos\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(partialHttpLog.http?.method).toBe('GET');\r\n    expect(partialHttpLog.http?.endpoint).toBe('/api/users');\r\n    expect(partialHttpLog.http?.url).toBeUndefined();\r\n  });\r\n\r\n  it('deve aceitar campos de usuário parciais', () => {\r\n    const partialUserLog: StandardLogData = {\r\n      severity: 'INFO',\r\n      message: 'Partial user',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      user: {\r\n        accountUserUid: 'user-123',\r\n        // outros campos opcionais omitidos\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(partialUserLog.user?.accountUserUid).toBe('user-123');\r\n    expect(partialUserLog.user?.accountUid).toBeUndefined();\r\n  });\r\n\r\n  it('deve aceitar campos de execução parciais', () => {\r\n    const partialExecLog: StandardLogData = {\r\n      severity: 'DEBUG',\r\n      message: 'Partial execution',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      execution: {\r\n        requestId: 'req-123',\r\n        controller: 'TestController',\r\n        // outros campos opcionais omitidos\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(partialExecLog.execution?.requestId).toBe('req-123');\r\n    expect(partialExecLog.execution?.controller).toBe('TestController');\r\n    expect(partialExecLog.execution?.awsRequestId).toBeUndefined();\r\n  });\r\n\r\n  it('deve aceitar performance com apenas durationMs', () => {\r\n    const durationOnlyLog: StandardLogData = {\r\n      severity: 'INFO',\r\n      message: 'Duration only',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      performance: {\r\n        durationMs: 500,\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(durationOnlyLog.performance?.durationMs).toBe(500);\r\n    expect(durationOnlyLog.performance?.success).toBeUndefined();\r\n  });\r\n\r\n  it('deve aceitar performance com apenas success', () => {\r\n    const successOnlyLog: StandardLogData = {\r\n      severity: 'INFO',\r\n      message: 'Success only',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      performance: {\r\n        success: true,\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(successOnlyLog.performance?.success).toBe(true);\r\n    expect(successOnlyLog.performance?.durationMs).toBeUndefined();\r\n  });\r\n\r\n  it('deve aceitar contexto com estruturas aninhadas complexas', () => {\r\n    const complexContextLog: StandardLogData = {\r\n      severity: 'ERROR',\r\n      message: 'Complex context',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n      context: {\r\n        level1: {\r\n          level2: {\r\n            level3: {\r\n              value: 'deep',\r\n              array: [1, 2, 3],\r\n            },\r\n          },\r\n        },\r\n        simpleValue: 'test',\r\n        numericValue: 123,\r\n        booleanValue: true,\r\n      },\r\n      timestamp: new Date().toISOString(),\r\n    };\r\n\r\n    expect(complexContextLog.context?.level1).toBeDefined();\r\n    expect(complexContextLog.context?.simpleValue).toBe('test');\r\n  });\r\n});\r\n\r\ndescribe('Types - IStandardLogger', () => {\r\n  it('deve definir interface com os 4 métodos de log', () => {\r\n    // Este é um teste de tipo, só para garantir que a interface está correta\r\n    const mockLogger: IStandardLogger = {\r\n      logError: async () => {},\r\n      logInfo: async () => {},\r\n      logWarn: async () => {},\r\n      logDebug: async () => {},\r\n    };\r\n\r\n    expect(mockLogger.logError).toBeDefined();\r\n    expect(mockLogger.logInfo).toBeDefined();\r\n    expect(mockLogger.logWarn).toBeDefined();\r\n    expect(mockLogger.logDebug).toBeDefined();\r\n  });\r\n\r\n  it('deve aceitar dados sem severity e timestamp nos métodos', async () => {\r\n    const mockLogger: IStandardLogger = {\r\n      logError: async (data) => {\r\n        expect(data.message).toBe('Error message');\r\n        expect(data.serviceName).toBe('test');\r\n        // @ts-expect-error - severity não deve existir\r\n        expect(data.severity).toBeUndefined();\r\n        // @ts-expect-error - timestamp não deve existir\r\n        expect(data.timestamp).toBeUndefined();\r\n      },\r\n      logInfo: async () => {},\r\n      logWarn: async () => {},\r\n      logDebug: async () => {},\r\n    };\r\n\r\n    await mockLogger.logError({\r\n      message: 'Error message',\r\n      serviceName: 'test',\r\n      environment: 'test',\r\n    });\r\n  });\r\n});\r\n\r\ndescribe('Types - Validação de campos', () => {\r\n  describe('severity', () => {\r\n    it('deve aceitar apenas valores válidos', () => {\r\n      const validSeverities = ['ERROR', 'WARN', 'INFO', 'DEBUG'] as const;\r\n\r\n      validSeverities.forEach((severity) => {\r\n        const log: StandardLogData = {\r\n          severity,\r\n          message: 'test',\r\n          serviceName: 'test',\r\n          environment: 'test',\r\n          timestamp: new Date().toISOString(),\r\n        };\r\n        expect(log.severity).toBe(severity);\r\n      });\r\n    });\r\n  });\r\n\r\n  describe('environment', () => {\r\n    it('deve aceitar ambientes comuns', () => {\r\n      const environments = ['development', 'staging', 'production', 'test'];\r\n\r\n      environments.forEach((env) => {\r\n        const log: StandardLogData = {\r\n          severity: 'INFO',\r\n          message: 'test',\r\n          serviceName: 'test',\r\n          environment: env,\r\n          timestamp: new Date().toISOString(),\r\n        };\r\n        expect(log.environment).toBe(env);\r\n      });\r\n    });\r\n  });\r\n\r\n  describe('timestamp', () => {\r\n    it('deve aceitar formato ISO 8601', () => {\r\n      const isoTimestamp = new Date().toISOString();\r\n      const log: StandardLogData = {\r\n        severity: 'INFO',\r\n        message: 'test',\r\n        serviceName: 'test',\r\n        environment: 'test',\r\n        timestamp: isoTimestamp,\r\n      };\r\n\r\n      expect(log.timestamp).toMatch(\r\n        /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{3}Z$/\r\n      );\r\n    });\r\n  });\r\n\r\n  describe('http.statusCode', () => {\r\n    it('deve aceitar códigos HTTP válidos', () => {\r\n      const statusCodes = [200, 201, 400, 401, 404, 500, 502, 503];\r\n\r\n      statusCodes.forEach((statusCode) => {\r\n        const log: StandardLogData = {\r\n          severity: 'INFO',\r\n          message: 'test',\r\n          serviceName: 'test',\r\n          environment: 'test',\r\n          http: { statusCode },\r\n          timestamp: new Date().toISOString(),\r\n        };\r\n        expect(log.http?.statusCode).toBe(statusCode);\r\n      });\r\n    });\r\n  });\r\n\r\n  describe('performance.durationMs', () => {\r\n    it('deve aceitar valores numéricos positivos', () => {\r\n      const durations = [0, 100, 500, 1000, 5000, 10000];\r\n\r\n      durations.forEach((durationMs) => {\r\n        const log: StandardLogData = {\r\n          severity: 'INFO',\r\n          message: 'test',\r\n          serviceName: 'test',\r\n          environment: 'test',\r\n          performance: { durationMs },\r\n          timestamp: new Date().toISOString(),\r\n        };\r\n        expect(log.performance?.durationMs).toBe(durationMs);\r\n      });\r\n    });\r\n  });\r\n\r\n  describe('performance.success', () => {\r\n    it('deve aceitar valores booleanos', () => {\r\n      [true, false].forEach((success) => {\r\n        const log: StandardLogData = {\r\n          severity: 'INFO',\r\n          message: 'test',\r\n          serviceName: 'test',\r\n          environment: 'test',\r\n          performance: { success },\r\n          timestamp: new Date().toISOString(),\r\n        };\r\n        expect(log.performance?.success).toBe(success);\r\n      });\r\n    });\r\n  });\r\n});\r\n"]}
325
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger-types.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/logger-types.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { describe, it, expect } from 'vitest';\nimport type { StandardLogData, IStandardLogger } from '../logger-types';\n\ndescribe('Types - StandardLogData', () => {\n  it('deve aceitar log mínimo válido', () => {\n    const minimalLog: StandardLogData = {\n      severity: 'INFO',\n      message: 'Test message',\n      serviceName: 'test-service',\n      environment: 'test',\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(minimalLog).toBeDefined();\n    expect(minimalLog.severity).toBe('INFO');\n  });\n\n  it('deve aceitar todos os níveis de severity', () => {\n    const severities: StandardLogData['severity'][] = [\n      'ERROR',\n      'WARN',\n      'INFO',\n      'DEBUG',\n    ];\n\n    severities.forEach((severity) => {\n      const log: StandardLogData = {\n        severity,\n        message: 'Test',\n        serviceName: 'test',\n        environment: 'test',\n        timestamp: new Date().toISOString(),\n      };\n      expect(log.severity).toBe(severity);\n    });\n  });\n\n  it('deve aceitar log completo com todos os campos opcionais', () => {\n    const completeLog: StandardLogData = {\n      severity: 'ERROR',\n      message: 'Complete log message',\n      error: new Error('Test error'),\n      serviceName: 'complete-service',\n      environment: 'production',\n      http: {\n        method: 'POST',\n        url: 'https://api.example.com/test',\n        endpoint: '/test',\n        statusCode: 500,\n        headers: { 'content-type': 'application/json' },\n        body: { test: 'data' },\n        params: { id: '123' },\n        query: { filter: 'active' },\n      },\n      user: {\n        accountUserUid: 'user-123',\n        accountUid: 'account-456',\n        applicationUid: 'app-789',\n      },\n      execution: {\n        requestId: 'req-abc',\n        awsRequestId: 'aws-xyz',\n        functionName: 'testFunction',\n        invocationId: 'inv-123',\n        controller: 'TestController',\n        controllerMethod: 'testMethod',\n        origin: 'mobile',\n      },\n      performance: {\n        durationMs: 1500,\n        success: false,\n      },\n      context: {\n        customField: 'customValue',\n        nested: {\n          data: 123,\n        },\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(completeLog).toBeDefined();\n    expect(completeLog.http).toBeDefined();\n    expect(completeLog.user).toBeDefined();\n    expect(completeLog.execution).toBeDefined();\n    expect(completeLog.performance).toBeDefined();\n    expect(completeLog.context).toBeDefined();\n  });\n\n  it('deve aceitar campos HTTP parciais', () => {\n    const partialHttpLog: StandardLogData = {\n      severity: 'INFO',\n      message: 'Partial HTTP',\n      serviceName: 'test',\n      environment: 'test',\n      http: {\n        method: 'GET',\n        endpoint: '/api/users',\n        // outros campos opcionais omitidos\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(partialHttpLog.http?.method).toBe('GET');\n    expect(partialHttpLog.http?.endpoint).toBe('/api/users');\n    expect(partialHttpLog.http?.url).toBeUndefined();\n  });\n\n  it('deve aceitar campos de usuário parciais', () => {\n    const partialUserLog: StandardLogData = {\n      severity: 'INFO',\n      message: 'Partial user',\n      serviceName: 'test',\n      environment: 'test',\n      user: {\n        accountUserUid: 'user-123',\n        // outros campos opcionais omitidos\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(partialUserLog.user?.accountUserUid).toBe('user-123');\n    expect(partialUserLog.user?.accountUid).toBeUndefined();\n  });\n\n  it('deve aceitar campos de execução parciais', () => {\n    const partialExecLog: StandardLogData = {\n      severity: 'DEBUG',\n      message: 'Partial execution',\n      serviceName: 'test',\n      environment: 'test',\n      execution: {\n        requestId: 'req-123',\n        controller: 'TestController',\n        // outros campos opcionais omitidos\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(partialExecLog.execution?.requestId).toBe('req-123');\n    expect(partialExecLog.execution?.controller).toBe('TestController');\n    expect(partialExecLog.execution?.awsRequestId).toBeUndefined();\n  });\n\n  it('deve aceitar performance com apenas durationMs', () => {\n    const durationOnlyLog: StandardLogData = {\n      severity: 'INFO',\n      message: 'Duration only',\n      serviceName: 'test',\n      environment: 'test',\n      performance: {\n        durationMs: 500,\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(durationOnlyLog.performance?.durationMs).toBe(500);\n    expect(durationOnlyLog.performance?.success).toBeUndefined();\n  });\n\n  it('deve aceitar performance com apenas success', () => {\n    const successOnlyLog: StandardLogData = {\n      severity: 'INFO',\n      message: 'Success only',\n      serviceName: 'test',\n      environment: 'test',\n      performance: {\n        success: true,\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(successOnlyLog.performance?.success).toBe(true);\n    expect(successOnlyLog.performance?.durationMs).toBeUndefined();\n  });\n\n  it('deve aceitar contexto com estruturas aninhadas complexas', () => {\n    const complexContextLog: StandardLogData = {\n      severity: 'ERROR',\n      message: 'Complex context',\n      serviceName: 'test',\n      environment: 'test',\n      context: {\n        level1: {\n          level2: {\n            level3: {\n              value: 'deep',\n              array: [1, 2, 3],\n            },\n          },\n        },\n        simpleValue: 'test',\n        numericValue: 123,\n        booleanValue: true,\n      },\n      timestamp: new Date().toISOString(),\n    };\n\n    expect(complexContextLog.context?.level1).toBeDefined();\n    expect(complexContextLog.context?.simpleValue).toBe('test');\n  });\n});\n\ndescribe('Types - IStandardLogger', () => {\n  it('deve definir interface com os 4 métodos de log', () => {\n    // Este é um teste de tipo, só para garantir que a interface está correta\n    const mockLogger: IStandardLogger = {\n      logError: async () => {},\n      logInfo: async () => {},\n      logWarn: async () => {},\n      logDebug: async () => {},\n    };\n\n    expect(mockLogger.logError).toBeDefined();\n    expect(mockLogger.logInfo).toBeDefined();\n    expect(mockLogger.logWarn).toBeDefined();\n    expect(mockLogger.logDebug).toBeDefined();\n  });\n\n  it('deve aceitar dados sem severity e timestamp nos métodos', async () => {\n    const mockLogger: IStandardLogger = {\n      logError: async (data) => {\n        expect(data.message).toBe('Error message');\n        expect(data.serviceName).toBe('test');\n        // @ts-expect-error - severity não deve existir\n        expect(data.severity).toBeUndefined();\n        // @ts-expect-error - timestamp não deve existir\n        expect(data.timestamp).toBeUndefined();\n      },\n      logInfo: async () => {},\n      logWarn: async () => {},\n      logDebug: async () => {},\n    };\n\n    await mockLogger.logError({\n      message: 'Error message',\n      serviceName: 'test',\n      environment: 'test',\n    });\n  });\n});\n\ndescribe('Types - Validação de campos', () => {\n  describe('severity', () => {\n    it('deve aceitar apenas valores válidos', () => {\n      const validSeverities = ['ERROR', 'WARN', 'INFO', 'DEBUG'] as const;\n\n      validSeverities.forEach((severity) => {\n        const log: StandardLogData = {\n          severity,\n          message: 'test',\n          serviceName: 'test',\n          environment: 'test',\n          timestamp: new Date().toISOString(),\n        };\n        expect(log.severity).toBe(severity);\n      });\n    });\n  });\n\n  describe('environment', () => {\n    it('deve aceitar ambientes comuns', () => {\n      const environments = ['development', 'staging', 'production', 'test'];\n\n      environments.forEach((env) => {\n        const log: StandardLogData = {\n          severity: 'INFO',\n          message: 'test',\n          serviceName: 'test',\n          environment: env,\n          timestamp: new Date().toISOString(),\n        };\n        expect(log.environment).toBe(env);\n      });\n    });\n  });\n\n  describe('timestamp', () => {\n    it('deve aceitar formato ISO 8601', () => {\n      const isoTimestamp = new Date().toISOString();\n      const log: StandardLogData = {\n        severity: 'INFO',\n        message: 'test',\n        serviceName: 'test',\n        environment: 'test',\n        timestamp: isoTimestamp,\n      };\n\n      expect(log.timestamp).toMatch(\n        /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{3}Z$/\n      );\n    });\n  });\n\n  describe('http.statusCode', () => {\n    it('deve aceitar códigos HTTP válidos', () => {\n      const statusCodes = [200, 201, 400, 401, 404, 500, 502, 503];\n\n      statusCodes.forEach((statusCode) => {\n        const log: StandardLogData = {\n          severity: 'INFO',\n          message: 'test',\n          serviceName: 'test',\n          environment: 'test',\n          http: { statusCode },\n          timestamp: new Date().toISOString(),\n        };\n        expect(log.http?.statusCode).toBe(statusCode);\n      });\n    });\n  });\n\n  describe('performance.durationMs', () => {\n    it('deve aceitar valores numéricos positivos', () => {\n      const durations = [0, 100, 500, 1000, 5000, 10000];\n\n      durations.forEach((durationMs) => {\n        const log: StandardLogData = {\n          severity: 'INFO',\n          message: 'test',\n          serviceName: 'test',\n          environment: 'test',\n          performance: { durationMs },\n          timestamp: new Date().toISOString(),\n        };\n        expect(log.performance?.durationMs).toBe(durationMs);\n      });\n    });\n  });\n\n  describe('performance.success', () => {\n    it('deve aceitar valores booleanos', () => {\n      [true, false].forEach((success) => {\n        const log: StandardLogData = {\n          severity: 'INFO',\n          message: 'test',\n          serviceName: 'test',\n          environment: 'test',\n          performance: { success },\n          timestamp: new Date().toISOString(),\n        };\n        expect(log.performance?.success).toBe(success);\n      });\n    });\n  });\n});\n"]}