langwatch 0.8.2 → 0.10.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.
Files changed (70) hide show
  1. package/dist/{add-EY2WXUSP.mjs → add-5FRWEQ32.mjs} +5 -5
  2. package/dist/{add-GEM46CRC.js → add-CXUS4ZSQ.js} +8 -8
  3. package/dist/{add-GEM46CRC.js.map → add-CXUS4ZSQ.js.map} +1 -1
  4. package/dist/{chunk-BP2WGNIV.js → chunk-A43BYF5Q.js} +6 -2
  5. package/dist/chunk-A43BYF5Q.js.map +1 -0
  6. package/dist/{chunk-KLVHQVMF.js → chunk-BTCJWUS5.js} +14 -14
  7. package/dist/{chunk-KLVHQVMF.js.map → chunk-BTCJWUS5.js.map} +1 -1
  8. package/dist/{chunk-PLCZYSRL.mjs → chunk-I3X7VMSP.mjs} +136 -60
  9. package/dist/chunk-I3X7VMSP.mjs.map +1 -0
  10. package/dist/{chunk-SRI6HEGF.js → chunk-NM5OKM7F.js} +142 -66
  11. package/dist/chunk-NM5OKM7F.js.map +1 -0
  12. package/dist/{chunk-VJV532JA.mjs → chunk-VGVWXKVM.mjs} +2 -2
  13. package/dist/{chunk-GNKQTK4I.mjs → chunk-W6FD5ZO3.mjs} +2 -2
  14. package/dist/chunk-W6FD5ZO3.mjs.map +1 -0
  15. package/dist/{chunk-DQU2PZAL.mjs → chunk-WHPBZSTS.mjs} +6 -2
  16. package/dist/chunk-WHPBZSTS.mjs.map +1 -0
  17. package/dist/{chunk-ZNWSX2QV.js → chunk-YWO3NE5A.js} +2 -2
  18. package/dist/chunk-YWO3NE5A.js.map +1 -0
  19. package/dist/cli/index.js +6 -6
  20. package/dist/cli/index.js.map +1 -1
  21. package/dist/cli/index.mjs +6 -6
  22. package/dist/cli/index.mjs.map +1 -1
  23. package/dist/{implementation-TF91Gn0l.d.ts → implementation-CPxv2BdW.d.ts} +1 -1
  24. package/dist/{implementation-pq0g2B5y.d.mts → implementation-CVrmD0bz.d.mts} +1 -1
  25. package/dist/index.d.mts +42 -31
  26. package/dist/index.d.ts +42 -31
  27. package/dist/index.js +14 -12
  28. package/dist/index.js.map +1 -1
  29. package/dist/index.mjs +8 -6
  30. package/dist/index.mjs.map +1 -1
  31. package/dist/{list-GCZWLGUG.mjs → list-DQ6XLQCK.mjs} +5 -5
  32. package/dist/{list-DRJJH66J.js → list-K6E3OGYH.js} +8 -8
  33. package/dist/{list-DRJJH66J.js.map → list-K6E3OGYH.js.map} +1 -1
  34. package/dist/{login-S4O6A5OF.js → login-HX7WMLPL.js} +3 -3
  35. package/dist/{login-S4O6A5OF.js.map → login-HX7WMLPL.js.map} +1 -1
  36. package/dist/{login-WHSTC3WT.mjs → login-TJ2NCUAJ.mjs} +2 -2
  37. package/dist/observability-sdk/index.d.mts +3 -3
  38. package/dist/observability-sdk/index.d.ts +3 -3
  39. package/dist/observability-sdk/index.js +4 -4
  40. package/dist/observability-sdk/index.js.map +1 -1
  41. package/dist/observability-sdk/index.mjs +8 -8
  42. package/dist/observability-sdk/instrumentation/langchain/index.d.mts +1 -1
  43. package/dist/observability-sdk/instrumentation/langchain/index.d.ts +1 -1
  44. package/dist/observability-sdk/instrumentation/langchain/index.js +3 -3
  45. package/dist/observability-sdk/instrumentation/langchain/index.mjs +1 -1
  46. package/dist/observability-sdk/setup/node/index.js +11 -11
  47. package/dist/observability-sdk/setup/node/index.js.map +1 -1
  48. package/dist/observability-sdk/setup/node/index.mjs +3 -3
  49. package/dist/observability-sdk/setup/node/index.mjs.map +1 -1
  50. package/dist/{remove-LBVMOEMQ.js → remove-45A7WUCB.js} +7 -7
  51. package/dist/{remove-LBVMOEMQ.js.map → remove-45A7WUCB.js.map} +1 -1
  52. package/dist/{remove-TISUKAUX.mjs → remove-5ZOYQTF4.mjs} +5 -5
  53. package/dist/{sync-SIHBU67A.js → sync-BE7XZC2A.js} +7 -7
  54. package/dist/{sync-SIHBU67A.js.map → sync-BE7XZC2A.js.map} +1 -1
  55. package/dist/{sync-QYFJZVU7.mjs → sync-LL6TTFMS.mjs} +5 -5
  56. package/dist/{types-DhEYjnRD.d.mts → types-Kts5RGLY.d.mts} +15 -1
  57. package/dist/{types-CAQOMGrf.d.ts → types-usU5mTCX.d.ts} +15 -1
  58. package/package.json +142 -124
  59. package/dist/chunk-BP2WGNIV.js.map +0 -1
  60. package/dist/chunk-DQU2PZAL.mjs.map +0 -1
  61. package/dist/chunk-GNKQTK4I.mjs.map +0 -1
  62. package/dist/chunk-PLCZYSRL.mjs.map +0 -1
  63. package/dist/chunk-SRI6HEGF.js.map +0 -1
  64. package/dist/chunk-ZNWSX2QV.js.map +0 -1
  65. /package/dist/{add-EY2WXUSP.mjs.map → add-5FRWEQ32.mjs.map} +0 -0
  66. /package/dist/{chunk-VJV532JA.mjs.map → chunk-VGVWXKVM.mjs.map} +0 -0
  67. /package/dist/{list-GCZWLGUG.mjs.map → list-DQ6XLQCK.mjs.map} +0 -0
  68. /package/dist/{login-WHSTC3WT.mjs.map → login-TJ2NCUAJ.mjs.map} +0 -0
  69. /package/dist/{remove-TISUKAUX.mjs.map → remove-5ZOYQTF4.mjs.map} +0 -0
  70. /package/dist/{sync-QYFJZVU7.mjs.map → sync-LL6TTFMS.mjs.map} +0 -0
@@ -7,14 +7,14 @@ var _chunkSNDTNU3Tjs = require('../chunk-SNDTNU3T.js');
7
7
 
8
8
 
9
9
 
10
- var _chunkBP2WGNIVjs = require('../chunk-BP2WGNIV.js');
10
+ var _chunkBTCJWUS5js = require('../chunk-BTCJWUS5.js');
11
+ require('../chunk-YWO3NE5A.js');
11
12
 
12
13
 
13
14
 
14
15
 
15
16
 
16
- var _chunkKLVHQVMFjs = require('../chunk-KLVHQVMF.js');
17
- require('../chunk-ZNWSX2QV.js');
17
+ var _chunkA43BYF5Qjs = require('../chunk-A43BYF5Q.js');
18
18
 
