langwatch 0.12.0 → 0.14.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 (71) hide show
  1. package/dist/{add-2UHFYNUA.mjs → add-36C7337U.mjs} +5 -5
  2. package/dist/{add-LUETMKBD.js → add-HNUQULX7.js} +8 -8
  3. package/dist/{add-LUETMKBD.js.map → add-HNUQULX7.js.map} +1 -1
  4. package/dist/chunk-2BALUJ3B.js +317 -0
  5. package/dist/chunk-2BALUJ3B.js.map +1 -0
  6. package/dist/{chunk-6SSCBYJM.js → chunk-4VAQQB35.js} +10 -10
  7. package/dist/{chunk-6SSCBYJM.js.map → chunk-4VAQQB35.js.map} +1 -1
  8. package/dist/{chunk-C4XUWCQR.js → chunk-D3YWZYYD.js} +2 -2
  9. package/dist/chunk-D3YWZYYD.js.map +1 -0
  10. package/dist/{chunk-BQRUUTN3.js → chunk-GNHX3RA6.js} +14 -14
  11. package/dist/{chunk-BQRUUTN3.js.map → chunk-GNHX3RA6.js.map} +1 -1
  12. package/dist/{chunk-WCNDT5SD.mjs → chunk-JX2FBF5Z.mjs} +2 -2
  13. package/dist/{chunk-IIUI2XYW.mjs → chunk-KD5U3MP3.mjs} +11 -2
  14. package/dist/chunk-KD5U3MP3.mjs.map +1 -0
  15. package/dist/chunk-KJQNNRAB.mjs +317 -0
  16. package/dist/chunk-KJQNNRAB.mjs.map +1 -0
  17. package/dist/{chunk-OTID7S7K.mjs → chunk-QOSICUZE.mjs} +3 -3
  18. package/dist/{chunk-ONXIZKC6.js → chunk-SHJZRXU7.js} +11 -2
  19. package/dist/chunk-SHJZRXU7.js.map +1 -0
  20. package/dist/{chunk-TB5KB737.mjs → chunk-WIB3D4PL.mjs} +2 -2
  21. package/dist/chunk-WIB3D4PL.mjs.map +1 -0
  22. package/dist/cli/index.js +6 -6
  23. package/dist/cli/index.mjs +6 -6
  24. package/dist/{implementation-Ck58nRkT.d.mts → implementation-Dl15eRjo.d.mts} +1 -1
  25. package/dist/{implementation-Bnc8Aymq.d.ts → implementation-gLzM6qpI.d.ts} +1 -1
  26. package/dist/index.d.mts +269 -56
  27. package/dist/index.d.ts +269 -56
  28. package/dist/index.js +344 -92
  29. package/dist/index.js.map +1 -1
  30. package/dist/index.mjs +338 -86
  31. package/dist/index.mjs.map +1 -1
  32. package/dist/{list-WV5LA6LD.mjs → list-S5UIBHSU.mjs} +5 -5
  33. package/dist/{list-7U3M64GY.js → list-U5HX65KF.js} +8 -8
  34. package/dist/{list-7U3M64GY.js.map → list-U5HX65KF.js.map} +1 -1
  35. package/dist/{login-QKRT6PXA.mjs → login-ALPTL4S6.mjs} +2 -2
  36. package/dist/{login-B7DKMN7P.js → login-IINYTYEF.js} +3 -3
  37. package/dist/{login-B7DKMN7P.js.map → login-IINYTYEF.js.map} +1 -1
  38. package/dist/observability-sdk/index.d.mts +3 -3
  39. package/dist/observability-sdk/index.d.ts +3 -3
  40. package/dist/observability-sdk/index.js +4 -4
  41. package/dist/observability-sdk/index.mjs +3 -3
  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.d.mts +24 -1
  47. package/dist/observability-sdk/setup/node/index.d.ts +24 -1
  48. package/dist/observability-sdk/setup/node/index.js +7 -292
  49. package/dist/observability-sdk/setup/node/index.js.map +1 -1
  50. package/dist/observability-sdk/setup/node/index.mjs +8 -293
  51. package/dist/observability-sdk/setup/node/index.mjs.map +1 -1
  52. package/dist/{remove-A4DKCN7A.js → remove-4NB23DL3.js} +7 -7
  53. package/dist/{remove-A4DKCN7A.js.map → remove-4NB23DL3.js.map} +1 -1
  54. package/dist/{remove-2OGMXSTR.mjs → remove-KVFBJ4XE.mjs} +5 -5
  55. package/dist/{sync-TNVCKWTC.mjs → sync-ITMRHKSW.mjs} +5 -5
  56. package/dist/{sync-WRZXIBZS.js → sync-UI7HBIDR.js} +7 -7
  57. package/dist/{sync-WRZXIBZS.js.map → sync-UI7HBIDR.js.map} +1 -1
  58. package/dist/{types-5h2Im4pl.d.mts → types-ExKeJEM0.d.mts} +1179 -17
  59. package/dist/{types-fo-Ij9pl.d.ts → types-WRcnQUom.d.ts} +1179 -17
  60. package/package.json +3 -2
  61. package/dist/chunk-C4XUWCQR.js.map +0 -1
  62. package/dist/chunk-IIUI2XYW.mjs.map +0 -1
  63. package/dist/chunk-ONXIZKC6.js.map +0 -1
  64. package/dist/chunk-TB5KB737.mjs.map +0 -1
  65. /package/dist/{add-2UHFYNUA.mjs.map → add-36C7337U.mjs.map} +0 -0
  66. /package/dist/{chunk-WCNDT5SD.mjs.map → chunk-JX2FBF5Z.mjs.map} +0 -0
  67. /package/dist/{chunk-OTID7S7K.mjs.map → chunk-QOSICUZE.mjs.map} +0 -0
  68. /package/dist/{list-WV5LA6LD.mjs.map → list-S5UIBHSU.mjs.map} +0 -0
  69. /package/dist/{login-QKRT6PXA.mjs.map → login-ALPTL4S6.mjs.map} +0 -0
  70. /package/dist/{remove-2OGMXSTR.mjs.map → remove-KVFBJ4XE.mjs.map} +0 -0
  71. /package/dist/{sync-TNVCKWTC.mjs.map → sync-ITMRHKSW.mjs.map} +0 -0
@@ -1,6 +1,6 @@
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 _chunkC4XUWCQRjs = require('./chunk-C4XUWCQR.js');
3
+ var _chunkD3YWZYYDjs = require('./chunk-D3YWZYYD.js');
4
4
  require('./chunk-OHM7JUMR.js');
5
5
 
6
6
  // src/cli/commands/login.ts
@@ -11,7 +11,7 @@ var _ora = require('ora'); var _ora2 = _interopRequireDefault(_ora);
11
11
  var _prompts = require('prompts'); var _prompts2 = _interopRequireDefault(_prompts);
