langwatch 0.3.2 → 0.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (206) hide show
  1. package/dist/{add-LBBS4I3H.js → add-RGWB3264.js} +35 -28
  2. package/dist/add-RGWB3264.js.map +1 -0
  3. package/dist/{add-RD3ZKFAT.mjs → add-WLUMK5VQ.mjs} +23 -16
  4. package/dist/add-WLUMK5VQ.mjs.map +1 -0
  5. package/dist/chunk-4ILMGMAP.mjs +155 -0
  6. package/dist/chunk-4ILMGMAP.mjs.map +1 -0
  7. package/dist/chunk-4TF2O2TH.js +207 -0
  8. package/dist/chunk-4TF2O2TH.js.map +1 -0
  9. package/dist/chunk-5N5BUR2Z.js +636 -0
  10. package/dist/chunk-5N5BUR2Z.js.map +1 -0
  11. package/dist/chunk-AZELEDOV.js +155 -0
  12. package/dist/chunk-AZELEDOV.js.map +1 -0
  13. package/dist/{chunk-YN4436PK.mjs → chunk-CU3443HD.mjs} +14 -9
  14. package/dist/{chunk-2JU376G7.js → chunk-D2CSG4SJ.js} +4 -4
  15. package/dist/chunk-D2CSG4SJ.js.map +1 -0
  16. package/dist/chunk-DEVJ7BPE.js +63 -0
  17. package/dist/chunk-DEVJ7BPE.js.map +1 -0
  18. package/dist/chunk-DISMHYXC.js +184 -0
  19. package/dist/chunk-DISMHYXC.js.map +1 -0
  20. package/dist/{chunk-E7UE2MPD.mjs → chunk-ECUXLXFT.mjs} +2 -2
  21. package/dist/chunk-EJWJXTPU.mjs +626 -0
  22. package/dist/chunk-EJWJXTPU.mjs.map +1 -0
  23. package/dist/chunk-FQSWUK5N.mjs +63 -0
  24. package/dist/chunk-FQSWUK5N.mjs.map +1 -0
  25. package/dist/{chunk-3GKPQB4R.mjs → chunk-HUI45ULC.mjs} +4 -4
  26. package/dist/chunk-HUI45ULC.mjs.map +1 -0
  27. package/dist/chunk-IZ2U3ABC.mjs +636 -0
  28. package/dist/chunk-IZ2U3ABC.mjs.map +1 -0
  29. package/dist/{chunk-HJU67C7H.js → chunk-K64Y6YUG.js} +10 -10
  30. package/dist/{chunk-HJU67C7H.js.map → chunk-K64Y6YUG.js.map} +1 -1
  31. package/dist/chunk-M4VUHTT2.js +626 -0
  32. package/dist/chunk-M4VUHTT2.js.map +1 -0
  33. package/dist/{chunk-PR3JDWC3.mjs → chunk-N2V6J3U2.mjs} +28 -3
  34. package/dist/chunk-N2V6J3U2.mjs.map +1 -0
  35. package/dist/{chunk-FJLK5CFL.js → chunk-OXBO24RB.js} +13 -8
  36. package/dist/chunk-OXBO24RB.js.map +1 -0
  37. package/dist/{chunk-SMXXAVMB.js → chunk-SGNJDRCT.js} +2 -2
  38. package/dist/chunk-SGNJDRCT.js.map +1 -0
  39. package/dist/{chunk-W5ZEP3CI.mjs → chunk-SYMZPWZE.mjs} +2 -2
  40. package/dist/chunk-SYMZPWZE.mjs.map +1 -0
  41. package/dist/{chunk-KGDAENGD.js → chunk-YH5TIVK2.js} +28 -3
  42. package/dist/chunk-YH5TIVK2.js.map +1 -0
  43. package/dist/chunk-YNQ44U6D.mjs +184 -0
  44. package/dist/chunk-YNQ44U6D.mjs.map +1 -0
  45. package/dist/chunk-ZJZ3MIWE.mjs +207 -0
  46. package/dist/chunk-ZJZ3MIWE.mjs.map +1 -0
  47. package/dist/cli/index.js +8 -8
  48. package/dist/cli/index.mjs +8 -8
  49. package/dist/{create-G5MTGOOH.js → create-7K2CC4KQ.js} +11 -11
  50. package/dist/{create-G5MTGOOH.js.map → create-7K2CC4KQ.js.map} +1 -1
  51. package/dist/{create-QUZYBMQB.mjs → create-MK7NEGCM.mjs} +8 -8
  52. package/dist/implementation-C4lvooSg.d.mts +576 -0
  53. package/dist/implementation-CzemP9jY.d.ts +576 -0
  54. package/dist/index-DTEZr0Jn.d.mts +34 -0
  55. package/dist/index-DTEZr0Jn.d.ts +34 -0
  56. package/dist/index.d.mts +121 -47
  57. package/dist/index.d.ts +121 -47
  58. package/dist/index.js +17 -12
  59. package/dist/index.js.map +1 -1
  60. package/dist/index.mjs +28 -23
  61. package/dist/index.mjs.map +1 -1
  62. package/dist/init-GDKJICSS.js +16 -0
  63. package/dist/{init-XU2JFY6N.js.map → init-GDKJICSS.js.map} +1 -1
  64. package/dist/{init-H67RW22E.mjs → init-RINSTP4L.mjs} +5 -5
  65. package/dist/{list-ZXFLAF52.js → list-DBUK47MA.js} +30 -17
  66. package/dist/list-DBUK47MA.js.map +1 -0
  67. package/dist/{list-7NPSX2E4.mjs → list-ZOMRKOBV.mjs} +29 -16
  68. package/dist/list-ZOMRKOBV.mjs.map +1 -0
  69. package/dist/{login-76NQIHKR.js → login-A7LEPNBR.js} +8 -4
  70. package/dist/login-A7LEPNBR.js.map +1 -0
  71. package/dist/{login-EK4WVOI2.mjs → login-ULPHWIAX.mjs} +8 -4
  72. package/dist/login-ULPHWIAX.mjs.map +1 -0
  73. package/dist/observability-sdk/index.d.mts +134 -0
  74. package/dist/observability-sdk/index.d.ts +134 -0
  75. package/dist/observability-sdk/index.js +42 -0
  76. package/dist/observability-sdk/index.js.map +1 -0
  77. package/dist/observability-sdk/index.mjs +42 -0
  78. package/dist/observability-sdk/instrumentation/langchain/index.d.mts +69 -0
  79. package/dist/observability-sdk/instrumentation/langchain/index.d.ts +69 -0
  80. package/dist/observability-sdk/instrumentation/langchain/index.js +518 -0
  81. package/dist/observability-sdk/instrumentation/langchain/index.js.map +1 -0
  82. package/dist/observability-sdk/instrumentation/langchain/index.mjs +518 -0
  83. package/dist/observability-sdk/instrumentation/langchain/index.mjs.map +1 -0
  84. package/dist/observability-sdk/setup/node/index.d.mts +368 -0
  85. package/dist/observability-sdk/setup/node/index.d.ts +368 -0
  86. package/dist/observability-sdk/setup/node/index.js +279 -0
  87. package/dist/observability-sdk/setup/node/index.js.map +1 -0
  88. package/dist/observability-sdk/setup/node/index.mjs +279 -0
  89. package/dist/observability-sdk/setup/node/index.mjs.map +1 -0
  90. package/dist/{remove-XBNGIVMR.js → remove-ODTJLFWR.js} +19 -15
  91. package/dist/remove-ODTJLFWR.js.map +1 -0
  92. package/dist/{remove-SDJYEPAY.mjs → remove-RAJBGHQQ.mjs} +12 -8
  93. package/dist/remove-RAJBGHQQ.mjs.map +1 -0
  94. package/dist/{sync-ST2IWXSB.mjs → sync-2IXPWN64.mjs} +40 -33
  95. package/dist/sync-2IXPWN64.mjs.map +1 -0
  96. package/dist/{sync-EISKGPTL.js → sync-PBOL5ODF.js} +53 -46
  97. package/dist/sync-PBOL5ODF.js.map +1 -0
  98. package/dist/{prompt-D-jpMrLS.d.mts → types-1q5wIYP5.d.mts} +628 -14
  99. package/dist/{prompt-D-jpMrLS.d.ts → types-C9k5gGhU.d.ts} +628 -14
  100. package/dist/types-DRiQaKFG.d.mts +254 -0
  101. package/dist/types-DRiQaKFG.d.ts +254 -0
  102. package/dist/types-Dmazk5Bk.d.mts +44 -0
  103. package/dist/types-Dmazk5Bk.d.ts +44 -0
  104. package/package.json +39 -39
  105. package/dist/add-LBBS4I3H.js.map +0 -1
  106. package/dist/add-RD3ZKFAT.mjs.map +0 -1
  107. package/dist/chunk-2JU376G7.js.map +0 -1
  108. package/dist/chunk-2ODBGSBI.js +0 -4
  109. package/dist/chunk-2ODBGSBI.js.map +0 -1
  110. package/dist/chunk-3GKPQB4R.mjs.map +0 -1
  111. package/dist/chunk-52GXX3MA.js +0 -426
  112. package/dist/chunk-52GXX3MA.js.map +0 -1
  113. package/dist/chunk-5NC5ILKA.js +0 -94
  114. package/dist/chunk-5NC5ILKA.js.map +0 -1
  115. package/dist/chunk-AAROJADR.mjs +0 -49
  116. package/dist/chunk-AAROJADR.mjs.map +0 -1
  117. package/dist/chunk-DTEKFQ4U.js +0 -159
  118. package/dist/chunk-DTEKFQ4U.js.map +0 -1
  119. package/dist/chunk-F63YKTXA.mjs +0 -47
  120. package/dist/chunk-F63YKTXA.mjs.map +0 -1
  121. package/dist/chunk-FJLK5CFL.js.map +0 -1
  122. package/dist/chunk-GJSEBQXF.mjs +0 -392
  123. package/dist/chunk-GJSEBQXF.mjs.map +0 -1
  124. package/dist/chunk-IGHXIIIK.js +0 -49
  125. package/dist/chunk-IGHXIIIK.js.map +0 -1
  126. package/dist/chunk-J7ICRUU4.mjs +0 -426
  127. package/dist/chunk-J7ICRUU4.mjs.map +0 -1
  128. package/dist/chunk-KGDAENGD.js.map +0 -1
  129. package/dist/chunk-LD74LVRU.js +0 -47
  130. package/dist/chunk-LD74LVRU.js.map +0 -1
  131. package/dist/chunk-PCQVQ7SB.js +0 -45
  132. package/dist/chunk-PCQVQ7SB.js.map +0 -1
  133. package/dist/chunk-PR3JDWC3.mjs.map +0 -1
  134. package/dist/chunk-PWZBLTHR.js +0 -118
  135. package/dist/chunk-PWZBLTHR.js.map +0 -1
  136. package/dist/chunk-QEWDG5QE.mjs +0 -45
  137. package/dist/chunk-QEWDG5QE.mjs.map +0 -1
  138. package/dist/chunk-SMXXAVMB.js.map +0 -1
  139. package/dist/chunk-STV4ZVNA.mjs +0 -118
  140. package/dist/chunk-STV4ZVNA.mjs.map +0 -1
  141. package/dist/chunk-T5AZMMVS.mjs +0 -94
  142. package/dist/chunk-T5AZMMVS.mjs.map +0 -1
  143. package/dist/chunk-UU33HCCZ.mjs +0 -159
  144. package/dist/chunk-UU33HCCZ.mjs.map +0 -1
  145. package/dist/chunk-VGHLQXKB.js +0 -392
  146. package/dist/chunk-VGHLQXKB.js.map +0 -1
  147. package/dist/chunk-W5ZEP3CI.mjs.map +0 -1
  148. package/dist/chunk-Y666BJA5.mjs +0 -4
  149. package/dist/chunk-YN4436PK.mjs.map +0 -1
  150. package/dist/client-B2HqIKg6.d.ts +0 -51
  151. package/dist/client-XyCqclCi.d.mts +0 -51
  152. package/dist/client-browser.d.mts +0 -8
  153. package/dist/client-browser.d.ts +0 -8
  154. package/dist/client-browser.js +0 -88
  155. package/dist/client-browser.js.map +0 -1
  156. package/dist/client-browser.mjs +0 -88
  157. package/dist/client-browser.mjs.map +0 -1
  158. package/dist/client-node.d.mts +0 -8
  159. package/dist/client-node.d.ts +0 -8
  160. package/dist/client-node.js +0 -95
  161. package/dist/client-node.js.map +0 -1
  162. package/dist/client-node.mjs +0 -95
  163. package/dist/client-node.mjs.map +0 -1
  164. package/dist/evaluation/index.d.mts +0 -897
  165. package/dist/evaluation/index.d.ts +0 -897
  166. package/dist/evaluation/index.js +0 -14
  167. package/dist/evaluation/index.js.map +0 -1
  168. package/dist/evaluation/index.mjs +0 -14
  169. package/dist/filterable-batch-span-processor-zO5kcjBY.d.mts +0 -64
  170. package/dist/filterable-batch-span-processor-zO5kcjBY.d.ts +0 -64
  171. package/dist/init-XU2JFY6N.js +0 -16
  172. package/dist/list-7NPSX2E4.mjs.map +0 -1
  173. package/dist/list-ZXFLAF52.js.map +0 -1
  174. package/dist/login-76NQIHKR.js.map +0 -1
  175. package/dist/login-EK4WVOI2.mjs.map +0 -1
  176. package/dist/observability/index.d.mts +0 -260
  177. package/dist/observability/index.d.ts +0 -260
  178. package/dist/observability/index.js +0 -21
  179. package/dist/observability/index.js.map +0 -1
  180. package/dist/observability/index.mjs +0 -21
  181. package/dist/observability/index.mjs.map +0 -1
  182. package/dist/observability/instrumentation/langchain/index.d.mts +0 -40
  183. package/dist/observability/instrumentation/langchain/index.d.ts +0 -40
  184. package/dist/observability/instrumentation/langchain/index.js +0 -668
  185. package/dist/observability/instrumentation/langchain/index.js.map +0 -1
  186. package/dist/observability/instrumentation/langchain/index.mjs +0 -668
  187. package/dist/observability/instrumentation/langchain/index.mjs.map +0 -1
  188. package/dist/prompt/index.d.mts +0 -10
  189. package/dist/prompt/index.d.ts +0 -10
  190. package/dist/prompt/index.js +0 -22
  191. package/dist/prompt/index.js.map +0 -1
  192. package/dist/prompt/index.mjs +0 -22
  193. package/dist/prompt/index.mjs.map +0 -1
  194. package/dist/record-evaluation-CmxMXa-3.d.mts +0 -25
  195. package/dist/record-evaluation-CmxMXa-3.d.ts +0 -25
  196. package/dist/remove-SDJYEPAY.mjs.map +0 -1
  197. package/dist/remove-XBNGIVMR.js.map +0 -1
  198. package/dist/sync-EISKGPTL.js.map +0 -1
  199. package/dist/sync-ST2IWXSB.mjs.map +0 -1
  200. package/dist/trace-CqaKo0kZ.d.ts +0 -622
  201. package/dist/trace-DtVc5GhF.d.mts +0 -622
  202. /package/dist/{chunk-Y666BJA5.mjs.map → chunk-CU3443HD.mjs.map} +0 -0
  203. /package/dist/{chunk-E7UE2MPD.mjs.map → chunk-ECUXLXFT.mjs.map} +0 -0
  204. /package/dist/{create-QUZYBMQB.mjs.map → create-MK7NEGCM.mjs.map} +0 -0
  205. /package/dist/{init-H67RW22E.mjs.map → init-RINSTP4L.mjs.map} +0 -0
  206. /package/dist/{evaluation → observability-sdk}/index.mjs.map +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-M4VUHTT2.js","../src/observability-sdk/span/types.ts","../src/internal/generated/types/tracer.generated.ts","../src/observability-sdk/span/implementation.ts","../src/observability-sdk/span/input-output.ts","../src/observability-sdk/tracer/implementation.ts"],"names":["z","result","_a","name"],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-M4VUHTT2.js","sourcesContent":[null,"import {\n type AttributeValue,\n type Span,\n type SpanOptions,\n} from \"@opentelemetry/api\";\nimport {\n type SpanInputOutput,\n type ChatMessage,\n} from \"../../internal/generated/types/tracer\";\nimport { type Prompt } from \"@/client-sdk/services/prompts\";\n\n\n/**\n * Simple chat message type with just role and content\n */\nexport interface SimpleChatMessage {\n role: string;\n content: unknown;\n}\n\n/**\n * Valid input/output types for span data\n */\nexport const INPUT_OUTPUT_TYPES = [\n \"text\",\n \"raw\",\n \"chat_messages\",\n \"list\",\n \"json\",\n \"guardrail_result\",\n \"evaluation_result\"\n] as const;\n\nexport type InputOutputType = typeof INPUT_OUTPUT_TYPES[number];\n\n\nexport type JsonSerializable =\n | string\n | number\n | boolean\n | null\n | JsonSerializable[]\n | Record<string, any>;\n\n// Import attributes types from parent\nimport type { SemConvAttributes } from \"../semconv\";\n\n/**\n * Supported types of spans for LangWatch observability. These types categorize the nature of the span for downstream analysis and visualization.\n *\n * @example\n * import { spanTypes, SpanType } from './span';\n * const myType: SpanType = 'llm';\n */\nexport const spanTypes = [\n \"span\",\n \"llm\",\n \"chain\",\n \"tool\",\n \"agent\",\n \"guardrail\",\n \"evaluation\",\n \"rag\",\n \"prompt\",\n \"workflow\",\n \"component\",\n \"module\",\n \"server\",\n \"client\",\n \"producer\",\n \"consumer\",\n \"task\",\n \"unknown\",\n] as const;\n\nexport type SpanType = (typeof spanTypes)[number];\n\n/**\n * Context for a RAG (Retrieval-Augmented Generation) span.\n *\n * This structure is used to record which document and chunk were retrieved and used as context for a generation.\n *\n * @property document_id - Unique identifier for the source document.\n * @property chunk_id - Unique identifier for the chunk within the document.\n * @property content - The actual content of the chunk provided to the model.\n *\n * @example\n * const ragContext: LangWatchSpanRAGContext = {\n * document_id: 'doc-123',\n * chunk_id: 'chunk-456',\n * content: 'Relevant passage from the document.'\n * };\n */\nexport interface LangWatchSpanRAGContext {\n document_id: string;\n chunk_id: string;\n content: string;\n}\n\n/**\n * Metrics for a LangWatch span.\n *\n * @property promptTokens - The number of prompt tokens used.\n * @property completionTokens - The number of completion tokens used.\n * @property cost - The cost of the span.\n */\nexport interface LangWatchSpanMetrics {\n /** The number of prompt tokens used */\n promptTokens?: number;\n /** The number of completion tokens used */\n completionTokens?: number;\n /** The cost of the span */\n cost?: number;\n}\n\n/**\n * Options for creating a LangWatch span.\n *\n * @param attributes - Additional attributes to add to the span.\n */\nexport interface LangWatchSpanOptions extends SpanOptions {\n /** Additional attributes to add to the span. */\n attributes?: SemConvAttributes;\n}\n\n/**\n * Extension of OpenTelemetry's Span with LangWatch-specific helpers for LLM, RAG, and GenAI tracing.\n *\n * This interface provides ergonomic methods for recording structured LLM/GenAI data, such as inputs, outputs, RAG contexts, and message events.\n *\n * All methods return `this` for chaining.\n *\n * @example\n * const span = createLangWatchSpan(otelSpan);\n * span\n * .setType('llm')\n * .setInput({ prompt: 'Hello' })\n * .setOutput('Hi!')\n * .addGenAIUserMessageEvent({ content: 'Hello' })\n * .addGenAIAssistantMessageEvent({ content: 'Hi!' });\n */\nexport interface LangWatchSpan extends Span {\n // /**\n // * Record the evaluation result for the span.\n // *\n // * @param details - The evaluation details\n // * @param attributes - Additional attributes to add to the evaluation span.\n // * @returns this\n // */\n // recordEvaluation(\n // details: RecordedEvaluationDetails,\n // attributes?: Attributes,\n // ): this;\n\n /**\n * Set multiple attributes for the span.\n *\n * @param attributes - The attributes object\n * @returns this\n */\n setAttributes(attributes: SemConvAttributes): this;\n\n /**\n * Set a single attribute for the span.\n *\n * @param key - The attribute key\n * @param value - The attribute value\n * @returns this\n */\n setAttribute(key: keyof SemConvAttributes, value: AttributeValue): this;\n\n /**\n * Set the type of the span (e.g., 'llm', 'rag', 'tool', etc).\n *\n * This is used for downstream filtering and analytics.\n *\n * @param type - The span type (see SpanType)\n * @returns this\n */\n setType(type: SpanType): this;\n\n /**\n * Set the request model name for the span.\n *\n * This is typically the model name sent in the API request (e.g., 'gpt-4', 'claude-3').\n *\n * @param model - The request model name\n * @returns this\n */\n setRequestModel(model: string): this;\n /**\n * Set the response model name for the span.\n *\n * This is the model name returned in the API response, if different from the request.\n *\n * @param model - The response model name\n * @returns this\n */\n setResponseModel(model: string): this;\n\n /**\n * Set multiple RAG contexts for the span.\n *\n * Use this to record all retrieved documents/chunks used as context for a generation.\n *\n * @param ragContexts - Array of RAG context objects\n * @returns this\n */\n setRAGContexts(ragContexts: LangWatchSpanRAGContext[]): this;\n /**\n * Set a single RAG context for the span.\n *\n * Use this if only one context was retrieved.\n *\n * @param ragContext - The RAG context object\n * @returns this\n */\n setRAGContext(ragContext: LangWatchSpanRAGContext): this;\n\n /**\n * Set the metrics for the span.\n *\n * @param metrics - The metrics object\n * @returns this\n */\n setMetrics(metrics: LangWatchSpanMetrics): this;\n\n /**\n * Set the selected prompt for the span. This will attach this prompt to the trace. If\n * this is set on multiple spans, the last one will be used.\n *\n * @param prompt - The prompt object\n * @returns this\n */\n setSelectedPrompt(prompt: Prompt): this;\n\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"text\" type\n * @param input - String input value\n * @returns this\n */\n setInput(type: \"text\", input: string): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"raw\" type\n * @param input - Any input value\n * @returns this\n */\n setInput(type: \"raw\", input: unknown): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"chat_messages\" type\n * @param input - Chat messages array (supports both ChatMessage[] and SimpleChatMessage[])\n * @returns this\n */\n setInput(type: \"chat_messages\", input: ChatMessage[] | SimpleChatMessage[]): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"list\" type\n * @param input - SpanInputOutput array\n * @returns this\n */\n setInput(type: \"list\", input: SpanInputOutput[]): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"json\" type\n * @param input - Any JSON-serializable value\n * @returns this\n */\n setInput(type: \"json\", input: unknown): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"guardrail_result\" type\n * @param input - Guardrail result value\n * @returns this\n */\n setInput(type: \"guardrail_result\", input: unknown): this;\n /**\n * Record the input to the span with explicit type control.\n *\n * @param type - Force as \"evaluation_result\" type\n * @param input - Evaluation result value\n * @returns this\n */\n setInput(type: \"evaluation_result\", input: unknown): this;\n /**\n * Record the input to the span with automatic type detection.\n *\n * Automatically detects: strings → text, ChatMessage[] → chat_messages,\n * arrays → list, objects → json.\n *\n * @param input - The input value (auto-detected type)\n * @returns this\n */\n setInput(input: unknown): this;\n\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"text\" type\n * @param output - String output value\n * @returns this\n */\n setOutput(type: \"text\", output: string): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"raw\" type\n * @param output - Any output value\n * @returns this\n */\n setOutput(type: \"raw\", output: unknown): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"chat_messages\" type\n * @param output - Chat messages array (supports both ChatMessage[] and SimpleChatMessage[])\n * @returns this\n */\n setOutput(type: \"chat_messages\", output: ChatMessage[] | SimpleChatMessage[]): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"list\" type\n * @param output - SpanInputOutput array\n * @returns this\n */\n setOutput(type: \"list\", output: SpanInputOutput[]): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"json\" type\n * @param output - Any JSON-serializable value\n * @returns this\n */\n setOutput(type: \"json\", output: unknown): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"guardrail_result\" type\n * @param output - Guardrail result value\n * @returns this\n */\n setOutput(type: \"guardrail_result\", output: unknown): this;\n /**\n * Record the output from the span with explicit type control.\n *\n * @param type - Force as \"evaluation_result\" type\n * @param output - Evaluation result value\n * @returns this\n */\n setOutput(type: \"evaluation_result\", output: unknown): this;\n /**\n * Record the output from the span with automatic type detection.\n *\n * Automatically detects: strings → text, ChatMessage[] → chat_messages,\n * arrays → list, objects → json.\n *\n * @param output - The output value (auto-detected type)\n * @returns this\n */\n setOutput(output: unknown): this;\n\n // /**\n // * Set the evaluation output for the span.\n // *\n // * @param guardrail - Whether the evaluation is a guardrail\n // * @param output - The evaluation result\n // * @returns this\n // */\n // setOutputEvaluation(guardrail: boolean, output: EvaluationResultModel): this;\n}\n","// Generated by ts-to-zod\nimport { z } from \"zod\";\nimport { type SpanInputOutput } from \"./tracer\";\n\nconst chatRoleSchema = z.union([\n z.literal(\"system\"),\n z.literal(\"user\"),\n z.literal(\"assistant\"),\n z.literal(\"function\"),\n z.literal(\"tool\"),\n z.literal(\"unknown\"),\n]);\n\nconst functionCallSchema = z.object({\n name: z.string().optional(),\n arguments: z.string().optional(),\n});\n\nconst toolCallSchema = z.object({\n id: z.string(),\n type: z.string(),\n function: functionCallSchema,\n});\n\nexport const rAGChunkSchema = z.object({\n document_id: z.string().optional().nullable(),\n chunk_id: z.string().optional().nullable(),\n content: z.union([z.string(), z.record(z.string(), z.any()), z.array(z.any())]),\n});\n\nexport const chatRichContentSchema = z.union([\n z.object({\n type: z.literal(\"text\"),\n text: z.string().optional(),\n }),\n z.object({\n text: z.string(),\n }),\n z.object({\n type: z.literal(\"image_url\"),\n image_url: z\n .object({\n url: z.string(),\n detail: z\n .union([z.literal(\"auto\"), z.literal(\"low\"), z.literal(\"high\")])\n .optional(),\n })\n .optional(),\n }),\n z.object({\n type: z.literal(\"tool_call\"),\n toolName: z.string().optional(),\n toolCallId: z.string().optional(),\n args: z.string().optional(),\n }),\n z.object({\n type: z.literal(\"tool_result\"),\n toolName: z.string().optional(),\n toolCallId: z.string().optional(),\n result: z.any().optional(),\n }),\n]);\n\nexport const chatMessageSchema = z.object({\n role: chatRoleSchema.optional(),\n content: z\n .union([z.string(), z.array(chatRichContentSchema)])\n .optional()\n .nullable(),\n function_call: functionCallSchema.optional().nullable(),\n tool_calls: z.array(toolCallSchema).optional().nullable(),\n tool_call_id: z.string().optional().nullable(),\n name: z.string().optional().nullable(),\n});\n\nconst typedValueTextSchema = z.object({\n type: z.literal(\"text\"),\n value: z.string(),\n});\n\nconst typedValueRawSchema = z.object({\n type: z.literal(\"raw\"),\n value: z.string(),\n});\n\nconst jSONSerializableSchema = z\n .union([\n z.string(),\n z.number(),\n z.boolean(),\n z.record(z.string(), z.any()),\n z.array(z.any()),\n ])\n .nullable();\n\nexport const typedValueJsonSchema = z.object({\n type: z.literal(\"json\"),\n value: jSONSerializableSchema,\n});\n\nexport const moneySchema = z.object({\n currency: z.string(),\n amount: z.number(),\n});\n\nexport const evaluationResultSchema = z.object({\n status: z.union([\n z.literal(\"processed\"),\n z.literal(\"skipped\"),\n z.literal(\"error\"),\n ]),\n passed: z.boolean().optional().nullable(),\n score: z.number().optional().nullable(),\n label: z.string().optional().nullable(),\n details: z.string().optional().nullable(),\n cost: moneySchema.optional().nullable(),\n});\n\nexport const typedValueGuardrailResultSchema = z.object({\n type: z.literal(\"guardrail_result\"),\n value: evaluationResultSchema,\n});\n\nexport const typedValueEvaluationResultSchema = z.object({\n type: z.literal(\"evaluation_result\"),\n value: evaluationResultSchema,\n});\n\nexport const typedValueChatMessagesSchema = z.object({\n type: z.literal(\"chat_messages\"),\n value: z.array(chatMessageSchema),\n});\n\nexport const spanInputOutputSchema: z.ZodSchema<SpanInputOutput> = z.lazy(() =>\n z.union([\n typedValueTextSchema,\n typedValueChatMessagesSchema,\n typedValueGuardrailResultSchema,\n typedValueEvaluationResultSchema,\n typedValueJsonSchema,\n typedValueRawSchema,\n z.object({\n type: z.literal(\"list\"),\n value: z.array(spanInputOutputSchema),\n }),\n ]),\n);\n\nexport const errorCaptureSchema = z.object({\n has_error: z.literal(true),\n message: z.string(),\n stacktrace: z.array(z.string()),\n});\n\nexport const spanMetricsSchema = z.object({\n prompt_tokens: z.number().optional().nullable(),\n completion_tokens: z.number().optional().nullable(),\n tokens_estimated: z.boolean().optional().nullable(),\n cost: z.number().optional().nullable(),\n});\n\nexport const spanTimestampsSchema = z.object({\n ignore_timestamps_on_write: z.boolean().optional().nullable(),\n started_at: z.number(),\n first_token_at: z.number().optional().nullable(),\n finished_at: z.number(),\n});\n\nexport const spanTypesSchema = z.union([\n z.literal(\"span\"),\n z.literal(\"llm\"),\n z.literal(\"chain\"),\n z.literal(\"tool\"),\n z.literal(\"agent\"),\n z.literal(\"rag\"),\n z.literal(\"guardrail\"),\n z.literal(\"evaluation\"),\n z.literal(\"workflow\"),\n z.literal(\"component\"),\n z.literal(\"module\"),\n z.literal(\"server\"),\n z.literal(\"client\"),\n z.literal(\"producer\"),\n z.literal(\"consumer\"),\n z.literal(\"task\"),\n z.literal(\"unknown\"),\n]);\n\nconst spanInputOutputValidatorSchema = spanInputOutputSchema.and(\n z.object({\n value: z.any(),\n }),\n);\n\nexport const traceInputSchema = z.object({\n value: z.string(),\n satisfaction_score: z.number().optional(),\n});\n\nexport const traceOutputSchema = z.object({\n value: z.string(),\n});\n\nconst primitiveTypeSchema = z\n .union([z.string(), z.number(), z.boolean(), z.undefined()])\n .nullable();\n\nexport const reservedTraceMetadataSchema = z.object({\n thread_id: z.string().optional().nullable(),\n user_id: z.string().optional().nullable(),\n customer_id: z.string().optional().nullable(),\n labels: z.array(z.string()).optional().nullable(),\n topic_id: z.string().optional().nullable(),\n subtopic_id: z.string().optional().nullable(),\n sdk_name: z.string().optional().nullable(),\n sdk_version: z.string().optional().nullable(),\n sdk_language: z.string().optional().nullable(),\n telemetry_sdk_language: z.string().optional().nullable(),\n telemetry_sdk_name: z.string().optional().nullable(),\n telemetry_sdk_version: z.string().optional().nullable(),\n prompt_ids: z.array(z.string()).optional().nullable(),\n prompt_version_ids: z.array(z.string()).optional().nullable(),\n});\n\nconst evaluationStatusSchema = z.union([\n z.literal(\"scheduled\"),\n z.literal(\"in_progress\"),\n z.literal(\"error\"),\n z.literal(\"skipped\"),\n z.literal(\"processed\"),\n]);\n\nexport const evaluationSchema = z.object({\n evaluation_id: z.string(),\n evaluator_id: z.string(),\n span_id: z.string().optional().nullable(),\n name: z.string(),\n type: z.string().optional().nullable(),\n is_guardrail: z.boolean().optional().nullable(),\n status: evaluationStatusSchema,\n passed: z.boolean().optional().nullable(),\n score: z.number().optional().nullable(),\n label: z.string().optional().nullable(),\n details: z.string().optional().nullable(),\n error: errorCaptureSchema.optional().nullable(),\n retries: z.number().optional().nullable(),\n timestamps: z.object({\n ignore_timestamps_on_write: z.boolean().optional().nullable(),\n inserted_at: z.number().optional().nullable(),\n started_at: z.number().optional().nullable(),\n finished_at: z.number().optional().nullable(),\n updated_at: z.number().optional().nullable(),\n }),\n});\n\nexport const elasticSearchEvaluationSchema = evaluationSchema;\n\nexport const rESTEvaluationSchema = evaluationSchema\n .omit({\n evaluation_id: true,\n evaluator_id: true,\n status: true,\n timestamps: true,\n retries: true,\n })\n .and(\n z.object({\n evaluation_id: z.string().optional().nullable(),\n evaluator_id: z.string().optional().nullable(),\n status: z\n .union([\n z.literal(\"processed\"),\n z.literal(\"skipped\"),\n z.literal(\"error\"),\n ])\n .optional()\n .nullable(),\n timestamps: z\n .object({\n started_at: z.number().optional().nullable(),\n finished_at: z.number().optional().nullable(),\n })\n .optional()\n .nullable(),\n }),\n );\n\nexport const contextsSchema = z.object({\n traceId: z.string(),\n contexts: z.array(rAGChunkSchema),\n});\n","import semconv from \"@opentelemetry/semantic-conventions/incubating\";\nimport {\n type Span,\n type SpanContext,\n type SpanStatus,\n type Attributes,\n type AttributeValue,\n type Link,\n type Exception,\n} from \"@opentelemetry/api\";\nimport {\n type SimpleChatMessage,\n type LangWatchSpan,\n type LangWatchSpanMetrics,\n type LangWatchSpanRAGContext,\n type SpanType,\n} from \"./types\";\nimport { type Prompt } from \"@/client-sdk/services/prompts\";\nimport { type ChatMessage, type SpanInputOutput } from \"../../internal/generated/types/tracer\";\nimport * as intSemconv from \"../semconv/attributes\";\nimport { processSpanInputOutput } from \"./input-output\";\nimport type { SemConvAttributeKey, SemConvAttributes } from \"../semconv\";\n\nclass LangWatchSpanInternal implements LangWatchSpan {\n constructor(private span: Span) { }\n setAttributes(attributes: SemConvAttributes): this {\n this.span.setAttributes(attributes);\n return this;\n }\n\n setAttribute(key: SemConvAttributeKey, value: AttributeValue): this {\n this.span.setAttribute(key, value);\n return this;\n }\n\n addEvent(name: string, attributes?: Attributes): this {\n this.span.addEvent(name, attributes);\n return this;\n }\n\n recordException(exception: Exception): this {\n this.span.recordException(exception);\n return this;\n }\n\n setStatus(status: SpanStatus): this {\n this.span.setStatus(status);\n return this;\n }\n\n updateName(name: string): this {\n this.span.updateName(name);\n return this;\n }\n\n end(endTime?: number): void {\n this.span.end(endTime);\n }\n\n isRecording(): boolean {\n return this.span.isRecording();\n }\n\n spanContext(): SpanContext {\n return this.span.spanContext();\n }\n\n addLink(link: Link): this {\n this.span.addLink(link);\n return this;\n }\n\n addLinks(links: Link[]): this {\n this.span.addLinks(links);\n return this;\n }\n\n setType(type: SpanType): this {\n return this.setAttribute(intSemconv.ATTR_LANGWATCH_SPAN_TYPE, type);\n }\n\n setSelectedPrompt(prompt: Prompt): this {\n return this.setAttributes({\n [intSemconv.ATTR_LANGWATCH_PROMPT_SELECTED_ID]: prompt.id,\n [intSemconv.ATTR_LANGWATCH_PROMPT_ID]: prompt.id,\n [intSemconv.ATTR_LANGWATCH_PROMPT_VERSION_ID]: prompt.versionId,\n [intSemconv.ATTR_LANGWATCH_PROMPT_VERSION_NUMBER]: prompt.version,\n });\n }\n\n setRequestModel(model: string): this {\n return this.setAttribute(semconv.ATTR_GEN_AI_REQUEST_MODEL, model);\n }\n\n setResponseModel(model: string): this {\n return this.setAttribute(semconv.ATTR_GEN_AI_RESPONSE_MODEL, model);\n }\n\n setRAGContexts(ragContexts: LangWatchSpanRAGContext[]): this {\n return this.setAttribute(\n intSemconv.ATTR_LANGWATCH_RAG_CONTEXTS,\n JSON.stringify({\n type: \"json\",\n value: ragContexts,\n })\n );\n }\n\n setRAGContext(ragContext: LangWatchSpanRAGContext): this {\n return this.setRAGContexts([ragContext]);\n }\n\n setMetrics(metrics: LangWatchSpanMetrics): this {\n return this.setAttribute(\n intSemconv.ATTR_LANGWATCH_METRICS,\n JSON.stringify({\n type: \"json\",\n value: metrics,\n })\n );\n }\n\n setInput(type: \"text\", input: string): this;\n setInput(type: \"raw\", input: any): this;\n setInput(type: \"chat_messages\", input: ChatMessage[] | SimpleChatMessage[]): this;\n setInput(type: \"list\", input: SpanInputOutput[]): this;\n setInput(type: \"json\", input: any): this;\n setInput(input: any): this;\n setInput(typeOrInput: any, input?: any): this {\n const spanInput = processSpanInputOutput(typeOrInput, input);\n return this.setAttribute(\n intSemconv.ATTR_LANGWATCH_INPUT,\n JSON.stringify(spanInput)\n );\n }\n\n setOutput(type: \"text\", output: string): this;\n setOutput(type: \"raw\", output: any): this;\n setOutput(type: \"chat_messages\", output: ChatMessage[] | SimpleChatMessage[]): this;\n setOutput(type: \"list\", output: SpanInputOutput[]): this;\n setOutput(type: \"json\", output: any): this;\n setOutput(output: any): this;\n setOutput(typeOrOutput: any, output?: any): this {\n const spanOutput = processSpanInputOutput(typeOrOutput, output);\n return this.setAttribute(\n intSemconv.ATTR_LANGWATCH_OUTPUT,\n JSON.stringify(spanOutput)\n );\n }\n}\n\n/**\n * Creates a LangWatchSpan, which adds additional methods to an OpenTelemetry Span.\n *\n * @param span - The OpenTelemetry Span to add LangWatch methods to\n * @returns A LangWatchSpan with additional methods for LLM/GenAI observability\n *\n * @example\n * ```typescript\n * import { createLangWatchSpan } from './span';\n * const otelSpan = tracer.startSpan('llm-call');\n * const span = createLangWatchSpan(otelSpan);\n * span.setType('llm').setInput('Prompt').setOutput('Completion');\n * ```\n */\nexport function createLangWatchSpan(span: Span): LangWatchSpan {\n return new LangWatchSpanInternal(span);\n}\n","import { z } from \"zod\";\nimport {\n chatMessageSchema,\n spanInputOutputSchema,\n} from \"../../internal/generated/types/tracer.generated\";\nimport { type ChatMessage, type SpanInputOutput } from \"../../internal/generated/types/tracer\";\nimport { type SimpleChatMessage, type JsonSerializable, type InputOutputType, INPUT_OUTPUT_TYPES } from \"./types\";\n\n/**\n * Zod schema for simple chat messages (less strict than the generated one)\n */\nconst simpleChatMessageSchema = z.object({\n role: z.string(),\n content: z.union([z.string(), z.array(z.any())]).nullable().optional()\n});\n\nconst simpleChatMessageArraySchema = z.array(simpleChatMessageSchema);\n\n/**\n * Utility function to create a safe fallback value\n */\nfunction createSafeFallbackValue(value: unknown): string {\n if (typeof value === 'object' && value !== null) {\n return `[${typeof value}]`;\n }\n return String(value);\n}\n\n/**\n * Utility function to create a safe SpanInputOutput fallback\n */\nfunction createSafeSpanInputOutput(type: \"text\" | \"raw\", value: unknown): SpanInputOutput {\n const safeValue = createSafeFallbackValue(value);\n return { type, value: safeValue } as SpanInputOutput;\n}\n\n/**\n * Simple type checks for common input/output types\n */\nfunction isString(value: unknown): value is string {\n return typeof value === \"string\";\n}\n\nfunction isObject(value: unknown): value is Record<string, unknown> {\n return typeof value === \"object\" && value !== null && !Array.isArray(value);\n}\n\nfunction isChatMessage(value: unknown): value is ChatMessage | SimpleChatMessage {\n if (!isObject(value)) return false;\n return (\n typeof value.role === \"string\" &&\n (typeof value.content === \"string\" || value.content === null || value.content === undefined)\n );\n}\n\nfunction isChatMessageArray(value: unknown): value is (ChatMessage | SimpleChatMessage)[] {\n return Array.isArray(value) && value.every(isChatMessage);\n}\n\n/**\n * Attempts to validate and convert chat messages with fallback strategies\n */\nfunction processChatMessages(value: unknown): SpanInputOutput {\n // Ensure we have an array\n const messages = Array.isArray(value) ? value : [value];\n\n // Strategy 1: Try strict schema first\n const strictResult = z.array(chatMessageSchema).safeParse(messages);\n if (strictResult.success) {\n return { type: \"chat_messages\", value: strictResult.data } as SpanInputOutput;\n }\n\n // Strategy 2: Try simple schema\n const simpleResult = simpleChatMessageArraySchema.safeParse(messages);\n if (simpleResult.success) {\n return { type: \"chat_messages\", value: simpleResult.data } as SpanInputOutput;\n }\n\n // Strategy 3: Fallback to text\n return createSafeSpanInputOutput(\"text\", JSON.stringify(messages));\n}\n\n/**\n * Converts any value to a SpanInputOutput format with soft validation.\n * Never throws errors, always returns a valid SpanInputOutput.\n */\nfunction convertToSpanInputOutput(value: unknown): SpanInputOutput {\n try {\n // Handle null/undefined\n if (value === null || value === undefined) {\n return spanInputOutputSchema.parse({ type: \"json\", value: null });\n }\n\n // Handle strings\n if (isString(value)) {\n return spanInputOutputSchema.parse({ type: \"text\", value });\n }\n\n // Handle chat messages (single message or array)\n if (isChatMessage(value) || (Array.isArray(value) && value.length > 0 && isChatMessageArray(value))) {\n return processChatMessages(value);\n }\n\n // Handle arrays (non-chat messages)\n if (Array.isArray(value)) {\n return spanInputOutputSchema.parse({\n type: \"list\",\n value: value.map(item => convertToSpanInputOutput(item))\n });\n }\n\n // Handle objects (fallback to json type)\n if (isObject(value)) {\n try {\n return spanInputOutputSchema.parse({ type: \"json\", value });\n } catch {\n // If json type fails, fall back to text\n return createSafeSpanInputOutput(\"text\", value);\n }\n }\n\n // Ultimate fallback for any other type\n return createSafeSpanInputOutput(\"text\", value);\n } catch {\n // Ultimate fallback - if any Zod validation fails, return as text\n return createSafeSpanInputOutput(\"text\", value);\n }\n}\n\n/**\n * Type guard to check if a value is a valid input/output type\n */\nexport function isValidInputOutputType(type: string): type is InputOutputType {\n return INPUT_OUTPUT_TYPES.includes(type as InputOutputType);\n}\n\n/**\n * Validates a value for a specific input/output type using Zod schemas\n */\nfunction validateValueForInputOutputType(type: InputOutputType, value: unknown): unknown {\n switch (type) {\n case \"chat_messages\": {\n const messages = Array.isArray(value) ? value : [value];\n\n // Try strict schema first\n const strictResult = z.array(chatMessageSchema).safeParse(messages);\n if (strictResult.success) {\n return strictResult.data;\n }\n\n // Try simple schema\n const simpleResult = simpleChatMessageArraySchema.safeParse(messages);\n if (simpleResult.success) {\n return simpleResult.data;\n }\n\n // Fallback\n return [{ role: \"user\", content: createSafeFallbackValue(value) }];\n }\n\n case \"list\": {\n const listResult = z.array(spanInputOutputSchema).safeParse(value);\n return listResult.success ? listResult.data : [{ type: \"text\", value: createSafeFallbackValue(value) }];\n }\n\n case \"json\": {\n // For JSON, we accept any serializable value\n try {\n JSON.stringify(value);\n return value;\n } catch {\n return createSafeFallbackValue(value);\n }\n }\n\n case \"text\":\n case \"raw\": {\n const stringResult = z.string().safeParse(value);\n return stringResult.success ? stringResult.data : createSafeFallbackValue(value);\n }\n\n case \"guardrail_result\":\n case \"evaluation_result\": {\n // These types accept any value, just ensure it's serializable\n try {\n JSON.stringify(value);\n return value;\n } catch {\n return createSafeFallbackValue(value);\n }\n }\n\n default:\n return value;\n }\n}\n\n/**\n * Processes input/output values for span storage with soft Zod validation.\n * Never throws errors, always returns a valid SpanInputOutput.\n * When a type is explicitly provided, it will be preferred over auto-detection.\n *\n * @param typeOrValue - Either the explicit type string or the value to auto-detect\n * @param value - The value when explicit type is provided\n * @returns A valid SpanInputOutput object ready for span storage\n */\nexport function processSpanInputOutput(\n typeOrValue: unknown,\n value?: unknown\n): SpanInputOutput {\n try {\n // If explicit type is provided, prefer it over auto-detection\n if (typeof typeOrValue === \"string\" && value !== undefined) {\n const type = isValidInputOutputType(typeOrValue) ? typeOrValue : \"json\";\n const validatedValue = validateValueForInputOutputType(type, value);\n\n // Final validation with spanInputOutputSchema\n const result = spanInputOutputSchema.safeParse({ type, value: validatedValue });\n return result.success ? result.data : createSafeSpanInputOutput(\"raw\", validatedValue);\n }\n\n // Auto-detect type when no explicit type is provided\n return convertToSpanInputOutput(typeOrValue);\n } catch {\n // Ultimate fallback - if any validation fails, return as text\n return createSafeSpanInputOutput(\"text\", typeOrValue);\n }\n}\n\n/**\n * Type-safe method signature for span input/output processing\n */\nexport type SpanInputOutputMethod<T> = {\n (type: \"text\", value: string): T;\n (type: \"raw\", value: unknown): T;\n (type: \"chat_messages\", value: ChatMessage[] | SimpleChatMessage[]): T;\n (type: \"list\", value: SpanInputOutput[]): T;\n (type: \"json\", value: JsonSerializable): T;\n (type: \"guardrail_result\", value: unknown): T;\n (type: \"evaluation_result\", value: unknown): T;\n (value: unknown): T;\n}\n","import {\n type Span,\n type SpanOptions,\n type Context,\n SpanStatusCode,\n type TracerProvider,\n trace,\n} from \"@opentelemetry/api\";\nimport { createLangWatchSpan } from \"../span\";\nimport { type LangWatchTracer } from \"./types\";\n\n/**\n * Get a LangWatch tracer from the global OpenTelemetry tracer provider.\n *\n * This is the primary entry point for obtaining a LangWatch tracer instance.\n * It uses the globally configured OpenTelemetry tracer provider and wraps\n * the resulting tracer with LangWatch-specific enhancements.\n *\n * **Prerequisites**: Ensure that LangWatch's observability setup has been\n * initialized before calling this function, otherwise the global tracer\n * provider may not be properly configured.\n *\n * @param name - The name of the tracer, typically your service or library name\n * @param version - Optional version identifier for the tracer\n * @returns A LangWatch tracer with enhanced functionality\n *\n * @example Basic usage\n * ```typescript\n * import { getLangWatchTracer } from '@langwatch/typescript-sdk';\n *\n * const tracer = getLangWatchTracer('my-service', '1.0.0');\n *\n * // Use the tracer to create spans\n * const result = await tracer.withActiveSpan('operation', async (span) => {\n * span.setAttributes({ userId: '123' });\n * return await performOperation();\n * });\n * ```\n *\n * @example Multiple tracers for different components\n * ```typescript\n * const apiTracer = getLangWatchTracer('api-server', '2.1.0');\n * const dbTracer = getLangWatchTracer('database-client', '1.5.2');\n *\n * // Each tracer can be used independently\n * await apiTracer.withActiveSpan('handle-request', async (span) => {\n * await dbTracer.withActiveSpan('query-users', async (dbSpan) => {\n * // Nested spans with proper parent-child relationships\n * });\n * });\n * ```\n */\nexport function getLangWatchTracer(\n name: string,\n version?: string,\n): LangWatchTracer {\n return getLangWatchTracerFromProvider(\n trace.getTracerProvider(),\n name,\n version,\n );\n}\n\n\n/**\n * Get a LangWatch tracer from a specific OpenTelemetry tracer provider.\n *\n * This function provides more control over which tracer provider is used,\n * allowing you to work with custom or multiple tracer provider instances.\n * This is useful in advanced scenarios where you need to:\n * - Use different tracer providers for different parts of your application\n * - Work with custom tracer provider configurations\n * - Test with mock tracer providers\n *\n * @param tracerProvider - The OpenTelemetry tracer provider to use\n * @param name - The name of the tracer, typically your service or library name\n * @param version - Optional version identifier for the tracer\n * @returns A LangWatch tracer with enhanced functionality\n *\n * @example Custom tracer provider\n * ```typescript\n * import { NodeTracerProvider } from '@opentelemetry/sdk-node';\n * import { getLangWatchTracerFromProvider } from '@langwatch/typescript-sdk';\n *\n * // Create a custom tracer provider with specific configuration\n * const customProvider = new NodeTracerProvider({\n * resource: Resource.default().merge(\n * new Resource({\n * [SemanticResourceAttributes.SERVICE_NAME]: 'custom-service',\n * })\n * )\n * });\n *\n * const tracer = getLangWatchTracerFromProvider(\n * customProvider,\n * 'custom-tracer',\n * '1.0.0'\n * );\n * ```\n *\n * @example Testing with mock provider\n * ```typescript\n * import { InMemorySpanExporter } from '@opentelemetry/sdk-trace-base';\n *\n * const mockExporter = new InMemorySpanExporter();\n * const testProvider = new NodeTracerProvider();\n * testProvider.addSpanProcessor(new SimpleSpanProcessor(mockExporter));\n *\n * const testTracer = getLangWatchTracerFromProvider(\n * testProvider,\n * 'test-tracer'\n * );\n *\n * // Use testTracer in tests and verify spans via mockExporter\n * ```\n */\nexport function getLangWatchTracerFromProvider(\n tracerProvider: TracerProvider,\n name: string,\n version?: string,\n): LangWatchTracer {\n const tracer = tracerProvider.getTracer(name, version);\n\n /**\n * ⚠️ Do not remove, or worse, move this declaration.\n * It's required so the proxy handler can reference the proxyInstance\n * without running afoul of JavaScript's temporal dead zone.\n */\n let proxyInstance: LangWatchTracer;\n\n const handler: ProxyHandler<LangWatchTracer> = {\n get(target, prop) {\n switch (prop) {\n case \"startActiveSpan\":\n return (...args: any[]) => {\n const spanArgs = normalizeSpanArgs(args);\n\n const wrappedFn = (span: Span, ...cbArgs: any[]) =>\n spanArgs.fn(createLangWatchSpan(span), ...cbArgs);\n\n if (spanArgs.context !== void 0)\n return target.startActiveSpan(spanArgs.name, spanArgs.options, spanArgs.context, wrappedFn);\n\n if (spanArgs.options !== void 0)\n return target.startActiveSpan(spanArgs.name, spanArgs.options, wrappedFn);\n\n return target.startActiveSpan(spanArgs.name, wrappedFn);\n };\n\n case \"withActiveSpan\":\n return (...args: any[]) => {\n const spanArgs = normalizeSpanArgs(args);\n\n const cb = (span: Span) => {\n const wrappedSpan = createLangWatchSpan(span);\n\n try {\n const result = spanArgs.fn(wrappedSpan);\n\n // If result is a promise, handle it async\n if (result && typeof result.then === \"function\") {\n return result\n .then((result: any) => {\n wrappedSpan.setStatus({\n code: SpanStatusCode.OK,\n });\n return result;\n })\n .catch((err: any) => {\n wrappedSpan.setStatus({\n code: SpanStatusCode.ERROR,\n message: err?.message || String(err),\n });\n wrappedSpan.recordException?.(err);\n throw err;\n })\n .finally(() => {\n wrappedSpan.end();\n });\n }\n\n // Sync result - end span and return\n wrappedSpan.setStatus({\n code: SpanStatusCode.OK,\n });\n wrappedSpan.end();\n return result;\n } catch (err: any) {\n wrappedSpan.setStatus({\n code: SpanStatusCode.ERROR,\n message: err?.message || String(err),\n });\n wrappedSpan.recordException?.(err);\n wrappedSpan.end();\n throw err;\n }\n };\n\n // Call target.startActiveSpan to avoid double-wrapping\n if (spanArgs.context !== void 0)\n return target.startActiveSpan(spanArgs.name, spanArgs.options, spanArgs.context, cb);\n if (spanArgs.options !== void 0)\n return target.startActiveSpan(spanArgs.name, spanArgs.options, cb);\n\n return target.startActiveSpan(spanArgs.name, cb);\n };\n\n case \"startSpan\":\n return (name: string, options?: SpanOptions, context?: Context) =>\n createLangWatchSpan(target.startSpan(name, options, context));\n\n default: {\n const value = (target as any)[prop];\n\n return typeof value === \"function\" ? value.bind(target) : value;\n }\n }\n },\n };\n\n // See comment above about why.\n // eslint-disable-next-line prefer-const\n proxyInstance = new Proxy(tracer, handler) as LangWatchTracer;\n return proxyInstance;\n}\n\n/**\n * Normalizes the variable arguments passed to span methods.\n * Handles the following overloaded signatures:\n * - (name, fn)\n * - (name, options, fn)\n * - (name, options, context, fn)\n *\n * @param args - The arguments array from the span method\n * @returns An object with normalized name, options, context, and fn properties\n * @throws Error if no callback function is found in the arguments\n */\nfunction normalizeSpanArgs(args: any[]) {\n const [name, arg2, arg3, arg4] = args;\n\n if (typeof arg4 === \"function\")\n return { name, options: arg2, context: arg3, fn: arg4 };\n\n if (typeof arg3 === \"function\") return { name, options: arg2, fn: arg3 };\n if (typeof arg2 === \"function\") return { name, fn: arg2 };\n\n throw new Error(\"Expected a span callback as the last argument\");\n}\n"]}
