sm-utility 2.4.23 → 2.4.25

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "sm-utility",
3
- "version": "2.4.23",
3
+ "version": "2.4.25",
4
4
  "description": "reusable utility codes for sm projects",
5
5
  "main": "index.js",
6
6
  "types": "./index.d.ts",
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.logError = void 0;
4
4
  const logger_1 = require("../../logger");
5
+ const tracing_1 = require("../../tracing");
5
6
  function logError(id, method, url, data, status, message) {
6
7
  const err = {
7
8
  ["context-id"]: id,
@@ -11,6 +12,14 @@ function logError(id, method, url, data, status, message) {
11
12
  status,
12
13
  message,
13
14
  };
15
+ const traceId = tracing_1.TracingContextProvider.getTraceId();
16
+ if (traceId) {
17
+ err['trace.id'] = traceId;
18
+ }
19
+ const spanId = tracing_1.TracingContextProvider.getSpanId();
20
+ if (spanId) {
21
+ err['span.id'] = spanId;
22
+ }
14
23
  logger_1.logger.error("sm-utility/api-error", { err });
15
24
  }
16
25
  exports.logError = logError;
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.logRequest = void 0;
4
4
  const logger_1 = require("../../logger");
5
+ const tracing_1 = require("../../tracing");
5
6
  function logRequest(id, method, url, body, params) {
6
7
  const request = {
7
8
  ["context-id"]: id,
@@ -10,6 +11,14 @@ function logRequest(id, method, url, body, params) {
10
11
  params,
11
12
  body,
12
13
  };
14
+ const traceId = tracing_1.TracingContextProvider.getTraceId();
15
+ if (traceId) {
16
+ request['trace.id'] = traceId;
17
+ }
18
+ const spanId = tracing_1.TracingContextProvider.getSpanId();
19
+ if (spanId) {
20
+ request['span.id'] = spanId;
21
+ }
13
22
  logger_1.logger.info("sm-utility/api-request", { request });
14
23
  }
15
24
  exports.logRequest = logRequest;
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.logResponse = void 0;
4
4
  const logger_1 = require("../../logger");
5
+ const tracing_1 = require("../../tracing");
5
6
  function logResponse(id, method, url, body, status, responseTime) {
6
7
  const response = {
7
8
  ["context-id"]: id,
@@ -11,6 +12,14 @@ function logResponse(id, method, url, body, status, responseTime) {
11
12
  status,
12
13
  responseTime,
13
14
  };
15
+ const traceId = tracing_1.TracingContextProvider.getTraceId();
16
+ if (traceId) {
17
+ response['trace.id'] = traceId;
18
+ }
19
+ const spanId = tracing_1.TracingContextProvider.getSpanId();
20
+ if (spanId) {
21
+ response['span.id'] = spanId;
22
+ }
14
23
  logger_1.logger.info("sm-utility/api-response", { response });
15
24
  }
16
25
  exports.logResponse = logResponse;
@@ -1,2 +1,3 @@
1
1
  export { OpenTelemetryTracer } from "./opentelemetry-tracer";
2
2
  export type { TracingConfig } from "./opentelemetry-tracer";
3
+ export { TracingContextProvider } from "./tracingContextProvider";
package/tracing/index.js CHANGED
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.OpenTelemetryTracer = void 0;
3
+ exports.TracingContextProvider = exports.OpenTelemetryTracer = void 0;
4
4
  var opentelemetry_tracer_1 = require("./opentelemetry-tracer");
5
5
  Object.defineProperty(exports, "OpenTelemetryTracer", { enumerable: true, get: function () { return opentelemetry_tracer_1.OpenTelemetryTracer; } });
6
+ var tracingContextProvider_1 = require("./tracingContextProvider");
7
+ Object.defineProperty(exports, "TracingContextProvider", { enumerable: true, get: function () { return tracingContextProvider_1.TracingContextProvider; } });
@@ -0,0 +1,10 @@
1
+ export declare class TracingContextProvider {
2
+ /**
3
+ * Returns the canonical OpenTelemetry trace id (32 hex chars)
4
+ */
5
+ static getTraceId(): string | undefined;
6
+ /**
7
+ * Returns the current span id (16 hex chars)
8
+ */
9
+ static getSpanId(): string | undefined;
10
+ }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TracingContextProvider = void 0;
4
+ const api_1 = require("@opentelemetry/api");
5
+ class TracingContextProvider {
6
+ /**
7
+ * Returns the canonical OpenTelemetry trace id (32 hex chars)
8
+ */
9
+ static getTraceId() {
10
+ var _a;
11
+ const span = api_1.trace.getSpan(api_1.context.active());
12
+ return (_a = span === null || span === void 0 ? void 0 : span.spanContext()) === null || _a === void 0 ? void 0 : _a.traceId;
13
+ }
14
+ /**
15
+ * Returns the current span id (16 hex chars)
16
+ */
17
+ static getSpanId() {
18
+ var _a;
19
+ const span = api_1.trace.getSpan(api_1.context.active());
20
+ return (_a = span === null || span === void 0 ? void 0 : span.spanContext()) === null || _a === void 0 ? void 0 : _a.spanId;
21
+ }
22
+ }
23
+ exports.TracingContextProvider = TracingContextProvider;