12
12
  var getEndpoint = () => {
13
13
  var _a;
14
- return (_a = process.env.LANGWATCH_ENDPOINT) != null ? _a : _chunkC4XUWCQRjs.DEFAULT_ENDPOINT;
14
+ return (_a = process.env.LANGWATCH_ENDPOINT) != null ? _a : _chunkD3YWZYYDjs.DEFAULT_ENDPOINT;
15
15
  };
16
16
  var updateEnvFile = (apiKey) => {
17
17
  const envPath = path.join(process.cwd(), ".env");
@@ -111,4 +111,4 @@ var loginCommand = async () => {
111
111
 
112
112
 
113
113
  exports.loginCommand = loginCommand;
114
- //# sourceMappingURL=login-B7DKMN7P.js.map
114
+ //# sourceMappingURL=login-IINYTYEF.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/login-B7DKMN7P.js","../src/cli/commands/login.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B;AACA;ACLA,+DAAoB;AACpB,uEAAsB;AACtB,4EAAkB;AAClB,oEAAgB;AAChB,oFAAoB;AAGpB,IAAM,YAAA,EAAc,CAAA,EAAA,GAAc;AAPlC,EAAA,IAAA,EAAA;AAQE,EAAA,OAAA,CAAO,GAAA,EAAA,OAAA,CAAQ,GAAA,CAAI,kBAAA,EAAA,GAAZ,KAAA,EAAA,GAAA,EAAkC,iCAAA;AAC3C,CAAA;AAEA,IAAM,cAAA,EAAgB,CACpB,MAAA,EAAA,GACyD;AACzD,EAAA,MAAM,QAAA,EAAe,IAAA,CAAA,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,CAAA,EAAG,MAAM,CAAA;AAG/C,EAAA,GAAA,CAAI,CAAI,EAAA,CAAA,UAAA,CAAW,OAAO,CAAA,EAAG;AAE3B,IAAG,EAAA,CAAA,aAAA,CAAc,OAAA,EAAS,CAAA,kBAAA,EAAqB,MAAM,CAAA;AAAA,CAAI,CAAA;AACzD,IAAA,OAAO,EAAE,OAAA,EAAS,IAAA,EAAM,OAAA,EAAS,KAAA,EAAO,IAAA,EAAM,QAAQ,CAAA;AAAA,EACxD;AAGA,EAAA,MAAM,QAAA,EAAa,EAAA,CAAA,YAAA,CAAa,OAAA,EAAS,OAAO,CAAA;AAChD,EAAA,MAAM,MAAA,EAAQ,OAAA,CAAQ,KAAA,CAAM,IAAI,CAAA;AAGhC,EAAA,IAAI,MAAA,EAAQ,KAAA;AACZ,EAAA,MAAM,aAAA,EAAe,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,EAAA,GAAS;AACvC,IAAA,GAAA,CAAI,IAAA,CAAK,UAAA,CAAW,oBAAoB,CAAA,EAAG;AACzC,MAAA,MAAA,EAAQ,IAAA;AACR,MAAA,OAAO,CAAA,kBAAA,EAAqB,MAAM,CAAA,CAAA;AACpC,IAAA;AACO,IAAA;AACR,EAAA;AAEW,EAAA;AAEoB,IAAA;AACV,MAAA;AACb,IAAA;AACiB,MAAA;AACxB,IAAA;AACF,EAAA;AAEuC,EAAA;AACL,EAAA;AACpC;AAEuD;AACjD,EAAA;AACqB,IAAA;AACf,IAAA;AACA,MAAA;AACJ,QAAA;AACF,MAAA;AACF,IAAA;AACY,IAAA;AAGiB,IAAA;AACF,IAAA;AAEQ,IAAA;AAGf,IAAA;AAEhB,IAAA;AAC+B,MAAA;AACf,MAAA;AACc,MAAA;AAC1B,IAAA;AACO,MAAA;AACY,MAAA;AAC3B,IAAA;AAEY,IAAA;AACW,IAAA;AACA,IAAA;AACA,IAAA;AACX,IAAA;AAGmB,IAAA;AACvB,MAAA;AACA,MAAA;AACG,MAAA;AACoB,MAAA;AACI,QAAA;AACtB,UAAA;AACT,QAAA;AACuB,QAAA;AACd,UAAA;AACT,QAAA;AACO,QAAA;AACT,MAAA;AACD,IAAA;AAEqB,IAAA;AACK,MAAA;AACX,MAAA;AAChB,IAAA;AAEoC,IAAA;AAGJ,IAAA;AAEpB,IAAA;AACY,IAAA;AAED,IAAA;AACE,MAAA;AACK,IAAA;AACL,MAAA;AAClB,IAAA;AACkB,MAAA;AACzB,IAAA;AAEY,IAAA;AACY,IAAA;AACD,IAAA;AACA,IAAA;AACT,EAAA;AACN,IAAA;AACA,MAAA;AAEF,QAAA;AAEJ,MAAA;AACF,IAAA;AACc,IAAA;AAChB,EAAA;AACF;ADzByC;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/login-B7DKMN7P.js","sourcesContent":[null,"import * as fs from \"fs\";\nimport * as path from \"path\";\nimport chalk from \"chalk\";\nimport ora from \"ora\";\nimport prompts from \"prompts\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\nconst getEndpoint = (): string => {\n return process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT;\n};\n\nconst updateEnvFile = (\n apiKey: string,\n): { created: boolean; updated: boolean; path: string } => {\n const envPath = path.join(process.cwd(), \".env\");\n\n // Check if .env exists\n if (!fs.existsSync(envPath)) {\n // Create new .env file\n fs.writeFileSync(envPath, `LANGWATCH_API_KEY=${apiKey}\\n`);\n return { created: true, updated: false, path: envPath };\n }\n\n // Read existing .env file\n const content = fs.readFileSync(envPath, \"utf-8\");\n const lines = content.split(\"\\n\");\n\n // Check if LANGWATCH_API_KEY already exists and update it\n let found = false;\n const updatedLines = lines.map((line) => {\n if (line.startsWith(\"LANGWATCH_API_KEY=\")) {\n found = true;\n return `LANGWATCH_API_KEY=${apiKey}`;\n }\n return line;\n });\n\n if (!found) {\n // Add to end of file\n if (content.endsWith(\"\\n\") || content === \"\") {\n updatedLines.push(`LANGWATCH_API_KEY=${apiKey}`);\n } else {\n updatedLines.push(\"\", `LANGWATCH_API_KEY=${apiKey}`);\n }\n }\n\n fs.writeFileSync(envPath, updatedLines.join(\"\\n\"));\n return { created: false, updated: found, path: envPath };\n};\n\nexport const loginCommand = async (): Promise<void> => {\n try {\n console.log(chalk.blue(\"🔐 LangWatch Login\"));\n console.log(\n chalk.gray(\n \"This will open your browser to get an API key from LangWatch.\",\n ),\n );\n console.log();\n\n // Get the authorization URL\n const endpoint = getEndpoint();\n const authUrl = `${endpoint}/authorize`;\n\n console.log(chalk.cyan(`Opening: ${authUrl}`));\n\n // Open browser\n const spinner = ora(\"Opening browser...\").start();\n\n try {\n const open = (await import(\"open\")).default;\n await open(authUrl);\n spinner.succeed(\"Browser opened\");\n } catch {\n spinner.fail(\"Failed to open browser\");\n console.log(chalk.yellow(`Please manually open: ${chalk.cyan(authUrl)}`));\n }\n\n console.log();\n console.log(chalk.gray(\"1. Log in to LangWatch in your browser\"));\n console.log(chalk.gray(\"2. Copy your API key\"));\n console.log(chalk.gray(\"3. Come back here and paste it\"));\n console.log();\n\n // Wait for user input using prompts library\n const response = await prompts({\n type: \"password\",\n name: \"apiKey\",\n message: \"Paste your API key here:\",\n validate: (value: string) => {\n if (!value || value.trim() === \"\") {\n return \"API key is required\";\n }\n if (value.length < 10) {\n return \"API key seems too short. Please check and try again.\";\n }\n return true;\n },\n });\n\n if (!response.apiKey) {\n console.log(chalk.yellow(\"Login cancelled\"));\n process.exit(0);\n }\n\n const apiKey = response.apiKey.trim();\n\n // Save to .env file\n const envResult = updateEnvFile(apiKey);\n\n console.log();\n console.log(chalk.green(\"✓ API key saved successfully!\"));\n\n if (envResult.created) {\n console.log(chalk.gray(`• Created .env file with your API key`));\n } else if (envResult.updated) {\n console.log(chalk.gray(`• Updated existing API key in .env file`));\n } else {\n console.log(chalk.gray(`• Added API key to existing .env file`));\n }\n\n console.log();\n console.log(chalk.green(\"🎉 You're all set! You can now use:\"));\n console.log(chalk.cyan(\" langwatch prompt add <name>\"));\n console.log(chalk.cyan(\" langwatch prompt sync\"));\n } catch (error) {\n console.error(\n chalk.red(\n `Error during login: ${\n error instanceof Error ? error.message : \"Unknown error\"\n }`,\n ),\n );\n process.exit(1);\n }\n};\n"]}
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/login-IINYTYEF.js","../src/cli/commands/login.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B,+BAA4B;AAC5B;AACA;ACLA,+DAAoB;AACpB,uEAAsB;AACtB,4EAAkB;AAClB,oEAAgB;AAChB,oFAAoB;AAGpB,IAAM,YAAA,EAAc,CAAA,EAAA,GAAc;AAPlC,EAAA,IAAA,EAAA;AAQE,EAAA,OAAA,CAAO,GAAA,EAAA,OAAA,CAAQ,GAAA,CAAI,kBAAA,EAAA,GAAZ,KAAA,EAAA,GAAA,EAAkC,iCAAA;AAC3C,CAAA;AAEA,IAAM,cAAA,EAAgB,CACpB,MAAA,EAAA,GACyD;AACzD,EAAA,MAAM,QAAA,EAAe,IAAA,CAAA,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,CAAA,EAAG,MAAM,CAAA;AAG/C,EAAA,GAAA,CAAI,CAAI,EAAA,CAAA,UAAA,CAAW,OAAO,CAAA,EAAG;AAE3B,IAAG,EAAA,CAAA,aAAA,CAAc,OAAA,EAAS,CAAA,kBAAA,EAAqB,MAAM,CAAA;AAAA,CAAI,CAAA;AACzD,IAAA,OAAO,EAAE,OAAA,EAAS,IAAA,EAAM,OAAA,EAAS,KAAA,EAAO,IAAA,EAAM,QAAQ,CAAA;AAAA,EACxD;AAGA,EAAA,MAAM,QAAA,EAAa,EAAA,CAAA,YAAA,CAAa,OAAA,EAAS,OAAO,CAAA;AAChD,EAAA,MAAM,MAAA,EAAQ,OAAA,CAAQ,KAAA,CAAM,IAAI,CAAA;AAGhC,EAAA,IAAI,MAAA,EAAQ,KAAA;AACZ,EAAA,MAAM,aAAA,EAAe,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,EAAA,GAAS;AACvC,IAAA,GAAA,CAAI,IAAA,CAAK,UAAA,CAAW,oBAAoB,CAAA,EAAG;AACzC,MAAA,MAAA,EAAQ,IAAA;AACR,MAAA,OAAO,CAAA,kBAAA,EAAqB,MAAM,CAAA,CAAA;AACpC,IAAA;AACO,IAAA;AACR,EAAA;AAEW,EAAA;AAEoB,IAAA;AACV,MAAA;AACb,IAAA;AACiB,MAAA;AACxB,IAAA;AACF,EAAA;AAEuC,EAAA;AACL,EAAA;AACpC;AAEuD;AACjD,EAAA;AACqB,IAAA;AACf,IAAA;AACA,MAAA;AACJ,QAAA;AACF,MAAA;AACF,IAAA;AACY,IAAA;AAGiB,IAAA;AACF,IAAA;AAEQ,IAAA;AAGf,IAAA;AAEhB,IAAA;AAC+B,MAAA;AACf,MAAA;AACc,MAAA;AAC1B,IAAA;AACO,MAAA;AACY,MAAA;AAC3B,IAAA;AAEY,IAAA;AACW,IAAA;AACA,IAAA;AACA,IAAA;AACX,IAAA;AAGmB,IAAA;AACvB,MAAA;AACA,MAAA;AACG,MAAA;AACoB,MAAA;AACI,QAAA;AACtB,UAAA;AACT,QAAA;AACuB,QAAA;AACd,UAAA;AACT,QAAA;AACO,QAAA;AACT,MAAA;AACD,IAAA;AAEqB,IAAA;AACK,MAAA;AACX,MAAA;AAChB,IAAA;AAEoC,IAAA;AAGJ,IAAA;AAEpB,IAAA;AACY,IAAA;AAED,IAAA;AACE,MAAA;AACK,IAAA;AACL,MAAA;AAClB,IAAA;AACkB,MAAA;AACzB,IAAA;AAEY,IAAA;AACY,IAAA;AACD,IAAA;AACA,IAAA;AACT,EAAA;AACN,IAAA;AACA,MAAA;AAEF,QAAA;AAEJ,MAAA;AACF,IAAA;AACc,IAAA;AAChB,EAAA;AACF;ADzByC;AACA;AACA","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/login-IINYTYEF.js","sourcesContent":[null,"import * as fs from \"fs\";\nimport * as path from \"path\";\nimport chalk from \"chalk\";\nimport ora from \"ora\";\nimport prompts from \"prompts\";\nimport { DEFAULT_ENDPOINT } from \"@/internal/constants\";\n\nconst getEndpoint = (): string => {\n return process.env.LANGWATCH_ENDPOINT ?? DEFAULT_ENDPOINT;\n};\n\nconst updateEnvFile = (\n apiKey: string,\n): { created: boolean; updated: boolean; path: string } => {\n const envPath = path.join(process.cwd(), \".env\");\n\n // Check if .env exists\n if (!fs.existsSync(envPath)) {\n // Create new .env file\n fs.writeFileSync(envPath, `LANGWATCH_API_KEY=${apiKey}\\n`);\n return { created: true, updated: false, path: envPath };\n }\n\n // Read existing .env file\n const content = fs.readFileSync(envPath, \"utf-8\");\n const lines = content.split(\"\\n\");\n\n // Check if LANGWATCH_API_KEY already exists and update it\n let found = false;\n const updatedLines = lines.map((line) => {\n if (line.startsWith(\"LANGWATCH_API_KEY=\")) {\n found = true;\n return `LANGWATCH_API_KEY=${apiKey}`;\n }\n return line;\n });\n\n if (!found) {\n // Add to end of file\n if (content.endsWith(\"\\n\") || content === \"\") {\n updatedLines.push(`LANGWATCH_API_KEY=${apiKey}`);\n } else {\n updatedLines.push(\"\", `LANGWATCH_API_KEY=${apiKey}`);\n }\n }\n\n fs.writeFileSync(envPath, updatedLines.join(\"\\n\"));\n return { created: false, updated: found, path: envPath };\n};\n\nexport const loginCommand = async (): Promise<void> => {\n try {\n console.log(chalk.blue(\"🔐 LangWatch Login\"));\n console.log(\n chalk.gray(\n \"This will open your browser to get an API key from LangWatch.\",\n ),\n );\n console.log();\n\n // Get the authorization URL\n const endpoint = getEndpoint();\n const authUrl = `${endpoint}/authorize`;\n\n console.log(chalk.cyan(`Opening: ${authUrl}`));\n\n // Open browser\n const spinner = ora(\"Opening browser...\").start();\n\n try {\n const open = (await import(\"open\")).default;\n await open(authUrl);\n spinner.succeed(\"Browser opened\");\n } catch {\n spinner.fail(\"Failed to open browser\");\n console.log(chalk.yellow(`Please manually open: ${chalk.cyan(authUrl)}`));\n }\n\n console.log();\n console.log(chalk.gray(\"1. Log in to LangWatch in your browser\"));\n console.log(chalk.gray(\"2. Copy your API key\"));\n console.log(chalk.gray(\"3. Come back here and paste it\"));\n console.log();\n\n // Wait for user input using prompts library\n const response = await prompts({\n type: \"password\",\n name: \"apiKey\",\n message: \"Paste your API key here:\",\n validate: (value: string) => {\n if (!value || value.trim() === \"\") {\n return \"API key is required\";\n }\n if (value.length < 10) {\n return \"API key seems too short. Please check and try again.\";\n }\n return true;\n },\n });\n\n if (!response.apiKey) {\n console.log(chalk.yellow(\"Login cancelled\"));\n process.exit(0);\n }\n\n const apiKey = response.apiKey.trim();\n\n // Save to .env file\n const envResult = updateEnvFile(apiKey);\n\n console.log();\n console.log(chalk.green(\"✓ API key saved successfully!\"));\n\n if (envResult.created) {\n console.log(chalk.gray(`• Created .env file with your API key`));\n } else if (envResult.updated) {\n console.log(chalk.gray(`• Updated existing API key in .env file`));\n } else {\n console.log(chalk.gray(`• Added API key to existing .env file`));\n }\n\n console.log();\n console.log(chalk.green(\"🎉 You're all set! You can now use:\"));\n console.log(chalk.cyan(\" langwatch prompt add <name>\"));\n console.log(chalk.cyan(\" langwatch prompt sync\"));\n } catch (error) {\n console.error(\n chalk.red(\n `Error during login: ${\n error instanceof Error ? error.message : \"Unknown error\"\n }`,\n ),\n );\n process.exit(1);\n }\n};\n"]}
@@ -1,9 +1,9 @@
1
- export { F as FilterableBatchSpanProcessor, L as LangWatchExporter, a as LangWatchExporterOptions, c as LangWatchLogger, L as LangWatchTraceExporter, a as LangWatchTraceExporterOptions, S as SpanProcessingExcludeRule, g as getLangWatchLogger, b as getLangWatchLoggerFromProvider, d as getLangWatchTracer, e as getLangWatchTracerFromProvider } from '../implementation-Ck58nRkT.mjs';
1
+ export { F as FilterableBatchSpanProcessor, L as LangWatchExporter, a as LangWatchExporterOptions, c as LangWatchLogger, L as LangWatchTraceExporter, a as LangWatchTraceExporterOptions, S as SpanProcessingExcludeRule, g as getLangWatchLogger, b as getLangWatchLoggerFromProvider, d as getLangWatchTracer, e as getLangWatchTracerFromProvider } from '../implementation-Dl15eRjo.mjs';
2
2
  import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
