@mecanizou/telemetry-hub 1.4.2 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,17 @@
1
+ # [1.5.0](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.4.2...v1.5.0) (2026-03-19)
2
+
3
+
4
+ ### Features
5
+
6
+ * Implemented logic on telemetry middleware to allow functions to use mecaniError as a parameter to determine which message should be launched ([c506b58](https://github.com/mecanizou-eco/telemetry-hub/commit/c506b589134789f93d68091659d8e9a4a93a6983))
7
+
8
+ ## [Unreleased]
9
+
10
+
11
+ ### Bug Fixes
12
+
13
+ * **sst/middy/middleware:** corrige `origin is not defined` no hook `onError` quando `checkMecaniError` é true ao repassar `origin` para `buildErrorContext` na trilha de `MecaniError`.
14
+
1
15
  ## [1.4.2](https://github.com/mecanizou-eco/telemetry-hub/compare/v1.4.1...v1.4.2) (2026-03-17)
2
16
 
3
17
 
@@ -1,5 +1,6 @@
1
1
  import middy from '@middy/core';
2
2
  interface MiddyMiddlewareOptions {
3
+ checkMecaniError: boolean;
3
4
  }
4
5
  export declare const middyTelemetryMiddleware: (options?: MiddyMiddlewareOptions) => middy.MiddlewareObj;
5
6
  export {};
@@ -11,6 +11,7 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.middyTelemetryMiddleware = void 0;
13
13
  const api_1 = require("@opentelemetry/api");
14
+ const mecanizou_errors_1 = require("mecanizou-errors");
14
15
  const node_perf_hooks_1 = require("node:perf_hooks");
15
16
  const telemetry_1 = require("../telemetry");
16
17
  const extraction_1 = require("../extraction");
@@ -107,7 +108,7 @@ const middyTelemetryMiddleware = (options) => ({
107
108
  }
108
109
  }),
109
110
  onError: (request) => __awaiter(void 0, void 0, void 0, function* () {
110
- var _a, _b, _c, _d, _e, _f, _g;
111
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
111
112
  try {
112
113
  const otelData = request.context.otel;
113
114
  if (!otelData)
@@ -117,12 +118,12 @@ const middyTelemetryMiddleware = (options) => ({
117
118
  if (error) {
118
119
  spanResult.setError(error);
119
120
  }
120
- const functionName = ((_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']['name']) || 'unknown';
121
- const requestId = ((_b = spanResult.span.attributes) === null || _b === void 0 ? void 0 : _b['requestId']) || 'unknown';
122
- const routeKey = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['http']['routeKey']) || 'unknown';
121
+ const functionName = ((_b = (_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']) === null || _b === void 0 ? void 0 : _b['name']) || 'unknown';
122
+ const requestId = ((_c = spanResult.span.attributes) === null || _c === void 0 ? void 0 : _c['requestId']) || 'unknown';
123
+ const routeKey = ((_e = (_d = spanResult.span.attributes) === null || _d === void 0 ? void 0 : _d['http']) === null || _e === void 0 ? void 0 : _e['routeKey']) || 'unknown';
123
124
  failureCounter.add(1, {
124
125
  origin,
125
- error_type: ((_d = error === null || error === void 0 ? void 0 : error.constructor) === null || _d === void 0 ? void 0 : _d.name) || 'UnknownError',
126
+ error_type: ((_f = error === null || error === void 0 ? void 0 : error.constructor) === null || _f === void 0 ? void 0 : _f.name) || 'UnknownError',
126
127
  functionName: functionName,
127
128
  requestId: requestId,
128
129
  routeKey: routeKey,
@@ -143,24 +144,38 @@ const middyTelemetryMiddleware = (options) => ({
143
144
  scopeAttributes: spanResult.span.attributes,
144
145
  forceNewInstance: true,
145
146
  });
146
- yield standardLogger.logError({
147
- message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
148
- error: error || undefined,
149
- environment,
150
- execution: {
151
- awsRequestId: (_f = (_e = spanResult.span.attributes) === null || _e === void 0 ? void 0 : _e['function']) === null || _f === void 0 ? void 0 : _f['aws_request_id'],
152
- origin,
153
- routeKey: routeKey,
154
- requestId: requestId,
155
- },
156
- performance: {
147
+ if (!(options === null || options === void 0 ? void 0 : options.checkMecaniError)) {
148
+ yield standardLogger.logError({
149
+ message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
150
+ error: error || undefined,
151
+ environment,
152
+ execution: {
153
+ awsRequestId: (_h = (_g = spanResult.span.attributes) === null || _g === void 0 ? void 0 : _g['function']) === null || _h === void 0 ? void 0 : _h['aws_request_id'],
154
+ origin,
155
+ routeKey: routeKey,
156
+ requestId: requestId,
157
+ },
158
+ performance: {
159
+ durationMs,
160
+ success: false,
161
+ },
162
+ context: {
163
+ errorType: (_j = error === null || error === void 0 ? void 0 : error.constructor) === null || _j === void 0 ? void 0 : _j.name,
164
+ },
165
+ });
166
+ }
167
+ else if (error) {
168
+ yield launchMecaniErrorLogMessage({
169
+ error,
170
+ standardLogger,
171
+ environment,
172
+ spanResult,
157
173
  durationMs,
158
- success: false,
159
- },
160
- context: {
161
- errorType: (_g = error === null || error === void 0 ? void 0 : error.constructor) === null || _g === void 0 ? void 0 : _g.name,
162
- },
163
- });
174
+ requestId,
175
+ routeKey,
176
+ origin
177
+ });
178
+ }
164
179
  spanResult.end();
165
180
  yield (0, telemetry_1.forceFlush)();
166
181
  }
@@ -170,4 +185,64 @@ const middyTelemetryMiddleware = (options) => ({
170
185
  }),
171
186
  });
172
187
  exports.middyTelemetryMiddleware = middyTelemetryMiddleware;
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { performance } from 'node:perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\n\ninterface MiddyMiddlewareOptions {}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware before hook:',\n        error\n      );\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware after hook:',\n        error\n      );\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        failureCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n        origin,\n      } = otelData;\n      const error = request.error;\n\n      // Marcar span como erro usando StandardTracer\n      if (error) {\n        spanResult.setError(error);\n      }\n\n      const functionName =\n        spanResult.span.attributes?.['function']['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logError({\n        message: error?.message || 'Unknown error occurred',\n        error: error || undefined,\n        environment,\n        execution: {\n          awsRequestId:\n            spanResult.span.attributes?.['function']?.['aws_request_id'],\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: false,\n        },\n        context: {\n          errorType: error?.constructor?.name,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware onError hook:',\n        error\n      );\n    }\n  },\n});\n"]}
188
+ const buildErrorContext = ({ message, error, environment, spanResult, durationMs, requestId, routeKey, errorEnum, origin, }) => {
189
+ var _a, _b, _c;
190
+ return ({
191
+ message,
192
+ error: error || undefined,
193
+ environment,
194
+ execution: {
195
+ awsRequestId: (_b = (_a = spanResult.span.attributes) === null || _a === void 0 ? void 0 : _a['function']) === null || _b === void 0 ? void 0 : _b['aws_request_id'],
196
+ origin,
197
+ routeKey,
198
+ requestId,
199
+ },
200
+ performance: {
201
+ durationMs,
202
+ success: false,
203
+ },
204
+ context: {
205
+ errorType: (_c = error === null || error === void 0 ? void 0 : error.constructor) === null || _c === void 0 ? void 0 : _c.name,
206
+ errorEnum,
207
+ },
208
+ });
209
+ };
210
+ const isMecaniError = (error) => {
211
+ const isWarning = (error === null || error === void 0 ? void 0 : error.name) === 'Warning';
212
+ const isException = (error === null || error === void 0 ? void 0 : error.name) === 'Exception';
213
+ return isWarning || isException || (0, mecanizou_errors_1.isMecaniError)(error);
214
+ };
215
+ const getErrorMessageAndEnum = (error) => {
216
+ if (isMecaniError(error)) {
217
+ const mecaniError = error;
218
+ return {
219
+ message: mecaniError.errorDetails,
220
+ errorEnum: mecaniError.errorEnum,
221
+ };
222
+ }
223
+ return {
224
+ message: (error === null || error === void 0 ? void 0 : error.message) || 'Unknown error occurred',
225
+ errorEnum: 'UNDEFINED_ERROR',
226
+ };
227
+ };
228
+ const launchMecaniErrorLogMessage = (_a) => __awaiter(void 0, [_a], void 0, function* ({ error, standardLogger, environment, spanResult, durationMs, requestId, routeKey, origin }) {
229
+ const { message, errorEnum } = getErrorMessageAndEnum(error);
230
+ const context = buildErrorContext({
231
+ message,
232
+ error,
233
+ environment,
234
+ spanResult,
235
+ durationMs,
236
+ requestId,
237
+ routeKey,
238
+ errorEnum,
239
+ origin,
240
+ });
241
+ if ((error === null || error === void 0 ? void 0 : error.name) === 'Warning') {
242
+ return yield standardLogger.logWarn(context);
243
+ }
244
+ else {
245
+ return yield standardLogger.logError(context);
246
+ }
247
+ });
248
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"middleware.js","sourceRoot":"","sources":["../../../src/sst/middy/middleware.ts"],"names":[],"mappings":"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","sourcesContent":["import middy from '@middy/core';\nimport { metrics, ValueType } from '@opentelemetry/api';\nimport { isMecaniError as mecaniErrorVerification, MecaniError } from 'mecanizou-errors';\nimport { performance } from 'node:perf_hooks';\nimport { forceFlush, getStandardLogger, getStandardTracer } from '../telemetry';\nimport { extractDefaultAttributes } from '../extraction';\nimport { StandardLogger, StandardSpanResult } from '../../core';\n\ninterface MiddyMiddlewareOptions {\n  checkMecaniError: boolean\n}\n\nexport const middyTelemetryMiddleware = (\n  options?: MiddyMiddlewareOptions\n): middy.MiddlewareObj => ({\n  before: async (request) => {\n    try {\n      const startTime = performance.now();\n\n      const attributes = extractDefaultAttributes(request) as any;\n\n      // Usar StandardTracer para criar span com atributos padronizados\n      const standardTracer = getStandardTracer();\n      const spanResult = standardTracer.startSpan({\n        ...attributes,\n        spanName: attributes.functionName,\n        environment: attributes.stage,\n        execution: {\n          awsRequestId: attributes.invocationId,\n          origin: attributes.origin,\n          routeKey: attributes.routeKey,\n          requestId: attributes.requestId,\n        },\n      });\n\n      const meter = metrics.getMeter(attributes.origin);\n\n      const executionTimeHistogram = meter.createHistogram(\n        'lambda_execution_duration',\n        {\n          description: 'Tempo total de execução do Lambda em ms',\n          unit: 'ms',\n          valueType: ValueType.DOUBLE,\n        }\n      );\n      const successCounter = meter.createCounter('total_successful', {\n        description: 'Total de operações bem-sucedidas',\n      });\n      const failureCounter = meter.createCounter('total_failed', {\n        description: 'Total de operações com falha',\n      });\n\n      (request.context as any).otel = {\n        spanResult,\n        meter,\n        executionTimeHistogram,\n        successCounter,\n        failureCounter,\n        startTime,\n        serviceName: attributes.serviceName,\n        environment: attributes.stage,\n        origin: attributes.origin,\n        routeKey: attributes.routeKey,\n        requestId: attributes.requestId,\n      };\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware before hook:',\n        error\n      );\n    }\n  },\n\n  after: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        successCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n      } = otelData;\n\n      const attributes = extractDefaultAttributes(request) as any;\n      const origin = attributes.origin || 'unknown';\n\n      // Marcar span como sucesso usando StandardTracer\n      spanResult.setSuccess(true);\n\n      const functionName = spanResult.span.attributes?.['function']?.['name'];\n      const routeKey = spanResult.span.attributes?.['http']?.['routeKey'];\n      const requestId =\n        spanResult.span.attributes?.['execution']?.['requestId'];\n\n      // Métricas\n      successCounter.add(1, {\n        origin,\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'success',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n      // Log estruturado de sucesso\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      await standardLogger.logInfo({\n        message: 'Request completed successfully',\n        ...attributes,\n        execution: {\n          origin,\n          routeKey: routeKey,\n          requestId: requestId,\n        },\n        performance: {\n          durationMs,\n          success: true,\n        },\n      });\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware after hook:',\n        error\n      );\n    }\n  },\n\n  onError: async (request) => {\n    try {\n      const otelData = (request.context as any).otel;\n      if (!otelData) return;\n\n      const {\n        spanResult,\n        failureCounter,\n        executionTimeHistogram,\n        startTime,\n        serviceName,\n        environment,\n        origin,\n      } = otelData;\n      const error = request.error;\n\n      // Marcar span como erro usando StandardTracer\n      if (error) {\n        spanResult.setError(error);\n      }\n\n      const functionName =\n        spanResult.span.attributes?.['function']?.['name'] || 'unknown';\n      const requestId = spanResult.span.attributes?.['requestId'] || 'unknown';\n      const routeKey =\n        spanResult.span.attributes?.['http']?.['routeKey'] || 'unknown';\n\n      // Métricas\n      failureCounter.add(1, {\n        origin,\n        error_type: error?.constructor?.name || 'UnknownError',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      const durationMs = performance.now() - startTime;\n\n      executionTimeHistogram.record(durationMs, {\n        origin,\n        status: 'error',\n        functionName: functionName,\n        requestId: requestId,\n        routeKey: routeKey,\n        serviceName: serviceName,\n        environmentName: environment,\n      });\n\n      // Log estruturado de erro\n      const standardLogger = getStandardLogger({\n        scopeAttributes: spanResult.span.attributes,\n        forceNewInstance: true,\n      });\n\n      if (!options?.checkMecaniError) {\n        await standardLogger.logError({\n          message: error?.message || 'Unknown error occurred',\n          error: error || undefined,\n          environment,\n          execution: {\n            awsRequestId:\n              spanResult.span.attributes?.['function']?.['aws_request_id'],\n            origin,\n            routeKey: routeKey,\n            requestId: requestId,\n          },\n          performance: {\n            durationMs,\n            success: false,\n          },\n          context: {\n            errorType: error?.constructor?.name,\n          },\n        });\n      } else if (error) {\n        await launchMecaniErrorLogMessage({ \n          error,\n          standardLogger,\n          environment,\n          spanResult,\n          durationMs,\n          requestId,\n          routeKey,\n          origin\n        })\n      }\n\n\n      // Finalizar span\n      spanResult.end();\n      await forceFlush();\n    } catch (error) {\n      console.error(\n        '[Telemetry] Error in middyTelemetryMiddleware onError hook:',\n        error\n      );\n    }\n  },\n});\n\nconst buildErrorContext = ({ \n  message,\n  error,\n  environment,\n  spanResult,\n  durationMs,\n  requestId,\n  routeKey,\n  errorEnum,\n  origin,\n}: {\n  message: string;\n  error: Error;\n  errorEnum: string;\n  environment: string;\n  spanResult: any;\n  durationMs: number;\n  routeKey: any;\n  requestId: any;\n  origin: string;\n}) => ({\n  message,\n  error: error || undefined,\n  environment,\n  execution: {\n    awsRequestId:\n      spanResult.span.attributes?.['function']?.['aws_request_id'],\n    origin,\n    routeKey,\n    requestId,\n  },\n  performance: {\n    durationMs,\n    success: false,\n  },\n  context: {\n    errorType: error?.constructor?.name,\n    errorEnum,\n  },\n});\n\nconst isMecaniError = (error: Error): boolean => {\n  const isWarning = error?.name === 'Warning'\n  const isException = error?.name === 'Exception'\n\n  return isWarning || isException || mecaniErrorVerification(error)\n}\n\nconst getErrorMessageAndEnum = (error: Error) => {\n  if (isMecaniError(error)) {\n    const mecaniError = error as MecaniError;\n\n    return {\n      message: mecaniError.errorDetails,\n      errorEnum: mecaniError.errorEnum,\n    }\n  }\n\n  return {\n    message: error?.message || 'Unknown error occurred',\n    errorEnum: 'UNDEFINED_ERROR',\n  }\n}\n\nconst launchMecaniErrorLogMessage = async ({ \n  error,\n  standardLogger,\n  environment,\n  spanResult,\n  durationMs,\n  requestId,\n  routeKey,\n  origin\n}: {\n  standardLogger: StandardLogger\n  error: Error;\n  environment: string;\n  spanResult: any;\n  durationMs: number;\n  routeKey: any;\n  requestId: any;\n  origin: string;\n  }): Promise<void> => {\n  \n  const { message, errorEnum } = getErrorMessageAndEnum(error);\n\n  const context = buildErrorContext({\n    message,\n    error,\n    environment,\n    spanResult,\n    durationMs,\n    requestId,\n    routeKey,\n    errorEnum,\n    origin,\n  });\n\n  if (error?.name === 'Warning') {\n    return await standardLogger.logWarn(context);\n  } else {\n    return await standardLogger.logError(context);\n  }\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mecanizou/telemetry-hub",
3
- "version": "1.4.2",
3
+ "version": "1.5.0",
4
4
  "description": "Mecanizou telemetry lib",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -26,6 +26,7 @@
26
26
  "eslint-plugin-prettier": "^5.5.4",
27
27
  "lint-staged": "^13.3.0",
28
28
  "prettier": "^3.6.2",
29
+ "mecanizou-errors": "^1.1.0",
29
30
  "semantic-release": "^25.0.2",
30
31
  "typescript": "^5.9.3",
31
32
  "vitest": "^4.0.13"