@@ -1,4 +1,8 @@
1
- // src/observability/processors/filterable-batch-span-processor.ts
1
+ import {
2
+ attributes_exports
3
+ } from "./chunk-YNQ44U6D.mjs";
4
+
5
+ // src/observability-sdk/processors/filterable-batch-span-processor.ts
2
6
  import {
3
7
  BatchSpanProcessor
4
8
  } from "@opentelemetry/sdk-trace-base";
@@ -44,7 +48,28 @@ var FilterableBatchSpanProcessor = class extends BatchSpanProcessor {
44
48
  }
45
49
  };
46
50
 
51
+ // src/observability-sdk/features/data-capture/presets.ts
52
+ var DataCapturePresets = {
53
+ /**
54
+ * Capture both input and output - useful for development and debugging.
55
+ */
56
+ CAPTURE_ALL: "all",
57
+ /**
58
+ * Capture nothing - useful for high-security environments.
59
+ */
60
+ CAPTURE_NONE: "none",
61
+ /**
62
+ * Capture only inputs - useful when you want to see what's being sent.
63
+ */
64
+ INPUT_ONLY: "input",
65
+ /**
66
+ * Capture only outputs - useful when you want to see responses.
67
+ */
68
+ OUTPUT_ONLY: "output"
69
+ };
70
+
47
71
  export {
48
- FilterableBatchSpanProcessor
72
+ FilterableBatchSpanProcessor,
73
+ DataCapturePresets
49
74
  };