3
3
  import { a as DataCaptureMode } from '../types-Dmazk5Bk.mjs';
4
4
  export { b as DataCaptureConfig, c as DataCaptureContext, D as DataCaptureOptions, d as DataCapturePredicate } from '../types-Dmazk5Bk.mjs';
5
- import { L as LangWatchSpan } from '../types-5h2Im4pl.mjs';
6
- export { f as INPUT_OUTPUT_TYPES, I as InputOutputType, J as JsonSerializable, b as LangWatchSpanMetrics, d as LangWatchSpanOptions, c as LangWatchSpanRAGContext, a as LangWatchTracer, e as SimpleChatMessage, S as SpanType, s as spanTypes } from '../types-5h2Im4pl.mjs';
5
+ import { L as LangWatchSpan } from '../types-ExKeJEM0.mjs';
6
+ export { f as INPUT_OUTPUT_TYPES, I as InputOutputType, J as JsonSerializable, b as LangWatchSpanMetrics, d as LangWatchSpanOptions, c as LangWatchSpanRAGContext, a as LangWatchTracer, e as SimpleChatMessage, S as SpanType, s as spanTypes } from '../types-ExKeJEM0.mjs';
7
7
  import { Span } from '@opentelemetry/api';
8
8
  export { b as SemConvAttributeKey, S as SemConvAttributes, a as SemConvLogRecordAttributes, l as attributes } from '../types-DRiQaKFG.mjs';