19
19
 
20
20
 
@@ -38,5 +38,5 @@ require('../chunk-OHM7JUMR.js');
38
38
 
39
39
 
40
40
 
41
- exports.DataCapturePresets = _chunkSNDTNU3Tjs.DataCapturePresets; exports.FilterableBatchSpanProcessor = _chunkSNDTNU3Tjs.FilterableBatchSpanProcessor; exports.LangWatchExporter = _chunkKLVHQVMFjs.LangWatchTraceExporter; exports.LangWatchLogsExporter = _chunkKLVHQVMFjs.LangWatchLogsExporter; exports.LangWatchTraceExporter = _chunkKLVHQVMFjs.LangWatchTraceExporter; exports.attributes = _chunkCKIZDPIJjs.attributes_exports; exports.createLangWatchSpan = _chunkBP2WGNIVjs.createLangWatchSpan; exports.getDataCaptureMode = _chunkCKIZDPIJjs.getDataCaptureMode; exports.getLangWatchLogger = _chunkKLVHQVMFjs.getLangWatchLogger; exports.getLangWatchLoggerFromProvider = _chunkKLVHQVMFjs.getLangWatchLoggerFromProvider; exports.getLangWatchTracer = _chunkBP2WGNIVjs.getLangWatchTracer; exports.getLangWatchTracerFromProvider = _chunkBP2WGNIVjs.getLangWatchTracerFromProvider; exports.shouldCaptureInput = _chunkCKIZDPIJjs.shouldCaptureInput; exports.shouldCaptureOutput = _chunkCKIZDPIJjs.shouldCaptureOutput; exports.spanTypes = _chunkBP2WGNIVjs.spanTypes;
41
+ exports.DataCapturePresets = _chunkSNDTNU3Tjs.DataCapturePresets; exports.FilterableBatchSpanProcessor = _chunkSNDTNU3Tjs.FilterableBatchSpanProcessor; exports.LangWatchExporter = _chunkBTCJWUS5js.LangWatchTraceExporter; exports.LangWatchLogsExporter = _chunkBTCJWUS5js.LangWatchLogsExporter; exports.LangWatchTraceExporter = _chunkBTCJWUS5js.LangWatchTraceExporter; exports.attributes = _chunkCKIZDPIJjs.attributes_exports; exports.createLangWatchSpan = _chunkA43BYF5Qjs.createLangWatchSpan; exports.getDataCaptureMode = _chunkCKIZDPIJjs.getDataCaptureMode; exports.getLangWatchLogger = _chunkBTCJWUS5js.getLangWatchLogger; exports.getLangWatchLoggerFromProvider = _chunkBTCJWUS5js.getLangWatchLoggerFromProvider; exports.getLangWatchTracer = _chunkA43BYF5Qjs.getLangWatchTracer; exports.getLangWatchTracerFromProvider = _chunkA43BYF5Qjs.getLangWatchTracerFromProvider; exports.shouldCaptureInput = _chunkCKIZDPIJjs.shouldCaptureInput; exports.shouldCaptureOutput = _chunkCKIZDPIJjs.shouldCaptureOutput; exports.spanTypes = _chunkA43BYF5Qjs.spanTypes;
42
42
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/index.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,uDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,4hCAAC","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/index.js"}
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/index.js"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,uDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B;AACE;AACA;AACA;AACA;AACF,uDAA6B;AAC7B,gCAA6B;AAC7B;AACE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACF,4hCAAC","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/index.js"}
@@ -2,19 +2,19 @@ import {
2
2
  DataCapturePresets,
3
3
  FilterableBatchSpanProcessor
4
4
  } from "../chunk-FEL5FLHA.mjs";