50
- //# sourceMappingURL=chunk-PR3JDWC3.mjs.map
75
+ //# sourceMappingURL=chunk-N2V6J3U2.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/observability-sdk/processors/filterable-batch-span-processor.ts","../src/observability-sdk/features/data-capture/presets.ts"],"sourcesContent":["/**\n * Filterable Batch Span Exporter for OpenTelemetry\n *\n * This module provides a BatchSpanProcessor subclass that allows filtering of spans before export\n * based on configurable rules. Spans matching any exclude rule are dropped and not exported.\n *\n * @module filterable-batch-span-exporter\n */\n\nimport {\n BatchSpanProcessor,\n type ReadableSpan,\n type SpanExporter,\n} from '@opentelemetry/sdk-trace-base';\n\n/**\n * A rule for excluding spans from export based on their name or instrumentation scope name.\n *\n * @property fieldName - The span field to match against ('span_name' or 'instrumentation_scope_name').\n * @property matchValue - The value to match against the field.\n * @property matchOperation - The operation to use for matching ('includes', 'exact_match', 'starts_with', 'ends_with').\n *\n * @example\n * const rule: SpanProcessingExcludeRule = {\n * fieldName: 'span_name',\n * matchValue: 'heartbeat',\n * matchOperation: 'exact_match',\n * };\n */\nexport interface SpanProcessingExcludeRule {\n fieldName: \"span_name\" | \"instrumentation_scope_name\";\n matchValue: string;\n matchOperation: \"includes\" | \"exact_match\" | \"starts_with\" | \"ends_with\";\n}\n\n/**\n * A BatchSpanProcessor that filters out spans matching any of the provided exclude rules before export.\n *\n * This is useful for dropping noisy or irrelevant spans (e.g., health checks, heartbeats) from being exported to your tracing backend.\n *\n * @example\n * import { FilterableBatchSpanProcessor } from './filterable-batch-span-exporter';\n * import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';\n *\n * const exporter = new OTLPTraceExporter({ url: '...' });\n * const filters = [\n * { fieldName: 'span_name', matchValue: 'heartbeat', matchOperation: 'exact_match' },\n * { fieldName: 'instrumentation_scope_name', matchValue: 'internal', matchOperation: 'starts_with' },\n * ];\n * provider.addSpanProcessor(new FilterableBatchSpanProcessor(exporter, filters));\n */\nexport class FilterableBatchSpanProcessor extends BatchSpanProcessor {\n private readonly _filters: SpanProcessingExcludeRule[];\n\n /**\n * Create a new FilterableBatchSpanProcessor.\n *\n * @param exporter - The underlying SpanExporter to use for exporting spans.\n * @param filters - An array of rules for excluding spans from export.\n */\n constructor(exporter: SpanExporter, filters: SpanProcessingExcludeRule[]) {\n super(exporter);\n this._filters = filters;\n }\n\n /**\n * Called when a span ends. If the span matches any exclude rule, it is dropped and not exported.\n *\n * @param span - The ReadableSpan that has ended.\n */\n override onEnd(span: ReadableSpan): void {\n for (const filter of this._filters) {\n let sourceValue: string;\n\n if (filter.fieldName === \"span_name\") {\n sourceValue = span.name;\n } else if (filter.fieldName === \"instrumentation_scope_name\") {\n sourceValue = span.instrumentationScope.name;\n } else {\n continue;\n }\n\n const matchValue = filter.matchValue;\n const matchOperation = filter.matchOperation;\n\n switch (true) {\n case matchOperation === \"exact_match\" && sourceValue === matchValue:\n case matchOperation === \"includes\" && sourceValue.includes(matchValue):\n case matchOperation === \"starts_with\" && sourceValue.startsWith(matchValue):\n case matchOperation === \"ends_with\" && sourceValue.endsWith(matchValue):\n return;\n\n default: break;\n }\n }\n\n super.onEnd(span);\n }\n}\n","import { type DataCaptureMode } from \"./types\";\n\n/**\n * Predefined data capture configurations for common use cases.\n */\nexport const DataCapturePresets = {\n /**\n * Capture both input and output - useful for development and debugging.\n */\n CAPTURE_ALL: \"all\" as DataCaptureMode,\n\n /**\n * Capture nothing - useful for high-security environments.\n */\n CAPTURE_NONE: \"none\" as DataCaptureMode,\n\n /**\n * Capture only inputs - useful when you want to see what's being sent.\n */\n INPUT_ONLY: \"input\" as DataCaptureMode,\n\n /**\n * Capture only outputs - useful when you want to see responses.\n */\n OUTPUT_ONLY: \"output\" as DataCaptureMode,\n} as const;\n"],"mappings":";;;;;AASA;AAAA,EACE;AAAA,OAGK;AAsCA,IAAM,+BAAN,cAA2C,mBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASnE,YAAY,UAAwB,SAAsC;AACxE,UAAM,QAAQ;AACd,SAAK,WAAW;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOS,MAAM,MAA0B;AACvC,eAAW,UAAU,KAAK,UAAU;AAClC,UAAI;AAEJ,UAAI,OAAO,cAAc,aAAa;AACpC,sBAAc,KAAK;AAAA,MACrB,WAAW,OAAO,cAAc,8BAA8B;AAC5D,sBAAc,KAAK,qBAAqB;AAAA,MAC1C,OAAO;AACL;AAAA,MACF;AAEA,YAAM,aAAa,OAAO;AAC1B,YAAM,iBAAiB,OAAO;AAE9B,cAAQ,MAAM;AAAA,QACZ,MAAK,mBAAmB,iBAAiB,gBAAgB;AAAA,QACzD,MAAK,mBAAmB,cAAc,YAAY,SAAS,UAAU;AAAA,QACrE,MAAK,mBAAmB,iBAAiB,YAAY,WAAW,UAAU;AAAA,QAC1E,MAAK,mBAAmB,eAAe,YAAY,SAAS,UAAU;AACpE;AAAA,QAEF;AAAS;AAAA,MACX;AAAA,IACF;AAEA,UAAM,MAAM,IAAI;AAAA,EAClB;AACF;;;AC7FO,IAAM,qBAAqB;AAAA;AAAA;AAAA;AAAA,EAIhC,aAAa;AAAA;AAAA;AAAA;AAAA,EAKb,cAAc;AAAA;AAAA;AAAA;AAAA,EAKd,YAAY;AAAA;AAAA;AAAA;AAAA,EAKZ,aAAa;AACf;","names":[]}
@@ -4,6 +4,9 @@ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
4
  var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