9
9
  import '@opentelemetry/sdk-trace-base';
@@ -1,9 +1,9 @@
1
- export { F as FilterableBatchSpanProcessor, L as LangWatchExporter, a as LangWatchExporterOptions, c as LangWatchLogger, L as LangWatchTraceExporter, a as LangWatchTraceExporterOptions, S as SpanProcessingExcludeRule, g as getLangWatchLogger, b as getLangWatchLoggerFromProvider, d as getLangWatchTracer, e as getLangWatchTracerFromProvider } from '../implementation-Bnc8Aymq.js';
1
+ export { F as FilterableBatchSpanProcessor, L as LangWatchExporter, a as LangWatchExporterOptions, c as LangWatchLogger, L as LangWatchTraceExporter, a as LangWatchTraceExporterOptions, S as SpanProcessingExcludeRule, g as getLangWatchLogger, b as getLangWatchLoggerFromProvider, d as getLangWatchTracer, e as getLangWatchTracerFromProvider } from '../implementation-gLzM6qpI.js';
2
2
  import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
3
3
  import { a as DataCaptureMode } from '../types-Dmazk5Bk.js';
4
4
  export { b as DataCaptureConfig, c as DataCaptureContext, D as DataCaptureOptions, d as DataCapturePredicate } from '../types-Dmazk5Bk.js';