5
- import {
6
- createLangWatchSpan,
7
- getLangWatchTracer,
8
- getLangWatchTracerFromProvider,
9
- spanTypes
10
- } from "../chunk-DQU2PZAL.mjs";
11
5
  import {
12
6
  LangWatchLogsExporter,
13
7
  LangWatchTraceExporter,
14
8
  getLangWatchLogger,
15
9
  getLangWatchLoggerFromProvider
16
- } from "../chunk-VJV532JA.mjs";
17
- import "../chunk-GNKQTK4I.mjs";
10
+ } from "../chunk-VGVWXKVM.mjs";
11
+ import "../chunk-W6FD5ZO3.mjs";
12
+ import {
13
+ createLangWatchSpan,
14
+ getLangWatchTracer,
15
+ getLangWatchTracerFromProvider,
16
+ spanTypes
17
+ } from "../chunk-WHPBZSTS.mjs";
18
18
  import {
19
19
  attributes_exports,
20
20
  getDataCaptureMode,
@@ -1,6 +1,6 @@
1
1
  import * as _opentelemetry_api from '@opentelemetry/api';
2
2
  import { Attributes } from '@opentelemetry/api';
3
- import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-DhEYjnRD.mjs';
3
+ import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-Kts5RGLY.mjs';
4
4
  import { AgentAction, AgentFinish } from '@langchain/core/agents';
5
5
  import { BaseCallbackHandler } from '@langchain/core/callbacks/base';
6
6
  import { DocumentInterface } from '@langchain/core/documents';
@@ -1,6 +1,6 @@
1
1
  import * as _opentelemetry_api from '@opentelemetry/api';
2
2
  import { Attributes } from '@opentelemetry/api';
3
- import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-CAQOMGrf.js';
3
+ import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-usU5mTCX.js';
4
4
  import { AgentAction, AgentFinish } from '@langchain/core/agents';
5
5
  import { BaseCallbackHandler } from '@langchain/core/callbacks/base';
6
6
  import { DocumentInterface } from '@langchain/core/documents';
@@ -1,7 +1,7 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
3
 
4
- var _chunkBP2WGNIVjs = require('../../../chunk-BP2WGNIV.js');
4
+ var _chunkA43BYF5Qjs = require('../../../chunk-A43BYF5Q.js');
5
5
 
6
6
 
7
7
 
@@ -31,7 +31,7 @@ var LangWatchCallbackHandler = class extends _base.BaseCallbackHandler {
31
31
  constructor() {
32
32
  super(...arguments);
33
33
  this.name = "LangWatchCallbackHandler";
34
- this.tracer = _chunkBP2WGNIVjs.getLangWatchTracer.call(void 0, "langwatch.instrumentation.langchain");
34
+ this.tracer = _chunkA43BYF5Qjs.getLangWatchTracer.call(void 0, "langwatch.instrumentation.langchain");
35
35
  this.spans = {};
36
36
  this.parentOf = {};
37
37
  this.skipped = {};
@@ -362,7 +362,7 @@ function wrapNonScalarValues(value) {
362
362
  if (value === null) return JSON.stringify(null);
363
363
  if (typeof value === "string" || typeof value === "number" || typeof value === "boolean")
364
364
  return value;
365
- const chatMessages = _chunkBP2WGNIVjs.chatMessageSchema.array().safeParse(value);
365
+ const chatMessages = _chunkA43BYF5Qjs.chatMessageSchema.array().safeParse(value);
366
366
  if (Array.isArray(value) && chatMessages.success) {
367
367
  return JSON.stringify({ type: "chat_messages", value: chatMessages.data });
368
368
  }
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  chatMessageSchema,
3
3
  getLangWatchTracer
4
- } from "../../../chunk-DQU2PZAL.mjs";
4
+ } from "../../../chunk-WHPBZSTS.mjs";
5
5
  import {
6
6
  shouldCaptureInput,
7
7
  shouldCaptureOutput
@@ -2,14 +2,14 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkKLVHQVMFjs = require('../../../chunk-KLVHQVMF.js');
5
+ var _chunkBTCJWUS5js = require('../../../chunk-BTCJWUS5.js');
6
6
 
7
7
 
8
8
 
9
9
 
10
10
 
11
11
 
12
- var _chunkZNWSX2QVjs = require('../../../chunk-ZNWSX2QV.js');
12
+ var _chunkYWO3NE5Ajs = require('../../../chunk-YWO3NE5A.js');
13
13
 
14
14
 
15
15
 
@@ -30,12 +30,12 @@ var _resources = require('@opentelemetry/resources');
30
30
  var _incubating = require('@opentelemetry/semantic-conventions/incubating'); var semconv = _interopRequireWildcard(_incubating);
31
31
  function createMergedResource(attributes, serviceName, givenResource) {
32
32
  const langwatchResource = _resources.resourceFromAttributes.call(void 0, {
33
- [semconv.ATTR_TELEMETRY_SDK_NAME]: _chunkZNWSX2QVjs.LANGWATCH_SDK_NAME_OBSERVABILITY,
34
- [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: _chunkZNWSX2QVjs.LANGWATCH_SDK_LANGUAGE,
35
- [semconv.ATTR_TELEMETRY_SDK_VERSION]: _chunkZNWSX2QVjs.LANGWATCH_SDK_VERSION
33
+ [semconv.ATTR_TELEMETRY_SDK_NAME]: _chunkYWO3NE5Ajs.LANGWATCH_SDK_NAME_OBSERVABILITY,
34
+ [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: _chunkYWO3NE5Ajs.LANGWATCH_SDK_LANGUAGE,
35
+ [semconv.ATTR_TELEMETRY_SDK_VERSION]: _chunkYWO3NE5Ajs.LANGWATCH_SDK_VERSION
36
36
  });
37
37
  const userResource = _resources.resourceFromAttributes.call(void 0, _chunkOHM7JUMRjs.__spreadValues.call(void 0, {
38
- [semconv.ATTR_SERVICE_NAME]: serviceName != null ? serviceName : _chunkZNWSX2QVjs.DEFAULT_SERVICE_NAME
38
+ [semconv.ATTR_SERVICE_NAME]: serviceName != null ? serviceName : _chunkYWO3NE5Ajs.DEFAULT_SERVICE_NAME
39
39
  }, attributes != null ? attributes : {}));
40
40
  return (givenResource != null ? givenResource : _resources.defaultResource.call(void 0, )).merge(langwatchResource).merge(userResource);
41
41
  }
@@ -91,7 +91,7 @@ var getLangWatchConfig = (options) => {
91
91
  return {
92
92
  disabled: isDisabled,
93
93
  apiKey: isDisabled ? void 0 : (_a = config.apiKey) != null ? _a : process.env.LANGWATCH_API_KEY,
94
- endpoint: isDisabled ? void 0 : (_c = (_b = config.endpoint) != null ? _b : process.env.LANGWATCH_ENDPOINT) != null ? _c : _chunkZNWSX2QVjs.DEFAULT_ENDPOINT,
94
+ endpoint: isDisabled ? void 0 : (_c = (_b = config.endpoint) != null ? _b : process.env.LANGWATCH_ENDPOINT) != null ? _c : _chunkYWO3NE5Ajs.DEFAULT_ENDPOINT,
95
95
  processorType: (_d = config.processorType) != null ? _d : "simple"
96
96
  };
97
97
  };
@@ -198,11 +198,11 @@ function createAndStartNodeSdk(options, logger, resource) {
198
198
  logger.debug("Console recording of logs enabled; adding console log record processor");
199
199
  }
200
200
  if (!langwatch.disabled) {
201
- const traceExporter = new (0, _chunkKLVHQVMFjs.LangWatchTraceExporter)({
201
+ const traceExporter = new (0, _chunkBTCJWUS5js.LangWatchTraceExporter)({
202
202
  apiKey: langwatch.apiKey,
203
203
  endpoint: langwatch.endpoint
204
204
  });
205
- const logExporter = new (0, _chunkKLVHQVMFjs.LangWatchLogsExporter)({
205
+ const logExporter = new (0, _chunkBTCJWUS5js.LangWatchLogsExporter)({
206
206
  apiKey: langwatch.apiKey,
207
207
  endpoint: langwatch.endpoint
208
208
  });
@@ -260,7 +260,7 @@ function createAndStartNodeSdk(options, logger, resource) {
260
260
  if (globalProvider.constructor.name === "ProxyTracerProvider") {
261
261
  logger.warn("Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround");
262
262
  const realProvider = globalProvider._delegate;
263
- if (realProvider && realProvider.constructor.name === "NodeTracerProvider") {
263
+ if ((realProvider == null ? void 0 : realProvider.constructor.name) === "NodeTracerProvider") {
264
264
  _api.trace.setGlobalTracerProvider(realProvider);
265
265
  logger.info("Successfully registered NodeTracerProvider globally for Next.js 15");
266
266
  } else {
@@ -272,7 +272,7 @@ function createAndStartNodeSdk(options, logger, resource) {
272
272
  });
273
273
  }
274
274
  if (loggerProvider) {
275
- _chunkKLVHQVMFjs.setLangWatchLoggerProvider.call(void 0, loggerProvider);
275
+ _chunkBTCJWUS5js.setLangWatchLoggerProvider.call(void 0, loggerProvider);
276
276
  logger.debug("Set LangWatch logger provider");
277
277
  }
278
278
  if (!((_e = options.advanced) == null ? void 0 : _e.disableAutoShutdown)) {
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/setup/node/index.js","../../../../src/observability-sdk/setup/node/setup.ts","../../../../src/observability-sdk/setup/utils.ts"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/setup/node/index.js","sourcesContent":[null,"import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'simple'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider && realProvider.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n process.on('SIGTERM', () => {\n void (async () => {\n logger.debug('SIGTERM received: shutting down OpenTelemetry...');\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n process.exit(0);\n }\n })();\n });\n }\n\n return sdk;\n}\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [semconv.ATTR_TELEMETRY_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [semconv.ATTR_TELEMETRY_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"]}
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/setup/node/index.js","../../../../src/observability-sdk/setup/node/setup.ts","../../../../src/observability-sdk/setup/utils.ts"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/setup/node/index.js","sourcesContent":[null,"import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'simple'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider?.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n process.on('SIGTERM', () => {\n void (async () => {\n logger.debug('SIGTERM received: shutting down OpenTelemetry...');\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n process.exit(0);\n }\n })();\n });\n }\n\n return sdk;\n}\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [semconv.ATTR_TELEMETRY_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [semconv.ATTR_TELEMETRY_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"]}
@@ -2,14 +2,14 @@ import {
2
2
  LangWatchLogsExporter,
3
3
  LangWatchTraceExporter,
4
4
  setLangWatchLoggerProvider
5
- } from "../../../chunk-VJV532JA.mjs";
5
+ } from "../../../chunk-VGVWXKVM.mjs";
6
6
  import {
7
7
  DEFAULT_ENDPOINT,
8
8
  DEFAULT_SERVICE_NAME,
9
9
  LANGWATCH_SDK_LANGUAGE,
10
10
  LANGWATCH_SDK_NAME_OBSERVABILITY,
11
11
  LANGWATCH_SDK_VERSION
12
- } from "../../../chunk-GNKQTK4I.mjs";
12
+ } from "../../../chunk-W6FD5ZO3.mjs";
13
13
  import {
14
14
  ConsoleLogger,
15
15
  initializeObservabilitySdkConfig
@@ -260,7 +260,7 @@ function createAndStartNodeSdk(options, logger, resource) {
260
260
  if (globalProvider.constructor.name === "ProxyTracerProvider") {
261
261
  logger.warn("Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround");
262
262
  const realProvider = globalProvider._delegate;
263
- if (realProvider && realProvider.constructor.name === "NodeTracerProvider") {
263
+ if ((realProvider == null ? void 0 : realProvider.constructor.name) === "NodeTracerProvider") {
264
264
  trace.setGlobalTracerProvider(realProvider);
265
265
  logger.info("Successfully registered NodeTracerProvider globally for Next.js 15");
266
266
  } else {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/observability-sdk/setup/node/setup.ts","../../../../src/observability-sdk/setup/utils.ts"],"sourcesContent":["import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'simple'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider && realProvider.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n process.on('SIGTERM', () => {\n void (async () => {\n logger.debug('SIGTERM received: shutting down OpenTelemetry...');\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n process.exit(0);\n }\n })();\n });\n }\n\n return sdk;\n}\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [semconv.ATTR_TELEMETRY_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [semconv.ATTR_TELEMETRY_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../../../src/observability-sdk/setup/node/setup.ts","../../../../src/observability-sdk/setup/utils.ts"],"sourcesContent":["import { NodeSDK } from \"@opentelemetry/sdk-node\";\nimport { SimpleLogRecordProcessor, BatchLogRecordProcessor, type LogRecordProcessor, ConsoleLogRecordExporter, LoggerProvider } from \"@opentelemetry/sdk-logs\";\nimport { createMergedResource, isConcreteProvider } from \"../utils\";\nimport { type SetupObservabilityOptions, type ObservabilityHandle } from \"./types\";\nimport { trace } from \"@opentelemetry/api\";\nimport {\n ConsoleSpanExporter,\n SimpleSpanProcessor,\n BatchSpanProcessor,\n type SpanProcessor,\n} from \"@opentelemetry/sdk-trace-base\";\nimport { type Resource } from \"@opentelemetry/resources\";\nimport { LangWatchLogsExporter, LangWatchTraceExporter } from \"../../exporters\";\nimport { ConsoleLogger, type Logger } from \"../../../logger\";\nimport { initializeObservabilitySdkConfig } from \"../../config\";\nimport { setLangWatchLoggerProvider } from \"../../logger\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\n// Helper functions\nconst createNoOpHandle = (logger: Logger): ObservabilityHandle => ({\n shutdown: async () => {\n logger.debug(\"Shutdown called for LangWatch no-op. Nothing will be shutdown\");\n },\n});\n\nconst getLangWatchConfig = (options: SetupObservabilityOptions) => {\n const isDisabled = options.langwatch === 'disabled';\n const config = typeof options.langwatch === 'object' ? options.langwatch : {};\n\n return {\n disabled: isDisabled,\n apiKey: isDisabled ? void 0 : (config.apiKey ?? process.env.LANGWATCH_API_KEY),\n endpoint: isDisabled ? void 0 : (config.endpoint ?? process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT),\n processorType: config.processorType ?? 'simple'\n };\n};\n\nconst checkForEarlyExit = (options: SetupObservabilityOptions, logger: Logger): ObservabilityHandle | null => {\n if (options.advanced?.disabled) {\n logger.debug(\"Observability disabled via advanced.disabled\");\n return createNoOpHandle(logger);\n }\n\n if (options.advanced?.skipOpenTelemetrySetup) {\n logger.debug(\"Skipping OpenTelemetry setup\");\n return createNoOpHandle(logger);\n }\n\n const globalProvider = trace.getTracerProvider();\n const alreadySetup = isConcreteProvider(globalProvider);\n\n if (alreadySetup && !options.advanced?.UNSAFE_forceOpenTelemetryReinitialization) {\n logger.error(\n `OpenTelemetry is already set up in this process.\\n` +\n `Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.\\n` +\n `You must either:\\n` +\n ` 1. Remove your existing OpenTelemetry setup and only use LangWatch,\\n` +\n ` 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.\\n` +\n `\\nFor step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:\\n` +\n ` https://docs.langwatch.ai/integration/typescript/guide\\n` +\n `\\nSee also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`,\n );\n return createNoOpHandle(logger);\n }\n\n if (alreadySetup) {\n logger.warn(\n \"OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. \" +\n \"Proceeding with reinitialization. This may cause conflicts.\"\n );\n }\n\n return null;\n};\n\nconst warnIfMisconfigured = (options: SetupObservabilityOptions, langwatch: ReturnType<typeof getLangWatchConfig>, logger: Logger) => {\n // Check if LangWatch is disabled but no alternative export mechanisms are provided\n // Note: If we reach this function, we know advanced.disabled and advanced.skipOpenTelemetrySetup are false\n // because those are handled as early exits in setupObservability()\n if (langwatch.disabled) {\n const hasAlternativeExport =\n options.spanProcessors?.length ??\n options.logRecordProcessors?.length ??\n options.debug?.consoleTracing ??\n options.debug?.consoleLogging ??\n options.traceExporter;\n\n if (!hasAlternativeExport) {\n const errorMessage =\n \"LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. \" +\n \"OpenTelemetry will be set up but traces will not be exported anywhere. \" +\n \"Either:\\n\" +\n \" 1. Enable LangWatch integration (remove langwatch: 'disabled')\\n\" +\n \" 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\\n\" +\n \" 3. Enable debug.consoleTracing or debug.consoleLogging for development\\n\" +\n \" 4. Use advanced.disabled to completely disable observability\\n\" +\n \" 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself\";\n\n if (options.advanced?.throwOnSetupError) {\n throw new Error(errorMessage);\n } else {\n logger.error(errorMessage);\n }\n }\n }\n};\n\nexport function setupObservability(options: SetupObservabilityOptions = {}): ObservabilityHandle {\n const logger = options.debug?.logger ?? new ConsoleLogger({\n level: options.debug?.logLevel ?? 'warn',\n prefix: \"LangWatch Observability SDK\",\n });\n\n initializeObservabilitySdkConfig({\n logger,\n dataCapture: options.dataCapture,\n });\n\n const earlyExit = checkForEarlyExit(options, logger);\n if (earlyExit) return earlyExit;\n\n try {\n const sdk = createAndStartNodeSdk(options, logger, createMergedResource(\n options.attributes,\n options.serviceName,\n options.resource,\n ));\n\n logger.info(\"LangWatch Observability SDK setup completed successfully\");\n\n return {\n shutdown: async () => {\n logger.debug(\"Shutting down NodeSDK\");\n await sdk?.shutdown();\n logger.info(\"NodeSDK shutdown complete\");\n },\n };\n } catch (err) {\n const errorMessage = err instanceof Error ? err.message : String(err);\n logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);\n\n if (err instanceof Error && err.stack) {\n logger.debug(`Stack trace: ${err.stack}`);\n }\n\n if (options.advanced?.throwOnSetupError) throw err;\n return createNoOpHandle(logger);\n }\n}\n\nexport function createAndStartNodeSdk(\n options: SetupObservabilityOptions,\n logger: Logger,\n resource: Resource,\n): NodeSDK {\n const langwatch = getLangWatchConfig(options);\n\n if (langwatch.disabled) {\n logger.warn(\"LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors\");\n } else {\n logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);\n }\n\n const spanProcessors: SpanProcessor[] = [];\n const logProcessors: LogRecordProcessor[] = [];\n\n // Console processors\n if (options.debug?.consoleTracing) {\n spanProcessors.push(new SimpleSpanProcessor(new ConsoleSpanExporter()));\n logger.debug(\"Console tracing enabled; adding console span exporter\");\n }\n if (options.debug?.consoleLogging) {\n logProcessors.push(new SimpleLogRecordProcessor(new ConsoleLogRecordExporter()));\n logger.debug(\"Console recording of logs enabled; adding console log record processor\");\n }\n\n if (!langwatch.disabled) {\n const traceExporter = new LangWatchTraceExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n const logExporter = new LangWatchLogsExporter({\n apiKey: langwatch.apiKey,\n endpoint: langwatch.endpoint,\n });\n\n if (langwatch.processorType === 'batch') {\n spanProcessors.push(new BatchSpanProcessor(traceExporter));\n logProcessors.push(new BatchLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n } else {\n spanProcessors.push(new SimpleSpanProcessor(traceExporter));\n logProcessors.push(new SimpleLogRecordProcessor(logExporter));\n logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);\n }\n }\n\n if (options.traceExporter) {\n spanProcessors.push(new SimpleSpanProcessor(options.traceExporter));\n logger.debug(`Added user-provided SpanProcessor to SDK`);\n }\n\n if (options.spanProcessors?.length) {\n spanProcessors.push(...options.spanProcessors);\n logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);\n }\n if (options.logRecordProcessors?.length) {\n logProcessors.push(...options.logRecordProcessors);\n logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);\n }\n\n warnIfMisconfigured(options, langwatch, logger);\n\n // Create logger provider\n const loggerProvider = logProcessors.length ? new LoggerProvider({\n resource,\n processors: logProcessors,\n }) : void 0;\n\n if (loggerProvider) {\n logger.debug(\"Created LangWatch logger provider\");\n }\n\n const sdk = new NodeSDK({\n resource,\n serviceName: options.serviceName,\n autoDetectResources: options.autoDetectResources,\n contextManager: options.contextManager,\n textMapPropagator: options.textMapPropagator,\n metricReader: options.metricReader,\n views: options.views,\n resourceDetectors: options.resourceDetectors,\n sampler: options.sampler,\n spanProcessors,\n logRecordProcessors: logProcessors,\n spanLimits: options.spanLimits,\n idGenerator: options.idGenerator,\n instrumentations: options.instrumentations,\n });\n\n sdk.start();\n logger.info(\"NodeSDK started successfully\");\n\n // Fix for Next.js 15: Explicitly verify and register provider if still proxy\n // See: https://github.com/langwatch/langwatch/issues/753\n if (process.env.NEXT_RUNTIME === 'nodejs') {\n // Wait a tick to ensure SDK initialization completes\n setImmediate(() => {\n const globalProvider = trace.getTracerProvider();\n\n // Check if provider is still a proxy (Next.js 15 issue)\n if (globalProvider.constructor.name === 'ProxyTracerProvider') {\n logger.warn('Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround');\n\n // Access the real provider from the delegate\n const realProvider = (globalProvider as any)._delegate;\n\n if (realProvider?.constructor.name === 'NodeTracerProvider') {\n // Explicitly register the real provider globally\n trace.setGlobalTracerProvider(realProvider);\n logger.info('Successfully registered NodeTracerProvider globally for Next.js 15');\n } else {\n logger.error('Could not find NodeTracerProvider in proxy delegate - spans may not be exported');\n }\n } else {\n logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);\n }\n });\n }\n\n if (loggerProvider) {\n setLangWatchLoggerProvider(loggerProvider);\n logger.debug(\"Set LangWatch logger provider\");\n }\n\n if (!options.advanced?.disableAutoShutdown) {\n process.on('SIGTERM', () => {\n void (async () => {\n logger.debug('SIGTERM received: shutting down OpenTelemetry...');\n try {\n await sdk.shutdown();\n logger.debug('OpenTelemetry shutdown complete');\n } catch (err) {\n logger.error('Error shutting down OpenTelemetry', err);\n } finally {\n process.exit(0);\n }\n })();\n });\n }\n\n return sdk;\n}\n","import {\n defaultResource,\n type Resource,\n resourceFromAttributes,\n} from \"@opentelemetry/resources\";\nimport { type Attributes } from \"@opentelemetry/api\";\nimport * as semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n LANGWATCH_SDK_LANGUAGE,\n LANGWATCH_SDK_VERSION,\n DEFAULT_SERVICE_NAME,\n LANGWATCH_SDK_NAME_OBSERVABILITY,\n} from \"../../internal/constants\";\n\n/**\n * Creates a merged resource from the given attributes, service name, and given resource.\n */\nexport function createMergedResource(\n attributes: Attributes | undefined,\n serviceName: string | undefined,\n givenResource: Resource | undefined,\n): Resource {\n const langwatchResource = resourceFromAttributes({\n [semconv.ATTR_TELEMETRY_SDK_NAME]: LANGWATCH_SDK_NAME_OBSERVABILITY,\n [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: LANGWATCH_SDK_LANGUAGE,\n [semconv.ATTR_TELEMETRY_SDK_VERSION]: LANGWATCH_SDK_VERSION,\n });\n\n const userResource = resourceFromAttributes({\n [semconv.ATTR_SERVICE_NAME]: serviceName ?? DEFAULT_SERVICE_NAME,\n ...(attributes ?? {}),\n });\n\n return (givenResource ?? defaultResource())\n .merge(langwatchResource)\n .merge(userResource);\n}\n\n/**\n * Returns the concrete OpenTelemetry provider (NodeTracerProvider or BasicTracerProvider),\n * either from the given provider or its delegate, or undefined if not found.\n */\nexport function getConcreteProvider(provider: unknown): unknown {\n if (!provider || typeof provider !== \"object\") return undefined;\n\n // Check provider itself\n const constructorName = (provider as any).constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(constructorName)) {\n return provider;\n }\n if (typeof (provider as any).addSpanProcessor === \"function\") {\n return provider;\n }\n\n // Check one level of delegate (ProxyTracerProvider pattern)\n let delegate;\n if (typeof (provider as any).getDelegate === \"function\") {\n delegate = (provider as any).getDelegate();\n } else if ((provider as any).delegate) {\n delegate = (provider as any).delegate;\n } else if ((provider as any)._delegate) {\n // Also check for _delegate (OpenTelemetry's actual property name)\n // See: https://github.com/langwatch/langwatch/issues/753\n delegate = (provider as any)._delegate;\n }\n\n if (delegate && typeof delegate === \"object\") {\n const delegateConstructorName = delegate.constructor?.name;\n if ([\"NodeTracerProvider\", \"BasicTracerProvider\"].includes(delegateConstructorName)) {\n return delegate;\n }\n if (typeof delegate.addSpanProcessor === \"function\") {\n return delegate;\n }\n }\n\n return void 0;\n}\n\n/**\n * Returns true if the given provider (or its delegate) is a concrete OpenTelemetry provider.\n */\nexport function isConcreteProvider(provider: unknown): boolean {\n return !!getConcreteProvider(provider);\n}\n\n"],"mappings":"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","names":[]}
@@ -1,10 +1,10 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { newObj[key] = obj[key]; } } } newObj.default = obj; return newObj; } } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkSRI6HEGFjs = require('./chunk-SRI6HEGF.js');
3
+ var _chunkNM5OKM7Fjs = require('./chunk-NM5OKM7F.js');
4
4
  require('./chunk-SNDTNU3T.js');
5
- require('./chunk-BP2WGNIV.js');
6
- require('./chunk-KLVHQVMF.js');
7
- require('./chunk-ZNWSX2QV.js');
5
+ require('./chunk-BTCJWUS5.js');
6
+ require('./chunk-YWO3NE5A.js');
7
+ require('./chunk-A43BYF5Q.js');
8
8
  require('./chunk-CKIZDPIJ.js');
9
9
 
10
10
 
@@ -87,7 +87,7 @@ var removeCommand = async (name) => {
87
87
  }
88
88
  } catch (error) {
89
89
  spinner.fail();
90
- if (error instanceof _chunkSRI6HEGFjs.PromptsError) {
90
+ if (error instanceof _chunkNM5OKM7Fjs.PromptsError) {
91
91
  console.error(_chalk2.default.red(`Error: ${error.message}`));
92
92
  } else {
93
93
  console.error(_chalk2.default.red(`Error removing prompt: ${error instanceof Error ? error.message : "Unknown error"}`));
@@ -95,7 +95,7 @@ var removeCommand = async (name) => {
95
95
  process.exit(1);
96
96
  }
97
97
  } catch (error) {
98
- if (error instanceof _chunkSRI6HEGFjs.PromptsError) {
98
+ if (error instanceof _chunkNM5OKM7Fjs.PromptsError) {
99
99
  console.error(_chalk2.default.red(`Error: ${error.message}`));
100
100
  } else {
101
101
  console.error(_chalk2.default.red(`Unexpected error: ${error instanceof Error ? error.message : "Unknown error"}`));
@@ -106,4 +106,4 @@ var removeCommand = async (name) => {
106
106
 
107
107
 
108
108
  exports.removeCommand = removeCommand;
109
- //# sourceMappingURL=remove-LBVMOEMQ.js.map
109
+ //# sourceMappingURL=remove-45A7WUCB.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/remove-LBVMOEMQ.js","../src/cli/commands/remove.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACA;ACdA,+DAAoB;AACpB,uEAAsB;AACtB,4EAAkB;AAClB,oEAAgB;AAIT,IAAM,cAAA,EAAgB,MAAA,CAAO,IAAA,EAAA,GAAgC;AAClE,EAAA,IAAI;AAEF,IAAA,GAAA,CAAI,CAAC,KAAA,GAAQ,IAAA,CAAK,IAAA,CAAK,EAAA,IAAM,EAAA,EAAI;AAC/B,MAAA,OAAA,CAAQ,KAAA,CAAM,eAAA,CAAM,GAAA,CAAI,oCAAoC,CAAC,CAAA;AAC7D,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA;AAAA,IAChB;AAGA,IAAA,MAAM,OAAA,EAAS,4BAAA,CAAY,iBAAA,CAAkB,CAAA;AAC7C,IAAA,MAAM,KAAA,EAAO,4BAAA,CAAY,eAAA,CAAgB,CAAA;AAGzC,IAAA,GAAA,CAAI,CAAC,MAAA,CAAO,OAAA,CAAQ,IAAI,CAAA,EAAG;AACzB,MAAA,OAAA,CAAQ,KAAA,CAAM,eAAA,CAAM,GAAA,CAAI,CAAA,eAAA,EAAkB,IAAI,CAAA,2BAAA,CAA6B,CAAC,CAAA;AAC5E,MAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,IAAA,CAAK,CAAA,mBAAA,EAAsB,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,OAAO,CAAA,CAAE,IAAA,CAAK,IAAI,EAAA,GAAK,MAAM,CAAA,CAAA;AAC/E,MAAA;AAChB,IAAA;AAEsC,IAAA;AAEhB,IAAA;AAEuC,IAAA;AAEzD,IAAA;AAEiB,MAAA;AACb,QAAA;AAEkE,QAAA;AACpB,UAAA;AACY,QAAA;AAChB,UAAA;AACvC,QAAA;AAEuE,UAAA;AAC9E,QAAA;AAGkC,QAAA;AACL,UAAA;AACoC,UAAA;AAC/C,UAAA;AAC2D,UAAA;AACtE,QAAA;AACW,UAAA;AACqD,UAAA;AACvE,QAAA;AAEyB,QAAA;AAC3B,MAAA;AAGmC,MAAA;AACN,MAAA;AACiC,QAAA;AACvB,QAAA;AACL,UAAA;AAGuB,UAAA;AACM,UAAA;AAE1C,UAAA;AACqE,UAAA;AAChF,YAAA;AACuC,cAAA;AACf,cAAA;AACD,gBAAA;AACa,gBAAA;AAC/B,cAAA;AACL,gBAAA;AACF,cAAA;AACM,YAAA;AACN,cAAA;AACF,YAAA;AACF,UAAA;AACF,QAAA;AACF,MAAA;AAG0B,MAAA;AACF,MAAA;AAGY,MAAA;AACJ,MAAA;AAEZ,MAAA;AACF,QAAA;AAC0D,QAAA;AAC5E,MAAA;AAEc,IAAA;AACD,MAAA;AACsB,MAAA;AACiB,QAAA;AAC7C,MAAA;AACsF,QAAA;AAC7F,MAAA;AACc,MAAA;AAChB,IAAA;AAEc,EAAA;AACqB,IAAA;AACiB,MAAA;AAC7C,IAAA;AACiF,MAAA;AACxF,IAAA;AACc,IAAA;AAChB,EAAA;AACF;ADdoG;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/remove-LBVMOEMQ.js","sourcesContent":[null,"import * as fs from \"fs\";\nimport * as path from \"path\";\nimport chalk from \"chalk\";\nimport ora from \"ora\";\nimport { FileManager } from \"../utils/fileManager\";\nimport { PromptsError } from \"@/client-sdk/services/prompts\";\n\nexport const removeCommand = async (name: string): Promise<void> => {\n try {\n // Validate prompt name\n if (!name || name.trim() === \"\") {\n console.error(chalk.red(\"Error: Prompt name cannot be empty\"));\n process.exit(1);\n }\n\n // Load existing config and lock\n const config = FileManager.loadPromptsConfig();\n const lock = FileManager.loadPromptsLock();\n\n // Check if prompt exists in dependencies\n if (!config.prompts[name]) {\n console.error(chalk.red(`Error: Prompt \"${name}\" not found in dependencies`));\n console.log(chalk.gray(`Available prompts: ${Object.keys(config.prompts).join(', ') || 'none'}`));\n process.exit(1);\n }\n\n const dependency = config.prompts[name];\n const isLocalPrompt = (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) ||\n (typeof dependency === \"object\" && dependency.file);\n\n const spinner = ora(`Removing ${chalk.cyan(name)}...`).start();\n\n try {\n // Handle local prompts\n if (isLocalPrompt) {\n let localFilePath: string;\n\n if (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) {\n localFilePath = path.resolve(dependency.slice(5)); // Remove \"file:\" prefix\n } else if (typeof dependency === \"object\" && dependency.file) {\n localFilePath = path.resolve(dependency.file);\n } else {\n // Fallback: assume it's in the prompts directory\n localFilePath = path.join(FileManager.getPromptsDir(), `${name}.prompt.yaml`);\n }\n\n // Delete the local file if it exists\n if (fs.existsSync(localFilePath)) {\n fs.unlinkSync(localFilePath);\n const relativePath = path.relative(process.cwd(), localFilePath);\n spinner.succeed();\n console.log(chalk.green(`✓ Removed local file ${chalk.gray(relativePath)}`));\n } else {\n spinner.succeed();\n console.log(chalk.yellow(`⚠ Local file not found (already deleted?)`));\n }\n\n console.log(chalk.yellow(`⚠ Note: This prompt may still exist on the server. Visit LangWatch to fully delete it.`));\n }\n\n // Remove materialized file if it exists\n const lockEntry = lock.prompts[name];\n if (lockEntry?.materialized) {\n const materializedPath = path.resolve(lockEntry.materialized);\n if (fs.existsSync(materializedPath)) {\n fs.unlinkSync(materializedPath);\n\n // Clean up empty directories\n const materializedDir = path.dirname(materializedPath);\n const rootMaterializedDir = FileManager.getMaterializedDir();\n\n let currentDir = materializedDir;\n while (currentDir !== rootMaterializedDir && currentDir !== path.dirname(currentDir)) {\n try {\n const entries = fs.readdirSync(currentDir);\n if (entries.length === 0) {\n fs.rmdirSync(currentDir);\n currentDir = path.dirname(currentDir);\n } else {\n break;\n }\n } catch {\n break;\n }\n }\n }\n }\n\n // Remove from config and lock\n delete config.prompts[name];\n delete lock.prompts[name];\n\n // Save updated files\n FileManager.savePromptsConfig(config);\n FileManager.savePromptsLock(lock);\n\n if (!isLocalPrompt) {\n spinner.succeed();\n console.log(chalk.green(`✓ Removed ${chalk.cyan(name)} from dependencies`));\n }\n\n } catch (error) {\n spinner.fail();\n if (error instanceof PromptsError) {\n console.error(chalk.red(`Error: ${error.message}`));\n } else {\n console.error(chalk.red(`Error removing prompt: ${error instanceof Error ? error.message : \"Unknown error\"}`));\n }\n process.exit(1);\n }\n\n } catch (error) {\n if (error instanceof PromptsError) {\n console.error(chalk.red(`Error: ${error.message}`));\n } else {\n console.error(chalk.red(`Unexpected error: ${error instanceof Error ? error.message : \"Unknown error\"}`));\n }\n process.exit(1);\n }\n};\n"]}
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/remove-45A7WUCB.js","../src/cli/commands/remove.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B,+BAA4B;AAC5B;AACA;ACdA,+DAAoB;AACpB,uEAAsB;AACtB,4EAAkB;AAClB,oEAAgB;AAIT,IAAM,cAAA,EAAgB,MAAA,CAAO,IAAA,EAAA,GAAgC;AAClE,EAAA,IAAI;AAEF,IAAA,GAAA,CAAI,CAAC,KAAA,GAAQ,IAAA,CAAK,IAAA,CAAK,EAAA,IAAM,EAAA,EAAI;AAC/B,MAAA,OAAA,CAAQ,KAAA,CAAM,eAAA,CAAM,GAAA,CAAI,oCAAoC,CAAC,CAAA;AAC7D,MAAA,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA;AAAA,IAChB;AAGA,IAAA,MAAM,OAAA,EAAS,4BAAA,CAAY,iBAAA,CAAkB,CAAA;AAC7C,IAAA,MAAM,KAAA,EAAO,4BAAA,CAAY,eAAA,CAAgB,CAAA;AAGzC,IAAA,GAAA,CAAI,CAAC,MAAA,CAAO,OAAA,CAAQ,IAAI,CAAA,EAAG;AACzB,MAAA,OAAA,CAAQ,KAAA,CAAM,eAAA,CAAM,GAAA,CAAI,CAAA,eAAA,EAAkB,IAAI,CAAA,2BAAA,CAA6B,CAAC,CAAA;AAC5E,MAAA,OAAA,CAAQ,GAAA,CAAI,eAAA,CAAM,IAAA,CAAK,CAAA,mBAAA,EAAsB,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,OAAO,CAAA,CAAE,IAAA,CAAK,IAAI,EAAA,GAAK,MAAM,CAAA,CAAA;AAC/E,MAAA;AAChB,IAAA;AAEsC,IAAA;AAEhB,IAAA;AAEuC,IAAA;AAEzD,IAAA;AAEiB,MAAA;AACb,QAAA;AAEkE,QAAA;AACpB,UAAA;AACY,QAAA;AAChB,UAAA;AACvC,QAAA;AAEuE,UAAA;AAC9E,QAAA;AAGkC,QAAA;AACL,UAAA;AACoC,UAAA;AAC/C,UAAA;AAC2D,UAAA;AACtE,QAAA;AACW,UAAA;AACqD,UAAA;AACvE,QAAA;AAEyB,QAAA;AAC3B,MAAA;AAGmC,MAAA;AACN,MAAA;AACiC,QAAA;AACvB,QAAA;AACL,UAAA;AAGuB,UAAA;AACM,UAAA;AAE1C,UAAA;AACqE,UAAA;AAChF,YAAA;AACuC,cAAA;AACf,cAAA;AACD,gBAAA;AACa,gBAAA;AAC/B,cAAA;AACL,gBAAA;AACF,cAAA;AACM,YAAA;AACN,cAAA;AACF,YAAA;AACF,UAAA;AACF,QAAA;AACF,MAAA;AAG0B,MAAA;AACF,MAAA;AAGY,MAAA;AACJ,MAAA;AAEZ,MAAA;AACF,QAAA;AAC0D,QAAA;AAC5E,MAAA;AAEc,IAAA;AACD,MAAA;AACsB,MAAA;AACiB,QAAA;AAC7C,MAAA;AACsF,QAAA;AAC7F,MAAA;AACc,MAAA;AAChB,IAAA;AAEc,EAAA;AACqB,IAAA;AACiB,MAAA;AAC7C,IAAA;AACiF,MAAA;AACxF,IAAA;AACc,IAAA;AAChB,EAAA;AACF;ADdoG;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/remove-45A7WUCB.js","sourcesContent":[null,"import * as fs from \"fs\";\nimport * as path from \"path\";\nimport chalk from \"chalk\";\nimport ora from \"ora\";\nimport { FileManager } from \"../utils/fileManager\";\nimport { PromptsError } from \"@/client-sdk/services/prompts\";\n\nexport const removeCommand = async (name: string): Promise<void> => {\n try {\n // Validate prompt name\n if (!name || name.trim() === \"\") {\n console.error(chalk.red(\"Error: Prompt name cannot be empty\"));\n process.exit(1);\n }\n\n // Load existing config and lock\n const config = FileManager.loadPromptsConfig();\n const lock = FileManager.loadPromptsLock();\n\n // Check if prompt exists in dependencies\n if (!config.prompts[name]) {\n console.error(chalk.red(`Error: Prompt \"${name}\" not found in dependencies`));\n console.log(chalk.gray(`Available prompts: ${Object.keys(config.prompts).join(', ') || 'none'}`));\n process.exit(1);\n }\n\n const dependency = config.prompts[name];\n const isLocalPrompt = (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) ||\n (typeof dependency === \"object\" && dependency.file);\n\n const spinner = ora(`Removing ${chalk.cyan(name)}...`).start();\n\n try {\n // Handle local prompts\n if (isLocalPrompt) {\n let localFilePath: string;\n\n if (typeof dependency === \"string\" && dependency.startsWith(\"file:\")) {\n localFilePath = path.resolve(dependency.slice(5)); // Remove \"file:\" prefix\n } else if (typeof dependency === \"object\" && dependency.file) {\n localFilePath = path.resolve(dependency.file);\n } else {\n // Fallback: assume it's in the prompts directory\n localFilePath = path.join(FileManager.getPromptsDir(), `${name}.prompt.yaml`);\n }\n\n // Delete the local file if it exists\n if (fs.existsSync(localFilePath)) {\n fs.unlinkSync(localFilePath);\n const relativePath = path.relative(process.cwd(), localFilePath);\n spinner.succeed();\n console.log(chalk.green(`✓ Removed local file ${chalk.gray(relativePath)}`));\n } else {\n spinner.succeed();\n console.log(chalk.yellow(`⚠ Local file not found (already deleted?)`));\n }\n\n console.log(chalk.yellow(`⚠ Note: This prompt may still exist on the server. Visit LangWatch to fully delete it.`));\n }\n\n // Remove materialized file if it exists\n const lockEntry = lock.prompts[name];\n if (lockEntry?.materialized) {\n const materializedPath = path.resolve(lockEntry.materialized);\n if (fs.existsSync(materializedPath)) {\n fs.unlinkSync(materializedPath);\n\n // Clean up empty directories\n const materializedDir = path.dirname(materializedPath);\n const rootMaterializedDir = FileManager.getMaterializedDir();\n\n let currentDir = materializedDir;\n while (currentDir !== rootMaterializedDir && currentDir !== path.dirname(currentDir)) {\n try {\n const entries = fs.readdirSync(currentDir);\n if (entries.length === 0) {\n fs.rmdirSync(currentDir);\n currentDir = path.dirname(currentDir);\n } else {\n break;\n }\n } catch {\n break;\n }\n }\n }\n }\n\n // Remove from config and lock\n delete config.prompts[name];\n delete lock.prompts[name];\n\n // Save updated files\n FileManager.savePromptsConfig(config);\n FileManager.savePromptsLock(lock);\n\n if (!isLocalPrompt) {\n spinner.succeed();\n console.log(chalk.green(`✓ Removed ${chalk.cyan(name)} from dependencies`));\n }\n\n } catch (error) {\n spinner.fail();\n if (error instanceof PromptsError) {\n console.error(chalk.red(`Error: ${error.message}`));\n } else {\n console.error(chalk.red(`Error removing prompt: ${error instanceof Error ? error.message : \"Unknown error\"}`));\n }\n process.exit(1);\n }\n\n } catch (error) {\n if (error instanceof PromptsError) {\n console.error(chalk.red(`Error: ${error.message}`));\n } else {\n console.error(chalk.red(`Unexpected error: ${error instanceof Error ? error.message : \"Unknown error\"}`));\n }\n process.exit(1);\n }\n};\n"]}
@@ -1,10 +1,10 @@
1
1
  import {
2
2
  PromptsError
3
- } from "./chunk-PLCZYSRL.mjs";
3
+ } from "./chunk-I3X7VMSP.mjs";
4
4
  import "./chunk-FEL5FLHA.mjs";
5
- import "./chunk-DQU2PZAL.mjs";
6
- import "./chunk-VJV532JA.mjs";
7
- import "./chunk-GNKQTK4I.mjs";
5
+ import "./chunk-VGVWXKVM.mjs";
6
+ import "./chunk-W6FD5ZO3.mjs";
7
+ import "./chunk-WHPBZSTS.mjs";
8
8
  import "./chunk-I2SOBPAF.mjs";
9
9
  import {
10
10
  FileManager
@@ -106,4 +106,4 @@ var removeCommand = async (name) => {
106
106
  export {
107
107
  removeCommand
108
108
  };
109
- //# sourceMappingURL=remove-TISUKAUX.mjs.map
109
+ //# sourceMappingURL=remove-5ZOYQTF4.mjs.map
@@ -4,11 +4,11 @@ var _chunkF6E4XQQUjs = require('./chunk-F6E4XQQU.js');
4
4
 
5
5
 
6
6
 
7
- var _chunkSRI6HEGFjs = require('./chunk-SRI6HEGF.js');
7
+ var _chunkNM5OKM7Fjs = require('./chunk-NM5OKM7F.js');
8
8
  require('./chunk-SNDTNU3T.js');
9
- require('./chunk-BP2WGNIV.js');
10
- require('./chunk-KLVHQVMF.js');
11
- require('./chunk-ZNWSX2QV.js');
9
+ require('./chunk-BTCJWUS5.js');
10
+ require('./chunk-YWO3NE5A.js');
11
+ require('./chunk-A43BYF5Q.js');
12
12
  require('./chunk-CKIZDPIJ.js');
13
13
 
14
14
 
@@ -74,7 +74,7 @@ var syncCommand = async () => {
74
74
  const startTime = Date.now();
75
75
  try {
76
76
  _chunkF6E4XQQUjs.checkApiKey.call(void 0, );
77
- const promptsApiService = new (0, _chunkSRI6HEGFjs.PromptsApiService)();
77
+ const promptsApiService = new (0, _chunkNM5OKM7Fjs.PromptsApiService)();
78
78
  await _chunkBYG3QS2Xjs.ensureProjectInitialized.call(void 0, false);
79
79
  const config = _chunkWAAQLJ67js.FileManager.loadPromptsConfig();
80
80
  const lock = _chunkWAAQLJ67js.FileManager.loadPromptsLock();
@@ -395,7 +395,7 @@ Tip: Add these to prompts.json to include them in sync operations.`
395
395
  process.exit(1);
396
396
  }
397
397
  } catch (error) {
398
- if (error instanceof _chunkSRI6HEGFjs.PromptsError) {
398
+ if (error instanceof _chunkNM5OKM7Fjs.PromptsError) {
399
399
  console.error(_chalk2.default.red(`Error: ${error.message}`));
400
400
  } else {
401
401
  console.error(
@@ -410,4 +410,4 @@ Tip: Add these to prompts.json to include them in sync operations.`
410
410
 
411
411
 
412
412
  exports.syncCommand = syncCommand;
413
- //# sourceMappingURL=sync-SIHBU67A.js.map
413
+ //# sourceMappingURL=sync-BE7XZC2A.js.map