6
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
+ var __typeError = (msg) => {
8
+ throw TypeError(msg);
9
+ };
7
10
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
11
  var __spreadValues = (a, b) => {
9
12
  for (var prop in b || (b = {}))
@@ -17,21 +20,23 @@ var __spreadValues = (a, b) => {
17
20
  return a;
18
21
  };
19
22
  var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
21
- get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
22
- }) : x)(function(x) {
23
- if (typeof require !== "undefined") return require.apply(this, arguments);
24
- throw Error('Dynamic require of "' + x + '" is not supported');
25
- });
26
23
  var __export = (target, all) => {
27
24
  for (var name in all)
28
25
  __defProp(target, name, { get: all[name], enumerable: true });
29
26
  };
27
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
28
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
29
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
30
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
31
+ var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
32
+
33
+
34
+
30
35
 
31
36
 
32
37
 
33
38
 
34
39
 
35
40
 
36
- exports.__spreadValues = __spreadValues; exports.__spreadProps = __spreadProps; exports.__require = __require; exports.__export = __export;
37
- //# sourceMappingURL=chunk-FJLK5CFL.js.map
41
+ exports.__spreadValues = __spreadValues; exports.__spreadProps = __spreadProps; exports.__export = __export; exports.__privateGet = __privateGet; exports.__privateAdd = __privateAdd; exports.__privateSet = __privateSet; exports.__privateMethod = __privateMethod;
42
+ //# sourceMappingURL=chunk-OXBO24RB.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-OXBO24RB.js"],"names":[],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-OXBO24RB.js"}
@@ -1,4 +1,4 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/prompt/converter.ts
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/cli/utils/promptConverter.ts
2
2
  var PromptConverter = class {
3
3
  /**
4
4
  * Converts a Prompt instance from the API service to the MaterializedPrompt format
@@ -97,4 +97,4 @@ var PromptConverter = class {
97
97
 
98
98
 
99
99
  exports.PromptConverter = PromptConverter;
100
- //# sourceMappingURL=chunk-SMXXAVMB.js.map
100
+ //# sourceMappingURL=chunk-SGNJDRCT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-SGNJDRCT.js","../src/cli/utils/promptConverter.ts"],"names":["_a"],"mappings":"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","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-SGNJDRCT.js","sourcesContent":[null,"import type { Prompt } from \"@/client-sdk/services/prompts/prompt\";\nimport type { LocalPromptConfig, MaterializedPrompt } from \"../types\";\n\n/**\n * Converter utility for transforming between YAML prompt format and API service format.\n *\n * The YAML format follows the GitHub .prompt.yaml file format standard,\n * while the API format is our internal prompt service schema tied to the database.\n *\n * This separation allows us to maintain and evolve both formats independently\n * while keeping the conversion logic centralized and well-tested.\n */\nexport class PromptConverter {\n /**\n * Converts a Prompt instance from the API service to the MaterializedPrompt format\n * used for saving to the .materialized directory.\n */\n static fromApiToMaterialized(prompt: Prompt): MaterializedPrompt {\n return {\n id: prompt.id,\n name: prompt.name,\n version: prompt.version,\n versionId: prompt.versionId,\n model: prompt.model,\n messages: prompt.messages,\n prompt: prompt.prompt,\n updatedAt: prompt.updatedAt,\n versionCreatedAt: prompt.versionCreatedAt,\n };\n }\n\n /**\n * Converts a MaterializedPrompt to the YAML content structure\n * for saving to .prompt.yaml files.\n */\n static fromMaterializedToYaml(prompt: MaterializedPrompt): {\n model: string;\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n return {\n model: prompt.model,\n messages: prompt.messages,\n };\n }\n\n /**\n * Converts a LocalPromptConfig (loaded from YAML) to the format\n * expected by the API service for upserting.\n */\n static fromLocalToApiFormat(config: LocalPromptConfig): {\n model: string;\n modelParameters?: {\n temperature?: number;\n max_tokens?: number;\n };\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n return {\n model: config.model,\n modelParameters: config.modelParameters,\n messages: config.messages,\n };\n }\n\n /**\n * Extracts the system prompt from messages array.\n * Used when converting to API format that separates system prompt from messages.\n */\n static extractSystemPrompt(messages: Array<{ role: string; content: string }>): string {\n return messages.find(m => m.role === \"system\")?.content || \"\";\n }\n\n /**\n * Filters out system messages from the messages array.\n * Used when converting to API format that handles system prompt separately.\n */\n static filterNonSystemMessages(messages: Array<{ role: string; content: string }>) {\n return messages.filter(m => m.role !== \"system\");\n }\n\n /**\n * Converts version specification strings to actual version constraints.\n * Handles npm-style version specs like \"latest\", \"5\", \"^5\", etc.\n */\n static parseVersionSpec(versionSpec: string): {\n type: \"latest\" | \"exact\" | \"tag\";\n value: string;\n } {\n if (versionSpec === \"latest\") {\n return { type: \"latest\", value: \"latest\" };\n }\n\n // For now, treat everything else as tags until we implement proper semver\n if (/^\\d+$/.test(versionSpec)) {\n return { type: \"exact\", value: versionSpec };\n }\n\n // Handle prefixes like ^, ~, etc. as tags for now\n return { type: \"tag\", value: versionSpec };\n }\n\n /**\n * Validates that a YAML config can be safely converted to API format.\n * Returns validation errors if any, or null if valid.\n */\n static validateForApiConversion(config: LocalPromptConfig): string[] {\n const errors: string[] = [];\n\n if (!config.model?.trim()) {\n errors.push(\"Model is required and cannot be empty\");\n }\n\n if (!config.messages || config.messages.length === 0) {\n errors.push(\"At least one message is required\");\n }\n\n if (config.messages) {\n config.messages.forEach((message, index) => {\n if (![\"system\", \"user\", \"assistant\"].includes(message.role)) {\n errors.push(`Message ${index}: role must be 'system', 'user', or 'assistant'`);\n }\n if (!message.content?.trim()) {\n errors.push(`Message ${index}: content cannot be empty`);\n }\n });\n }\n\n return errors;\n }\n}\n"]}
@@ -1,4 +1,4 @@
1
- // src/prompt/converter.ts
1
+ // src/cli/utils/promptConverter.ts
2
2
  var PromptConverter = class {
3
3
  /**
4
4
  * Converts a Prompt instance from the API service to the MaterializedPrompt format
@@ -97,4 +97,4 @@ var PromptConverter = class {
97
97
  export {
98
98
  PromptConverter
99
99
  };
100
- //# sourceMappingURL=chunk-W5ZEP3CI.mjs.map
100
+ //# sourceMappingURL=chunk-SYMZPWZE.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/utils/promptConverter.ts"],"sourcesContent":["import type { Prompt } from \"@/client-sdk/services/prompts/prompt\";\nimport type { LocalPromptConfig, MaterializedPrompt } from \"../types\";\n\n/**\n * Converter utility for transforming between YAML prompt format and API service format.\n *\n * The YAML format follows the GitHub .prompt.yaml file format standard,\n * while the API format is our internal prompt service schema tied to the database.\n *\n * This separation allows us to maintain and evolve both formats independently\n * while keeping the conversion logic centralized and well-tested.\n */\nexport class PromptConverter {\n /**\n * Converts a Prompt instance from the API service to the MaterializedPrompt format\n * used for saving to the .materialized directory.\n */\n static fromApiToMaterialized(prompt: Prompt): MaterializedPrompt {\n return {\n id: prompt.id,\n name: prompt.name,\n version: prompt.version,\n versionId: prompt.versionId,\n model: prompt.model,\n messages: prompt.messages,\n prompt: prompt.prompt,\n updatedAt: prompt.updatedAt,\n versionCreatedAt: prompt.versionCreatedAt,\n };\n }\n\n /**\n * Converts a MaterializedPrompt to the YAML content structure\n * for saving to .prompt.yaml files.\n */\n static fromMaterializedToYaml(prompt: MaterializedPrompt): {\n model: string;\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n return {\n model: prompt.model,\n messages: prompt.messages,\n };\n }\n\n /**\n * Converts a LocalPromptConfig (loaded from YAML) to the format\n * expected by the API service for upserting.\n */\n static fromLocalToApiFormat(config: LocalPromptConfig): {\n model: string;\n modelParameters?: {\n temperature?: number;\n max_tokens?: number;\n };\n messages: Array<{\n role: \"system\" | \"user\" | \"assistant\";\n content: string;\n }>;\n } {\n return {\n model: config.model,\n modelParameters: config.modelParameters,\n messages: config.messages,\n };\n }\n\n /**\n * Extracts the system prompt from messages array.\n * Used when converting to API format that separates system prompt from messages.\n */\n static extractSystemPrompt(messages: Array<{ role: string; content: string }>): string {\n return messages.find(m => m.role === \"system\")?.content || \"\";\n }\n\n /**\n * Filters out system messages from the messages array.\n * Used when converting to API format that handles system prompt separately.\n */\n static filterNonSystemMessages(messages: Array<{ role: string; content: string }>) {\n return messages.filter(m => m.role !== \"system\");\n }\n\n /**\n * Converts version specification strings to actual version constraints.\n * Handles npm-style version specs like \"latest\", \"5\", \"^5\", etc.\n */\n static parseVersionSpec(versionSpec: string): {\n type: \"latest\" | \"exact\" | \"tag\";\n value: string;\n } {\n if (versionSpec === \"latest\") {\n return { type: \"latest\", value: \"latest\" };\n }\n\n // For now, treat everything else as tags until we implement proper semver\n if (/^\\d+$/.test(versionSpec)) {\n return { type: \"exact\", value: versionSpec };\n }\n\n // Handle prefixes like ^, ~, etc. as tags for now\n return { type: \"tag\", value: versionSpec };\n }\n\n /**\n * Validates that a YAML config can be safely converted to API format.\n * Returns validation errors if any, or null if valid.\n */\n static validateForApiConversion(config: LocalPromptConfig): string[] {\n const errors: string[] = [];\n\n if (!config.model?.trim()) {\n errors.push(\"Model is required and cannot be empty\");\n }\n\n if (!config.messages || config.messages.length === 0) {\n errors.push(\"At least one message is required\");\n }\n\n if (config.messages) {\n config.messages.forEach((message, index) => {\n if (![\"system\", \"user\", \"assistant\"].includes(message.role)) {\n errors.push(`Message ${index}: role must be 'system', 'user', or 'assistant'`);\n }\n if (!message.content?.trim()) {\n errors.push(`Message ${index}: content cannot be empty`);\n }\n });\n }\n\n return errors;\n }\n}\n"],"mappings":";AAYO,IAAM,kBAAN,MAAsB;AAAA;AAAA;AAAA;AAAA;AAAA,EAK3B,OAAO,sBAAsB,QAAoC;AAC/D,WAAO;AAAA,MACL,IAAI,OAAO;AAAA,MACX,MAAM,OAAO;AAAA,MACb,SAAS,OAAO;AAAA,MAChB,WAAW,OAAO;AAAA,MAClB,OAAO,OAAO;AAAA,MACd,UAAU,OAAO;AAAA,MACjB,QAAQ,OAAO;AAAA,MACf,WAAW,OAAO;AAAA,MAClB,kBAAkB,OAAO;AAAA,IAC3B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,uBAAuB,QAM5B;AACA,WAAO;AAAA,MACL,OAAO,OAAO;AAAA,MACd,UAAU,OAAO;AAAA,IACnB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,qBAAqB,QAU1B;AACA,WAAO;AAAA,MACL,OAAO,OAAO;AAAA,MACd,iBAAiB,OAAO;AAAA,MACxB,UAAU,OAAO;AAAA,IACnB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,oBAAoB,UAA4D;AA1EzF;AA2EI,aAAO,cAAS,KAAK,OAAK,EAAE,SAAS,QAAQ,MAAtC,mBAAyC,YAAW;AAAA,EAC7D;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,wBAAwB,UAAoD;AACjF,WAAO,SAAS,OAAO,OAAK,EAAE,SAAS,QAAQ;AAAA,EACjD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,iBAAiB,aAGtB;AACA,QAAI,gBAAgB,UAAU;AAC5B,aAAO,EAAE,MAAM,UAAU,OAAO,SAAS;AAAA,IAC3C;AAGA,QAAI,QAAQ,KAAK,WAAW,GAAG;AAC7B,aAAO,EAAE,MAAM,SAAS,OAAO,YAAY;AAAA,IAC7C;AAGA,WAAO,EAAE,MAAM,OAAO,OAAO,YAAY;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,yBAAyB,QAAqC;AA/GvE;AAgHI,UAAM,SAAmB,CAAC;AAE1B,QAAI,GAAC,YAAO,UAAP,mBAAc,SAAQ;AACzB,aAAO,KAAK,uCAAuC;AAAA,IACrD;AAEA,QAAI,CAAC,OAAO,YAAY,OAAO,SAAS,WAAW,GAAG;AACpD,aAAO,KAAK,kCAAkC;AAAA,IAChD;AAEA,QAAI,OAAO,UAAU;AACnB,aAAO,SAAS,QAAQ,CAAC,SAAS,UAAU;AA3HlD,YAAAA;AA4HQ,YAAI,CAAC,CAAC,UAAU,QAAQ,WAAW,EAAE,SAAS,QAAQ,IAAI,GAAG;AAC3D,iBAAO,KAAK,WAAW,KAAK,iDAAiD;AAAA,QAC/E;AACA,YAAI,GAACA,MAAA,QAAQ,YAAR,gBAAAA,IAAiB,SAAQ;AAC5B,iBAAO,KAAK,WAAW,KAAK,2BAA2B;AAAA,QACzD;AAAA,MACF,CAAC;AAAA,IACH;AAEA,WAAO;AAAA,EACT;AACF;","names":["_a"]}
@@ -1,4 +1,8 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/observability/processors/filterable-batch-span-processor.ts
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkDISMHYXCjs = require('./chunk-DISMHYXC.js');
4
+
5
+ // src/observability-sdk/processors/filterable-batch-span-processor.ts
2
6
 
3
7
 
4
8
  var _sdktracebase = require('@opentelemetry/sdk-trace-base');
@@ -44,7 +48,28 @@ var FilterableBatchSpanProcessor = class extends _sdktracebase.BatchSpanProcesso
44
48
  }
45
49
  };
46
50
 
51
+ // src/observability-sdk/features/data-capture/presets.ts
52
+ var DataCapturePresets = {
53
+ /**
54
+ * Capture both input and output - useful for development and debugging.
55
+ */
56
+ CAPTURE_ALL: "all",
57
+ /**
58
+ * Capture nothing - useful for high-security environments.
59
+ */
60
+ CAPTURE_NONE: "none",
61
+ /**
62
+ * Capture only inputs - useful when you want to see what's being sent.
63
+ */
64
+ INPUT_ONLY: "input",
65
+ /**
66
+ * Capture only outputs - useful when you want to see responses.
67
+ */
68
+ OUTPUT_ONLY: "output"
69
+ };
70
+
71
+
47
72
 
48
73
 
49
- exports.FilterableBatchSpanProcessor = FilterableBatchSpanProcessor;
50
- //# sourceMappingURL=chunk-KGDAENGD.js.map
74
+ exports.FilterableBatchSpanProcessor = FilterableBatchSpanProcessor; exports.DataCapturePresets = DataCapturePresets;
75
+ //# sourceMappingURL=chunk-YH5TIVK2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YH5TIVK2.js","../src/observability-sdk/processors/filterable-batch-span-processor.ts","../src/observability-sdk/features/data-capture/presets.ts"],"names":[],"mappings":"AAAA;AACE;AACF,sDAA4B;AAC5B;AACA;ACKA;AACE;AAAA,6DAGK;AAsCA,IAAM,6BAAA,EAAN,MAAA,QAA2C,iCAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASnE,WAAA,CAAY,QAAA,EAAwB,OAAA,EAAsC;AACxE,IAAA,KAAA,CAAM,QAAQ,CAAA;AACd,IAAA,IAAA,CAAK,SAAA,EAAW,OAAA;AAAA,EAClB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOS,KAAA,CAAM,IAAA,EAA0B;AACvC,IAAA,IAAA,CAAA,MAAW,OAAA,GAAU,IAAA,CAAK,QAAA,EAAU;AAClC,MAAA,IAAI,WAAA;AAEJ,MAAA,GAAA,CAAI,MAAA,CAAO,UAAA,IAAc,WAAA,EAAa;AACpC,QAAA,YAAA,EAAc,IAAA,CAAK,IAAA;AAAA,MACrB,EAAA,KAAA,GAAA,CAAW,MAAA,CAAO,UAAA,IAAc,4BAAA,EAA8B;AAC5D,QAAA,YAAA,EAAc,IAAA,CAAK,oBAAA,CAAqB,IAAA;AAAA,MAC1C,EAAA,KAAO;AACL,QAAA,QAAA;AAAA,MACF;AAEA,MAAA,MAAM,WAAA,EAAa,MAAA,CAAO,UAAA;AAC1B,MAAA,MAAM,eAAA,EAAiB,MAAA,CAAO,cAAA;AAE9B,MAAA,OAAA,CAAQ,IAAA,EAAM;AAAA,QACZ,KAAA,CAAK,eAAA,IAAmB,cAAA,GAAiB,YAAA,IAAgB,UAAA,CAAA;AAAA,QACzD,KAAA,CAAK,eAAA,IAAmB,WAAA,GAAc,WAAA,CAAY,QAAA,CAAS,UAAU,CAAA,CAAA;AAAA,QACrE,KAAA,CAAK,eAAA,IAAmB,cAAA,GAAiB,WAAA,CAAY,UAAA,CAAW,UAAU,CAAA,CAAA;AAAA,QAC1E,KAAA,CAAK,eAAA,IAAmB,YAAA,GAAe,WAAA,CAAY,QAAA,CAAS,UAAU,CAAA,CAAA;AACpE,UAAA,MAAA;AAAA,QAEF,OAAA;AAAS,UAAA,KAAA;AAAA,MACX;AAAA,IACF;AAEA,IAAA,KAAA,CAAM,KAAA,CAAM,IAAI,CAAA;AAAA,EAClB;AACF,CAAA;ADjDA;AACA;AE7CO,IAAM,mBAAA,EAAqB;AAAA;AAAA;AAAA;AAAA,EAIhC,WAAA,EAAa,KAAA;AAAA;AAAA;AAAA;AAAA,EAKb,YAAA,EAAc,MAAA;AAAA;AAAA;AAAA;AAAA,EAKd,UAAA,EAAY,OAAA;AAAA;AAAA;AAAA;AAAA,EAKZ,WAAA,EAAa;AACf,CAAA;AF4CA;AACA;AACE;AACA;AACF,qHAAC","file":"/home/runner/work/langwatch/langwatch/typescript-sdk/dist/chunk-YH5TIVK2.js","sourcesContent":[null,"/**\n * Filterable Batch Span Exporter for OpenTelemetry\n *\n * This module provides a BatchSpanProcessor subclass that allows filtering of spans before export\n * based on configurable rules. Spans matching any exclude rule are dropped and not exported.\n *\n * @module filterable-batch-span-exporter\n */\n\nimport {\n BatchSpanProcessor,\n type ReadableSpan,\n type SpanExporter,\n} from '@opentelemetry/sdk-trace-base';\n\n/**\n * A rule for excluding spans from export based on their name or instrumentation scope name.\n *\n * @property fieldName - The span field to match against ('span_name' or 'instrumentation_scope_name').\n * @property matchValue - The value to match against the field.\n * @property matchOperation - The operation to use for matching ('includes', 'exact_match', 'starts_with', 'ends_with').\n *\n * @example\n * const rule: SpanProcessingExcludeRule = {\n * fieldName: 'span_name',\n * matchValue: 'heartbeat',\n * matchOperation: 'exact_match',\n * };\n */\nexport interface SpanProcessingExcludeRule {\n fieldName: \"span_name\" | \"instrumentation_scope_name\";\n matchValue: string;\n matchOperation: \"includes\" | \"exact_match\" | \"starts_with\" | \"ends_with\";\n}\n\n/**\n * A BatchSpanProcessor that filters out spans matching any of the provided exclude rules before export.\n *\n * This is useful for dropping noisy or irrelevant spans (e.g., health checks, heartbeats) from being exported to your tracing backend.\n *\n * @example\n * import { FilterableBatchSpanProcessor } from './filterable-batch-span-exporter';\n * import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';\n *\n * const exporter = new OTLPTraceExporter({ url: '...' });\n * const filters = [\n * { fieldName: 'span_name', matchValue: 'heartbeat', matchOperation: 'exact_match' },\n * { fieldName: 'instrumentation_scope_name', matchValue: 'internal', matchOperation: 'starts_with' },\n * ];\n * provider.addSpanProcessor(new FilterableBatchSpanProcessor(exporter, filters));\n */\nexport class FilterableBatchSpanProcessor extends BatchSpanProcessor {\n private readonly _filters: SpanProcessingExcludeRule[];\n\n /**\n * Create a new FilterableBatchSpanProcessor.\n *\n * @param exporter - The underlying SpanExporter to use for exporting spans.\n * @param filters - An array of rules for excluding spans from export.\n */\n constructor(exporter: SpanExporter, filters: SpanProcessingExcludeRule[]) {\n super(exporter);\n this._filters = filters;\n }\n\n /**\n * Called when a span ends. If the span matches any exclude rule, it is dropped and not exported.\n *\n * @param span - The ReadableSpan that has ended.\n */\n override onEnd(span: ReadableSpan): void {\n for (const filter of this._filters) {\n let sourceValue: string;\n\n if (filter.fieldName === \"span_name\") {\n sourceValue = span.name;\n } else if (filter.fieldName === \"instrumentation_scope_name\") {\n sourceValue = span.instrumentationScope.name;\n } else {\n continue;\n }\n\n const matchValue = filter.matchValue;\n const matchOperation = filter.matchOperation;\n\n switch (true) {\n case matchOperation === \"exact_match\" && sourceValue === matchValue:\n case matchOperation === \"includes\" && sourceValue.includes(matchValue):\n case matchOperation === \"starts_with\" && sourceValue.startsWith(matchValue):\n case matchOperation === \"ends_with\" && sourceValue.endsWith(matchValue):\n return;\n\n default: break;\n }\n }\n\n super.onEnd(span);\n }\n}\n","import { type DataCaptureMode } from \"./types\";\n\n/**\n * Predefined data capture configurations for common use cases.\n */\nexport const DataCapturePresets = {\n /**\n * Capture both input and output - useful for development and debugging.\n */\n CAPTURE_ALL: \"all\" as DataCaptureMode,\n\n /**\n * Capture nothing - useful for high-security environments.\n */\n CAPTURE_NONE: \"none\" as DataCaptureMode,\n\n /**\n * Capture only inputs - useful when you want to see what's being sent.\n */\n INPUT_ONLY: \"input\" as DataCaptureMode,\n\n /**\n * Capture only outputs - useful when you want to see responses.\n */\n OUTPUT_ONLY: \"output\" as DataCaptureMode,\n} as const;\n"]}
@@ -0,0 +1,184 @@
1
+ import {
2
+ __export
3
+ } from "./chunk-CU3443HD.mjs";
4
+
5
+ // src/logger/index.ts
6
+ var logLevelOrder = {
7
+ debug: 0,
8
+ info: 1,
9
+ warn: 2,
10
+ error: 3
11
+ };
12
+ var NoOpLogger = class {
13
+ debug() {
14
+ }
15
+ info() {
16
+ }
17
+ warn() {
18
+ }
19
+ error() {
20
+ }
21
+ };
22
+ var ConsoleLogger = class {
23
+ constructor(options = { level: "warn" }) {
24
+ this.level = options.level;
25
+ this.prefix = options.prefix;
26
+ }
27
+ shouldLog(level) {
28
+ return logLevelOrder[level] >= logLevelOrder[this.level];
29
+ }
30
+ format(message) {
31
+ return this.prefix ? `[${this.prefix}] ${message}` : message;
32
+ }
33
+ debug(message, ...args) {
34
+ if (this.shouldLog("debug")) console.debug(this.format(message), ...args);
35
+ }
36
+ info(message, ...args) {
37
+ if (this.shouldLog("info")) console.info(this.format(message), ...args);
38
+ }
39
+ warn(message, ...args) {
40
+ if (this.shouldLog("warn")) console.warn(this.format(message), ...args);
41
+ }
42
+ error(message, ...args) {
43
+ if (this.shouldLog("error")) console.error(this.format(message), ...args);
44
+ }
45
+ };
46
+
47
+ // src/observability-sdk/semconv/attributes.ts
48
+ var attributes_exports = {};
49
+ __export(attributes_exports, {
50
+ ATTR_LANGWATCH_CUSTOMER_ID: () => ATTR_LANGWATCH_CUSTOMER_ID,
51
+ ATTR_LANGWATCH_EVALUATION_CUSTOM: () => ATTR_LANGWATCH_EVALUATION_CUSTOM,
52
+ ATTR_LANGWATCH_INPUT: () => ATTR_LANGWATCH_INPUT,
53
+ ATTR_LANGWATCH_LANGCHAIN_EVENT_NAME: () => ATTR_LANGWATCH_LANGCHAIN_EVENT_NAME,
54
+ ATTR_LANGWATCH_LANGCHAIN_RUN_EXTRA_PARAMS: () => ATTR_LANGWATCH_LANGCHAIN_RUN_EXTRA_PARAMS,
55
+ ATTR_LANGWATCH_LANGCHAIN_RUN_ID: () => ATTR_LANGWATCH_LANGCHAIN_RUN_ID,
56
+ ATTR_LANGWATCH_LANGCHAIN_RUN_METADATA: () => ATTR_LANGWATCH_LANGCHAIN_RUN_METADATA,
57
+ ATTR_LANGWATCH_LANGCHAIN_RUN_PARENT_ID: () => ATTR_LANGWATCH_LANGCHAIN_RUN_PARENT_ID,
58
+ ATTR_LANGWATCH_LANGCHAIN_RUN_TAGS: () => ATTR_LANGWATCH_LANGCHAIN_RUN_TAGS,
59
+ ATTR_LANGWATCH_LANGCHAIN_RUN_TYPE: () => ATTR_LANGWATCH_LANGCHAIN_RUN_TYPE,
60
+ ATTR_LANGWATCH_LANGCHAIN_TAGS: () => ATTR_LANGWATCH_LANGCHAIN_TAGS,
61
+ ATTR_LANGWATCH_METRICS: () => ATTR_LANGWATCH_METRICS,
62
+ ATTR_LANGWATCH_OUTPUT: () => ATTR_LANGWATCH_OUTPUT,
63
+ ATTR_LANGWATCH_PARAMS: () => ATTR_LANGWATCH_PARAMS,
64
+ ATTR_LANGWATCH_PROMPT_HANDLE: () => ATTR_LANGWATCH_PROMPT_HANDLE,
65
+ ATTR_LANGWATCH_PROMPT_ID: () => ATTR_LANGWATCH_PROMPT_ID,
66
+ ATTR_LANGWATCH_PROMPT_SELECTED_ID: () => ATTR_LANGWATCH_PROMPT_SELECTED_ID,
67
+ ATTR_LANGWATCH_PROMPT_VARIABLES: () => ATTR_LANGWATCH_PROMPT_VARIABLES,
68
+ ATTR_LANGWATCH_PROMPT_VERSION_ID: () => ATTR_LANGWATCH_PROMPT_VERSION_ID,
69
+ ATTR_LANGWATCH_PROMPT_VERSION_NUMBER: () => ATTR_LANGWATCH_PROMPT_VERSION_NUMBER,
70
+ ATTR_LANGWATCH_RAG_CONTEXTS: () => ATTR_LANGWATCH_RAG_CONTEXTS,
71
+ ATTR_LANGWATCH_SDK_LANGUAGE: () => ATTR_LANGWATCH_SDK_LANGUAGE,
72
+ ATTR_LANGWATCH_SDK_NAME: () => ATTR_LANGWATCH_SDK_NAME,
73
+ ATTR_LANGWATCH_SDK_VERSION: () => ATTR_LANGWATCH_SDK_VERSION,
74
+ ATTR_LANGWATCH_SPAN_TYPE: () => ATTR_LANGWATCH_SPAN_TYPE,
75
+ ATTR_LANGWATCH_STREAMING: () => ATTR_LANGWATCH_STREAMING,
76
+ ATTR_LANGWATCH_TAGS: () => ATTR_LANGWATCH_TAGS,
77
+ ATTR_LANGWATCH_THREAD_ID: () => ATTR_LANGWATCH_THREAD_ID,
78
+ ATTR_LANGWATCH_TIMESTAMPS: () => ATTR_LANGWATCH_TIMESTAMPS,
79
+ ATTR_LANGWATCH_USER_ID: () => ATTR_LANGWATCH_USER_ID
80
+ });
81
+ var ATTR_LANGWATCH_INPUT = "langwatch.input";
82
+ var ATTR_LANGWATCH_OUTPUT = "langwatch.output";
83
+ var ATTR_LANGWATCH_SPAN_TYPE = "langwatch.span.type";
84
+ var ATTR_LANGWATCH_RAG_CONTEXTS = "langwatch.contexts";
85
+ var ATTR_LANGWATCH_METRICS = "langwatch.metrics";
86
+ var ATTR_LANGWATCH_SDK_VERSION = "langwatch.sdk.version";
87
+ var ATTR_LANGWATCH_SDK_NAME = "langwatch.sdk.name";
88
+ var ATTR_LANGWATCH_SDK_LANGUAGE = "langwatch.sdk.language";
89
+ var ATTR_LANGWATCH_TIMESTAMPS = "langwatch.timestamps";
90
+ var ATTR_LANGWATCH_EVALUATION_CUSTOM = "langwatch.evaluation.custom";
91
+ var ATTR_LANGWATCH_PARAMS = "langwatch.params";
92
+ var ATTR_LANGWATCH_CUSTOMER_ID = "langwatch.customer.id";
93
+ var ATTR_LANGWATCH_THREAD_ID = "langwatch.thread.id";
94
+ var ATTR_LANGWATCH_USER_ID = "langwatch.user.id";
95
+ var ATTR_LANGWATCH_TAGS = "langwatch.tags";
96
+ var ATTR_LANGWATCH_STREAMING = "langwatch.gen_ai.streaming";
97
+ var ATTR_LANGWATCH_PROMPT_ID = "langwatch.prompt.id";
98
+ var ATTR_LANGWATCH_PROMPT_HANDLE = "langwatch.prompt.handle";
99
+ var ATTR_LANGWATCH_PROMPT_VERSION_ID = "langwatch.prompt.version.id";
100
+ var ATTR_LANGWATCH_PROMPT_VARIABLES = "langwatch.prompt.variables";
101
+ var ATTR_LANGWATCH_PROMPT_SELECTED_ID = "langwatch.prompt.selected.id";
102
+ var ATTR_LANGWATCH_PROMPT_VERSION_NUMBER = "langwatch.prompt.version.number";
103
+ var ATTR_LANGWATCH_LANGCHAIN_TAGS = "langwatch.langchain.tags";
104
+ var ATTR_LANGWATCH_LANGCHAIN_EVENT_NAME = "langwatch.langchain.event_name";
105
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_ID = "langwatch.langchain.run.id";
106
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_TAGS = "langwatch.langchain.run.tags";
107
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_TYPE = "langwatch.langchain.run.type";
108
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_METADATA = "langwatch.langchain.run.metadata";
109
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_EXTRA_PARAMS = "langwatch.langchain.run.extra_params";
110
+ var ATTR_LANGWATCH_LANGCHAIN_RUN_PARENT_ID = "langwatch.langchain.run.parent.id";
111
+
112
+ // src/observability-sdk/features/data-capture/utils.ts
113
+ function validateDataCaptureMode(mode) {
114
+ return ["none", "input", "output", "all"].includes(mode);
115
+ }
116
+
117
+ // src/observability-sdk/config.ts
118
+ var observabilitySdkConfig = null;
119
+ function initializeObservabilitySdkConfig(config) {
120
+ observabilitySdkConfig = config;
121
+ }
122
+ function getObservabilitySdkConfig(options) {
123
+ if (!observabilitySdkConfig) {
124
+ const message = "[LangWatch Observability SDK] Please call setupObservability() before using the Observability SDK";
125
+ if ((options == null ? void 0 : options.throwOnUninitialized) || process.env.NODE_ENV === "development") {
126
+ throw new Error(message);
127
+ }
128
+ return {
129
+ logger: new NoOpLogger()
130
+ };
131
+ }
132
+ return observabilitySdkConfig;
133
+ }
134
+ function getObservabilitySdkLogger() {
135
+ return getObservabilitySdkConfig().logger;
136
+ }
137
+ function getDataCaptureMode() {
138
+ const config = getObservabilitySdkConfig();
139
+ if (!config.dataCapture) {
140
+ return "all";
141
+ }
142
+ if (typeof config.dataCapture === "string") {
143
+ const validModes = ["none", "input", "output", "all"];
144
+ if (validModes.includes(config.dataCapture)) {
145
+ return config.dataCapture;
146
+ }
147
+ getObservabilitySdkLogger().warn(
148
+ `Invalid data capture mode: ${config.dataCapture}. Using default: "all"`
149
+ );
150
+ return "all";
151
+ }
152
+ if (typeof config.dataCapture === "object" && config.dataCapture.mode && validateDataCaptureMode(config.dataCapture.mode)) {
153
+ return config.dataCapture.mode;
154
+ }
155
+ return "all";
156
+ }
157
+ function shouldCaptureInput() {
158
+ const mode = getDataCaptureMode();
159
+ return mode === "input" || mode === "all";
160
+ }
161
+ function shouldCaptureOutput() {
162
+ const mode = getDataCaptureMode();
163
+ return mode === "output" || mode === "all";
164
+ }
165
+
166
+ export {
167
+ NoOpLogger,
168
+ ConsoleLogger,
169
+ ATTR_LANGWATCH_INPUT,
170
+ ATTR_LANGWATCH_OUTPUT,
171
+ ATTR_LANGWATCH_SPAN_TYPE,
172
+ ATTR_LANGWATCH_RAG_CONTEXTS,
173
+ ATTR_LANGWATCH_METRICS,
174
+ ATTR_LANGWATCH_PROMPT_ID,
175
+ ATTR_LANGWATCH_PROMPT_VERSION_ID,
176
+ ATTR_LANGWATCH_PROMPT_SELECTED_ID,
177
+ ATTR_LANGWATCH_PROMPT_VERSION_NUMBER,
178
+ attributes_exports,
179
+ initializeObservabilitySdkConfig,
180
+ getDataCaptureMode,
181
+ shouldCaptureInput,
182
+ shouldCaptureOutput
183
+ };
184
+ //# sourceMappingURL=chunk-YNQ44U6D.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/logger/index.ts","../src/observability-sdk/semconv/attributes.ts","../src/observability-sdk/features/data-capture/utils.ts","../src/observability-sdk/config.ts"],"sourcesContent":["// Logger utility for SDKs\n//\n// Usage:\n// - If you pass your own Logger implementation, the SDK will use it as-is (no log level filtering or prefixing applied).\n// - If you use ConsoleLogger, you can specify log level and prefix options.\n// - NoOpLogger disables all logging.\n//\n// Example:\n// const logger = new ConsoleLogger({ level: \"warn\", prefix: \"SDK\" });\n// logger.info(\"This will not show\");\n// logger.warn(\"This will show with prefix\");\n//\n// // If you pass your own logger, SDK will not filter logs:\n// const customLogger: Logger = { ... };\n// // SDK uses customLogger as-is\n\nexport type LogLevel = \"debug\" | \"info\" | \"warn\" | \"error\";\n\nconst logLevelOrder: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n} as const;\n\nexport interface Logger {\n debug(message: string, ...args: unknown[]): void;\n info(message: string, ...args: unknown[]): void;\n warn(message: string, ...args: unknown[]): void;\n error(message: string, ...args: unknown[]): void;\n}\n\nexport class NoOpLogger implements Logger {\n debug(): void { /* noop */ }\n info(): void { /* noop */ }\n warn(): void { /* noop */ }\n error(): void { /* noop */ }\n}\n\ninterface ConsoleLoggerOptions {\n level: LogLevel;\n prefix?: string;\n}\n\n/**\n * ConsoleLogger applies log level filtering and optional prefixing.\n * If you pass your own Logger, the SDK will not apply log level filtering or prefixing.\n */\nexport class ConsoleLogger implements Logger {\n private level: LogLevel;\n private prefix?: string;\n\n constructor(options: ConsoleLoggerOptions = { level: \"warn\" }) {\n this.level = options.level;\n this.prefix = options.prefix;\n }\n\n private shouldLog(level: LogLevel): boolean {\n return logLevelOrder[level] >= logLevelOrder[this.level];\n }\n\n private format(message: string): string {\n return this.prefix ? `[${this.prefix}] ${message}` : message;\n }\n\n debug(message: string, ...args: unknown[]): void {\n if (this.shouldLog(\"debug\")) console.debug(this.format(message), ...args);\n }\n info(message: string, ...args: unknown[]): void {\n if (this.shouldLog(\"info\")) console.info(this.format(message), ...args);\n }\n warn(message: string, ...args: unknown[]): void {\n if (this.shouldLog(\"warn\")) console.warn(this.format(message), ...args);\n }\n error(message: string, ...args: unknown[]): void {\n if (this.shouldLog(\"error\")) console.error(this.format(message), ...args);\n }\n}\n","/*\n This file contains the semantic conventions for attributes either owned by LangWatch, or\n which are no yet part of the OpenTelemetry semantic conventions for Gen AI.\n\n Any that are not yet part of the OpenTelemetry semantic conventions for Gen AI are\n marked with an UNSTABLE_ prefix.\n*/\n\n/**\n * LangWatch input data attribute key\n * Used to store the input data for a span or event\n */\nexport const ATTR_LANGWATCH_INPUT = \"langwatch.input\";\n\n/**\n * LangWatch output data attribute key\n * Used to store the output data for a span or event\n */\nexport const ATTR_LANGWATCH_OUTPUT = \"langwatch.output\";\n\n/**\n * LangWatch span type attribute key\n * Used to identify the type of span being traced\n */\nexport const ATTR_LANGWATCH_SPAN_TYPE = \"langwatch.span.type\";\n\n/**\n * LangWatch RAG contexts attribute key\n * Used to store retrieval-augmented generation contexts\n */\nexport const ATTR_LANGWATCH_RAG_CONTEXTS = \"langwatch.contexts\";\n\n/**\n * LangWatch metrics attribute key\n * Used to store custom metrics data\n */\nexport const ATTR_LANGWATCH_METRICS = \"langwatch.metrics\";\n\n/**\n * LangWatch SDK version attribute key\n * Used to track the version of the LangWatch SDK being used\n */\nexport const ATTR_LANGWATCH_SDK_VERSION = \"langwatch.sdk.version\";\n\n/**\n * LangWatch SDK name attribute key\n * Used to identify the LangWatch SDK implementation\n */\nexport const ATTR_LANGWATCH_SDK_NAME = \"langwatch.sdk.name\";\n\n/**\n * LangWatch SDK language attribute key\n * Used to identify the programming language of the SDK\n */\nexport const ATTR_LANGWATCH_SDK_LANGUAGE = \"langwatch.sdk.language\";\n\n/**\n * LangWatch timestamps attribute key\n * Used to store timing information for events\n */\nexport const ATTR_LANGWATCH_TIMESTAMPS = \"langwatch.timestamps\";\n\n/**\n * LangWatch custom evaluation attribute key\n * Used to store custom evaluation data\n */\nexport const ATTR_LANGWATCH_EVALUATION_CUSTOM = \"langwatch.evaluation.custom\";\n\n/**\n * LangWatch parameters attribute key\n * Used to store parameter data for operations\n */\nexport const ATTR_LANGWATCH_PARAMS = \"langwatch.params\";\n\n/**\n * LangWatch customer ID attribute key\n * Used to identify the customer associated with the trace\n */\nexport const ATTR_LANGWATCH_CUSTOMER_ID = \"langwatch.customer.id\";\n\n/**\n * LangWatch thread ID attribute key\n * Used to group related operations within a conversation thread\n */\nexport const ATTR_LANGWATCH_THREAD_ID = \"langwatch.thread.id\";\n\n/**\n * LangWatch user ID attribute key\n * Used to store the user ID for a span or event\n */\nexport const ATTR_LANGWATCH_USER_ID = \"langwatch.user.id\";\n\n/**\n * LangWatch tags attribute key\n * Used to store tags for a span or event\n */\nexport const ATTR_LANGWATCH_TAGS = \"langwatch.tags\";\n\n/**\n * LangWatch streaming attribute key\n * Used to indicate if the operation involves streaming\n */\nexport const ATTR_LANGWATCH_STREAMING = \"langwatch.gen_ai.streaming\";\n\n/**\n * LangWatch prompt ID attribute key\n * Used to identify the specific prompt being used\n */\nexport const ATTR_LANGWATCH_PROMPT_ID = \"langwatch.prompt.id\";\n\n/**\n * LangWatch prompt ID attribute key\n * Used to identify the specific prompt being used\n */\nexport const ATTR_LANGWATCH_PROMPT_HANDLE = \"langwatch.prompt.handle\";\n\n/**\n * LangWatch prompt version ID attribute key\n * Used to identify the specific version of a prompt\n */\nexport const ATTR_LANGWATCH_PROMPT_VERSION_ID = \"langwatch.prompt.version.id\";\n\n/**\n * LangWatch prompt variables attribute key\n * Used to store variables used in prompt templates\n */\nexport const ATTR_LANGWATCH_PROMPT_VARIABLES = \"langwatch.prompt.variables\";\n\n/**\n * LangWatch prompt selected ID attribute key\n * Used to identify which prompt was selected from a set\n */\nexport const ATTR_LANGWATCH_PROMPT_SELECTED_ID = \"langwatch.prompt.selected.id\";\n\n/**\n * LangWatch prompt version number attribute key\n * Used to track the version number of a prompt\n */\nexport const ATTR_LANGWATCH_PROMPT_VERSION_NUMBER =\n \"langwatch.prompt.version.number\";\n\n/**\n * LangWatch LangChain tags attribute key\n * Used to store tags associated with LangChain operations\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_TAGS = \"langwatch.langchain.tags\";\n\n/**\n * LangWatch LangChain event name attribute key\n * Used to identify the specific LangChain event type\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_EVENT_NAME = \"langwatch.langchain.event_name\";\n\n/**\n * LangWatch LangChain run ID attribute key\n * Used to identify a specific LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_ID = \"langwatch.langchain.run.id\";\n\n/**\n * LangWatch LangChain run tags attribute key\n * Used to store tags associated with a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_TAGS = \"langwatch.langchain.run.tags\";\n\n/**\n * LangWatch LangChain run type attribute key\n * Used to identify the type of LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_TYPE = \"langwatch.langchain.run.type\";\n\n/**\n * LangWatch LangChain run metadata attribute key\n * Used to store metadata associated with a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_METADATA = \"langwatch.langchain.run.metadata\";\n\n/**\n * LangWatch LangChain run extra parameters attribute key\n * Used to store additional parameters for a LangChain run\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_EXTRA_PARAMS = \"langwatch.langchain.run.extra_params\";\n\n/**\n * LangWatch LangChain run parent ID attribute key\n * Used to identify the parent run in a hierarchical structure\n */\nexport const ATTR_LANGWATCH_LANGCHAIN_RUN_PARENT_ID =\n \"langwatch.langchain.run.parent.id\";\n","import { type DataCaptureMode } from \"./types\";\n\n/**\n * Validates a data capture mode.\n */\nexport function validateDataCaptureMode(mode: DataCaptureMode): boolean {\n return [\"none\", \"input\", \"output\", \"all\"].includes(mode);\n}\n","import { type Logger, NoOpLogger } from \"../logger/index.js\";\nimport {\n type DataCaptureMode,\n type DataCaptureContext,\n type DataCaptureOptions,\n} from \"./features/data-capture/types.js\";\nimport { validateDataCaptureMode } from \"./features/data-capture/utils.js\";\n\n/**\n * @module observability/config\n * @description\n * Provides configuration management for the LangWatch Observability SDK, including logger and data capture settings.\n *\n * @remarks\n * This module allows you to initialize, retrieve, and reset the global observability configuration. It also provides utilities for determining data capture behavior based on context and configuration.\n *\n * @see {@link ObservabilityConfig}\n * @see {@link initializeObservabilitySdkConfig}\n * @see {@link getObservabilitySdkConfig}\n * @see {@link resetObservabilitySdkConfig}\n * @see {@link getDataCaptureMode}\n * @see {@link shouldCaptureInput}\n * @see {@link shouldCaptureOutput}\n */\n/**\n * Configuration options for the LangWatch Observability SDK.\n *\n * @property logger - The logger instance to use for SDK logging.\n * @property dataCapture - Configuration for automatic data capture. Can be a string, function, or object.\n *\n * @example\n * ```ts\n * import { ObservabilityConfig, initializeObservabilitySdkConfig } from \"@langwatch/observability\";\n *\n * const config: ObservabilityConfig = {\n * logger: new ConsoleLogger(),\n * dataCapture: \"all\",\n * };\n *\n * initializeObservabilitySdkConfig(config);\n * ```\n */\nexport interface ObservabilityConfig {\n /**\n * The logger to use for the observability SDK.\n *\n * @default NoOpLogger\n */\n logger: Logger;\n\n /**\n * Configuration for automatic data capture.\n *\n * @default \"all\"\n */\n dataCapture?: DataCaptureOptions;\n}\n\n/**\n * The observability SDK config.\n */\nlet observabilitySdkConfig: ObservabilityConfig | null = null;\n\n/**\n * Initializes the global observability SDK configuration.\n *\n * @param config - The configuration object to use.\n *\n * @remarks\n * This function should be called once at application startup, before using any observability features.\n *\n * @warning\n * Calling this function will intentionally overwrite any existing configuration. This is by design to allow re-initialization in dynamic or testing environments. If you call this function multiple times, the most recent configuration will take effect.\n *\n * @example\n * ```ts\n * initializeObservabilitySdkConfig({ logger: new ConsoleLogger() });\n * ```\n */\nexport function initializeObservabilitySdkConfig(config: ObservabilityConfig) {\n observabilitySdkConfig = config;\n}\n\n/**\n * Resets the global observability SDK configuration to its initial state (`null`).\n *\n * @remarks\n * Useful for testing or re-initializing the SDK in dynamic environments.\n *\n * @example\n * ```ts\n * resetObservabilitySdkConfig();\n * ```\n */\nexport function resetObservabilitySdkConfig() {\n observabilitySdkConfig = null;\n}\n\n/**\n * Retrieves the current observability SDK configuration.\n *\n * @param options - Optional settings.\n * @param options.throwOnUninitialized - If true, throws an error if the config is not initialized. Defaults to `false` unless `NODE_ENV` is `development`.\n * @returns The current {@link ObservabilityConfig}.\n *\n * @throws {Error} If the config is uninitialized and `throwOnUninitialized` is true or in development mode.\n *\n * @example\n * ```ts\n * const config = getObservabilitySdkConfig();\n * ```\n */\nexport function getObservabilitySdkConfig(options?: {\n throwOnUninitialized?: boolean;\n}): ObservabilityConfig {\n if (!observabilitySdkConfig) {\n const message =\n \"[LangWatch Observability SDK] Please call setupObservability() before using the Observability SDK\";\n\n if (\n options?.throwOnUninitialized ||\n process.env.NODE_ENV === \"development\"\n ) {\n throw new Error(message);\n }\n\n // Use a default logger that can be configured\n return {\n logger: new NoOpLogger(),\n };\n }\n return observabilitySdkConfig;\n}\n\n/**\n * Gets the logger instance from the current observability SDK configuration.\n *\n * @returns The configured {@link Logger} instance.\n *\n * @example\n * ```ts\n * const logger = getObservabilitySdkLogger();\n * logger.info(\"Observability initialized\");\n * ```\n */\nexport function getObservabilitySdkLogger(): Logger {\n return getObservabilitySdkConfig().logger;\n}\n\n/**\n * Determines the effective data capture mode.\n *\n * @returns The resolved {@link DataCaptureMode} (\"all\", \"input\", or \"output\").\n *\n * @remarks\n * The mode is determined by the configuration, which can be a string, function, or object. Defaults to \"all\" if not specified.\n *\n * @example\n * ```ts\n * const mode = getDataCaptureMode();\n * ```\n */\nexport function getDataCaptureMode(): DataCaptureMode {\n const config = getObservabilitySdkConfig();\n\n if (!config.dataCapture) {\n return \"all\"; // Default: capture both input and output\n }\n\n // Handle different config formats\n if (typeof config.dataCapture === \"string\") {\n const validModes: DataCaptureMode[] = [\"none\", \"input\", \"output\", \"all\"];\n if (validModes.includes(config.dataCapture)) {\n return config.dataCapture;\n }\n\n\n getObservabilitySdkLogger().warn(\n `Invalid data capture mode: ${config.dataCapture}. Using default: \"all\"`,\n );\n\n return \"all\";\n }\n\n if (typeof config.dataCapture === \"object\" && config.dataCapture.mode &&validateDataCaptureMode(config.dataCapture.mode)) {\n return config.dataCapture.mode;\n }\n\n return \"all\"; // Default fallback\n}\n\n/**\n * Determines if input data should be captured.\n *\n * @returns `true` if input should be captured, otherwise `false`.\n *\n * @example\n * ```ts\n * if (shouldCaptureInput()) {\n * // Capture input\n * }\n * ```\n */\nexport function shouldCaptureInput(): boolean {\n const mode = getDataCaptureMode();\n return mode === \"input\" || mode === \"all\";\n}\n\n/**\n * Determines if output data should be captured.\n *\n * @returns `true` if output should be captured, otherwise `false`.\n *\n * @example\n * ```ts\n * if (shouldCaptureOutput()) {\n * // Capture output\n * }\n * ```\n */\nexport function shouldCaptureOutput(): boolean {\n const mode = getDataCaptureMode();\n return mode === \"output\" || mode === \"all\";\n}\n"],"mappings":"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","names":[]}