5
- import { L as LangWatchSpan } from '../types-fo-Ij9pl.js';
6
- export { f as INPUT_OUTPUT_TYPES, I as InputOutputType, J as JsonSerializable, b as LangWatchSpanMetrics, d as LangWatchSpanOptions, c as LangWatchSpanRAGContext, a as LangWatchTracer, e as SimpleChatMessage, S as SpanType, s as spanTypes } from '../types-fo-Ij9pl.js';
5
+ import { L as LangWatchSpan } from '../types-WRcnQUom.js';
6
+ export { f as INPUT_OUTPUT_TYPES, I as InputOutputType, J as JsonSerializable, b as LangWatchSpanMetrics, d as LangWatchSpanOptions, c as LangWatchSpanRAGContext, a as LangWatchTracer, e as SimpleChatMessage, S as SpanType, s as spanTypes } from '../types-WRcnQUom.js';
7
7
  import { Span } from '@opentelemetry/api';
8
8
  export { b as SemConvAttributeKey, S as SemConvAttributes, a as SemConvLogRecordAttributes, l as attributes } from '../types-DRiQaKFG.js';
9
9
  import '@opentelemetry/sdk-trace-base';
@@ -7,14 +7,14 @@ var _chunkASTAIRXGjs = require('../chunk-ASTAIRXG.js');
7
7
 
8
8
 
9
9
 
10
- var _chunkONXIZKC6js = require('../chunk-ONXIZKC6.js');
10
+ var _chunkSHJZRXU7js = require('../chunk-SHJZRXU7.js');
11
11
 
12
12
 
13
13
 
14
14
 
15
15
 
16
- var _chunkBQRUUTN3js = require('../chunk-BQRUUTN3.js');
17
- require('../chunk-C4XUWCQR.js');
16
+ var _chunkGNHX3RA6js = require('../chunk-GNHX3RA6.js');
17
+ require('../chunk-D3YWZYYD.js');
18
18
 
19
19
 
20
20
 
@@ -38,5 +38,5 @@ require('../chunk-OHM7JUMR.js');
38
38
 
39
39
 
40
40
 
41
- exports.DataCapturePresets = _chunkASTAIRXGjs.DataCapturePresets; exports.FilterableBatchSpanProcessor = _chunkASTAIRXGjs.FilterableBatchSpanProcessor; exports.LangWatchExporter = _chunkBQRUUTN3js.LangWatchTraceExporter; exports.LangWatchLogsExporter = _chunkBQRUUTN3js.LangWatchLogsExporter; exports.LangWatchTraceExporter = _chunkBQRUUTN3js.LangWatchTraceExporter; exports.attributes = _chunk5MQQRSVMjs.attributes_exports; exports.createLangWatchSpan = _chunkONXIZKC6js.createLangWatchSpan; exports.getDataCaptureMode = _chunk5MQQRSVMjs.getDataCaptureMode; exports.getLangWatchLogger = _chunkBQRUUTN3js.getLangWatchLogger; exports.getLangWatchLoggerFromProvider = _chunkBQRUUTN3js.getLangWatchLoggerFromProvider; exports.getLangWatchTracer = _chunkONXIZKC6js.getLangWatchTracer; exports.getLangWatchTracerFromProvider = _chunkONXIZKC6js.getLangWatchTracerFromProvider; exports.shouldCaptureInput = _chunk5MQQRSVMjs.shouldCaptureInput; exports.shouldCaptureOutput = _chunk5MQQRSVMjs.shouldCaptureOutput; exports.spanTypes = _chunkONXIZKC6js.spanTypes;
41
+ exports.DataCapturePresets = _chunkASTAIRXGjs.DataCapturePresets; exports.FilterableBatchSpanProcessor = _chunkASTAIRXGjs.FilterableBatchSpanProcessor; exports.LangWatchExporter = _chunkGNHX3RA6js.LangWatchTraceExporter; exports.LangWatchLogsExporter = _chunkGNHX3RA6js.LangWatchLogsExporter; exports.LangWatchTraceExporter = _chunkGNHX3RA6js.LangWatchTraceExporter; exports.attributes = _chunk5MQQRSVMjs.attributes_exports; exports.createLangWatchSpan = _chunkSHJZRXU7js.createLangWatchSpan; exports.getDataCaptureMode = _chunk5MQQRSVMjs.getDataCaptureMode; exports.getLangWatchLogger = _chunkGNHX3RA6js.getLangWatchLogger; exports.getLangWatchLoggerFromProvider = _chunkGNHX3RA6js.getLangWatchLoggerFromProvider; exports.getLangWatchTracer = _chunkSHJZRXU7js.getLangWatchTracer; exports.getLangWatchTracerFromProvider = _chunkSHJZRXU7js.getLangWatchTracerFromProvider; exports.shouldCaptureInput = _chunk5MQQRSVMjs.shouldCaptureInput; exports.shouldCaptureOutput = _chunk5MQQRSVMjs.shouldCaptureOutput; exports.spanTypes = _chunkSHJZRXU7js.spanTypes;
42
42
  //# sourceMappingURL=index.js.map
