@mecanizou/telemetry-hub 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/workflows/pull_request.yml +32 -32
- package/.github/workflows/release.yml +129 -129
- package/.prettierignore +4 -4
- package/DOCS_GUIDE.md +151 -0
- package/README.md +248 -0
- package/dist/check-if-is-working.js +1 -1
- package/dist/core/index.d.ts +2 -0
- package/dist/core/index.js +6 -0
- package/dist/core/logger.d.ts +13 -0
- package/dist/core/logger.js +123 -0
- package/dist/core/types.d.ts +43 -0
- package/dist/core/types.js +3 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +2 -2
- package/dist/services/index.d.ts +1 -0
- package/dist/services/index.js +18 -0
- package/dist/services/telemetry/config.d.ts +20 -0
- package/dist/services/telemetry/config.js +113 -0
- package/dist/services/telemetry/external-service.d.ts +20 -0
- package/dist/services/telemetry/external-service.js +69 -0
- package/dist/services/telemetry/index.d.ts +3 -0
- package/dist/services/telemetry/index.js +20 -0
- package/dist/services/telemetry/sync-log-record-processor.d.ts +11 -0
- package/dist/services/telemetry/sync-log-record-processor.js +74 -0
- package/dist/sst/index.d.ts +1 -0
- package/dist/sst/index.js +18 -0
- package/dist/sst/middy/index.d.ts +1 -0
- package/dist/sst/middy/index.js +18 -0
- package/dist/sst/middy/middleware.d.ts +5 -0
- package/dist/sst/middy/middleware.js +172 -0
- package/dist/sst/telemetry.d.ts +3 -0
- package/dist/sst/telemetry.js +111 -0
- package/dist/telemetry/core/__tests__/logger-types.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/logger-types.test.js +325 -0
- package/dist/telemetry/core/__tests__/logger.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/logger.test.js +337 -0
- package/dist/telemetry/core/__tests__/tracer.test.d.ts +1 -0
- package/dist/telemetry/core/__tests__/tracer.test.js +330 -0
- package/dist/telemetry/core/index.d.ts +4 -0
- package/dist/telemetry/core/index.js +8 -0
- package/dist/telemetry/core/logger-types.d.ts +43 -0
- package/dist/telemetry/core/logger-types.js +3 -0
- package/dist/telemetry/core/logger.d.ts +13 -0
- package/dist/telemetry/core/logger.js +123 -0
- package/dist/telemetry/core/tracer-types.d.ts +50 -0
- package/dist/telemetry/core/tracer-types.js +3 -0
- package/dist/telemetry/core/tracer.d.ts +10 -0
- package/dist/telemetry/core/tracer.js +114 -0
- package/dist/telemetry/index.d.ts +3 -0
- package/dist/telemetry/index.js +20 -0
- package/dist/telemetry/sst/__tests__/telemetry.test.d.ts +1 -0
- package/dist/telemetry/sst/__tests__/telemetry.test.js +138 -0
- package/dist/telemetry/sst/index.d.ts +1 -0
- package/dist/telemetry/sst/index.js +18 -0
- package/dist/telemetry/sst/middy/index.d.ts +1 -0
- package/dist/telemetry/sst/middy/index.js +18 -0
- package/dist/telemetry/sst/middy/middleware.d.ts +5 -0
- package/dist/telemetry/sst/middy/middleware.js +157 -0
- package/dist/telemetry/sst/telemetry.d.ts +4 -0
- package/dist/telemetry/sst/telemetry.js +121 -0
- package/dist/telemetry/tsed/__tests__/config.test.d.ts +1 -0
- package/dist/telemetry/tsed/__tests__/config.test.js +146 -0
- package/dist/telemetry/tsed/__tests__/service.test.d.ts +1 -0
- package/dist/telemetry/tsed/__tests__/service.test.js +63 -0
- package/dist/telemetry/tsed/config.d.ts +26 -0
- package/dist/telemetry/tsed/config.js +166 -0
- package/dist/telemetry/tsed/index.d.ts +4 -0
- package/dist/telemetry/tsed/index.js +21 -0
- package/dist/telemetry/tsed/log-telemetry.d.ts +1 -0
- package/dist/telemetry/tsed/log-telemetry.js +196 -0
- package/dist/telemetry/tsed/service.d.ts +26 -0
- package/dist/telemetry/tsed/service.js +150 -0
- package/dist/telemetry/tsed/sync-log-record-processor.d.ts +11 -0
- package/dist/telemetry/tsed/sync-log-record-processor.js +74 -0
- package/dist/telemetry.d.ts +1 -0
- package/dist/telemetry.js +81 -0
- package/dist/tsed/config.d.ts +20 -0
- package/dist/tsed/config.js +113 -0
- package/dist/tsed/index.d.ts +3 -0
- package/dist/tsed/index.js +20 -0
- package/dist/tsed/log-telemetry.d.ts +1 -0
- package/dist/tsed/log-telemetry.js +81 -0
- package/dist/tsed/service.d.ts +24 -0
- package/dist/tsed/service.js +131 -0
- package/dist/tsed/sync-log-record-processor.d.ts +11 -0
- package/dist/tsed/sync-log-record-processor.js +74 -0
- package/package.json +72 -56
- package/release.config.js +23 -23
- package/vitest.config.ts +22 -0
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TelemetryProvider = void 0;
|
|
13
|
+
const sdk_logs_1 = require("@opentelemetry/sdk-logs");
|
|
14
|
+
const exporter_logs_otlp_http_1 = require("@opentelemetry/exporter-logs-otlp-http");
|
|
15
|
+
const resources_1 = require("@opentelemetry/resources");
|
|
16
|
+
const semantic_conventions_1 = require("@opentelemetry/semantic-conventions");
|
|
17
|
+
const sync_log_record_processor_1 = require("./sync-log-record-processor");
|
|
18
|
+
class TelemetryProvider {
|
|
19
|
+
constructor() {
|
|
20
|
+
this.loggerProvider = null;
|
|
21
|
+
this.initialized = false;
|
|
22
|
+
if (!this.initialized && process.env.OTEL_EXPORTER_OTLP_ENDPOINT) {
|
|
23
|
+
const serviceName = process.env.SERVICE_NAME || 'unknown-service';
|
|
24
|
+
const serviceStage = process.env.STAGE;
|
|
25
|
+
this.initialize({
|
|
26
|
+
endpoint: process.env.OTEL_EXPORTER_OTLP_ENDPOINT || '',
|
|
27
|
+
username: process.env.OTEL_EXPORTER_OTLP_USER || '',
|
|
28
|
+
password: process.env.OTEL_EXPORTER_OTLP_PASS || '',
|
|
29
|
+
serviceName: `${serviceName}-${serviceStage}`,
|
|
30
|
+
serviceVersion: process.env.npm_package_version || '1.0.0',
|
|
31
|
+
enabled: process.env.OTEL_ENABLED !== 'false',
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
initialize(config) {
|
|
36
|
+
if (this.initialized) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (config.enabled === false) {
|
|
40
|
+
console.log('[Telemetry] OpenTelemetry is disabled');
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (!config.endpoint || !config.username || !config.password) {
|
|
44
|
+
if (process.env.NODE_ENV !== 'test' &&
|
|
45
|
+
process.env.OTEL_EXPORTER_OTLP_ENDPOINT) {
|
|
46
|
+
console.error('[Telemetry] Missing required configuration');
|
|
47
|
+
}
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
try {
|
|
51
|
+
const resource = (0, resources_1.resourceFromAttributes)({
|
|
52
|
+
[semantic_conventions_1.ATTR_SERVICE_NAME]: config.serviceName || 'unknown-service',
|
|
53
|
+
[semantic_conventions_1.ATTR_SERVICE_VERSION]: config.serviceVersion || '1.0.0',
|
|
54
|
+
});
|
|
55
|
+
const logExporter = new exporter_logs_otlp_http_1.OTLPLogExporter({
|
|
56
|
+
url: `${config.endpoint}/v1/logs`,
|
|
57
|
+
headers: {
|
|
58
|
+
Authorization: `Basic ${Buffer.from(`${config.username}:${config.password}`).toString('base64')}`,
|
|
59
|
+
},
|
|
60
|
+
timeoutMillis: 5000,
|
|
61
|
+
concurrencyLimit: 1,
|
|
62
|
+
});
|
|
63
|
+
const syncProcessor = new sync_log_record_processor_1.SyncLogRecordProcessor(logExporter);
|
|
64
|
+
this.loggerProvider = new sdk_logs_1.LoggerProvider({
|
|
65
|
+
resource,
|
|
66
|
+
processors: [syncProcessor],
|
|
67
|
+
});
|
|
68
|
+
this.initialized = true;
|
|
69
|
+
console.log('[Telemetry] OpenTelemetry initialized successfully');
|
|
70
|
+
}
|
|
71
|
+
catch (error) {
|
|
72
|
+
console.error('[Telemetry] Failed to initialize OpenTelemetry:', error);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
getLoggerProvider() {
|
|
76
|
+
return this.loggerProvider;
|
|
77
|
+
}
|
|
78
|
+
isInitialized() {
|
|
79
|
+
return this.initialized;
|
|
80
|
+
}
|
|
81
|
+
forceFlush() {
|
|
82
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
83
|
+
if (!this.loggerProvider) {
|
|
84
|
+
console.warn('[Telemetry] forceFlush called but loggerProvider is null');
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
try {
|
|
88
|
+
const startTime = Date.now();
|
|
89
|
+
console.log('[Telemetry] Starting forceFlush...');
|
|
90
|
+
yield this.loggerProvider.forceFlush();
|
|
91
|
+
const duration = Date.now() - startTime;
|
|
92
|
+
console.log(`[Telemetry] forceFlush completed successfully in ${duration}ms`);
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
console.error('[Telemetry] Failed to force flush logs:', error);
|
|
96
|
+
throw error;
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
shutdown() {
|
|
101
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
102
|
+
if (this.loggerProvider) {
|
|
103
|
+
yield this.loggerProvider.shutdown();
|
|
104
|
+
this.initialized = false;
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
$onDestroy() {
|
|
109
|
+
return this.shutdown();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
exports.TelemetryProvider = TelemetryProvider;
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/services/telemetry/config.ts"],"names":[],"mappings":"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","sourcesContent":["import { LoggerProvider } from '@opentelemetry/sdk-logs';\r\nimport { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';\r\nimport { resourceFromAttributes } from '@opentelemetry/resources';\r\nimport {\r\n  ATTR_SERVICE_NAME,\r\n  ATTR_SERVICE_VERSION,\r\n} from '@opentelemetry/semantic-conventions';\r\nimport { SyncLogRecordProcessor } from './sync-log-record-processor';\r\n\r\nexport interface TelemetryConfig {\r\n  endpoint: string;\r\n  username: string;\r\n  password: string;\r\n  serviceName?: string;\r\n  serviceVersion?: string;\r\n  enabled?: boolean;\r\n}\r\n\r\nexport class TelemetryProvider {\r\n  private loggerProvider: LoggerProvider | null = null;\r\n  private initialized = false;\r\n\r\n  constructor() {\r\n    // Auto-initialize synchronously with environment variables\r\n    if (!this.initialized && process.env.OTEL_EXPORTER_OTLP_ENDPOINT) {\r\n      const serviceName = process.env.SERVICE_NAME || 'unknown-service';\r\n      const serviceStage = process.env.STAGE;\r\n      this.initialize({\r\n        endpoint: process.env.OTEL_EXPORTER_OTLP_ENDPOINT || '',\r\n        username: process.env.OTEL_EXPORTER_OTLP_USER || '',\r\n        password: process.env.OTEL_EXPORTER_OTLP_PASS || '',\r\n        serviceName: `${serviceName}-${serviceStage}`,\r\n        serviceVersion: process.env.npm_package_version || '1.0.0',\r\n        enabled: process.env.OTEL_ENABLED !== 'false',\r\n      });\r\n    }\r\n  }\r\n\r\n  public initialize(config: TelemetryConfig): void {\r\n    if (this.initialized) {\r\n      return;\r\n    }\r\n\r\n    if (config.enabled === false) {\r\n      console.log('[Telemetry] OpenTelemetry is disabled');\r\n      return;\r\n    }\r\n\r\n    if (!config.endpoint || !config.username || !config.password) {\r\n      // Não logar erro se estivermos em modo de build\r\n      if (\r\n        process.env.NODE_ENV !== 'test' &&\r\n        process.env.OTEL_EXPORTER_OTLP_ENDPOINT\r\n      ) {\r\n        console.error('[Telemetry] Missing required configuration');\r\n      }\r\n      return;\r\n    }\r\n\r\n    try {\r\n      // Create resource with service information\r\n      const resource = resourceFromAttributes({\r\n        [ATTR_SERVICE_NAME]: config.serviceName || 'unknown-service',\r\n        [ATTR_SERVICE_VERSION]: config.serviceVersion || '1.0.0',\r\n      });\r\n\r\n      // Create OTLP exporter with authentication and timeout configuration\r\n      const logExporter = new OTLPLogExporter({\r\n        url: `${config.endpoint}/v1/logs`,\r\n        headers: {\r\n          Authorization: `Basic ${Buffer.from(`${config.username}:${config.password}`).toString('base64')}`,\r\n        },\r\n        timeoutMillis: 5000, // 5 second timeout for exports\r\n        concurrencyLimit: 1, // Process one export at a time\r\n      });\r\n\r\n      // Use custom SyncLogRecordProcessor instead of SimpleLogRecordProcessor\r\n      // This ensures that the async HTTP export is properly awaited in Lambda\r\n      // environments where execution context freezes after handler returns\r\n      const syncProcessor = new SyncLogRecordProcessor(logExporter);\r\n\r\n      // Create logger provider with resource and processors\r\n      this.loggerProvider = new LoggerProvider({\r\n        resource,\r\n        processors: [syncProcessor],\r\n      });\r\n\r\n      this.initialized = true;\r\n      console.log('[Telemetry] OpenTelemetry initialized successfully');\r\n    } catch (error) {\r\n      console.error('[Telemetry] Failed to initialize OpenTelemetry:', error);\r\n    }\r\n  }\r\n\r\n  public getLoggerProvider(): LoggerProvider | null {\r\n    return this.loggerProvider;\r\n  }\r\n\r\n  public isInitialized(): boolean {\r\n    return this.initialized;\r\n  }\r\n\r\n  /**\r\n   * Force flush all pending logs to ensure they are sent before Lambda freezes\r\n   * This is critical in AWS Lambda environments where execution context freezes\r\n   * immediately after the handler returns, potentially before async HTTP requests complete\r\n   */\r\n  public async forceFlush(): Promise<void> {\r\n    if (!this.loggerProvider) {\r\n      console.warn('[Telemetry] forceFlush called but loggerProvider is null');\r\n      return;\r\n    }\r\n\r\n    try {\r\n      const startTime = Date.now();\r\n      console.log('[Telemetry] Starting forceFlush...');\r\n\r\n      // forceFlush ensures all pending logs are exported immediately\r\n      await this.loggerProvider.forceFlush();\r\n\r\n      const duration = Date.now() - startTime;\r\n      console.log(\r\n        `[Telemetry] forceFlush completed successfully in ${duration}ms`\r\n      );\r\n    } catch (error) {\r\n      console.error('[Telemetry] Failed to force flush logs:', error);\r\n      throw error;\r\n    }\r\n  }\r\n\r\n  public async shutdown(): Promise<void> {\r\n    if (this.loggerProvider) {\r\n      await this.loggerProvider.shutdown();\r\n      this.initialized = false;\r\n    }\r\n  }\r\n\r\n  $onDestroy(): Promise<void> {\r\n    return this.shutdown();\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { TelemetryProvider } from './config';
|
|
2
|
+
export interface ErrorLogData {
|
|
3
|
+
error: Error;
|
|
4
|
+
context?: Record<string, any>;
|
|
5
|
+
accountUserUid?: string;
|
|
6
|
+
accountUid?: string;
|
|
7
|
+
requestId?: string;
|
|
8
|
+
endpoint?: string;
|
|
9
|
+
method?: string;
|
|
10
|
+
controller?: string;
|
|
11
|
+
controllerMethod?: string;
|
|
12
|
+
applicationUid?: string;
|
|
13
|
+
awsRequestId?: string;
|
|
14
|
+
}
|
|
15
|
+
export declare class TelemetryService {
|
|
16
|
+
private readonly telemetryProvider;
|
|
17
|
+
constructor(telemetryProvider: TelemetryProvider);
|
|
18
|
+
logError(data: ErrorLogData): Promise<void>;
|
|
19
|
+
logException(error: Error, context?: Record<string, any>): Promise<void>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.TelemetryService = void 0;
|
|
13
|
+
const api_logs_1 = require("@opentelemetry/api-logs");
|
|
14
|
+
class TelemetryService {
|
|
15
|
+
constructor(telemetryProvider) {
|
|
16
|
+
this.telemetryProvider = telemetryProvider;
|
|
17
|
+
}
|
|
18
|
+
logError(data) {
|
|
19
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
20
|
+
if (!this.telemetryProvider.isInitialized()) {
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
const loggerProvider = this.telemetryProvider.getLoggerProvider();
|
|
24
|
+
if (!loggerProvider) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
try {
|
|
28
|
+
const logger = loggerProvider.getLogger('cart-service-error-logger', '1.0.0');
|
|
29
|
+
const logRecord = {
|
|
30
|
+
severityNumber: api_logs_1.SeverityNumber.ERROR,
|
|
31
|
+
severityText: 'ERROR',
|
|
32
|
+
body: data.error.message,
|
|
33
|
+
attributes: {
|
|
34
|
+
'error.type': data.error.name,
|
|
35
|
+
'error.message': data.error.message,
|
|
36
|
+
'error.stack': data.error.stack || '',
|
|
37
|
+
'service.name': 'cart-service',
|
|
38
|
+
'accountUser.uid': data.accountUserUid || 'not provided',
|
|
39
|
+
'account.uid': data.accountUid || 'not provided',
|
|
40
|
+
'application.uid': data.applicationUid || 'not provided',
|
|
41
|
+
'request.id': data.requestId || 'not provided',
|
|
42
|
+
'aws.request.id': data.awsRequestId || 'not provided',
|
|
43
|
+
'http.endpoint': data.endpoint || 'not provided',
|
|
44
|
+
'http.method': data.method || 'not provided',
|
|
45
|
+
'controller.name': data.controller || 'not provided',
|
|
46
|
+
'controller.method': data.controllerMethod || 'not provided',
|
|
47
|
+
'error.context': JSON.stringify(data.context) || 'not provided',
|
|
48
|
+
timestamp: new Date().toISOString(),
|
|
49
|
+
},
|
|
50
|
+
};
|
|
51
|
+
logger.emit(logRecord);
|
|
52
|
+
yield this.telemetryProvider.forceFlush();
|
|
53
|
+
}
|
|
54
|
+
catch (error) {
|
|
55
|
+
console.error('[TelemetryService] Failed to log error:', error);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
logException(error, context) {
|
|
60
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
yield this.logError({
|
|
62
|
+
error,
|
|
63
|
+
context,
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
exports.TelemetryService = TelemetryService;
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXh0ZXJuYWwtc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2aWNlcy90ZWxlbWV0cnkvZXh0ZXJuYWwtc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFBQSxzREFBeUQ7QUFpQnpELE1BQWEsZ0JBQWdCO0lBQzNCLFlBQTZCLGlCQUFvQztRQUFwQyxzQkFBaUIsR0FBakIsaUJBQWlCLENBQW1CO0lBQUcsQ0FBQztJQUV4RCxRQUFRLENBQUMsSUFBa0I7O1lBQ3RDLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQztnQkFDNUMsT0FBTztZQUNULENBQUM7WUFFRCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNsRSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7Z0JBQ3BCLE9BQU87WUFDVCxDQUFDO1lBRUQsSUFBSSxDQUFDO2dCQUNILE1BQU0sTUFBTSxHQUFHLGNBQWMsQ0FBQyxTQUFTLENBQ3JDLDJCQUEyQixFQUMzQixPQUFPLENBQ1IsQ0FBQztnQkFFRixNQUFNLFNBQVMsR0FBRztvQkFDaEIsY0FBYyxFQUFFLHlCQUFjLENBQUMsS0FBSztvQkFDcEMsWUFBWSxFQUFFLE9BQU87b0JBQ3JCLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU87b0JBQ3hCLFVBQVUsRUFBRTt3QkFDVixZQUFZLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJO3dCQUM3QixlQUFlLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPO3dCQUNuQyxhQUFhLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksRUFBRTt3QkFDckMsY0FBYyxFQUFFLGNBQWM7d0JBQzlCLGlCQUFpQixFQUFFLElBQUksQ0FBQyxjQUFjLElBQUksY0FBYzt3QkFDeEQsYUFBYSxFQUFFLElBQUksQ0FBQyxVQUFVLElBQUksY0FBYzt3QkFDaEQsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLGNBQWMsSUFBSSxjQUFjO3dCQUN4RCxZQUFZLEVBQUUsSUFBSSxDQUFDLFNBQVMsSUFBSSxjQUFjO3dCQUM5QyxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsWUFBWSxJQUFJLGNBQWM7d0JBQ3JELGVBQWUsRUFBRSxJQUFJLENBQUMsUUFBUSxJQUFJLGNBQWM7d0JBQ2hELGFBQWEsRUFBRSxJQUFJLENBQUMsTUFBTSxJQUFJLGNBQWM7d0JBQzVDLGlCQUFpQixFQUFFLElBQUksQ0FBQyxVQUFVLElBQUksY0FBYzt3QkFDcEQsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixJQUFJLGNBQWM7d0JBQzVELGVBQWUsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxjQUFjO3dCQUMvRCxTQUFTLEVBQUUsSUFBSSxJQUFJLEVBQUUsQ0FBQyxXQUFXLEVBQUU7cUJBQ3BDO2lCQUNGLENBQUM7Z0JBRUYsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztnQkFLdkIsTUFBTSxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDNUMsQ0FBQztZQUFDLE9BQU8sS0FBSyxFQUFFLENBQUM7Z0JBQ2YsT0FBTyxDQUFDLEtBQUssQ0FBQyx5Q0FBeUMsRUFBRSxLQUFLLENBQUMsQ0FBQztZQUVsRSxDQUFDO1FBQ0gsQ0FBQztLQUFBO0lBRVksWUFBWSxDQUN2QixLQUFZLEVBQ1osT0FBNkI7O1lBRTdCLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQztnQkFDbEIsS0FBSztnQkFDTCxPQUFPO2FBQ1IsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztLQUFBO0NBQ0Y7QUEvREQsNENBK0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2V2ZXJpdHlOdW1iZXIgfSBmcm9tICdAb3BlbnRlbGVtZXRyeS9hcGktbG9ncyc7XHJcbmltcG9ydCB7IFRlbGVtZXRyeVByb3ZpZGVyIH0gZnJvbSAnLi9jb25maWcnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBFcnJvckxvZ0RhdGEge1xyXG4gIGVycm9yOiBFcnJvcjtcclxuICBjb250ZXh0PzogUmVjb3JkPHN0cmluZywgYW55PjtcclxuICBhY2NvdW50VXNlclVpZD86IHN0cmluZztcclxuICBhY2NvdW50VWlkPzogc3RyaW5nO1xyXG4gIHJlcXVlc3RJZD86IHN0cmluZztcclxuICBlbmRwb2ludD86IHN0cmluZztcclxuICBtZXRob2Q/OiBzdHJpbmc7XHJcbiAgY29udHJvbGxlcj86IHN0cmluZztcclxuICBjb250cm9sbGVyTWV0aG9kPzogc3RyaW5nO1xyXG4gIGFwcGxpY2F0aW9uVWlkPzogc3RyaW5nO1xyXG4gIGF3c1JlcXVlc3RJZD86IHN0cmluZztcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIFRlbGVtZXRyeVNlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgdGVsZW1ldHJ5UHJvdmlkZXI6IFRlbGVtZXRyeVByb3ZpZGVyKSB7fVxyXG5cclxuICBwdWJsaWMgYXN5bmMgbG9nRXJyb3IoZGF0YTogRXJyb3JMb2dEYXRhKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBpZiAoIXRoaXMudGVsZW1ldHJ5UHJvdmlkZXIuaXNJbml0aWFsaXplZCgpKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBsb2dnZXJQcm92aWRlciA9IHRoaXMudGVsZW1ldHJ5UHJvdmlkZXIuZ2V0TG9nZ2VyUHJvdmlkZXIoKTtcclxuICAgIGlmICghbG9nZ2VyUHJvdmlkZXIpIHtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG5cclxuICAgIHRyeSB7XHJcbiAgICAgIGNvbnN0IGxvZ2dlciA9IGxvZ2dlclByb3ZpZGVyLmdldExvZ2dlcihcclxuICAgICAgICAnY2FydC1zZXJ2aWNlLWVycm9yLWxvZ2dlcicsXHJcbiAgICAgICAgJzEuMC4wJ1xyXG4gICAgICApO1xyXG5cclxuICAgICAgY29uc3QgbG9nUmVjb3JkID0ge1xyXG4gICAgICAgIHNldmVyaXR5TnVtYmVyOiBTZXZlcml0eU51bWJlci5FUlJPUixcclxuICAgICAgICBzZXZlcml0eVRleHQ6ICdFUlJPUicsXHJcbiAgICAgICAgYm9keTogZGF0YS5lcnJvci5tZXNzYWdlLFxyXG4gICAgICAgIGF0dHJpYnV0ZXM6IHtcclxuICAgICAgICAgICdlcnJvci50eXBlJzogZGF0YS5lcnJvci5uYW1lLFxyXG4gICAgICAgICAgJ2Vycm9yLm1lc3NhZ2UnOiBkYXRhLmVycm9yLm1lc3NhZ2UsXHJcbiAgICAgICAgICAnZXJyb3Iuc3RhY2snOiBkYXRhLmVycm9yLnN0YWNrIHx8ICcnLFxyXG4gICAgICAgICAgJ3NlcnZpY2UubmFtZSc6ICdjYXJ0LXNlcnZpY2UnLFxyXG4gICAgICAgICAgJ2FjY291bnRVc2VyLnVpZCc6IGRhdGEuYWNjb3VudFVzZXJVaWQgfHwgJ25vdCBwcm92aWRlZCcsXHJcbiAgICAgICAgICAnYWNjb3VudC51aWQnOiBkYXRhLmFjY291bnRVaWQgfHwgJ25vdCBwcm92aWRlZCcsXHJcbiAgICAgICAgICAnYXBwbGljYXRpb24udWlkJzogZGF0YS5hcHBsaWNhdGlvblVpZCB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgICdyZXF1ZXN0LmlkJzogZGF0YS5yZXF1ZXN0SWQgfHwgJ25vdCBwcm92aWRlZCcsXHJcbiAgICAgICAgICAnYXdzLnJlcXVlc3QuaWQnOiBkYXRhLmF3c1JlcXVlc3RJZCB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgICdodHRwLmVuZHBvaW50JzogZGF0YS5lbmRwb2ludCB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgICdodHRwLm1ldGhvZCc6IGRhdGEubWV0aG9kIHx8ICdub3QgcHJvdmlkZWQnLFxyXG4gICAgICAgICAgJ2NvbnRyb2xsZXIubmFtZSc6IGRhdGEuY29udHJvbGxlciB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgICdjb250cm9sbGVyLm1ldGhvZCc6IGRhdGEuY29udHJvbGxlck1ldGhvZCB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgICdlcnJvci5jb250ZXh0JzogSlNPTi5zdHJpbmdpZnkoZGF0YS5jb250ZXh0KSB8fCAnbm90IHByb3ZpZGVkJyxcclxuICAgICAgICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b0lTT1N0cmluZygpLFxyXG4gICAgICAgIH0sXHJcbiAgICAgIH07XHJcblxyXG4gICAgICBsb2dnZXIuZW1pdChsb2dSZWNvcmQpO1xyXG5cclxuICAgICAgLy8gQ1JJVElDQUw6IEZvcmNlIGZsdXNoIHRvIGVuc3VyZSBsb2cgaXMgc2VudCBiZWZvcmUgTGFtYmRhIGZyZWV6ZXNcclxuICAgICAgLy8gV2l0aG91dCB0aGlzLCB0aGUgYXN5bmMgSFRUUCByZXF1ZXN0IG1heSBub3QgY29tcGxldGUgYmVmb3JlXHJcbiAgICAgIC8vIHRoZSBMYW1iZGEgZXhlY3V0aW9uIGNvbnRleHQgZnJlZXplc1xyXG4gICAgICBhd2FpdCB0aGlzLnRlbGVtZXRyeVByb3ZpZGVyLmZvcmNlRmx1c2goKTtcclxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XHJcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ1tUZWxlbWV0cnlTZXJ2aWNlXSBGYWlsZWQgdG8gbG9nIGVycm9yOicsIGVycm9yKTtcclxuICAgICAgLy8gRG9uJ3QgcmUtdGhyb3cgdG8gYXZvaWQgYnJlYWtpbmcgdGhlIGFwcGxpY2F0aW9uIGZsb3dcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBhc3luYyBsb2dFeGNlcHRpb24oXHJcbiAgICBlcnJvcjogRXJyb3IsXHJcbiAgICBjb250ZXh0PzogUmVjb3JkPHN0cmluZywgYW55PlxyXG4gICk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgYXdhaXQgdGhpcy5sb2dFcnJvcih7XHJcbiAgICAgIGVycm9yLFxyXG4gICAgICBjb250ZXh0LFxyXG4gICAgfSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./config"), exports);
|
|
18
|
+
__exportStar(require("./external-service"), exports);
|
|
19
|
+
__exportStar(require("../../telemetry"), exports);
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmljZXMvdGVsZW1ldHJ5L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwyQ0FBeUI7QUFDekIscURBQW1DO0FBQ25DLGtEQUFnQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29uZmlnJztcclxuZXhwb3J0ICogZnJvbSAnLi9leHRlcm5hbC1zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi4vLi4vdGVsZW1ldHJ5JztcclxuIl19
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { LogRecordProcessor, ReadableLogRecord } from '@opentelemetry/sdk-logs';
|
|
2
|
+
import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
|
|
3
|
+
import { Context } from '@opentelemetry/api';
|
|
4
|
+
export declare class SyncLogRecordProcessor implements LogRecordProcessor {
|
|
5
|
+
private readonly exporter;
|
|
6
|
+
private readonly pendingExports;
|
|
7
|
+
constructor(exporter: OTLPLogExporter);
|
|
8
|
+
onEmit(logRecord: ReadableLogRecord, _context?: Context): void;
|
|
9
|
+
forceFlush(): Promise<void>;
|
|
10
|
+
shutdown(): Promise<void>;
|
|
11
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.SyncLogRecordProcessor = void 0;
|
|
13
|
+
class SyncLogRecordProcessor {
|
|
14
|
+
constructor(exporter) {
|
|
15
|
+
this.pendingExports = [];
|
|
16
|
+
this.exporter = exporter;
|
|
17
|
+
}
|
|
18
|
+
onEmit(logRecord, _context) {
|
|
19
|
+
const exportPromise = new Promise((resolve, reject) => {
|
|
20
|
+
this.exporter.export([logRecord], (result) => {
|
|
21
|
+
if (result.code === 0) {
|
|
22
|
+
resolve();
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
console.error('[SyncLogRecordProcessor] Export failed:', result.error);
|
|
26
|
+
reject(result.error instanceof Error
|
|
27
|
+
? result.error
|
|
28
|
+
: new Error(String(result.error)));
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
})
|
|
32
|
+
.then(() => {
|
|
33
|
+
const index = this.pendingExports.indexOf(exportPromise);
|
|
34
|
+
if (index > -1) {
|
|
35
|
+
this.pendingExports.splice(index, 1);
|
|
36
|
+
}
|
|
37
|
+
})
|
|
38
|
+
.catch((error) => {
|
|
39
|
+
console.error('[SyncLogRecordProcessor] Export error:', error);
|
|
40
|
+
const index = this.pendingExports.indexOf(exportPromise);
|
|
41
|
+
if (index > -1) {
|
|
42
|
+
this.pendingExports.splice(index, 1);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
this.pendingExports.push(exportPromise);
|
|
46
|
+
}
|
|
47
|
+
forceFlush() {
|
|
48
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
49
|
+
console.log(`[SyncLogRecordProcessor] forceFlush called with ${this.pendingExports.length} pending exports`);
|
|
50
|
+
if (this.pendingExports.length === 0) {
|
|
51
|
+
console.log('[SyncLogRecordProcessor] No pending exports to flush');
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
try {
|
|
55
|
+
yield Promise.all(this.pendingExports);
|
|
56
|
+
console.log('[SyncLogRecordProcessor] All pending exports completed');
|
|
57
|
+
}
|
|
58
|
+
catch (error) {
|
|
59
|
+
console.error('[SyncLogRecordProcessor] Error during forceFlush:', error);
|
|
60
|
+
throw error;
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
shutdown() {
|
|
65
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
66
|
+
console.log('[SyncLogRecordProcessor] Shutting down...');
|
|
67
|
+
yield this.forceFlush();
|
|
68
|
+
yield this.exporter.shutdown();
|
|
69
|
+
console.log('[SyncLogRecordProcessor] Shutdown complete');
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
exports.SyncLogRecordProcessor = SyncLogRecordProcessor;
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3luYy1sb2ctcmVjb3JkLXByb2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2aWNlcy90ZWxlbWV0cnkvc3luYy1sb2ctcmVjb3JkLXByb2Nlc3Nvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFZQSxNQUFhLHNCQUFzQjtJQUlqQyxZQUFZLFFBQXlCO1FBRnBCLG1CQUFjLEdBQW9CLEVBQUUsQ0FBQztRQUdwRCxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUMzQixDQUFDO0lBRUQsTUFBTSxDQUFDLFNBQTRCLEVBQUUsUUFBa0I7UUFJckQsTUFBTSxhQUFhLEdBQUcsSUFBSSxPQUFPLENBQU8sQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDMUQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxFQUFFO2dCQUMzQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUM7b0JBQ3RCLE9BQU8sRUFBRSxDQUFDO2dCQUNaLENBQUM7cUJBQU0sQ0FBQztvQkFDTixPQUFPLENBQUMsS0FBSyxDQUNYLHlDQUF5QyxFQUN6QyxNQUFNLENBQUMsS0FBSyxDQUNiLENBQUM7b0JBQ0YsTUFBTSxDQUNKLE1BQU0sQ0FBQyxLQUFLLFlBQVksS0FBSzt3QkFDM0IsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLO3dCQUNkLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQ3BDLENBQUM7Z0JBQ0osQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDO2FBQ0MsSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNULE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBQ3pELElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ2YsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3ZDLENBQUM7UUFDSCxDQUFDLENBQUM7YUFDRCxLQUFLLENBQUMsQ0FBQyxLQUFjLEVBQUUsRUFBRTtZQUN4QixPQUFPLENBQUMsS0FBSyxDQUFDLHdDQUF3QyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQy9ELE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBQ3pELElBQUksS0FBSyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQ2YsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQ3ZDLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVMLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFSyxVQUFVOztZQUNkLE9BQU8sQ0FBQyxHQUFHLENBQ1QsbURBQW1ELElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxrQkFBa0IsQ0FDaEcsQ0FBQztZQUVGLElBQUksSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7Z0JBQ3JDLE9BQU8sQ0FBQyxHQUFHLENBQUMsc0RBQXNELENBQUMsQ0FBQztnQkFDcEUsT0FBTztZQUNULENBQUM7WUFFRCxJQUFJLENBQUM7Z0JBRUgsTUFBTSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztnQkFDdkMsT0FBTyxDQUFDLEdBQUcsQ0FBQyx3REFBd0QsQ0FBQyxDQUFDO1lBQ3hFLENBQUM7WUFBQyxPQUFPLEtBQUssRUFBRSxDQUFDO2dCQUNmLE9BQU8sQ0FBQyxLQUFLLENBQUMsbURBQW1ELEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQzFFLE1BQU0sS0FBSyxDQUFDO1lBQ2QsQ0FBQztRQUNILENBQUM7S0FBQTtJQUVLLFFBQVE7O1lBQ1osT0FBTyxDQUFDLEdBQUcsQ0FBQywyQ0FBMkMsQ0FBQyxDQUFDO1lBQ3pELE1BQU0sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3hCLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUMvQixPQUFPLENBQUMsR0FBRyxDQUFDLDRDQUE0QyxDQUFDLENBQUM7UUFDNUQsQ0FBQztLQUFBO0NBQ0Y7QUF4RUQsd0RBd0VDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTG9nUmVjb3JkUHJvY2Vzc29yLCBSZWFkYWJsZUxvZ1JlY29yZCB9IGZyb20gJ0BvcGVudGVsZW1ldHJ5L3Nkay1sb2dzJztcclxuaW1wb3J0IHsgT1RMUExvZ0V4cG9ydGVyIH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvZXhwb3J0ZXItbG9ncy1vdGxwLWh0dHAnO1xyXG5pbXBvcnQgeyBDb250ZXh0IH0gZnJvbSAnQG9wZW50ZWxlbWV0cnkvYXBpJztcclxuXHJcbi8qKlxyXG4gKiBDdXN0b20gTG9nUmVjb3JkUHJvY2Vzc29yIHRoYXQgZW5zdXJlcyBzeW5jaHJvbm91cyBleHBvcnQgZm9yIEFXUyBMYW1iZGFcclxuICpcclxuICogVGhpcyBwcm9jZXNzb3Igd3JhcHMgdGhlIE9UTFAgZXhwb3J0ZXIgYW5kIGVuc3VyZXMgdGhhdCBsb2dzIGFyZSBhY3R1YWxseVxyXG4gKiBleHBvcnRlZCBzeW5jaHJvbm91c2x5IGJ5IGltbWVkaWF0ZWx5IGNhbGxpbmcgZXhwb3J0KCkgYW5kIHdhaXRpbmcgZm9yIGl0XHJcbiAqIHRvIGNvbXBsZXRlLCByYXRoZXIgdGhhbiByZWx5aW5nIG9uIFNpbXBsZUxvZ1JlY29yZFByb2Nlc3NvciB3aGljaCBtYXkgbm90XHJcbiAqIHByb3Blcmx5IGF3YWl0IHRoZSBhc3luYyBIVFRQIHJlcXVlc3QgaW4gTGFtYmRhIGVudmlyb25tZW50cy5cclxuICovXHJcbmV4cG9ydCBjbGFzcyBTeW5jTG9nUmVjb3JkUHJvY2Vzc29yIGltcGxlbWVudHMgTG9nUmVjb3JkUHJvY2Vzc29yIHtcclxuICBwcml2YXRlIHJlYWRvbmx5IGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXI7XHJcbiAgcHJpdmF0ZSByZWFkb25seSBwZW5kaW5nRXhwb3J0czogUHJvbWlzZTx2b2lkPltdID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKGV4cG9ydGVyOiBPVExQTG9nRXhwb3J0ZXIpIHtcclxuICAgIHRoaXMuZXhwb3J0ZXIgPSBleHBvcnRlcjtcclxuICB9XHJcblxyXG4gIG9uRW1pdChsb2dSZWNvcmQ6IFJlYWRhYmxlTG9nUmVjb3JkLCBfY29udGV4dD86IENvbnRleHQpOiB2b2lkIHtcclxuICAgIC8vIEV4cG9ydCBpbW1lZGlhdGVseSBhbmQgdHJhY2sgdGhlIHByb21pc2VcclxuICAgIC8vIFRoZSBleHBvcnQgbWV0aG9kIHJldHVybnMgdm9pZCwgYnV0IGludGVybmFsbHkgdHJpZ2dlcnMgYXN5bmMgSFRUUCByZXF1ZXN0XHJcbiAgICAvLyBXZSBuZWVkIHRvIHdyYXAgaXQgdG8gdHJhY2sgY29tcGxldGlvblxyXG4gICAgY29uc3QgZXhwb3J0UHJvbWlzZSA9IG5ldyBQcm9taXNlPHZvaWQ+KChyZXNvbHZlLCByZWplY3QpID0+IHtcclxuICAgICAgdGhpcy5leHBvcnRlci5leHBvcnQoW2xvZ1JlY29yZF0sIChyZXN1bHQpID0+IHtcclxuICAgICAgICBpZiAocmVzdWx0LmNvZGUgPT09IDApIHtcclxuICAgICAgICAgIHJlc29sdmUoKTtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgY29uc29sZS5lcnJvcihcclxuICAgICAgICAgICAgJ1tTeW5jTG9nUmVjb3JkUHJvY2Vzc29yXSBFeHBvcnQgZmFpbGVkOicsXHJcbiAgICAgICAgICAgIHJlc3VsdC5lcnJvclxyXG4gICAgICAgICAgKTtcclxuICAgICAgICAgIHJlamVjdChcclxuICAgICAgICAgICAgcmVzdWx0LmVycm9yIGluc3RhbmNlb2YgRXJyb3JcclxuICAgICAgICAgICAgICA/IHJlc3VsdC5lcnJvclxyXG4gICAgICAgICAgICAgIDogbmV3IEVycm9yKFN0cmluZyhyZXN1bHQuZXJyb3IpKVxyXG4gICAgICAgICAgKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG4gICAgfSlcclxuICAgICAgLnRoZW4oKCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IGluZGV4ID0gdGhpcy5wZW5kaW5nRXhwb3J0cy5pbmRleE9mKGV4cG9ydFByb21pc2UpO1xyXG4gICAgICAgIGlmIChpbmRleCA+IC0xKSB7XHJcbiAgICAgICAgICB0aGlzLnBlbmRpbmdFeHBvcnRzLnNwbGljZShpbmRleCwgMSk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9KVxyXG4gICAgICAuY2F0Y2goKGVycm9yOiB1bmtub3duKSA9PiB7XHJcbiAgICAgICAgY29uc29sZS5lcnJvcignW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEV4cG9ydCBlcnJvcjonLCBlcnJvcik7XHJcbiAgICAgICAgY29uc3QgaW5kZXggPSB0aGlzLnBlbmRpbmdFeHBvcnRzLmluZGV4T2YoZXhwb3J0UHJvbWlzZSk7XHJcbiAgICAgICAgaWYgKGluZGV4ID4gLTEpIHtcclxuICAgICAgICAgIHRoaXMucGVuZGluZ0V4cG9ydHMuc3BsaWNlKGluZGV4LCAxKTtcclxuICAgICAgICB9XHJcbiAgICAgIH0pO1xyXG5cclxuICAgIHRoaXMucGVuZGluZ0V4cG9ydHMucHVzaChleHBvcnRQcm9taXNlKTtcclxuICB9XHJcblxyXG4gIGFzeW5jIGZvcmNlRmx1c2goKTogUHJvbWlzZTx2b2lkPiB7XHJcbiAgICBjb25zb2xlLmxvZyhcclxuICAgICAgYFtTeW5jTG9nUmVjb3JkUHJvY2Vzc29yXSBmb3JjZUZsdXNoIGNhbGxlZCB3aXRoICR7dGhpcy5wZW5kaW5nRXhwb3J0cy5sZW5ndGh9IHBlbmRpbmcgZXhwb3J0c2BcclxuICAgICk7XHJcblxyXG4gICAgaWYgKHRoaXMucGVuZGluZ0V4cG9ydHMubGVuZ3RoID09PSAwKSB7XHJcbiAgICAgIGNvbnNvbGUubG9nKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gTm8gcGVuZGluZyBleHBvcnRzIHRvIGZsdXNoJyk7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcbiAgICB0cnkge1xyXG4gICAgICAvLyBXYWl0IGZvciBhbGwgcGVuZGluZyBleHBvcnRzIHRvIGNvbXBsZXRlXHJcbiAgICAgIGF3YWl0IFByb21pc2UuYWxsKHRoaXMucGVuZGluZ0V4cG9ydHMpO1xyXG4gICAgICBjb25zb2xlLmxvZygnW1N5bmNMb2dSZWNvcmRQcm9jZXNzb3JdIEFsbCBwZW5kaW5nIGV4cG9ydHMgY29tcGxldGVkJyk7XHJcbiAgICB9IGNhdGNoIChlcnJvcikge1xyXG4gICAgICBjb25zb2xlLmVycm9yKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gRXJyb3IgZHVyaW5nIGZvcmNlRmx1c2g6JywgZXJyb3IpO1xyXG4gICAgICB0aHJvdyBlcnJvcjtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGFzeW5jIHNodXRkb3duKCk6IFByb21pc2U8dm9pZD4ge1xyXG4gICAgY29uc29sZS5sb2coJ1tTeW5jTG9nUmVjb3JkUHJvY2Vzc29yXSBTaHV0dGluZyBkb3duLi4uJyk7XHJcbiAgICBhd2FpdCB0aGlzLmZvcmNlRmx1c2goKTtcclxuICAgIGF3YWl0IHRoaXMuZXhwb3J0ZXIuc2h1dGRvd24oKTtcclxuICAgIGNvbnNvbGUubG9nKCdbU3luY0xvZ1JlY29yZFByb2Nlc3Nvcl0gU2h1dGRvd24gY29tcGxldGUnKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './middy';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./middy"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVsZW1ldHJ5L3NzdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMENBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taWRkeSc7XHJcbiJdfQ==
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './middleware';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./middleware"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGVsZW1ldHJ5L3NzdC9taWRkeS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsK0NBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taWRkbGV3YXJlJztcclxuIl19
|
|
@@ -0,0 +1,172 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.middyMiddleware = void 0;
|
|
13
|
+
const api_1 = require("@opentelemetry/api");
|
|
14
|
+
const telemetry_1 = require("../telemetry");
|
|
15
|
+
const perf_hooks_1 = require("perf_hooks");
|
|
16
|
+
const middyMiddleware = (options) => ({
|
|
17
|
+
before: (request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
18
|
+
const startTime = perf_hooks_1.performance.now();
|
|
19
|
+
const { context: lambdaContext } = request;
|
|
20
|
+
const functionName = lambdaContext.functionName;
|
|
21
|
+
const invocationId = lambdaContext.awsRequestId;
|
|
22
|
+
const serviceName = process.env.SERVICE_NAME || 'search-engine';
|
|
23
|
+
const event = request.event;
|
|
24
|
+
const queryStringParameters = (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {};
|
|
25
|
+
const origin = queryStringParameters.origin || 'unknown';
|
|
26
|
+
let stage = process.env.STAGE || 'development';
|
|
27
|
+
if (stage === 'prod')
|
|
28
|
+
stage = 'production';
|
|
29
|
+
const tracer = api_1.trace.getTracer(serviceName);
|
|
30
|
+
const meter = api_1.metrics.getMeter(origin);
|
|
31
|
+
const span = tracer.startSpan(functionName, {
|
|
32
|
+
kind: 1,
|
|
33
|
+
attributes: {
|
|
34
|
+
'faas.name': functionName,
|
|
35
|
+
'faas.invocation_id': invocationId,
|
|
36
|
+
origin,
|
|
37
|
+
'service.name': serviceName,
|
|
38
|
+
'deployment.environment.name': stage,
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
const executionTimeHistogram = meter.createHistogram('lambda_execution_duration', {
|
|
42
|
+
description: 'Tempo total de execução do Lambda em ms',
|
|
43
|
+
unit: 'ms',
|
|
44
|
+
valueType: api_1.ValueType.DOUBLE,
|
|
45
|
+
});
|
|
46
|
+
const successCounter = meter.createCounter('total_successful_purchases', {
|
|
47
|
+
description: 'Total de compras bem-sucedidas',
|
|
48
|
+
});
|
|
49
|
+
const failureCounter = meter.createCounter('total_failed_purchases', {
|
|
50
|
+
description: 'Total de compras com falha',
|
|
51
|
+
});
|
|
52
|
+
request.context.otel = {
|
|
53
|
+
span,
|
|
54
|
+
meter,
|
|
55
|
+
executionTimeHistogram,
|
|
56
|
+
successCounter,
|
|
57
|
+
failureCounter,
|
|
58
|
+
startTime,
|
|
59
|
+
};
|
|
60
|
+
}),
|
|
61
|
+
after: (request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
62
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
63
|
+
const otelData = request.context.otel;
|
|
64
|
+
if (!otelData)
|
|
65
|
+
return;
|
|
66
|
+
const event = request.event;
|
|
67
|
+
const queryStringParameters = (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {};
|
|
68
|
+
const origin = queryStringParameters.origin || 'unknown';
|
|
69
|
+
const { span, successCounter, executionTimeHistogram, startTime } = otelData;
|
|
70
|
+
span.setStatus({ code: api_1.SpanStatusCode.OK });
|
|
71
|
+
span.setAttribute('execution.success', true);
|
|
72
|
+
successCounter.add(1, {
|
|
73
|
+
origin,
|
|
74
|
+
'faas.name': ((_a = span.attributes) === null || _a === void 0 ? void 0 : _a['faas.name']) || 'unknown',
|
|
75
|
+
'service.name': ((_b = span.attributes) === null || _b === void 0 ? void 0 : _b['service.name']) || 'search-engine',
|
|
76
|
+
'deployment.environment.name': (_c = span.attributes) === null || _c === void 0 ? void 0 : _c['deployment.environment.name'],
|
|
77
|
+
});
|
|
78
|
+
const durationMs = perf_hooks_1.performance.now() - startTime;
|
|
79
|
+
executionTimeHistogram.record(durationMs, {
|
|
80
|
+
origin: ((_d = span.attributes) === null || _d === void 0 ? void 0 : _d['origin']) || 'unknown',
|
|
81
|
+
status: 'success',
|
|
82
|
+
'faas.name': ((_e = span.attributes) === null || _e === void 0 ? void 0 : _e['faas.name']) || 'unknown',
|
|
83
|
+
'service.name': ((_f = span.attributes) === null || _f === void 0 ? void 0 : _f['service.name']) || 'search-engine',
|
|
84
|
+
'deployment.environment.name': (_g = span.attributes) === null || _g === void 0 ? void 0 : _g['deployment.environment.name'],
|
|
85
|
+
});
|
|
86
|
+
const standardLogger = (0, telemetry_1.getStandardLogger)();
|
|
87
|
+
let stage = process.env.STAGE || 'development';
|
|
88
|
+
if (stage === 'prod')
|
|
89
|
+
stage = 'production';
|
|
90
|
+
yield standardLogger.logInfo({
|
|
91
|
+
message: 'Request completed successfully',
|
|
92
|
+
serviceName: ((_h = span.attributes) === null || _h === void 0 ? void 0 : _h['service.name']) || 'sst-service',
|
|
93
|
+
environment: stage,
|
|
94
|
+
execution: {
|
|
95
|
+
functionName: (_j = span.attributes) === null || _j === void 0 ? void 0 : _j['faas.name'],
|
|
96
|
+
invocationId: (_k = span.attributes) === null || _k === void 0 ? void 0 : _k['faas.invocation_id'],
|
|
97
|
+
origin,
|
|
98
|
+
},
|
|
99
|
+
performance: {
|
|
100
|
+
durationMs,
|
|
101
|
+
success: true,
|
|
102
|
+
},
|
|
103
|
+
});
|
|
104
|
+
span.end();
|
|
105
|
+
yield (0, telemetry_1.forceFlush)();
|
|
106
|
+
}),
|
|
107
|
+
onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
|
|
108
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s;
|
|
109
|
+
const otelData = request.context.otel;
|
|
110
|
+
if (!otelData)
|
|
111
|
+
return;
|
|
112
|
+
const event = request.event;
|
|
113
|
+
const queryStringParameters = (event === null || event === void 0 ? void 0 : event.queryStringParameters) || {};
|
|
114
|
+
const origin = queryStringParameters.origin || 'unknown';
|
|
115
|
+
const { span, failureCounter, executionTimeHistogram, startTime } = otelData;
|
|
116
|
+
const error = request.error;
|
|
117
|
+
span.recordException(error);
|
|
118
|
+
span.setStatus({
|
|
119
|
+
code: api_1.SpanStatusCode.ERROR,
|
|
120
|
+
message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error',
|
|
121
|
+
});
|
|
122
|
+
span.setAttribute('execution.success', false);
|
|
123
|
+
span.setAttribute('error.type', ((_a = error === null || error === void 0 ? void 0 : error.constructor) === null || _a === void 0 ? void 0 : _a.name) || 'UnknownError');
|
|
124
|
+
span.setAttribute('deployment.environment.name', ((_b = span.attributes) === null || _b === void 0 ? void 0 : _b['deployment.environment.name']) || 'development');
|
|
125
|
+
span.setAttribute('service.name', ((_c = span.attributes) === null || _c === void 0 ? void 0 : _c['service.name']) || 'providers-purchase-integrator');
|
|
126
|
+
span.setAttribute('faas.name', ((_d = span.attributes) === null || _d === void 0 ? void 0 : _d['faas.name']) || 'unknown');
|
|
127
|
+
span.setAttribute('origin', origin);
|
|
128
|
+
span.setAttribute('faas.invocation_id', (_e = span.attributes) === null || _e === void 0 ? void 0 : _e['faas.invocation_id']);
|
|
129
|
+
failureCounter.add(1, {
|
|
130
|
+
origin,
|
|
131
|
+
error_type: ((_f = error === null || error === void 0 ? void 0 : error.constructor) === null || _f === void 0 ? void 0 : _f.name) || 'UnknownError',
|
|
132
|
+
'faas.name': ((_g = span.attributes) === null || _g === void 0 ? void 0 : _g['faas.name']) || 'unknown',
|
|
133
|
+
'service.name': ((_h = span.attributes) === null || _h === void 0 ? void 0 : _h['service.name']) || 'search-engine',
|
|
134
|
+
'deployment.environment.name': (_j = span.attributes) === null || _j === void 0 ? void 0 : _j['deployment.environment.name'],
|
|
135
|
+
});
|
|
136
|
+
const durationMs = perf_hooks_1.performance.now() - startTime;
|
|
137
|
+
executionTimeHistogram.record(durationMs, {
|
|
138
|
+
origin: ((_k = span.attributes) === null || _k === void 0 ? void 0 : _k['origin']) || 'unknown',
|
|
139
|
+
status: 'error',
|
|
140
|
+
'faas.name': ((_l = span.attributes) === null || _l === void 0 ? void 0 : _l['faas.name']) || 'unknown',
|
|
141
|
+
'service.name': ((_m = span.attributes) === null || _m === void 0 ? void 0 : _m['service.name']) || 'search-engine',
|
|
142
|
+
'deployment.environment.name': (_o = span.attributes) === null || _o === void 0 ? void 0 : _o['deployment.environment.name'],
|
|
143
|
+
});
|
|
144
|
+
const standardLogger = (0, telemetry_1.getStandardLogger)();
|
|
145
|
+
let stage = process.env.STAGE || 'development';
|
|
146
|
+
if (stage === 'prod')
|
|
147
|
+
stage = 'production';
|
|
148
|
+
yield standardLogger.logError({
|
|
149
|
+
message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
|
|
150
|
+
error: error || undefined,
|
|
151
|
+
serviceName: ((_p = span.attributes) === null || _p === void 0 ? void 0 : _p['service.name']) || 'sst-service',
|
|
152
|
+
environment: stage,
|
|
153
|
+
execution: {
|
|
154
|
+
functionName: (_q = span.attributes) === null || _q === void 0 ? void 0 : _q['faas.name'],
|
|
155
|
+
invocationId: (_r = span.attributes) === null || _r === void 0 ? void 0 : _r['faas.invocation_id'],
|
|
156
|
+
awsRequestId: (_s = span.attributes) === null || _s === void 0 ? void 0 : _s['faas.invocation_id'],
|
|
157
|
+
origin,
|
|
158
|
+
},
|
|
159
|
+
performance: {
|
|
160
|
+
durationMs,
|
|
161
|
+
success: false,
|
|
162
|
+
},
|
|
163
|
+
context: {
|
|
164
|
+
queryStringParameters,
|
|
165
|
+
},
|
|
166
|
+
});
|
|
167
|
+
span.end();
|
|
168
|
+
yield (0, telemetry_1.forceFlush)();
|
|
169
|
+
}),
|
|
170
|
+
});
|
|
171
|
+
exports.middyMiddleware = middyMiddleware;
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/telemetry/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\r\nimport { trace, SpanStatusCode, metrics, ValueType } from '@opentelemetry/api';\r\nimport { forceFlush, getStandardLogger } from '../telemetry';\r\nimport { performance } from 'perf_hooks';\r\n\r\ninterface MiddyMiddlewareOptions {}\r\n\r\nexport const middyMiddleware = (\r\n  options?: MiddyMiddlewareOptions\r\n): middy.MiddlewareObj => ({\r\n  before: async (request) => {\r\n    const startTime = performance.now();\r\n\r\n    const { context: lambdaContext } = request;\r\n    const functionName = lambdaContext.functionName;\r\n    const invocationId = lambdaContext.awsRequestId;\r\n    const serviceName = process.env.SERVICE_NAME || 'search-engine';\r\n    const event = request.event as any;\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n    let stage = process.env.STAGE || 'development';\r\n    if (stage === 'prod') stage = 'production';\r\n\r\n    const tracer = trace.getTracer(serviceName);\r\n    const meter = metrics.getMeter(origin);\r\n\r\n    const span = tracer.startSpan(functionName, {\r\n      kind: 1,\r\n      attributes: {\r\n        'faas.name': functionName,\r\n        'faas.invocation_id': invocationId,\r\n        origin,\r\n        'service.name': serviceName,\r\n        'deployment.environment.name': stage,\r\n      },\r\n    });\r\n\r\n    const executionTimeHistogram = meter.createHistogram(\r\n      'lambda_execution_duration',\r\n      {\r\n        description: 'Tempo total de execução do Lambda em ms',\r\n        unit: 'ms',\r\n        valueType: ValueType.DOUBLE,\r\n      }\r\n    );\r\n    const successCounter = meter.createCounter('total_successful_purchases', {\r\n      description: 'Total de compras bem-sucedidas',\r\n    });\r\n    const failureCounter = meter.createCounter('total_failed_purchases', {\r\n      description: 'Total de compras com falha',\r\n    });\r\n\r\n    (request.context as any).otel = {\r\n      span,\r\n      meter,\r\n      executionTimeHistogram,\r\n      successCounter,\r\n      failureCounter,\r\n      startTime,\r\n    };\r\n  },\r\n\r\n  after: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n    const event = request.event as any;\r\n\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n\r\n    const { span, successCounter, executionTimeHistogram, startTime } =\r\n      otelData;\r\n\r\n    span.setStatus({ code: SpanStatusCode.OK });\r\n    span.setAttribute('execution.success', true);\r\n    successCounter.add(1, {\r\n      origin,\r\n      'faas.name': span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': span.attributes?.['service.name'] || 'search-engine',\r\n      'deployment.environment.name':\r\n        span.attributes?.['deployment.environment.name'],\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin: span.attributes?.['origin'] || 'unknown',\r\n      status: 'success',\r\n      'faas.name': span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': span.attributes?.['service.name'] || 'search-engine',\r\n      'deployment.environment.name':\r\n        span.attributes?.['deployment.environment.name'],\r\n    });\r\n\r\n    // Log estruturado de sucesso\r\n    const standardLogger = getStandardLogger();\r\n    let stage = process.env.STAGE || 'development';\r\n    if (stage === 'prod') stage = 'production';\r\n\r\n    await standardLogger.logInfo({\r\n      message: 'Request completed successfully',\r\n      serviceName:\r\n        (span.attributes?.['service.name'] as string) || 'sst-service',\r\n      environment: stage,\r\n      execution: {\r\n        functionName: span.attributes?.['faas.name'] as string,\r\n        invocationId: span.attributes?.['faas.invocation_id'] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: true,\r\n      },\r\n    });\r\n\r\n    span.end();\r\n    await forceFlush();\r\n  },\r\n\r\n  onError: async (request) => {\r\n    const otelData = (request.context as any).otel;\r\n    if (!otelData) return;\r\n    const event = request.event as any;\r\n\r\n    const queryStringParameters = event?.queryStringParameters || {};\r\n    const origin = queryStringParameters.origin || 'unknown';\r\n\r\n    const { span, failureCounter, executionTimeHistogram, startTime } =\r\n      otelData;\r\n    const error = request.error;\r\n\r\n    span.recordException(error);\r\n    span.setStatus({\r\n      code: SpanStatusCode.ERROR,\r\n      message: error?.message || 'Unknown error',\r\n    });\r\n    span.setAttribute('execution.success', false);\r\n    span.setAttribute('error.type', error?.constructor?.name || 'UnknownError');\r\n    span.setAttribute(\r\n      'deployment.environment.name',\r\n      span.attributes?.['deployment.environment.name'] || 'development'\r\n    );\r\n    span.setAttribute(\r\n      'service.name',\r\n      span.attributes?.['service.name'] || 'providers-purchase-integrator'\r\n    );\r\n    span.setAttribute('faas.name', span.attributes?.['faas.name'] || 'unknown');\r\n    span.setAttribute('origin', origin);\r\n    span.setAttribute(\r\n      'faas.invocation_id',\r\n      span.attributes?.['faas.invocation_id']\r\n    );\r\n\r\n    failureCounter.add(1, {\r\n      origin,\r\n      error_type: error?.constructor?.name || 'UnknownError',\r\n      'faas.name': span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': span.attributes?.['service.name'] || 'search-engine',\r\n      'deployment.environment.name':\r\n        span.attributes?.['deployment.environment.name'],\r\n    });\r\n\r\n    const durationMs = performance.now() - startTime;\r\n\r\n    executionTimeHistogram.record(durationMs, {\r\n      origin: span.attributes?.['origin'] || 'unknown',\r\n      status: 'error',\r\n      'faas.name': span.attributes?.['faas.name'] || 'unknown',\r\n      'service.name': span.attributes?.['service.name'] || 'search-engine',\r\n      'deployment.environment.name':\r\n        span.attributes?.['deployment.environment.name'],\r\n    });\r\n\r\n    // Log estruturado de erro\r\n    const standardLogger = getStandardLogger();\r\n    let stage = process.env.STAGE || 'development';\r\n    if (stage === 'prod') stage = 'production';\r\n\r\n    await standardLogger.logError({\r\n      message: error?.message || 'Unknown error occurred',\r\n      error: error || undefined,\r\n      serviceName:\r\n        (span.attributes?.['service.name'] as string) || 'sst-service',\r\n      environment: stage,\r\n      execution: {\r\n        functionName: span.attributes?.['faas.name'] as string,\r\n        invocationId: span.attributes?.['faas.invocation_id'] as string,\r\n        awsRequestId: span.attributes?.['faas.invocation_id'] as string,\r\n        origin,\r\n      },\r\n      performance: {\r\n        durationMs,\r\n        success: false,\r\n      },\r\n      context: {\r\n        queryStringParameters,\r\n      },\r\n    });\r\n\r\n    span.end();\r\n    await forceFlush();\r\n  },\r\n});\r\n"]}
|