@@ -7,14 +7,14 @@ import {
7
7
  getLangWatchTracer,
8
8
  getLangWatchTracerFromProvider,
9
9
  spanTypes
10
- } from "../chunk-IIUI2XYW.mjs";
10
+ } from "../chunk-KD5U3MP3.mjs";
11
11
  import {
12
12
  LangWatchLogsExporter,
13
13
  LangWatchTraceExporter,
14
14
  getLangWatchLogger,
15
15
  getLangWatchLoggerFromProvider
16
- } from "../chunk-WCNDT5SD.mjs";
17
- import "../chunk-TB5KB737.mjs";
16
+ } from "../chunk-JX2FBF5Z.mjs";
17
+ import "../chunk-WIB3D4PL.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-5h2Im4pl.mjs';
3
+ import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-ExKeJEM0.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-fo-Ij9pl.js';
3
+ import { L as LangWatchSpan, a as LangWatchTracer, C as ChatMessage } from '../../../types-WRcnQUom.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 _chunkONXIZKC6js = require('../../../chunk-ONXIZKC6.js');
4
+ var _chunkSHJZRXU7js = require('../../../chunk-SHJZRXU7.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 = _chunkONXIZKC6js.getLangWatchTracer.call(void 0, "langwatch.instrumentation.langchain");
34
+ this.tracer = _chunkSHJZRXU7js.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 = _chunkONXIZKC6js.chatMessageSchema.array().safeParse(value);
365
+ const chatMessages = _chunkSHJZRXU7js.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-IIUI2XYW.mjs";
4
+ } from "../../../chunk-KD5U3MP3.mjs";
5
5
  import {
6
6
  shouldCaptureInput,
7
7
  shouldCaptureOutput
@@ -364,5 +364,28 @@ interface ObservabilityHandle {
364
364
  }
365
365
 
366
366
  declare function setupObservability(options?: SetupObservabilityOptions): ObservabilityHandle;
367
+ /**
368
+ * Ensure observability is set up, but only if not already configured.
369
+ *
370
+ * This is an idempotent function that:
371
+ * - Does nothing if OpenTelemetry is already configured (by you or another library)
372
+ * - Sets up LangWatch observability if no tracer provider exists
373
+ * - Does nothing if LANGWATCH_API_KEY is not set
374
+ *
375
+ * This is useful for libraries/SDKs that want to ensure tracing is available
376
+ * without conflicting with user's existing observability setup.
377
+ *
378
+ * @example
379
+ * ```typescript
380
+ * import { ensureSetup } from "langwatch/observability/node";
381
+ *
382
+ * // Safe to call - won't conflict with existing setup
383
+ * ensureSetup();
384
+ *
385
+ * // Now you can use tracing
386
+ * const tracer = trace.getTracer("my-app");
387
+ * ```
388
+ */
389
+ declare const ensureSetup: () => ObservabilityHandle;
367
390
 
368
- export { type ObservabilityHandle, type SetupObservabilityOptions, setupObservability };
391
+ export { type ObservabilityHandle, type SetupObservabilityOptions, ensureSetup, setupObservability };
@@ -364,5 +364,28 @@ interface ObservabilityHandle {
364
364
  }
365
365
 
366
366
  declare function setupObservability(options?: SetupObservabilityOptions): ObservabilityHandle;
367
+ /**
368
+ * Ensure observability is set up, but only if not already configured.
369
+ *
370
+ * This is an idempotent function that:
371
+ * - Does nothing if OpenTelemetry is already configured (by you or another library)
372
+ * - Sets up LangWatch observability if no tracer provider exists
373
+ * - Does nothing if LANGWATCH_API_KEY is not set
374
+ *
375
+ * This is useful for libraries/SDKs that want to ensure tracing is available
376
+ * without conflicting with user's existing observability setup.
377
+ *
378
+ * @example
379
+ * ```typescript
380
+ * import { ensureSetup } from "langwatch/observability/node";
381
+ *
382
+ * // Safe to call - won't conflict with existing setup
383
+ * ensureSetup();
384
+ *
385
+ * // Now you can use tracing
386
+ * const tracer = trace.getTracer("my-app");
387
+ * ```
388
+ */
389
+ declare const ensureSetup: () => ObservabilityHandle;
367
390
 
368
- export { type ObservabilityHandle, type SetupObservabilityOptions, setupObservability };
391
+ export { type ObservabilityHandle, type SetupObservabilityOptions, ensureSetup, setupObservability };
@@ -1,298 +1,13 @@
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; } }
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
3
 
4
+ var _chunk2BALUJ3Bjs = require('../../../chunk-2BALUJ3B.js');
5
+ require('../../../chunk-GNHX3RA6.js');
6
+ require('../../../chunk-D3YWZYYD.js');
7
+ require('../../../chunk-5MQQRSVM.js');
8
+ require('../../../chunk-OHM7JUMR.js');
4
9
 
5
- var _chunkBQRUUTN3js = require('../../../chunk-BQRUUTN3.js');
6
10
 
7
11
 
8
-
9
-
10
-
11
-
12
- var _chunkC4XUWCQRjs = require('../../../chunk-C4XUWCQR.js');
13
-
14
-
15
-
16
- var _chunk5MQQRSVMjs = require('../../../chunk-5MQQRSVM.js');
17
-
18
-
19
- var _chunkOHM7JUMRjs = require('../../../chunk-OHM7JUMR.js');
20
-
21
- // src/observability-sdk/setup/node/setup.ts
22
- var _sdknode = require('@opentelemetry/sdk-node');
23
- var _sdklogs = require('@opentelemetry/sdk-logs');
24
-
25
- // src/observability-sdk/setup/utils.ts
26
-
27
-
28
-
29
- var _resources = require('@opentelemetry/resources');
30
- var _incubating = require('@opentelemetry/semantic-conventions/incubating'); var semconv = _interopRequireWildcard(_incubating);
31
- function createMergedResource(attributes, serviceName, givenResource) {
32
- const langwatchResource = _resources.resourceFromAttributes.call(void 0, {
33
- [semconv.ATTR_TELEMETRY_SDK_NAME]: _chunkC4XUWCQRjs.LANGWATCH_SDK_NAME_OBSERVABILITY,
34
- [semconv.ATTR_TELEMETRY_SDK_LANGUAGE]: _chunkC4XUWCQRjs.LANGWATCH_SDK_LANGUAGE,
35
- [semconv.ATTR_TELEMETRY_SDK_VERSION]: _chunkC4XUWCQRjs.LANGWATCH_SDK_VERSION
36
- });
37
- const userResource = _resources.resourceFromAttributes.call(void 0, _chunkOHM7JUMRjs.__spreadValues.call(void 0, {
38
- [semconv.ATTR_SERVICE_NAME]: serviceName != null ? serviceName : _chunkC4XUWCQRjs.DEFAULT_SERVICE_NAME
39
- }, attributes != null ? attributes : {}));
40
- return (givenResource != null ? givenResource : _resources.defaultResource.call(void 0, )).merge(langwatchResource).merge(userResource);
41
- }
42
- function getConcreteProvider(provider) {
43
- var _a, _b;
44
- if (!provider || typeof provider !== "object") return void 0;
45
- const constructorName = (_a = provider.constructor) == null ? void 0 : _a.name;
46
- if (["NodeTracerProvider", "BasicTracerProvider"].includes(constructorName)) {
47
- return provider;
48
- }
49
- if (typeof provider.addSpanProcessor === "function") {
50
- return provider;
51
- }
52
- let delegate;
53
- if (typeof provider.getDelegate === "function") {
54
- delegate = provider.getDelegate();
55
- } else if (provider.delegate) {
56
- delegate = provider.delegate;
57
- } else if (provider._delegate) {
58
- delegate = provider._delegate;
59
- }
60
- if (delegate && typeof delegate === "object") {
61
- const delegateConstructorName = (_b = delegate.constructor) == null ? void 0 : _b.name;
62
- if (["NodeTracerProvider", "BasicTracerProvider"].includes(delegateConstructorName)) {
63
- return delegate;
64
- }
65
- if (typeof delegate.addSpanProcessor === "function") {
66
- return delegate;
67
- }
68
- }
69
- return void 0;
70
- }
71
- function isConcreteProvider(provider) {
72
- return !!getConcreteProvider(provider);
73
- }
74
-
75
- // src/observability-sdk/setup/node/setup.ts
76
- var _api = require('@opentelemetry/api');
77
-
78
-
79
-
80
-
81
- var _sdktracebase = require('@opentelemetry/sdk-trace-base');
82
- var createNoOpHandle = (logger) => ({
83
- shutdown: async () => {
84
- logger.debug("Shutdown called for LangWatch no-op. Nothing will be shutdown");
85
- }
86
- });
87
- var getLangWatchConfig = (options) => {
88
- var _a, _b, _c, _d;
89
- const isDisabled = options.langwatch === "disabled";
90
- const config = typeof options.langwatch === "object" ? options.langwatch : {};
91
- return {
92
- disabled: isDisabled,
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 : _chunkC4XUWCQRjs.DEFAULT_ENDPOINT,
95
- processorType: (_d = config.processorType) != null ? _d : "simple"
96
- };
97
- };
98
- var checkForEarlyExit = (options, logger) => {
99
- var _a, _b, _c;
100
- if ((_a = options.advanced) == null ? void 0 : _a.disabled) {
101
- logger.debug("Observability disabled via advanced.disabled");
102
- return createNoOpHandle(logger);
103
- }
104
- if ((_b = options.advanced) == null ? void 0 : _b.skipOpenTelemetrySetup) {
105
- logger.debug("Skipping OpenTelemetry setup");
106
- return createNoOpHandle(logger);
107
- }
108
- const globalProvider = _api.trace.getTracerProvider();
109
- const alreadySetup = isConcreteProvider(globalProvider);
110
- if (alreadySetup && !((_c = options.advanced) == null ? void 0 : _c.UNSAFE_forceOpenTelemetryReinitialization)) {
111
- logger.error(
112
- `OpenTelemetry is already set up in this process.
113
- Spans will NOT be sent to LangWatch unless you add the LangWatch span processor or exporter to your existing OpenTelemetry setup.
114
- You must either:
115
- 1. Remove your existing OpenTelemetry setup and only use LangWatch,
116
- 2. Add the LangWatch span processor to your existing setup, or replace the existing exporter with the LangWatch exporter.
117
-
118
- For step-by-step instructions, see the LangWatch docs and check out the integration guide for your framework:
119
- https://docs.langwatch.ai/integration/typescript/guide
120
-
121
- See also: https://github.com/open-telemetry/opentelemetry-js/issues/5299`
122
- );
123
- return createNoOpHandle(logger);
124
- }
125
- if (alreadySetup) {
126
- logger.warn(
127
- "OpenTelemetry is already set up, but UNSAFE_forceOpenTelemetryReinitialization=true. Proceeding with reinitialization. This may cause conflicts."
128
- );
129
- }
130
- return null;
131
- };
132
- var warnIfMisconfigured = (options, langwatch, logger) => {
133
- var _a, _b, _c, _d, _e, _f, _g, _h, _i;
134
- if (langwatch.disabled) {
135
- const hasAlternativeExport = (_h = (_g = (_e = (_c = (_a = options.spanProcessors) == null ? void 0 : _a.length) != null ? _c : (_b = options.logRecordProcessors) == null ? void 0 : _b.length) != null ? _e : (_d = options.debug) == null ? void 0 : _d.consoleTracing) != null ? _g : (_f = options.debug) == null ? void 0 : _f.consoleLogging) != null ? _h : options.traceExporter;
136
- if (!hasAlternativeExport) {
137
- const errorMessage = "LangWatch integration is disabled but no custom span processors, trace exporters, or console tracing is configured. OpenTelemetry will be set up but traces will not be exported anywhere. Either:\n 1. Enable LangWatch integration (remove langwatch: 'disabled')\n 2. Provide custom spanProcessors, logRecordProcessors, or traceExporter\n 3. Enable debug.consoleTracing or debug.consoleLogging for development\n 4. Use advanced.disabled to completely disable observability\n 5. Use advanced.skipOpenTelemetrySetup to handle OpenTelemetry setup yourself";
138
- if ((_i = options.advanced) == null ? void 0 : _i.throwOnSetupError) {
139
- throw new Error(errorMessage);
140
- } else {
141
- logger.error(errorMessage);
142
- }
143
- }
144
- }
145
- };
146
- function setupObservability(options = {}) {
147
- var _a, _b, _c, _d, _e;
148
- const logger = (_d = (_a = options.debug) == null ? void 0 : _a.logger) != null ? _d : new (0, _chunk5MQQRSVMjs.ConsoleLogger)({
149
- level: (_c = (_b = options.debug) == null ? void 0 : _b.logLevel) != null ? _c : "warn",
150
- prefix: "LangWatch Observability SDK"
151
- });
152
- _chunk5MQQRSVMjs.initializeObservabilitySdkConfig.call(void 0, {
153
- logger,
154
- dataCapture: options.dataCapture
155
- });
156
- const earlyExit = checkForEarlyExit(options, logger);
157
- if (earlyExit) return earlyExit;
158
- try {
159
- const sdk = createAndStartNodeSdk(options, logger, createMergedResource(
160
- options.attributes,
161
- options.serviceName,
162
- options.resource
163
- ));
164
- logger.info("LangWatch Observability SDK setup completed successfully");
165
- return {
166
- shutdown: async () => {
167
- logger.debug("Shutting down NodeSDK");
168
- await (sdk == null ? void 0 : sdk.shutdown());
169
- logger.info("NodeSDK shutdown complete");
170
- }
171
- };
172
- } catch (err) {
173
- const errorMessage = err instanceof Error ? err.message : String(err);
174
- logger.error(`Failed to initialize NodeSDK: ${errorMessage}`);
175
- if (err instanceof Error && err.stack) {
176
- logger.debug(`Stack trace: ${err.stack}`);
177
- }
178
- if ((_e = options.advanced) == null ? void 0 : _e.throwOnSetupError) throw err;
179
- return createNoOpHandle(logger);
180
- }
181
- }
182
- function createAndStartNodeSdk(options, logger, resource) {
183
- var _a, _b, _c, _d, _e;
184
- const langwatch = getLangWatchConfig(options);
185
- if (langwatch.disabled) {
186
- logger.warn("LangWatch integration disabled, using user-provided SpanProcessors and LogRecordProcessors");
187
- } else {
188
- logger.info(`Using LangWatch ${langwatch.processorType} processors for tracing and logging`);
189
- }
190
- const spanProcessors = [];
191
- const logProcessors = [];
192
- if ((_a = options.debug) == null ? void 0 : _a.consoleTracing) {
193
- spanProcessors.push(new (0, _sdktracebase.SimpleSpanProcessor)(new (0, _sdktracebase.ConsoleSpanExporter)()));
194
- logger.debug("Console tracing enabled; adding console span exporter");
195
- }
196
- if ((_b = options.debug) == null ? void 0 : _b.consoleLogging) {
197
- logProcessors.push(new (0, _sdklogs.SimpleLogRecordProcessor)(new (0, _sdklogs.ConsoleLogRecordExporter)()));
198
- logger.debug("Console recording of logs enabled; adding console log record processor");
199
- }
200
- if (!langwatch.disabled) {
201
- const traceExporter = new (0, _chunkBQRUUTN3js.LangWatchTraceExporter)({
202
- apiKey: langwatch.apiKey,
203
- endpoint: langwatch.endpoint
204
- });
205
- const logExporter = new (0, _chunkBQRUUTN3js.LangWatchLogsExporter)({
206
- apiKey: langwatch.apiKey,
207
- endpoint: langwatch.endpoint
208
- });
209
- if (langwatch.processorType === "batch") {
210
- spanProcessors.push(new (0, _sdktracebase.BatchSpanProcessor)(traceExporter));
211
- logProcessors.push(new (0, _sdklogs.BatchLogRecordProcessor)(logExporter));
212
- logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);
213
- } else {
214
- spanProcessors.push(new (0, _sdktracebase.SimpleSpanProcessor)(traceExporter));
215
- logProcessors.push(new (0, _sdklogs.SimpleLogRecordProcessor)(logExporter));
216
- logger.debug(`Added LangWatch ${langwatch.processorType} SpanProcessor and LogRecordProcessor to SDK`);
217
- }
218
- }
219
- if (options.traceExporter) {
220
- spanProcessors.push(new (0, _sdktracebase.SimpleSpanProcessor)(options.traceExporter));
221
- logger.debug(`Added user-provided SpanProcessor to SDK`);
222
- }
223
- if ((_c = options.spanProcessors) == null ? void 0 : _c.length) {
224
- spanProcessors.push(...options.spanProcessors);
225
- logger.debug(`Added user-provided ${options.spanProcessors.length} SpanProcessors to SDK`);
226
- }
227
- if ((_d = options.logRecordProcessors) == null ? void 0 : _d.length) {
228
- logProcessors.push(...options.logRecordProcessors);
229
- logger.debug(`Added user-provided ${options.logRecordProcessors.length} LogRecordProcessors to SDK`);
230
- }
231
- warnIfMisconfigured(options, langwatch, logger);
232
- const loggerProvider = logProcessors.length ? new (0, _sdklogs.LoggerProvider)({
233
- resource,
234
- processors: logProcessors
235
- }) : void 0;
236
- if (loggerProvider) {
237
- logger.debug("Created LangWatch logger provider");
238
- }
239
- const sdk = new (0, _sdknode.NodeSDK)({
240
- resource,
241
- serviceName: options.serviceName,
242
- autoDetectResources: options.autoDetectResources,
243
- contextManager: options.contextManager,
244
- textMapPropagator: options.textMapPropagator,
245
- metricReader: options.metricReader,
246
- views: options.views,
247
- resourceDetectors: options.resourceDetectors,
248
- sampler: options.sampler,
249
- spanProcessors,
250
- logRecordProcessors: logProcessors,
251
- spanLimits: options.spanLimits,
252
- idGenerator: options.idGenerator,
253
- instrumentations: options.instrumentations
254
- });
255
- sdk.start();
256
- logger.info("NodeSDK started successfully");
257
- if (process.env.NEXT_RUNTIME === "nodejs") {
258
- setImmediate(() => {
259
- const globalProvider = _api.trace.getTracerProvider();
260
- if (globalProvider.constructor.name === "ProxyTracerProvider") {
261
- logger.warn("Global provider is still ProxyTracerProvider after SDK start - applying Next.js 15 workaround");
262
- const realProvider = globalProvider._delegate;
263
- if ((realProvider == null ? void 0 : realProvider.constructor.name) === "NodeTracerProvider") {
264
- _api.trace.setGlobalTracerProvider(realProvider);
265
- logger.info("Successfully registered NodeTracerProvider globally for Next.js 15");
266
- } else {
267
- logger.error("Could not find NodeTracerProvider in proxy delegate - spans may not be exported");
268
- }
269
- } else {
270
- logger.debug(`Provider registered correctly: ${globalProvider.constructor.name}`);
271
- }
272
- });
273
- }
274
- if (loggerProvider) {
275
- _chunkBQRUUTN3js.setLangWatchLoggerProvider.call(void 0, loggerProvider);
276
- logger.debug("Set LangWatch logger provider");
277
- }
278
- if (!((_e = options.advanced) == null ? void 0 : _e.disableAutoShutdown)) {
279
- process.on("SIGTERM", () => {
280
- void (async () => {
281
- logger.debug("SIGTERM received: shutting down OpenTelemetry...");
282
- try {
283
- await sdk.shutdown();
284
- logger.debug("OpenTelemetry shutdown complete");
285
- } catch (err) {
286
- logger.error("Error shutting down OpenTelemetry", err);
287
- } finally {
288
- process.exit(0);
289
- }
290
- })();
291
- });
292
- }
293
- return sdk;
294
- }
295
-
296
-
297
- exports.setupObservability = setupObservability;
12
+ exports.ensureSetup = _chunk2BALUJ3Bjs.ensureSetup; exports.setupObservability = _chunk2BALUJ3Bjs.setupObservability;
298
13
  //# sourceMappingURL=index.js.map
@@ -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?.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"],"names":[],"mappings":"AAAA;AACE;AACA;AACF,6DAAmC;AACnC,sCAAmC;AACnC,sCAAmC;AACnC,sCAAmC;AACnC,sCAAmC;AACnC;AACE;AACA;AACF,qHAAC","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/observability-sdk/setup/node/index.js"}