@mcp-use/inspector 0.4.1 → 0.4.2

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 (977) hide show
  1. package/dist/cli/inspect.js +494 -152
  2. package/dist/client/assets/1c-1LwXCeaM.js +1 -0
  3. package/dist/client/assets/abap-C_CBbMnB.js +1 -0
  4. package/dist/client/assets/abnf-CqunyC29.js +1 -0
  5. package/dist/client/assets/abnf-Dl0nB3FF.js +1 -0
  6. package/dist/client/assets/accesslog-Dyx4zD-U.js +1 -0
  7. package/dist/client/assets/actionscript-C26AcnTI.js +1 -0
  8. package/dist/client/assets/actionscript-j49rsMcf.js +1 -0
  9. package/dist/client/assets/ada-BX725jFl.js +1 -0
  10. package/dist/client/assets/ada-hbKcShTz.js +1 -0
  11. package/dist/client/assets/agda-DhZ1RJF_.js +1 -0
  12. package/dist/client/assets/al-DgP2kVCg.js +1 -0
  13. package/dist/client/assets/angelscript-kr0j6as3.js +1 -0
  14. package/dist/client/assets/antlr4-BS3OIu8p.js +1 -0
  15. package/dist/client/assets/apache-D2YLUenx.js +1 -0
  16. package/dist/client/assets/apacheconf-DxF2tf7X.js +1 -0
  17. package/dist/client/assets/apex-CB1rApcz.js +1 -0
  18. package/dist/client/assets/api_chain-3SKETdru.js +15 -0
  19. package/dist/client/assets/apl-BaRelSYQ.js +1 -0
  20. package/dist/client/assets/applescript-BV6r0vOg.js +1 -0
  21. package/dist/client/assets/applescript-CBXJGTwD.js +1 -0
  22. package/dist/client/assets/aql-CRa5w9sh.js +1 -0
  23. package/dist/client/assets/arcade-pblJoyUV.js +1 -0
  24. package/dist/client/assets/arduino-BJzx0aI4.js +1 -0
  25. package/dist/client/assets/arduino-C8Hvy8zI.js +1 -0
  26. package/dist/client/assets/arff-DKr6H6Gn.js +1 -0
  27. package/dist/client/assets/armasm-Cb0n7QyY.js +1 -0
  28. package/dist/client/assets/asciidoc-CaW32vdw.js +1 -0
  29. package/dist/client/assets/asciidoc-DEUbzgzD.js +1 -0
  30. package/dist/client/assets/asm6502-D-qvz9Nj.js +1 -0
  31. package/dist/client/assets/asmatmel--NnPZCww.js +1 -0
  32. package/dist/client/assets/aspectj-D2EcGUnV.js +1 -0
  33. package/dist/client/assets/aspnet-jExzHcT5.js +1 -0
  34. package/dist/client/assets/autohotkey-BNBZGzFC.js +1 -0
  35. package/dist/client/assets/autohotkey-BhTDcK3I.js +1 -0
  36. package/dist/client/assets/autoit-Cbom03rp.js +1 -0
  37. package/dist/client/assets/autoit-CuVWp-C-.js +1 -0
  38. package/dist/client/assets/avisynth-im3i7vGW.js +1 -0
  39. package/dist/client/assets/avrasm-WrKdYrqC.js +1 -0
  40. package/dist/client/assets/avro-idl-5N4Kkatt.js +1 -0
  41. package/dist/client/assets/awk-DTAvXRS6.js +1 -0
  42. package/dist/client/assets/axapta-D6iCXT0X.js +1 -0
  43. package/dist/client/assets/bash-DgpcKAEV.js +1 -0
  44. package/dist/client/assets/bash-Dp2p1czB.js +1 -0
  45. package/dist/client/assets/basic-BuNBl12J.js +1 -0
  46. package/dist/client/assets/basic-DoCiPuhP.js +1 -0
  47. package/dist/client/assets/batch-LD3Xps_N.js +1 -0
  48. package/dist/client/assets/bbcode-CEBIc7A0.js +1 -0
  49. package/dist/client/assets/bicep-DpTpz4-R.js +1 -0
  50. package/dist/client/assets/birb-D5rzgvgL.js +1 -0
  51. package/dist/client/assets/bison-DIOvX5by.js +1 -0
  52. package/dist/client/assets/bnf-Bq9MUbvb.js +1 -0
  53. package/dist/client/assets/bnf-DZhmYi8o.js +1 -0
  54. package/dist/client/assets/brainfuck-D9zJtTAf.js +1 -0
  55. package/dist/client/assets/brainfuck-DB8-U-Kr.js +1 -0
  56. package/dist/client/assets/brightscript-l-qwRCoE.js +1 -0
  57. package/dist/client/assets/bro-B6PmV0fl.js +1 -0
  58. package/dist/client/assets/bsl-CCbE99HJ.js +1 -0
  59. package/dist/client/assets/c-CKX-6wqR.js +1 -0
  60. package/dist/client/assets/c-jAZcOhb1.js +1 -0
  61. package/dist/client/assets/c-like-ezlGQVKl.js +1 -0
  62. package/dist/client/assets/cal-DI8ggXUw.js +1 -0
  63. package/dist/client/assets/capnproto-_AY5dSbQ.js +1 -0
  64. package/dist/client/assets/ceylon-DhXQNTW2.js +1 -0
  65. package/dist/client/assets/cfscript-D2vQsyGT.js +1 -0
  66. package/dist/client/assets/chaiscript-B6s8iVkN.js +1 -0
  67. package/dist/client/assets/cil-2wkoeycK.js +1 -0
  68. package/dist/client/assets/clean-CYq8bwen.js +1 -0
  69. package/dist/client/assets/clike-CcDxgrrV.js +1 -0
  70. package/dist/client/assets/clojure-B0QONKHe.js +1 -0
  71. package/dist/client/assets/clojure-DHbp9ZvJ.js +1 -0
  72. package/dist/client/assets/clojure-repl-DS4d0m_-.js +1 -0
  73. package/dist/client/assets/cmake-D9-goF-V.js +1 -0
  74. package/dist/client/assets/cmake-G7nBYrGQ.js +1 -0
  75. package/dist/client/assets/cobol-DoTFpdYR.js +1 -0
  76. package/dist/client/assets/coffeescript-CVaQbBah.js +1 -0
  77. package/dist/client/assets/coffeescript-fGblLc_b.js +1 -0
  78. package/dist/client/assets/combine_docs_chain-Bi09clmQ.js +3 -0
  79. package/dist/client/assets/concurnas-C71UuVo5.js +1 -0
  80. package/dist/client/assets/coq-CjQDaRNG.js +1 -0
  81. package/dist/client/assets/coq-DxyAJCwZ.js +1 -0
  82. package/dist/client/assets/cos-BPDGAug3.js +1 -0
  83. package/dist/client/assets/cpp-BGz3alx4.js +1 -0
  84. package/dist/client/assets/cpp-CYtgT1RC.js +1 -0
  85. package/dist/client/assets/crmsh-Cqz7J2uL.js +1 -0
  86. package/dist/client/assets/crystal-Xhn8eS_8.js +1 -0
  87. package/dist/client/assets/crystal-dqmDzSs_.js +1 -0
  88. package/dist/client/assets/csharp-DRUUa0y5.js +1 -0
  89. package/dist/client/assets/csharp-R4VDBdEl.js +1 -0
  90. package/dist/client/assets/cshtml-C1llnqB8.js +1 -0
  91. package/dist/client/assets/csp-CFVd7sCm.js +1 -0
  92. package/dist/client/assets/csp-Cb1BZoWZ.js +1 -0
  93. package/dist/client/assets/css-BBhlHsUT.js +1 -0
  94. package/dist/client/assets/css-DNJ_5GQ2.js +1 -0
  95. package/dist/client/assets/css-extras-kpJL186f.js +1 -0
  96. package/dist/client/assets/csv-CUFhfgT7.js +1 -0
  97. package/dist/client/assets/cypher-DbthTYax.js +1 -0
  98. package/dist/client/assets/d-BaAkXIHL.js +1 -0
  99. package/dist/client/assets/d-CrpxWz0Q.js +1 -0
  100. package/dist/client/assets/dart-pg9sg7zR.js +1 -0
  101. package/dist/client/assets/dart-pgknyWq_.js +1 -0
  102. package/dist/client/assets/dataweave-nm3b6RCA.js +1 -0
  103. package/dist/client/assets/dax-n_XJjCsK.js +1 -0
  104. package/dist/client/assets/deep-compare-strict-DtUHXpbW.js +1 -0
  105. package/dist/client/assets/delphi-DL162Fps.js +1 -0
  106. package/dist/client/assets/dhall-CFg1Wt18.js +1 -0
  107. package/dist/client/assets/diff-R2Ywj4m0.js +1 -0
  108. package/dist/client/assets/diff-VqmH3Tr4.js +1 -0
  109. package/dist/client/assets/django-B0_SGlZF.js +1 -0
  110. package/dist/client/assets/django-CKqf_LeY.js +1 -0
  111. package/dist/client/assets/dns-BJqUXkVQ.js +1 -0
  112. package/dist/client/assets/dns-zone-file-iMy4RKG0.js +1 -0
  113. package/dist/client/assets/docker-DibCy3fp.js +1 -0
  114. package/dist/client/assets/dockerfile-CxFEMtOd.js +1 -0
  115. package/dist/client/assets/dos-CXYqTuvU.js +1 -0
  116. package/dist/client/assets/dot-DMz2AwJG.js +1 -0
  117. package/dist/client/assets/dsconfig-BSafpNO4.js +1 -0
  118. package/dist/client/assets/dts-CQ4ddadK.js +1 -0
  119. package/dist/client/assets/dust-DHdg5dKL.js +1 -0
  120. package/dist/client/assets/ebnf-DFWNGUts.js +1 -0
  121. package/dist/client/assets/ebnf-n_HuLYlN.js +1 -0
  122. package/dist/client/assets/editorconfig-q1hr8mZn.js +1 -0
  123. package/dist/client/assets/eiffel-DeM5iKH1.js +1 -0
  124. package/dist/client/assets/ejs-DuY-wppU.js +1 -0
  125. package/dist/client/assets/elixir-CMqX3Vo7.js +1 -0
  126. package/dist/client/assets/elixir-DOyh2gCH.js +1 -0
  127. package/dist/client/assets/elm-CIB45FSl.js +1 -0
  128. package/dist/client/assets/elm-CKaXJe02.js +1 -0
  129. package/dist/client/assets/erb-BZihNRd4.js +1 -0
  130. package/dist/client/assets/erb-DJthf16s.js +1 -0
  131. package/dist/client/assets/erlang-5xmHrF5K.js +1 -0
  132. package/dist/client/assets/erlang-DqPZXzL1.js +1 -0
  133. package/dist/client/assets/erlang-repl-DNdGW8Zj.js +1 -0
  134. package/dist/client/assets/etlua-CUdYfjfk.js +1 -0
  135. package/dist/client/assets/excel-CSZ_Agvf.js +1 -0
  136. package/dist/client/assets/excel-formula-KhMpjq6w.js +1 -0
  137. package/dist/client/assets/factor-D1oDLHPM.js +1 -0
  138. package/dist/client/assets/false-Dj25Ots1.js +1 -0
  139. package/dist/client/assets/few_shot-ZsJ5YbeJ.js +3 -0
  140. package/dist/client/assets/firestore-security-rules-QPJCjY65.js +1 -0
  141. package/dist/client/assets/fix-CgPPbcZl.js +1 -0
  142. package/dist/client/assets/flix-KP63yuil.js +1 -0
  143. package/dist/client/assets/flow-CEsJlKGR.js +1 -0
  144. package/dist/client/assets/fortran-BdRBXTm6.js +1 -0
  145. package/dist/client/assets/fortran-XO3Rx-Jc.js +1 -0
  146. package/dist/client/assets/fsharp-9gv4Z2bM.js +1 -0
  147. package/dist/client/assets/fsharp-B2Hgpxf4.js +1 -0
  148. package/dist/client/assets/ftl-Ctn1WYqN.js +1 -0
  149. package/dist/client/assets/gams-BRP9WTr2.js +1 -0
  150. package/dist/client/assets/gap-BCLaOkB8.js +1 -0
  151. package/dist/client/assets/gauss-DHPLtN-0.js +1 -0
  152. package/dist/client/assets/gcode-Bs3WYoEH.js +1 -0
  153. package/dist/client/assets/gcode-BxW22EgL.js +1 -0
  154. package/dist/client/assets/gdscript-kh48HHIG.js +1 -0
  155. package/dist/client/assets/gedcom-DjXr2tK4.js +1 -0
  156. package/dist/client/assets/gherkin-Cs2i2WTH.js +1 -0
  157. package/dist/client/assets/gherkin-DEfHrW1U.js +1 -0
  158. package/dist/client/assets/git-BR1n084B.js +1 -0
  159. package/dist/client/assets/glsl-C-ccf05D.js +1 -0
  160. package/dist/client/assets/glsl-Q8QGHfqT.js +1 -0
  161. package/dist/client/assets/gml-Bxnjqd2J.js +1 -0
  162. package/dist/client/assets/gml-DHxWO88N.js +1 -0
  163. package/dist/client/assets/gn-HfbOFyhD.js +1 -0
  164. package/dist/client/assets/go-BRHVkY2d.js +1 -0
  165. package/dist/client/assets/go-DjF_fz-h.js +1 -0
  166. package/dist/client/assets/go-module-KY-i9rhL.js +1 -0
  167. package/dist/client/assets/golo-BajSy2sT.js +1 -0
  168. package/dist/client/assets/gradle-Ct1ckrhx.js +1 -0
  169. package/dist/client/assets/graphql-XMPh__BW.js +1 -0
  170. package/dist/client/assets/groovy-CLOoHbmE.js +1 -0
  171. package/dist/client/assets/groovy-SqYFnqzf.js +1 -0
  172. package/dist/client/assets/haml-B2XBKI9L.js +1 -0
  173. package/dist/client/assets/haml-BylNh74w.js +1 -0
  174. package/dist/client/assets/handlebars-BgXKFDaT.js +1 -0
  175. package/dist/client/assets/handlebars-Ck07Sc0o.js +1 -0
  176. package/dist/client/assets/haskell-CObxIh2K.js +1 -0
  177. package/dist/client/assets/haskell-DoLZrDsM.js +1 -0
  178. package/dist/client/assets/haxe-D0a6ys8O.js +1 -0
  179. package/dist/client/assets/haxe-rdGDQixh.js +1 -0
  180. package/dist/client/assets/hcl-C8wgyAy_.js +1 -0
  181. package/dist/client/assets/hlsl-Lrpx1Tc-.js +1 -0
  182. package/dist/client/assets/hoon-B4-f2eBX.js +1 -0
  183. package/dist/client/assets/hpkp-D3acZRbt.js +1 -0
  184. package/dist/client/assets/hsp-UZY8No82.js +1 -0
  185. package/dist/client/assets/hsts-DOghoEM6.js +1 -0
  186. package/dist/client/assets/htmlbars-Bq_yaVt9.js +1 -0
  187. package/dist/client/assets/http-BvqO3lye.js +1 -0
  188. package/dist/client/assets/http-CwSNWevT.js +1 -0
  189. package/dist/client/assets/hy-DXteTZ_v.js +1 -0
  190. package/dist/client/assets/ichigojam-p84mF3EG.js +1 -0
  191. package/dist/client/assets/icon-D_8mafNt.js +1 -0
  192. package/dist/client/assets/icu-message-format-jtRBhdPJ.js +1 -0
  193. package/dist/client/assets/idris-CgbppSal.js +1 -0
  194. package/dist/client/assets/iecst-BQaNgXgE.js +1 -0
  195. package/dist/client/assets/ignore-CCz-HdeY.js +1 -0
  196. package/dist/client/assets/index-BXxIkNj2.js +212 -0
  197. package/dist/client/assets/index-Boe6IUZP.js +4 -0
  198. package/dist/client/assets/index-BtU-sGqa.js +1 -0
  199. package/dist/client/assets/index-C2et5R9-.js +25 -0
  200. package/dist/client/assets/index-DPVUiW-t.js +48 -0
  201. package/dist/client/assets/index-DUE1m-ya.css +1 -0
  202. package/dist/client/assets/index-DvNb1_yp.js +1752 -0
  203. package/dist/client/assets/inform7-BNQuDEVU.js +1 -0
  204. package/dist/client/assets/inform7-BtFnzoSE.js +1 -0
  205. package/dist/client/assets/ini-AEjHJgjB.js +1 -0
  206. package/dist/client/assets/ini-qYTUOJdn.js +1 -0
  207. package/dist/client/assets/io-B4db0oLC.js +1 -0
  208. package/dist/client/assets/irpf90-BlhxaivT.js +1 -0
  209. package/dist/client/assets/isbl-nLNS4UMz.js +1 -0
  210. package/dist/client/assets/j-gDKXD_fI.js +1 -0
  211. package/dist/client/assets/java-CPua5RH2.js +1 -0
  212. package/dist/client/assets/java-D8C3oys1.js +1 -0
  213. package/dist/client/assets/javadoc-BmNqF9RP.js +1 -0
  214. package/dist/client/assets/javadoclike-DWlDvZlE.js +1 -0
  215. package/dist/client/assets/javascript-6_uNPAYO.js +1 -0
  216. package/dist/client/assets/javascript-CK9yxltA.js +1 -0
  217. package/dist/client/assets/javastacktrace-D9I7bJWr.js +1 -0
  218. package/dist/client/assets/jboss-cli-Bva6ngl4.js +1 -0
  219. package/dist/client/assets/jexl-CnppheXw.js +1 -0
  220. package/dist/client/assets/jolie-yqjJZ-bs.js +1 -0
  221. package/dist/client/assets/jq-Brf0g9jb.js +1 -0
  222. package/dist/client/assets/js-extras-Dp696qa_.js +1 -0
  223. package/dist/client/assets/js-templates-dCI_hGk0.js +1 -0
  224. package/dist/client/assets/jsdoc-Bpj4wBeZ.js +1 -0
  225. package/dist/client/assets/json-CCgVPibO.js +1 -0
  226. package/dist/client/assets/json-CV69Dri1.js +1 -0
  227. package/dist/client/assets/json-ZW4Ys-1H.js +5 -0
  228. package/dist/client/assets/json5-LM1zx7Zj.js +1 -0
  229. package/dist/client/assets/jsonp-B1x75JFy.js +1 -0
  230. package/dist/client/assets/jsstacktrace-DTAWKN9h.js +1 -0
  231. package/dist/client/assets/jsx-3rzZJUGT.js +1 -0
  232. package/dist/client/assets/julia-Bd4vWNB7.js +1 -0
  233. package/dist/client/assets/julia-Bt8Zd57o.js +1 -0
  234. package/dist/client/assets/julia-repl-B64Hrqt1.js +1 -0
  235. package/dist/client/assets/keepalived-CyHqRgry.js +1 -0
  236. package/dist/client/assets/keyman-Dh9P2AZO.js +1 -0
  237. package/dist/client/assets/kotlin-DZ27n0zO.js +1 -0
  238. package/dist/client/assets/kotlin-So3HH0i8.js +1 -0
  239. package/dist/client/assets/kumir-yFLgdLEG.js +1 -0
  240. package/dist/client/assets/kusto-jJgzwrC1.js +1 -0
  241. package/dist/client/assets/langfuse-YA2S23SM-CxwiV0VJ.js +239 -0
  242. package/dist/client/assets/lasso-z61_tmK5.js +1 -0
  243. package/dist/client/assets/latex-Cep2d1LJ.js +1 -0
  244. package/dist/client/assets/latex-DojLKwEv.js +1 -0
  245. package/dist/client/assets/latte-CGtpgHFd.js +1 -0
  246. package/dist/client/assets/ldif-BvrQzS5w.js +1 -0
  247. package/dist/client/assets/leaf-DQ83VGIa.js +1 -0
  248. package/dist/client/assets/less-CsTgLIyq.js +1 -0
  249. package/dist/client/assets/less-wBT9IhUl.js +1 -0
  250. package/dist/client/assets/lilypond-DRMyNbzU.js +1 -0
  251. package/dist/client/assets/liquid-DwRBX2Mk.js +1 -0
  252. package/dist/client/assets/lisp-CW7pIJr0.js +1 -0
  253. package/dist/client/assets/lisp-gGskDznl.js +1 -0
  254. package/dist/client/assets/livecodeserver-BOL8repk.js +1 -0
  255. package/dist/client/assets/livescript-DY_XGEQ6.js +1 -0
  256. package/dist/client/assets/livescript-zFDn6lCa.js +1 -0
  257. package/dist/client/assets/llm_chain-CYdmV1P-.js +1 -0
  258. package/dist/client/assets/llvm-Db1cms20.js +1 -0
  259. package/dist/client/assets/llvm-NarBPnao.js +1 -0
  260. package/dist/client/assets/log-CQ0x5Z45.js +1 -0
  261. package/dist/client/assets/lolcode-CVtFmVW0.js +1 -0
  262. package/dist/client/assets/lsl-B4IDwLY_.js +1 -0
  263. package/dist/client/assets/lua-Bj_30OMu.js +1 -0
  264. package/dist/client/assets/lua-zB_TCBSt.js +1 -0
  265. package/dist/client/assets/magma-BTrLPael.js +1 -0
  266. package/dist/client/assets/makefile-CJj95oiA.js +1 -0
  267. package/dist/client/assets/makefile-Dv5XcHEA.js +1 -0
  268. package/dist/client/assets/markdown-BVL8Mrbo.js +1 -0
  269. package/dist/client/assets/markdown-ZWbNf69g.js +1 -0
  270. package/dist/client/assets/markup-DwEbHSdk.js +1 -0
  271. package/dist/client/assets/markup-templating-BCY5Gqhe.js +1 -0
  272. package/dist/client/assets/mathematica-mn-kUPuq.js +1 -0
  273. package/dist/client/assets/matlab-B_JWjsmK.js +1 -0
  274. package/dist/client/assets/matlab-zaWm_7CP.js +1 -0
  275. package/dist/client/assets/maxima-DRu8jnbv.js +1 -0
  276. package/dist/client/assets/maxscript-CsLwRh8_.js +1 -0
  277. package/dist/client/assets/mel-CfLv1HgU.js +1 -0
  278. package/dist/client/assets/mel-CuEU7Fv9.js +1 -0
  279. package/dist/client/assets/mercury-DbgN2V6g.js +1 -0
  280. package/dist/client/assets/mermaid-SSP6q0TH.js +1 -0
  281. package/dist/client/assets/mipsasm-He_mKgrS.js +1 -0
  282. package/dist/client/assets/mizar-BcmslZ8H.js +1 -0
  283. package/dist/client/assets/mizar-C7ejUTMl.js +1 -0
  284. package/dist/client/assets/mojolicious-817c6Ky0.js +1 -0
  285. package/dist/client/assets/mongodb-C33CGdPe.js +1 -0
  286. package/dist/client/assets/monkey-DS14SkBw.js +1 -0
  287. package/dist/client/assets/monkey-vhvYckq9.js +1 -0
  288. package/dist/client/assets/moonscript-CAOuGEqf.js +1 -0
  289. package/dist/client/assets/moonscript-Dm6VHN52.js +1 -0
  290. package/dist/client/assets/n1ql-BgL97zgT.js +1 -0
  291. package/dist/client/assets/n1ql-CftkJovc.js +1 -0
  292. package/dist/client/assets/n4js-CZBi560e.js +1 -0
  293. package/dist/client/assets/nand2tetris-hdl-BmJJLFLW.js +1 -0
  294. package/dist/client/assets/naniscript-5Agj3pFK.js +1 -0
  295. package/dist/client/assets/nasm-ALVrFRFg.js +1 -0
  296. package/dist/client/assets/neon-CfoXjcng.js +1 -0
  297. package/dist/client/assets/nevod-BV3EPOzl.js +1 -0
  298. package/dist/client/assets/nginx-DKkh7pDW.js +1 -0
  299. package/dist/client/assets/nginx-DnnEyUL2.js +1 -0
  300. package/dist/client/assets/nim-B7OFIVrx.js +1 -0
  301. package/dist/client/assets/nim-Df338CwG.js +1 -0
  302. package/dist/client/assets/nix-CpFUtISK.js +1 -0
  303. package/dist/client/assets/nix-DwUHuKa8.js +1 -0
  304. package/dist/client/assets/node-repl-Dm685JeL.js +1 -0
  305. package/dist/client/assets/nsis-Cw-yBAXx.js +1 -0
  306. package/dist/client/assets/nsis-exP5PZ5F.js +1 -0
  307. package/dist/client/assets/objectivec-Ba7S1x4Z.js +1 -0
  308. package/dist/client/assets/objectivec-CpK_agtc.js +1 -0
  309. package/dist/client/assets/ocaml-B4rrnP2N.js +1 -0
  310. package/dist/client/assets/ocaml-C7y2xiF_.js +1 -0
  311. package/dist/client/assets/opencl-BU-wiKBZ.js +1 -0
  312. package/dist/client/assets/openqasm-DmsXUwSY.js +1 -0
  313. package/dist/client/assets/openscad-BxRavlOk.js +1 -0
  314. package/dist/client/assets/oxygene-ChVyQtUM.js +1 -0
  315. package/dist/client/assets/oz-DqysyeBI.js +1 -0
  316. package/dist/client/assets/parigp-a9e-pkxj.js +1 -0
  317. package/dist/client/assets/parser-DzDykvBh.js +1 -0
  318. package/dist/client/assets/parser3-Jh8cJWvr.js +1 -0
  319. package/dist/client/assets/pascal-DByeZgix.js +1 -0
  320. package/dist/client/assets/pascaligo-COnLnb9d.js +1 -0
  321. package/dist/client/assets/pcaxis-C1PungVs.js +1 -0
  322. package/dist/client/assets/peoplecode-Dqzrbpxz.js +1 -0
  323. package/dist/client/assets/perl-C2Pc_F0Z.js +1 -0
  324. package/dist/client/assets/perl-ZHxsYES_.js +1 -0
  325. package/dist/client/assets/pf-DiW7WjDK.js +1 -0
  326. package/dist/client/assets/pgsql-WLS_2uin.js +1 -0
  327. package/dist/client/assets/php-BMal-KNI.js +1 -0
  328. package/dist/client/assets/php-extras-ZiDWZXXF.js +1 -0
  329. package/dist/client/assets/php-ftVaLoJf.js +1 -0
  330. package/dist/client/assets/php-template-DrD8Iqet.js +1 -0
  331. package/dist/client/assets/phpdoc-xizP2cNg.js +1 -0
  332. package/dist/client/assets/plaintext-BohDqSfI.js +1 -0
  333. package/dist/client/assets/plsql-Czj593yP.js +1 -0
  334. package/dist/client/assets/pony-iUg-w_X5.js +1 -0
  335. package/dist/client/assets/powerquery-CzSzf70Y.js +1 -0
  336. package/dist/client/assets/powershell-BAZk0u0I.js +1 -0
  337. package/dist/client/assets/powershell-zh0CGQvC.js +1 -0
  338. package/dist/client/assets/processing-Bkkc3JFE.js +1 -0
  339. package/dist/client/assets/processing-Cesy-djn.js +1 -0
  340. package/dist/client/assets/profile-D0HB42KL.js +1 -0
  341. package/dist/client/assets/prolog-N6JDETEr.js +1 -0
  342. package/dist/client/assets/prolog-jx91Hgq1.js +1 -0
  343. package/dist/client/assets/promql-DiTeUQom.js +1 -0
  344. package/dist/client/assets/properties-D9NBnO2K.js +1 -0
  345. package/dist/client/assets/properties-DxjeXBXu.js +1 -0
  346. package/dist/client/assets/protobuf-CPzUjTjp.js +1 -0
  347. package/dist/client/assets/protobuf-DR_d55cY.js +1 -0
  348. package/dist/client/assets/psl-BX4miJEK.js +1 -0
  349. package/dist/client/assets/pug-gStri_Xq.js +1 -0
  350. package/dist/client/assets/puppet-BfquW406.js +1 -0
  351. package/dist/client/assets/puppet-HgPyCb6I.js +1 -0
  352. package/dist/client/assets/pure-pPwtUw2w.js +1 -0
  353. package/dist/client/assets/purebasic-D_XzMZMf.js +1 -0
  354. package/dist/client/assets/purebasic-Djh1kKJ1.js +1 -0
  355. package/dist/client/assets/purescript-BvaZNrm5.js +1 -0
  356. package/dist/client/assets/python-BveZWkv5.js +1 -0
  357. package/dist/client/assets/python-repl-DWTtrG3B.js +1 -0
  358. package/dist/client/assets/python-xFqxwqhF.js +1 -0
  359. package/dist/client/assets/q-7E0rMyyM.js +1 -0
  360. package/dist/client/assets/q-BnQZdm_9.js +1 -0
  361. package/dist/client/assets/qml-Bno1x8E0.js +1 -0
  362. package/dist/client/assets/qml-C41hwjiH.js +1 -0
  363. package/dist/client/assets/qore-F9aW8Qay.js +1 -0
  364. package/dist/client/assets/qsharp-Cf8IuW15.js +1 -0
  365. package/dist/client/assets/r-DkLvSbO-.js +1 -0
  366. package/dist/client/assets/r-GkkqJzmk.js +1 -0
  367. package/dist/client/assets/racket-BKb2RiQ5.js +1 -0
  368. package/dist/client/assets/reason-CibDMoCx.js +1 -0
  369. package/dist/client/assets/reasonml-BM7bA_2e.js +1 -0
  370. package/dist/client/assets/regex-mW64ik50.js +1 -0
  371. package/dist/client/assets/rego-C9b4jKE_.js +1 -0
  372. package/dist/client/assets/renpy-ekwT19TS.js +1 -0
  373. package/dist/client/assets/rest-Bja87_dE.js +1 -0
  374. package/dist/client/assets/rib-oGRSUkxj.js +1 -0
  375. package/dist/client/assets/rip-CcP64Z_V.js +1 -0
  376. package/dist/client/assets/roboconf-BZOjeXzh.js +1 -0
  377. package/dist/client/assets/roboconf-D8S4hOX-.js +1 -0
  378. package/dist/client/assets/robotframework-C5hzdsKk.js +1 -0
  379. package/dist/client/assets/routeros-TvMB2SCe.js +1 -0
  380. package/dist/client/assets/rsl-8Mhw2dbV.js +1 -0
  381. package/dist/client/assets/ruby-CQZfcCSN.js +1 -0
  382. package/dist/client/assets/ruby-D7TR7FoI.js +1 -0
  383. package/dist/client/assets/ruleslanguage-COtwfMu7.js +1 -0
  384. package/dist/client/assets/rust-CJ_U1HS9.js +1 -0
  385. package/dist/client/assets/rust-D8s4_ADS.js +1 -0
  386. package/dist/client/assets/sas-B4rn5kbO.js +1 -0
  387. package/dist/client/assets/sas-C1C7PN--.js +1 -0
  388. package/dist/client/assets/sass-BnBDJQGm.js +1 -0
  389. package/dist/client/assets/scala-DisWYV_M.js +1 -0
  390. package/dist/client/assets/scala-x7UuZkVC.js +1 -0
  391. package/dist/client/assets/scheme-CeJT1MFb.js +1 -0
  392. package/dist/client/assets/scheme-Dn26tErI.js +1 -0
  393. package/dist/client/assets/scilab-BYgblvQa.js +1 -0
  394. package/dist/client/assets/scss-Cqg4bzhF.js +1 -0
  395. package/dist/client/assets/scss-DP8YKwTY.js +1 -0
  396. package/dist/client/assets/sequential_chain-BSDR0Wvv.js +1 -0
  397. package/dist/client/assets/shell-D9VaP7bc.js +1 -0
  398. package/dist/client/assets/shell-session-BDyRJ9Be.js +1 -0
  399. package/dist/client/assets/smali-B7-hotzt.js +1 -0
  400. package/dist/client/assets/smali-DF8hIxm5.js +1 -0
  401. package/dist/client/assets/smalltalk-BasWhrFV.js +1 -0
  402. package/dist/client/assets/smalltalk-Cxhqyq1g.js +1 -0
  403. package/dist/client/assets/smarty-YPsWDfMu.js +1 -0
  404. package/dist/client/assets/sml-Bg4vM9Vz.js +1 -0
  405. package/dist/client/assets/sml-DKttm-11.js +1 -0
  406. package/dist/client/assets/solidity-CLEvZ0m9.js +1 -0
  407. package/dist/client/assets/solution-file-DCxferRY.js +1 -0
  408. package/dist/client/assets/soy-025o1YZY.js +1 -0
  409. package/dist/client/assets/sparql-DkGltLyu.js +1 -0
  410. package/dist/client/assets/splunk-spl-CyDITQAL.js +1 -0
  411. package/dist/client/assets/sqf-BzPjezhl.js +1 -0
  412. package/dist/client/assets/sqf-DIsLhnWS.js +1 -0
  413. package/dist/client/assets/sql-But40W87.js +1 -0
  414. package/dist/client/assets/sql-DUE1sX6o.js +1 -0
  415. package/dist/client/assets/sql_more-BXQ-Pyn2.js +1 -0
  416. package/dist/client/assets/squirrel-CtvhUxEH.js +1 -0
  417. package/dist/client/assets/stan-8KVO6VLv.js +1 -0
  418. package/dist/client/assets/stan-C5rc7fu9.js +1 -0
  419. package/dist/client/assets/stata-DwaNhV36.js +1 -0
  420. package/dist/client/assets/step21-6a1s9YHA.js +1 -0
  421. package/dist/client/assets/stylus-12AOc-lY.js +1 -0
  422. package/dist/client/assets/stylus-CcmeKxff.js +1 -0
  423. package/dist/client/assets/subunit-DIdRxN33.js +1 -0
  424. package/dist/client/assets/swift-5MdubKvU.js +1 -0
  425. package/dist/client/assets/swift-DS9AtGXO.js +1 -0
  426. package/dist/client/assets/systemd-DXqmwld0.js +1 -0
  427. package/dist/client/assets/t4-cs-Bp09xvYg.js +1 -0
  428. package/dist/client/assets/t4-templating--Vl_qOe8.js +1 -0
  429. package/dist/client/assets/t4-vb-mVJ-NJFi.js +1 -0
  430. package/dist/client/assets/taggerscript-DXq4WP9F.js +1 -0
  431. package/dist/client/assets/tap-DIj8MGZO.js +1 -0
  432. package/dist/client/assets/tap-lZ1UPH2V.js +1 -0
  433. package/dist/client/assets/tcl-BYx7iVza.js +1 -0
  434. package/dist/client/assets/tcl-Di47CT9m.js +1 -0
  435. package/dist/client/assets/textile-Cu4suufn.js +1 -0
  436. package/dist/client/assets/thrift-DFY4_p49.js +1 -0
  437. package/dist/client/assets/toml-CxJkeLz2.js +1 -0
  438. package/dist/client/assets/tp-BLoTMneh.js +1 -0
  439. package/dist/client/assets/tremor-D60yO7sk.js +1 -0
  440. package/dist/client/assets/tsx-CcgVpv-E.js +1 -0
  441. package/dist/client/assets/tt2-B_ZTPXns.js +1 -0
  442. package/dist/client/assets/turtle-D0qQDbux.js +1 -0
  443. package/dist/client/assets/twig-CYLrk8wJ.js +1 -0
  444. package/dist/client/assets/twig-DOsUIVNH.js +1 -0
  445. package/dist/client/assets/types-CmQi9glY.js +81 -0
  446. package/dist/client/assets/typescript-1ETX30Fe.js +1 -0
  447. package/dist/client/assets/typescript-CESUcp84.js +1 -0
  448. package/dist/client/assets/typoscript-BUWpsiVo.js +1 -0
  449. package/dist/client/assets/unrealscript-aYFlCsFL.js +1 -0
  450. package/dist/client/assets/uorazor-H39AMVmc.js +1 -0
  451. package/dist/client/assets/uri-CK8hAd4M.js +1 -0
  452. package/dist/client/assets/v-C6LgZJLT.js +1 -0
  453. package/dist/client/assets/v4-BKrj-4V8.js +1 -0
  454. package/dist/client/assets/vala-1_TnBoKp.js +1 -0
  455. package/dist/client/assets/vala-CpbfXvML.js +1 -0
  456. package/dist/client/assets/vbnet-Bl26F7Jp.js +1 -0
  457. package/dist/client/assets/vbnet-vqH9_0Ma.js +1 -0
  458. package/dist/client/assets/vbscript-CXsWPnMk.js +1 -0
  459. package/dist/client/assets/vbscript-html-B6D_PN9T.js +1 -0
  460. package/dist/client/assets/vector_db_qa-Dl73pdLE.js +9 -0
  461. package/dist/client/assets/velocity-BovabnLc.js +1 -0
  462. package/dist/client/assets/verilog-DroIKKk3.js +1 -0
  463. package/dist/client/assets/verilog-VwZ_BUzH.js +1 -0
  464. package/dist/client/assets/vhdl-BiGLm3u6.js +1 -0
  465. package/dist/client/assets/vhdl-taMaJCau.js +1 -0
  466. package/dist/client/assets/vim-Bb-DygKM.js +1 -0
  467. package/dist/client/assets/vim-Xh36tdBL.js +1 -0
  468. package/dist/client/assets/visual-basic-D2m-ZC8T.js +1 -0
  469. package/dist/client/assets/warpscript-YLGBYh6G.js +1 -0
  470. package/dist/client/assets/wasm-BHWPsKqd.js +1 -0
  471. package/dist/client/assets/web-idl-9w-kVVy3.js +1 -0
  472. package/dist/client/assets/wiki-C4aEAQsg.js +1 -0
  473. package/dist/client/assets/wolfram-CJBoH9IO.js +1 -0
  474. package/dist/client/assets/wren-C8PfUac6.js +1 -0
  475. package/dist/client/assets/x86asm-C_x8h4KC.js +1 -0
  476. package/dist/client/assets/xeora-CEF6aMGJ.js +1 -0
  477. package/dist/client/assets/xl-33K-LjPn.js +1 -0
  478. package/dist/client/assets/xml-DjWiials.js +1 -0
  479. package/dist/client/assets/xml-doc-Bf_ueS1d.js +1 -0
  480. package/dist/client/assets/xojo-DPFQcYAC.js +1 -0
  481. package/dist/client/assets/xquery-CxdnVY9l.js +1 -0
  482. package/dist/client/assets/xquery-F0cAQCqq.js +1 -0
  483. package/dist/client/assets/yaml-BNSiEiNu.js +1 -0
  484. package/dist/client/assets/yaml-CKP_qo6T.js +1 -0
  485. package/dist/client/assets/yang-DnKFU7Us.js +1 -0
  486. package/dist/client/assets/zephir-Bn5eEsal.js +1 -0
  487. package/dist/client/assets/zig-BXjkkJwj.js +1 -0
  488. package/dist/client/assets/zodToJsonSchema-DueTETVe.js +8 -0
  489. package/dist/client/index.html +3 -3
  490. package/dist/server/chunk-64PVSQ35.js +115 -0
  491. package/dist/server/chunk-ITXAOTZI.js +195 -0
  492. package/dist/server/chunk-WCF7WJPU.js +211 -0
  493. package/dist/server/index.d.ts +1 -0
  494. package/dist/server/index.d.ts.map +1 -1
  495. package/dist/server/index.js +6 -0
  496. package/dist/server/server.d.ts.map +1 -1
  497. package/dist/server/server.js +16 -278
  498. package/dist/server/shared-routes.d.ts +14 -0
  499. package/dist/server/shared-routes.d.ts.map +1 -0
  500. package/dist/server/shared-routes.js +10 -0
  501. package/dist/server/shared-static.d.ts +10 -0
  502. package/dist/server/shared-static.d.ts.map +1 -0
  503. package/dist/server/shared-static.js +10 -0
  504. package/dist/server/shared-utils-browser.d.ts +58 -0
  505. package/dist/server/shared-utils-browser.d.ts.map +1 -0
  506. package/dist/server/shared-utils-browser.js +9 -0
  507. package/package.json +2 -2
  508. package/dist/client/assets/1c-PqvIW6SA.js +0 -1
  509. package/dist/client/assets/abap-BelgPNR9.js +0 -1
  510. package/dist/client/assets/abnf-CEeM48hy.js +0 -1
  511. package/dist/client/assets/abnf-Cj2eJzks.js +0 -1
  512. package/dist/client/assets/accesslog-BS5KopaV.js +0 -1
  513. package/dist/client/assets/actionscript-B36rOfTq.js +0 -1
  514. package/dist/client/assets/actionscript-CghosOGs.js +0 -1
  515. package/dist/client/assets/ada-BUX6ujjk.js +0 -1
  516. package/dist/client/assets/ada-D1WrpsLK.js +0 -1
  517. package/dist/client/assets/agda-Blh6gBWZ.js +0 -1
  518. package/dist/client/assets/al-PdSYsap_.js +0 -1
  519. package/dist/client/assets/angelscript-B57iTJjL.js +0 -1
  520. package/dist/client/assets/antlr4-Cy6lJ2TV.js +0 -1
  521. package/dist/client/assets/apache-D5VqZ3UN.js +0 -1
  522. package/dist/client/assets/apacheconf-C-t-pOM6.js +0 -1
  523. package/dist/client/assets/apex-CWp8tDte.js +0 -1
  524. package/dist/client/assets/apl-BwRk4aGt.js +0 -1
  525. package/dist/client/assets/applescript-BGSQsLEj.js +0 -1
  526. package/dist/client/assets/applescript-D-TZt-fA.js +0 -1
  527. package/dist/client/assets/aql-D24KNg5P.js +0 -1
  528. package/dist/client/assets/arcade-DFoH8Qnf.js +0 -1
  529. package/dist/client/assets/arduino-DFYnlifP.js +0 -1
  530. package/dist/client/assets/arduino-Dx6PZeO3.js +0 -1
  531. package/dist/client/assets/arff-makXNtKY.js +0 -1
  532. package/dist/client/assets/armasm-CryDMqyu.js +0 -1
  533. package/dist/client/assets/asciidoc-Cuv7GzcI.js +0 -1
  534. package/dist/client/assets/asciidoc-Cyi2UbM2.js +0 -1
  535. package/dist/client/assets/asm6502-DWF4aoz3.js +0 -1
  536. package/dist/client/assets/asmatmel-CKRxZEVW.js +0 -1
  537. package/dist/client/assets/aspectj-DlWP2G3N.js +0 -1
  538. package/dist/client/assets/aspnet-DxQSQCWq.js +0 -1
  539. package/dist/client/assets/autohotkey-C3FVkUCg.js +0 -1
  540. package/dist/client/assets/autohotkey-CVo0l6LU.js +0 -1
  541. package/dist/client/assets/autoit-C1XBDSRu.js +0 -1
  542. package/dist/client/assets/autoit-DsPlZX_0.js +0 -1
  543. package/dist/client/assets/avisynth-D5BOhNzX.js +0 -1
  544. package/dist/client/assets/avrasm-B76BfEPk.js +0 -1
  545. package/dist/client/assets/avro-idl-BYLQ7gwz.js +0 -1
  546. package/dist/client/assets/awk-j_kWwjM_.js +0 -1
  547. package/dist/client/assets/axapta-BqqTtpXI.js +0 -1
  548. package/dist/client/assets/bash-Bax5rQzD.js +0 -1
  549. package/dist/client/assets/bash-CS2ZsL17.js +0 -1
  550. package/dist/client/assets/basic-DM88bxyf.js +0 -1
  551. package/dist/client/assets/basic-j4CflWCp.js +0 -1
  552. package/dist/client/assets/batch-B25J79Og.js +0 -1
  553. package/dist/client/assets/bbcode-C71lMxFC.js +0 -1
  554. package/dist/client/assets/bicep-C7SxY_1s.js +0 -1
  555. package/dist/client/assets/birb-CvP2EAV9.js +0 -1
  556. package/dist/client/assets/bison-DQiL2aM7.js +0 -1
  557. package/dist/client/assets/bnf-C0-ZbyvZ.js +0 -1
  558. package/dist/client/assets/bnf-C8REIHuK.js +0 -1
  559. package/dist/client/assets/brainfuck-Br2Kwq3E.js +0 -1
  560. package/dist/client/assets/brainfuck-hg_3TaHX.js +0 -1
  561. package/dist/client/assets/brightscript-C4SqnBe-.js +0 -1
  562. package/dist/client/assets/bro-gyj2mAPX.js +0 -1
  563. package/dist/client/assets/bsl-DzMczg3l.js +0 -1
  564. package/dist/client/assets/c-like-Dl4yypz6.js +0 -1
  565. package/dist/client/assets/c-smqcsO6d.js +0 -1
  566. package/dist/client/assets/c-vemspO5D.js +0 -1
  567. package/dist/client/assets/cal-MRXTtIlv.js +0 -1
  568. package/dist/client/assets/capnproto-ggQ_-3vu.js +0 -1
  569. package/dist/client/assets/ceylon-Pf4R8GB5.js +0 -1
  570. package/dist/client/assets/cfscript-D7IAtjdU.js +0 -1
  571. package/dist/client/assets/chaiscript-gb6Nplw4.js +0 -1
  572. package/dist/client/assets/cil-DoVcPR2t.js +0 -1
  573. package/dist/client/assets/clean-BylB4Wcr.js +0 -1
  574. package/dist/client/assets/clike-C9djHdbe.js +0 -1
  575. package/dist/client/assets/clojure-Cg_6RksI.js +0 -1
  576. package/dist/client/assets/clojure-ktQqrkdJ.js +0 -1
  577. package/dist/client/assets/clojure-repl-0X--WhhR.js +0 -1
  578. package/dist/client/assets/cmake-DuRpnx9C.js +0 -1
  579. package/dist/client/assets/cmake-f9Owxa0e.js +0 -1
  580. package/dist/client/assets/cobol-DNT4YVO8.js +0 -1
  581. package/dist/client/assets/coffeescript-C3VmTx1F.js +0 -1
  582. package/dist/client/assets/coffeescript-mXgQgDBD.js +0 -1
  583. package/dist/client/assets/concurnas-hIXFse1k.js +0 -1
  584. package/dist/client/assets/coq-rojx-u25.js +0 -1
  585. package/dist/client/assets/coq-u54Tu7uM.js +0 -1
  586. package/dist/client/assets/cos-BuNDEnV_.js +0 -1
  587. package/dist/client/assets/cpp-BsxIUPzG.js +0 -1
  588. package/dist/client/assets/cpp-kqGL0-RY.js +0 -1
  589. package/dist/client/assets/crmsh-DW_tBn6g.js +0 -1
  590. package/dist/client/assets/crystal-CorlR1lW.js +0 -1
  591. package/dist/client/assets/crystal-DQXY8IGf.js +0 -1
  592. package/dist/client/assets/csharp-CfBoiT3X.js +0 -1
  593. package/dist/client/assets/csharp-TVtaTQDE.js +0 -1
  594. package/dist/client/assets/cshtml-oa1h_cwA.js +0 -1
  595. package/dist/client/assets/csp-DUy_gvFA.js +0 -1
  596. package/dist/client/assets/csp-DaTcNKRb.js +0 -1
  597. package/dist/client/assets/css-DJkC9IAE.js +0 -1
  598. package/dist/client/assets/css-DYNgXBLh.js +0 -1
  599. package/dist/client/assets/css-extras-BnfbNYaP.js +0 -1
  600. package/dist/client/assets/csv-OdcWDCVf.js +0 -1
  601. package/dist/client/assets/cypher-DW2nA7nO.js +0 -1
  602. package/dist/client/assets/d-Bnbo9teU.js +0 -1
  603. package/dist/client/assets/d-C9_IrnzN.js +0 -1
  604. package/dist/client/assets/dart-4wZ-fiyX.js +0 -1
  605. package/dist/client/assets/dart-DCrnLbxG.js +0 -1
  606. package/dist/client/assets/dataweave-gbdqlJOu.js +0 -1
  607. package/dist/client/assets/dax-DVGnED9r.js +0 -1
  608. package/dist/client/assets/delphi-C9bu_N8X.js +0 -1
  609. package/dist/client/assets/dhall-CQ_09OqU.js +0 -1
  610. package/dist/client/assets/diff-CLAKSpiP.js +0 -1
  611. package/dist/client/assets/diff-D_i66Wu6.js +0 -1
  612. package/dist/client/assets/django-BNTmcGd2.js +0 -1
  613. package/dist/client/assets/django-C5gZ93CT.js +0 -1
  614. package/dist/client/assets/dns-0tTeXz8U.js +0 -1
  615. package/dist/client/assets/dns-zone-file-00-cWTIY.js +0 -1
  616. package/dist/client/assets/docker-YU7m3T9O.js +0 -1
  617. package/dist/client/assets/dockerfile-CkuIU-9c.js +0 -1
  618. package/dist/client/assets/dos-CzYVK19Y.js +0 -1
  619. package/dist/client/assets/dot-fhaEknCB.js +0 -1
  620. package/dist/client/assets/dsconfig-BuXhMpfM.js +0 -1
  621. package/dist/client/assets/dts-Cbyx7VH8.js +0 -1
  622. package/dist/client/assets/dust-q29lMG-Y.js +0 -1
  623. package/dist/client/assets/ebnf-AxluDBNC.js +0 -1
  624. package/dist/client/assets/ebnf-CT56IjeN.js +0 -1
  625. package/dist/client/assets/editorconfig-zTIBFx-5.js +0 -1
  626. package/dist/client/assets/eiffel-CxIUujGF.js +0 -1
  627. package/dist/client/assets/ejs-fxUoujMW.js +0 -1
  628. package/dist/client/assets/elixir-Blwj-NS1.js +0 -1
  629. package/dist/client/assets/elixir-CP1wfVRP.js +0 -1
  630. package/dist/client/assets/elm-BIc--Snd.js +0 -1
  631. package/dist/client/assets/elm-BOegK_Le.js +0 -1
  632. package/dist/client/assets/erb-CIKmTa1j.js +0 -1
  633. package/dist/client/assets/erb-VQAidlR5.js +0 -1
  634. package/dist/client/assets/erlang-CyAjKDd-.js +0 -1
  635. package/dist/client/assets/erlang-fn4v6iw6.js +0 -1
  636. package/dist/client/assets/erlang-repl-QqB2rMxU.js +0 -1
  637. package/dist/client/assets/etlua-CYsus25N.js +0 -1
  638. package/dist/client/assets/excel-24R22AVy.js +0 -1
  639. package/dist/client/assets/excel-formula-CMIeKycl.js +0 -1
  640. package/dist/client/assets/factor-B_57o35H.js +0 -1
  641. package/dist/client/assets/false-CcMnSase.js +0 -1
  642. package/dist/client/assets/firestore-security-rules-CzQH3Ez7.js +0 -1
  643. package/dist/client/assets/fix-bvxZr6vI.js +0 -1
  644. package/dist/client/assets/flix-CohKtx_z.js +0 -1
  645. package/dist/client/assets/flow-DBm4T5h5.js +0 -1
  646. package/dist/client/assets/fortran-BxyOCfB-.js +0 -1
  647. package/dist/client/assets/fortran-BzZTVxUy.js +0 -1
  648. package/dist/client/assets/fsharp-CZEAdz34.js +0 -1
  649. package/dist/client/assets/fsharp-iHZ8MX6O.js +0 -1
  650. package/dist/client/assets/ftl-CugoJTf9.js +0 -1
  651. package/dist/client/assets/gams-Cq76o3M-.js +0 -1
  652. package/dist/client/assets/gap-CEnckQoT.js +0 -1
  653. package/dist/client/assets/gauss-CIV1aLHQ.js +0 -1
  654. package/dist/client/assets/gcode-Cw42XjR0.js +0 -1
  655. package/dist/client/assets/gcode-L0KpR6Rl.js +0 -1
  656. package/dist/client/assets/gdscript-BNmuHvxU.js +0 -1
  657. package/dist/client/assets/gedcom-oplvdpf9.js +0 -1
  658. package/dist/client/assets/gherkin-CDWxYJuD.js +0 -1
  659. package/dist/client/assets/gherkin-DDgZB-HP.js +0 -1
  660. package/dist/client/assets/git-DU0TZvlm.js +0 -1
  661. package/dist/client/assets/glsl-CL632KcI.js +0 -1
  662. package/dist/client/assets/glsl-CkzScgIt.js +0 -1
  663. package/dist/client/assets/gml-C3IZRUKj.js +0 -1
  664. package/dist/client/assets/gml-FUSaNcv8.js +0 -1
  665. package/dist/client/assets/gn-Dl3gBdEg.js +0 -1
  666. package/dist/client/assets/go-BIxp-H1I.js +0 -1
  667. package/dist/client/assets/go-CoEC45wa.js +0 -1
  668. package/dist/client/assets/go-module-DMeHiY8o.js +0 -1
  669. package/dist/client/assets/golo-BKfHfKsC.js +0 -1
  670. package/dist/client/assets/gradle-SZS-JZLO.js +0 -1
  671. package/dist/client/assets/graphql-BuQO5Mrr.js +0 -1
  672. package/dist/client/assets/groovy-Ip-S4scK.js +0 -1
  673. package/dist/client/assets/groovy-SdBmZv2u.js +0 -1
  674. package/dist/client/assets/haml-CeX2l1v-.js +0 -1
  675. package/dist/client/assets/haml-DTgrUzFG.js +0 -1
  676. package/dist/client/assets/handlebars-B9ixiNj0.js +0 -1
  677. package/dist/client/assets/handlebars-COVdTa35.js +0 -1
  678. package/dist/client/assets/haskell-ByaNOAXE.js +0 -1
  679. package/dist/client/assets/haskell-D2O0V0HZ.js +0 -1
  680. package/dist/client/assets/haxe-Bwp-176T.js +0 -1
  681. package/dist/client/assets/haxe-C7BMBCwV.js +0 -1
  682. package/dist/client/assets/hcl-Bt7ykFMI.js +0 -1
  683. package/dist/client/assets/hlsl-D3oVpCST.js +0 -1
  684. package/dist/client/assets/hoon-De-xveic.js +0 -1
  685. package/dist/client/assets/hpkp-BywwbeUV.js +0 -1
  686. package/dist/client/assets/hsp-DOzjcKiY.js +0 -1
  687. package/dist/client/assets/hsts-6KuMA87-.js +0 -1
  688. package/dist/client/assets/htmlbars-DJc15m3r.js +0 -1
  689. package/dist/client/assets/http-Cg8mLPnI.js +0 -1
  690. package/dist/client/assets/http-D2RJQojN.js +0 -1
  691. package/dist/client/assets/hy-DctawBC8.js +0 -1
  692. package/dist/client/assets/ichigojam-CUrrEA3H.js +0 -1
  693. package/dist/client/assets/icon-BupOe3wF.js +0 -1
  694. package/dist/client/assets/icu-message-format-BAbI-QAD.js +0 -1
  695. package/dist/client/assets/idris-BWFQ-nN-.js +0 -1
  696. package/dist/client/assets/iecst-YzBmgNBV.js +0 -1
  697. package/dist/client/assets/ignore-Bd706Oq6.js +0 -1
  698. package/dist/client/assets/index-Ck7Qs7an.css +0 -1
  699. package/dist/client/assets/index-Cy3m9aYL.js +0 -1751
  700. package/dist/client/assets/inform7-DNvbuiSo.js +0 -1
  701. package/dist/client/assets/inform7-bKdoGMtw.js +0 -1
  702. package/dist/client/assets/ini-BhTiO_Ux.js +0 -1
  703. package/dist/client/assets/ini-bSfMwH8M.js +0 -1
  704. package/dist/client/assets/io-D-38ELdi.js +0 -1
  705. package/dist/client/assets/irpf90-DvGYmKk8.js +0 -1
  706. package/dist/client/assets/isbl-BpuzaC-J.js +0 -1
  707. package/dist/client/assets/j-C1MKtJ4T.js +0 -1
  708. package/dist/client/assets/java-DrkXtYXZ.js +0 -1
  709. package/dist/client/assets/java-KlyEglHf.js +0 -1
  710. package/dist/client/assets/javadoc-CvxNq7nj.js +0 -1
  711. package/dist/client/assets/javadoclike-CP20cwli.js +0 -1
  712. package/dist/client/assets/javascript-B0UI8Dmt.js +0 -1
  713. package/dist/client/assets/javascript-CUohYg-4.js +0 -1
  714. package/dist/client/assets/javastacktrace-MIo11Z2f.js +0 -1
  715. package/dist/client/assets/jboss-cli-_CTFWmTd.js +0 -1
  716. package/dist/client/assets/jexl-CavV8R1G.js +0 -1
  717. package/dist/client/assets/jolie-BGGmiVZe.js +0 -1
  718. package/dist/client/assets/jq-0gtHFFdV.js +0 -1
  719. package/dist/client/assets/js-extras-ijurcxf8.js +0 -1
  720. package/dist/client/assets/js-templates-DQg4oOLh.js +0 -1
  721. package/dist/client/assets/jsdoc-2udSoQpT.js +0 -1
  722. package/dist/client/assets/json-CI4oYK49.js +0 -1
  723. package/dist/client/assets/json-DoXf83jP.js +0 -1
  724. package/dist/client/assets/json5-Br4gEsUV.js +0 -1
  725. package/dist/client/assets/jsonp-B5BfAAJc.js +0 -1
  726. package/dist/client/assets/jsstacktrace-Bo8q_h5l.js +0 -1
  727. package/dist/client/assets/jsx-DI-OH9kR.js +0 -1
  728. package/dist/client/assets/julia-BH5c9L9E.js +0 -1
  729. package/dist/client/assets/julia-DJHKLbaf.js +0 -1
  730. package/dist/client/assets/julia-repl-D7KluTJr.js +0 -1
  731. package/dist/client/assets/keepalived-BzA3F1oa.js +0 -1
  732. package/dist/client/assets/keyman-D1qXZnqN.js +0 -1
  733. package/dist/client/assets/kotlin-BB-Ajng9.js +0 -1
  734. package/dist/client/assets/kotlin-CIlAYWDb.js +0 -1
  735. package/dist/client/assets/kumir-Bt4HQ139.js +0 -1
  736. package/dist/client/assets/kusto-BL8YUwX_.js +0 -1
  737. package/dist/client/assets/lasso-Bftb53pp.js +0 -1
  738. package/dist/client/assets/latex-BhCrDjrc.js +0 -1
  739. package/dist/client/assets/latex-DDq5wpjY.js +0 -1
  740. package/dist/client/assets/latte-CoOBhGsu.js +0 -1
  741. package/dist/client/assets/ldif-zHaI5CJK.js +0 -1
  742. package/dist/client/assets/leaf-CIifw1r4.js +0 -1
  743. package/dist/client/assets/less-B_rDg9fP.js +0 -1
  744. package/dist/client/assets/less-D7j-00ml.js +0 -1
  745. package/dist/client/assets/lilypond-_39Tmwqu.js +0 -1
  746. package/dist/client/assets/liquid-CwPo9tD3.js +0 -1
  747. package/dist/client/assets/lisp-4l9f0rLB.js +0 -1
  748. package/dist/client/assets/lisp-CIQ0lv4S.js +0 -1
  749. package/dist/client/assets/livecodeserver-Ddp-Eqw3.js +0 -1
  750. package/dist/client/assets/livescript-Cs3Extyk.js +0 -1
  751. package/dist/client/assets/livescript-EidzCbzw.js +0 -1
  752. package/dist/client/assets/llvm-CtsC6M1F.js +0 -1
  753. package/dist/client/assets/llvm-DXYVhqUZ.js +0 -1
  754. package/dist/client/assets/log-B3GTD9Zp.js +0 -1
  755. package/dist/client/assets/lolcode-Bak-2457.js +0 -1
  756. package/dist/client/assets/lsl-Bn38RFsW.js +0 -1
  757. package/dist/client/assets/lua-frcfnvd5.js +0 -1
  758. package/dist/client/assets/lua-reBOt9Qc.js +0 -1
  759. package/dist/client/assets/magma-Dfn9jCb1.js +0 -1
  760. package/dist/client/assets/makefile-1VrSPBEE.js +0 -1
  761. package/dist/client/assets/makefile-DsP7T_Ei.js +0 -1
  762. package/dist/client/assets/markdown-ApxS9W1u.js +0 -1
  763. package/dist/client/assets/markdown-CbdU1KS3.js +0 -1
  764. package/dist/client/assets/markup-kikX4Srb.js +0 -1
  765. package/dist/client/assets/markup-templating-BhTi6Zv2.js +0 -1
  766. package/dist/client/assets/mathematica-B_ymujac.js +0 -1
  767. package/dist/client/assets/matlab-BfwkIcY0.js +0 -1
  768. package/dist/client/assets/matlab-DgrI8PhT.js +0 -1
  769. package/dist/client/assets/maxima-BCBFBxHU.js +0 -1
  770. package/dist/client/assets/maxscript-B_ffO9vL.js +0 -1
  771. package/dist/client/assets/mel-BIi14igQ.js +0 -1
  772. package/dist/client/assets/mel-BhZQ5sRR.js +0 -1
  773. package/dist/client/assets/mercury-BXuaIMS8.js +0 -1
  774. package/dist/client/assets/mermaid-CNSLnAz1.js +0 -1
  775. package/dist/client/assets/mipsasm-BaC7G4fM.js +0 -1
  776. package/dist/client/assets/mizar-BzpVK25S.js +0 -1
  777. package/dist/client/assets/mizar-gtErANNO.js +0 -1
  778. package/dist/client/assets/mojolicious-BKO88W4a.js +0 -1
  779. package/dist/client/assets/mongodb-xMiAAI9M.js +0 -1
  780. package/dist/client/assets/monkey-Cr7En-7e.js +0 -1
  781. package/dist/client/assets/monkey-Dw_oRyoZ.js +0 -1
  782. package/dist/client/assets/moonscript-DxUoHvU9.js +0 -1
  783. package/dist/client/assets/moonscript-gRKZFzx9.js +0 -1
  784. package/dist/client/assets/n1ql-BI1i7rNp.js +0 -1
  785. package/dist/client/assets/n1ql-BdWs_J58.js +0 -1
  786. package/dist/client/assets/n4js-CDnOfsi7.js +0 -1
  787. package/dist/client/assets/nand2tetris-hdl-p1dmfaDZ.js +0 -1
  788. package/dist/client/assets/naniscript-CwZWi_NC.js +0 -1
  789. package/dist/client/assets/nasm-Bt5CPZ4F.js +0 -1
  790. package/dist/client/assets/neon-CGyckrqJ.js +0 -1
  791. package/dist/client/assets/nevod-ByFtnK9Z.js +0 -1
  792. package/dist/client/assets/nginx-COWw32Jq.js +0 -1
  793. package/dist/client/assets/nginx-DwZrICQ4.js +0 -1
  794. package/dist/client/assets/nim-CKdiMe-W.js +0 -1
  795. package/dist/client/assets/nim-Cp20bFC6.js +0 -1
  796. package/dist/client/assets/nix-DqRJXXwQ.js +0 -1
  797. package/dist/client/assets/nix-y2J7z1cM.js +0 -1
  798. package/dist/client/assets/node-repl-H1gy43Ls.js +0 -1
  799. package/dist/client/assets/nsis-Bo3H_KNf.js +0 -1
  800. package/dist/client/assets/nsis-CwvvrjXZ.js +0 -1
  801. package/dist/client/assets/objectivec-B2baZOGn.js +0 -1
  802. package/dist/client/assets/objectivec-CIKs0e2s.js +0 -1
  803. package/dist/client/assets/ocaml-BtmnhzAV.js +0 -1
  804. package/dist/client/assets/ocaml-CRKckqXU.js +0 -1
  805. package/dist/client/assets/opencl-DnEJH3tl.js +0 -1
  806. package/dist/client/assets/openqasm-C4pSJ1Lz.js +0 -1
  807. package/dist/client/assets/openscad-m06aVSiu.js +0 -1
  808. package/dist/client/assets/oxygene-F4jw9ijz.js +0 -1
  809. package/dist/client/assets/oz-fKbxlquf.js +0 -1
  810. package/dist/client/assets/parigp-Bab5JV43.js +0 -1
  811. package/dist/client/assets/parser-BN_kZcMf.js +0 -1
  812. package/dist/client/assets/parser3-BPU8TcZm.js +0 -1
  813. package/dist/client/assets/pascal-Bi2NUjn_.js +0 -1
  814. package/dist/client/assets/pascaligo-FrCgTygh.js +0 -1
  815. package/dist/client/assets/pcaxis-DapRsmSF.js +0 -1
  816. package/dist/client/assets/peoplecode-Bni8ZIYn.js +0 -1
  817. package/dist/client/assets/perl-B2QfDra3.js +0 -1
  818. package/dist/client/assets/perl-Ba2POgEe.js +0 -1
  819. package/dist/client/assets/pf-BLCA4UBZ.js +0 -1
  820. package/dist/client/assets/pgsql-uNtwUpSN.js +0 -1
  821. package/dist/client/assets/php-Dw8LKZRS.js +0 -1
  822. package/dist/client/assets/php-c_XYv3KV.js +0 -1
  823. package/dist/client/assets/php-extras-v6npZ0Az.js +0 -1
  824. package/dist/client/assets/php-template-okOd90r_.js +0 -1
  825. package/dist/client/assets/phpdoc-C_0yiIZf.js +0 -1
  826. package/dist/client/assets/plaintext-Q5C0U37U.js +0 -1
  827. package/dist/client/assets/plsql-CXnRMDVK.js +0 -1
  828. package/dist/client/assets/pony-CZpozjYU.js +0 -1
  829. package/dist/client/assets/powerquery-BSGXNA0V.js +0 -1
  830. package/dist/client/assets/powershell-B4-yQyEW.js +0 -1
  831. package/dist/client/assets/powershell-DuVwH5Ev.js +0 -1
  832. package/dist/client/assets/processing-D1kHatyN.js +0 -1
  833. package/dist/client/assets/processing-DoIEZbvV.js +0 -1
  834. package/dist/client/assets/profile-DauYVSAu.js +0 -1
  835. package/dist/client/assets/prolog-DTjFJ5Gd.js +0 -1
  836. package/dist/client/assets/prolog-DayJ-s9T.js +0 -1
  837. package/dist/client/assets/promql-DUIF6hRh.js +0 -1
  838. package/dist/client/assets/properties-Bg6mwP6v.js +0 -1
  839. package/dist/client/assets/properties-DCfcYzV9.js +0 -1
  840. package/dist/client/assets/protobuf-CNPefqb0.js +0 -1
  841. package/dist/client/assets/protobuf-DAy8qINX.js +0 -1
  842. package/dist/client/assets/psl-B1BQjuQc.js +0 -1
  843. package/dist/client/assets/pug-CtZ0-X8J.js +0 -1
  844. package/dist/client/assets/puppet-DJbZlWLs.js +0 -1
  845. package/dist/client/assets/puppet-H1L99DPJ.js +0 -1
  846. package/dist/client/assets/pure-DqSpIlkB.js +0 -1
  847. package/dist/client/assets/purebasic-Ca_xuLxc.js +0 -1
  848. package/dist/client/assets/purebasic-Lw-c9fjD.js +0 -1
  849. package/dist/client/assets/purescript-Cx0LhCuw.js +0 -1
  850. package/dist/client/assets/python-BZ0zcVB2.js +0 -1
  851. package/dist/client/assets/python-OZLvhRFv.js +0 -1
  852. package/dist/client/assets/python-repl-CKhW9TWa.js +0 -1
  853. package/dist/client/assets/q-BLMcwOtC.js +0 -1
  854. package/dist/client/assets/q-CVAjh3WU.js +0 -1
  855. package/dist/client/assets/qml-Dwdhs-JD.js +0 -1
  856. package/dist/client/assets/qml-bSGOTnNZ.js +0 -1
  857. package/dist/client/assets/qore-JeHVzYZS.js +0 -1
  858. package/dist/client/assets/qsharp-LbMqMzTl.js +0 -1
  859. package/dist/client/assets/r-CjpPv3sz.js +0 -1
  860. package/dist/client/assets/r-pLgm_IkM.js +0 -1
  861. package/dist/client/assets/racket-C_sJszik.js +0 -1
  862. package/dist/client/assets/reason-C9XC1FeF.js +0 -1
  863. package/dist/client/assets/reasonml-CSodofD_.js +0 -1
  864. package/dist/client/assets/regex-DGnOIdjT.js +0 -1
  865. package/dist/client/assets/rego-Y7-EtrxG.js +0 -1
  866. package/dist/client/assets/renpy-B90OOFM2.js +0 -1
  867. package/dist/client/assets/rest-DVufLd56.js +0 -1
  868. package/dist/client/assets/rib-DYXxa5TZ.js +0 -1
  869. package/dist/client/assets/rip-AG18bzN-.js +0 -1
  870. package/dist/client/assets/roboconf-Bt4CAEOV.js +0 -1
  871. package/dist/client/assets/roboconf-CruQ4d6h.js +0 -1
  872. package/dist/client/assets/robotframework-Bi8Lkfxo.js +0 -1
  873. package/dist/client/assets/routeros-CTG7EhTq.js +0 -1
  874. package/dist/client/assets/rsl-BwPYqLZJ.js +0 -1
  875. package/dist/client/assets/ruby-CUpensY-.js +0 -1
  876. package/dist/client/assets/ruby-OXQwg_4q.js +0 -1
  877. package/dist/client/assets/ruleslanguage-CVXvg3hQ.js +0 -1
  878. package/dist/client/assets/rust-BXCHAsps.js +0 -1
  879. package/dist/client/assets/rust-CqiTpIlx.js +0 -1
  880. package/dist/client/assets/sas-7VqkMty_.js +0 -1
  881. package/dist/client/assets/sas-xgOHrTyQ.js +0 -1
  882. package/dist/client/assets/sass-Css_KIkX.js +0 -1
  883. package/dist/client/assets/scala-CVqeOMDO.js +0 -1
  884. package/dist/client/assets/scala-XzlAmOMD.js +0 -1
  885. package/dist/client/assets/scheme-CO1TpD7C.js +0 -1
  886. package/dist/client/assets/scheme-DCwRingc.js +0 -1
  887. package/dist/client/assets/scilab-pokPHqec.js +0 -1
  888. package/dist/client/assets/scss-CyRe9xeH.js +0 -1
  889. package/dist/client/assets/scss-D-NMsr6H.js +0 -1
  890. package/dist/client/assets/shell-BG95lyQH.js +0 -1
  891. package/dist/client/assets/shell-session-CEc9By_i.js +0 -1
  892. package/dist/client/assets/smali-C57XQY9P.js +0 -1
  893. package/dist/client/assets/smali-Dk12rb91.js +0 -1
  894. package/dist/client/assets/smalltalk-BTwL10Ph.js +0 -1
  895. package/dist/client/assets/smalltalk-DlWwMguN.js +0 -1
  896. package/dist/client/assets/smarty-CnKP4Uw4.js +0 -1
  897. package/dist/client/assets/sml-BQccgEkB.js +0 -1
  898. package/dist/client/assets/sml-DrlkdC9Y.js +0 -1
  899. package/dist/client/assets/solidity-Dvk-QEsy.js +0 -1
  900. package/dist/client/assets/solution-file-CZ36jeQw.js +0 -1
  901. package/dist/client/assets/soy-Cj6RNkwH.js +0 -1
  902. package/dist/client/assets/sparql-CGlDRY61.js +0 -1
  903. package/dist/client/assets/splunk-spl-c7ApjsvO.js +0 -1
  904. package/dist/client/assets/sqf-BNZ8g-QB.js +0 -1
  905. package/dist/client/assets/sqf-CrfM-U2O.js +0 -1
  906. package/dist/client/assets/sql-BnhCwxSW.js +0 -1
  907. package/dist/client/assets/sql-DqEq8Oyn.js +0 -1
  908. package/dist/client/assets/sql_more-viS599yU.js +0 -1
  909. package/dist/client/assets/squirrel-B7Ax4QUZ.js +0 -1
  910. package/dist/client/assets/stan-B0emjQf0.js +0 -1
  911. package/dist/client/assets/stan-DrW1-7Zo.js +0 -1
  912. package/dist/client/assets/stata-D1z_6oKT.js +0 -1
  913. package/dist/client/assets/step21-CSo2fPFh.js +0 -1
  914. package/dist/client/assets/stylus-DSH0cEZs.js +0 -1
  915. package/dist/client/assets/stylus-VBFjxQvx.js +0 -1
  916. package/dist/client/assets/subunit-Cut7Z046.js +0 -1
  917. package/dist/client/assets/swift-Ch44yT6Z.js +0 -1
  918. package/dist/client/assets/swift-pJAPjCEZ.js +0 -1
  919. package/dist/client/assets/systemd-DGMbWSvc.js +0 -1
  920. package/dist/client/assets/t4-cs-fn58V-uN.js +0 -1
  921. package/dist/client/assets/t4-templating-CfnBXWtj.js +0 -1
  922. package/dist/client/assets/t4-vb-Dd0C3hI0.js +0 -1
  923. package/dist/client/assets/taggerscript-CvicMPpV.js +0 -1
  924. package/dist/client/assets/tap-DAwz1913.js +0 -1
  925. package/dist/client/assets/tap-D_Urp1cK.js +0 -1
  926. package/dist/client/assets/tcl-CFowaoco.js +0 -1
  927. package/dist/client/assets/tcl-DHRJGygz.js +0 -1
  928. package/dist/client/assets/textile-Dfly9rTQ.js +0 -1
  929. package/dist/client/assets/thrift-C9EXu84V.js +0 -1
  930. package/dist/client/assets/toml-B89g-cUG.js +0 -1
  931. package/dist/client/assets/tp-CnV5Q4JZ.js +0 -1
  932. package/dist/client/assets/tremor-jOBGQvOD.js +0 -1
  933. package/dist/client/assets/tsx-BKLpg4qL.js +0 -1
  934. package/dist/client/assets/tt2-BNm2KDys.js +0 -1
  935. package/dist/client/assets/turtle-S-ENP6ld.js +0 -1
  936. package/dist/client/assets/twig-Cylcj4u8.js +0 -1
  937. package/dist/client/assets/twig-DQnPh7N5.js +0 -1
  938. package/dist/client/assets/typescript-CIBNEys2.js +0 -1
  939. package/dist/client/assets/typescript-cYLvxTbJ.js +0 -1
  940. package/dist/client/assets/typoscript-ZYm0YCvr.js +0 -1
  941. package/dist/client/assets/unrealscript-BvSm39Ue.js +0 -1
  942. package/dist/client/assets/uorazor-KZYIPTma.js +0 -1
  943. package/dist/client/assets/uri-CNcaOUZ5.js +0 -1
  944. package/dist/client/assets/v-D_7RfvgB.js +0 -1
  945. package/dist/client/assets/vala-BjZqBeZ8.js +0 -1
  946. package/dist/client/assets/vala-VkQiMYL3.js +0 -1
  947. package/dist/client/assets/vbnet-B6T3i4-b.js +0 -1
  948. package/dist/client/assets/vbnet-xnByL5z0.js +0 -1
  949. package/dist/client/assets/vbscript-DyJZkZCw.js +0 -1
  950. package/dist/client/assets/vbscript-html-DuIOMZOn.js +0 -1
  951. package/dist/client/assets/velocity-D53C0GVg.js +0 -1
  952. package/dist/client/assets/verilog-CgO3bhvZ.js +0 -1
  953. package/dist/client/assets/verilog-DgSZ-i1D.js +0 -1
  954. package/dist/client/assets/vhdl-C2pF0FRQ.js +0 -1
  955. package/dist/client/assets/vhdl-DBB3eVzb.js +0 -1
  956. package/dist/client/assets/vim-B5nFgRCO.js +0 -1
  957. package/dist/client/assets/vim-BKrK805V.js +0 -1
  958. package/dist/client/assets/visual-basic-sZvvMTQS.js +0 -1
  959. package/dist/client/assets/warpscript-DTzr0tvB.js +0 -1
  960. package/dist/client/assets/wasm-qBKYSfDo.js +0 -1
  961. package/dist/client/assets/web-idl-QGu3xmOs.js +0 -1
  962. package/dist/client/assets/wiki-BtUdgwX3.js +0 -1
  963. package/dist/client/assets/wolfram-_VLRe_VI.js +0 -1
  964. package/dist/client/assets/wren-DCAeYAio.js +0 -1
  965. package/dist/client/assets/x86asm-y5-uAHCt.js +0 -1
  966. package/dist/client/assets/xeora-B3SL41fu.js +0 -1
  967. package/dist/client/assets/xl-DO_Q47xK.js +0 -1
  968. package/dist/client/assets/xml-B9J8WYcq.js +0 -1
  969. package/dist/client/assets/xml-doc-R7Ouri_5.js +0 -1
  970. package/dist/client/assets/xojo-DBmeSVbv.js +0 -1
  971. package/dist/client/assets/xquery-BFnTbqti.js +0 -1
  972. package/dist/client/assets/xquery-BqAURrjq.js +0 -1
  973. package/dist/client/assets/yaml-B7RCjynQ.js +0 -1
  974. package/dist/client/assets/yaml-CknTuhGP.js +0 -1
  975. package/dist/client/assets/yang-Bm6yGkrE.js +0 -1
  976. package/dist/client/assets/zephir-B8TuMdMt.js +0 -1
  977. package/dist/client/assets/zig-xu0whDB7.js +0 -1
@@ -0,0 +1,4 @@
1
+ import{Langfuse as T}from"./index-BtU-sGqa.js";import{b as _,d as I,A as p,e as y,H as M,C as S,S as w,T as D}from"./langfuse-YA2S23SM-CxwiV0VJ.js";import"./zodToJsonSchema-DueTETVe.js";import"./index-DvNb1_yp.js";import"./deep-compare-strict-DtUHXpbW.js";import"./v4-BKrj-4V8.js";class b extends _{static lc_name(){return"FunctionMessage"}constructor(t,e){typeof t=="string"&&(t={content:t,name:e}),super(t)}_getType(){return"function"}}const u="langsmith:hidden";class k extends I{constructor(t){super(),this.name="CallbackHandler",this.rootProvided=!1,this.updateRoot=!1,this.debugEnabled=!1,this.completionStartTimes={},t&&"root"in t?(this.langfuse=t.root.client,this.rootObservationId=t.root.observationId??void 0,this.traceId=t.root.traceId,this.rootProvided=!0,this.updateRoot=t.updateRoot??!1,this.metadata=t.metadata):(this.langfuse=new T({...t,persistence:"memory",sdkIntegration:t?.sdkIntegration??"LANGCHAIN"}),this.sessionId=t?.sessionId,this.userId=t?.userId,this.metadata=t?.metadata,this.tags=t?.tags),this.version=t?.version,this.promptToParentRunMap=new Map,this.traceUpdates=new Map}async flushAsync(){return this.langfuse.flushAsync()}async shutdownAsync(){return this.langfuse.shutdownAsync()}debug(t=!0){this.langfuse.debug(t),this.debugEnabled=t}_log(t){this.debugEnabled&&console.log(t)}async handleNewToken(t,e){return e&&!(e in this.completionStartTimes)&&(this._log(`LLM first streaming token: ${e}`),this.completionStartTimes[e]=new Date),Promise.resolve()}async handleLLMNewToken(t,e,s,i,n,a){return s&&!(s in this.completionStartTimes)&&(this._log(`LLM first streaming token: ${s}`),this.completionStartTimes[s]=new Date),Promise.resolve()}getTraceId(){return this.traceId}getTraceUrl(){return this.traceId?`${this.langfuse.baseUrl}/trace/${this.traceId}`:void 0}getLangchainRunId(){return this.topLevelObservationId}async handleRetrieverError(t,e,s){try{this._log(`Retriever error: ${t} with ID: ${e}`),this.langfuse._updateSpan({id:e,traceId:this.traceId,level:"ERROR",statusMessage:t.toString(),endTime:new Date,version:this.version}),this.updateTrace(e,s,t.toString())}catch(i){this._log(i)}}async handleChainStart(t,e,s,i,n,a,o,c){try{this._log(`Chain start with Id: ${s}`);const h=c??t.id.at(-1)?.toString()??"Langchain Run";this.registerLangfusePrompt(i,a);let r=e;typeof e=="object"&&"input"in e&&Array.isArray(e.input)&&e.input.every(d=>d instanceof _)?r=e.input.map(d=>this.extractChatMessageContent(d)):typeof e=="object"&&"content"in e&&typeof e.content=="string"&&(r=e.content),this.generateTrace(h,s,i,n,a,r),this.langfuse.span({id:s,traceId:this.traceId,parentObservationId:i??this.rootObservationId,name:h,metadata:this.joinTagsAndMetaData(n,a),input:r,version:this.version,level:n&&n.includes(u)?"DEBUG":void 0}),i||this.traceUpdates.set(s,{tags:n,userId:a&&"langfuseUserId"in a&&typeof a.langfuseUserId=="string"?a.langfuseUserId:void 0,sessionId:a&&"langfuseSessionId"in a&&typeof a.langfuseSessionId=="string"?a.langfuseSessionId:void 0})}catch(h){this._log(h)}}registerLangfusePrompt(t,e){e&&"langfusePrompt"in e&&t&&this.promptToParentRunMap.set(t,e.langfusePrompt)}deregisterLangfusePrompt(t){this.promptToParentRunMap.delete(t)}async handleAgentAction(t,e,s){try{this._log(`Agent action with ID: ${e}`),this.langfuse.span({id:e,parentObservationId:s,traceId:this.traceId,endTime:new Date,input:t,version:this.version})}catch(i){this._log(i)}}async handleAgentEnd(t,e,s){try{this._log(`Agent finish with ID: ${e}`),this.langfuse._updateSpan({id:e,traceId:this.traceId,endTime:new Date,output:t,version:this.version}),this.updateTrace(e,s,t)}catch(i){this._log(i)}}async handleChainError(t,e,s){try{this._log(`Chain error: ${t} with ID: ${e}`);const i=this.parseAzureRefusalError(t);this.langfuse._updateSpan({id:e,traceId:this.traceId,level:"ERROR",statusMessage:t.toString()+i,endTime:new Date,version:this.version}),this.updateTrace(e,s,t.toString()+i)}catch(i){this._log(i)}}generateTrace(t,e,s,i,n,a){this.traceId&&!s&&!this.rootProvided&&(this.traceId=void 0,this.topLevelObservationId=void 0);const o={name:t,metadata:this.joinTagsAndMetaData(i,n,this.metadata),userId:this.userId,version:this.version,sessionId:this.sessionId,input:a,tags:this.tags};this.traceId||(this.langfuse.trace({id:e,...o}),this.traceId=e),this.rootProvided&&this.updateRoot&&(this.rootObservationId?this.langfuse._updateSpan({id:this.rootObservationId,traceId:this.traceId,...o}):this.langfuse.trace({id:this.traceId,...o})),this.topLevelObservationId=s?this.topLevelObservationId:e}async handleGenerationStart(t,e,s,i,n,a,o,c){this._log(`Generation start with ID: ${s}`);const h=c??t.id.at(-1)?.toString()??"Langchain Generation";this.generateTrace(h,s,i,a,o,e);const r={},d=n?.invocation_params;for(const[f,l]of Object.entries({temperature:d?.temperature,max_tokens:d?.max_tokens,top_p:d?.top_p,frequency_penalty:d?.frequency_penalty,presence_penalty:d?.presence_penalty,request_timeout:d?.request_timeout}))l!=null&&(r[f]=l);let m;if(n){const f=n.invocation_params.model,l=o&&"ls_model_name"in o?o.ls_model_name:void 0;m=f??l}const v=this.promptToParentRunMap.get(i??"root");v&&i&&this.deregisterLangfusePrompt(i),this.langfuse.generation({id:s,traceId:this.traceId,name:c??t.id.at(-1)?.toString(),metadata:this.joinTagsAndMetaData(a,o),parentObservationId:i??this.rootObservationId,input:e,model:m,modelParameters:r,version:this.version,prompt:v,level:a&&a.includes(u)?"DEBUG":void 0})}async handleChatModelStart(t,e,s,i,n,a,o,c){try{this._log(`Chat model start with ID: ${s}`);const h=e.flatMap(r=>r.map(d=>this.extractChatMessageContent(d)));this.handleGenerationStart(t,h,s,i,n,a,o,c)}catch(h){this._log(h)}}async handleChainEnd(t,e,s){try{this._log(`Chain end with ID: ${e}`);let i=t;typeof t=="object"&&"output"in t&&typeof t.output=="string"&&(i=t.output),this.langfuse._updateSpan({id:e,traceId:this.traceId,output:i,endTime:new Date,version:this.version}),this.updateTrace(e,s,i),this.deregisterLangfusePrompt(e)}catch(i){this._log(i)}}async handleLLMStart(t,e,s,i,n,a,o,c){try{this._log(`LLM start with ID: ${s}`),this.handleGenerationStart(t,e,s,i,n,a,o,c)}catch(h){this._log(h)}}async handleToolStart(t,e,s,i,n,a,o){try{this._log(`Tool start with ID: ${s}`),this.langfuse.span({id:s,parentObservationId:i,traceId:this.traceId,name:o??t.id.at(-1)?.toString(),input:e,metadata:this.joinTagsAndMetaData(n,a),version:this.version,level:n&&n.includes(u)?"DEBUG":void 0})}catch(c){this._log(c)}}async handleRetrieverStart(t,e,s,i,n,a,o){try{this._log(`Retriever start with ID: ${s}`),this.langfuse.span({id:s,parentObservationId:i,traceId:this.traceId,name:o??t.id.at(-1)?.toString(),input:e,metadata:this.joinTagsAndMetaData(n,a),version:this.version,level:n&&n.includes(u)?"DEBUG":void 0})}catch(c){this._log(c)}}async handleRetrieverEnd(t,e,s){try{this._log(`Retriever end with ID: ${e}`),this.langfuse._updateSpan({id:e,traceId:this.traceId,output:t,endTime:new Date,version:this.version}),this.updateTrace(e,s,t)}catch(i){this._log(i)}}async handleToolEnd(t,e,s){try{this._log(`Tool end with ID: ${e}`),this.langfuse._updateSpan({id:e,traceId:this.traceId,output:t,endTime:new Date,version:this.version}),this.updateTrace(e,s,t)}catch(i){this._log(i)}}async handleToolError(t,e,s){try{this._log(`Tool error ${t} with ID: ${e}`),this.langfuse._updateSpan({id:e,traceId:this.traceId,level:"ERROR",statusMessage:t.toString(),endTime:new Date,version:this.version}),this.updateTrace(e,s,t.toString())}catch(i){this._log(i)}}async handleLLMEnd(t,e,s){try{this._log(`LLM end with ID: ${e}`);const i=t.generations[t.generations.length-1][t.generations[t.generations.length-1].length-1],n=this.extractUsageMetadata(i)??t.llmOutput?.tokenUsage,a=this.extractModelNameFromMetadata(i),o={input:n?.input_tokens??("promptTokens"in n?n?.promptTokens:void 0),output:n?.output_tokens??("completionTokens"in n?n?.completionTokens:void 0),total:n?.total_tokens??("totalTokens"in n?n?.totalTokens:void 0)};if(n&&"input_token_details"in n)for(const[h,r]of Object.entries(n.input_token_details??{}))o[`input_${h}`]=r,"input"in o&&typeof r=="number"&&(o.input=Math.max(0,o.input-r));if(n&&"output_token_details"in n)for(const[h,r]of Object.entries(n.output_token_details??{}))o[`output_${h}`]=r,"output"in o&&typeof r=="number"&&(o.output=Math.max(0,o.output-r));const c="message"in i&&i.message instanceof _?this.extractChatMessageContent(i.message):i.text;this.langfuse._updateGeneration({id:e,model:a,traceId:this.traceId,output:c,endTime:new Date,completionStartTime:e in this.completionStartTimes?this.completionStartTimes[e]:void 0,usage:o,usageDetails:o,version:this.version}),e in this.completionStartTimes&&delete this.completionStartTimes[e],this.updateTrace(e,s,c)}catch(i){this._log(i)}}extractUsageMetadata(t){try{return"message"in t&&(t.message instanceof p||t.message instanceof y)?t.message.usage_metadata:void 0}catch(e){this._log(`Error extracting usage metadata: ${e}`);return}}extractModelNameFromMetadata(t){try{return"message"in t&&(t.message instanceof p||t.message instanceof y)?t.message.response_metadata.model_name:void 0}catch{}}extractChatMessageContent(t){let e;return t instanceof M?e={content:t.content,role:"user"}:t instanceof S?e={content:t.content,role:t.role}:t instanceof p?e={content:t.content,role:"assistant"}:t instanceof w?e={content:t.content,role:"system"}:t instanceof b?e={content:t.content,additional_kwargs:t.additional_kwargs,role:t.name}:t instanceof D?e={content:t.content,additional_kwargs:t.additional_kwargs,role:t.name}:t.name?e={role:t.name,content:t.content}:e={content:t.content},t.additional_kwargs.function_call||t.additional_kwargs.tool_calls?{...e,additional_kwargs:t.additional_kwargs}:e}async handleLLMError(t,e,s){try{this._log(`LLM error ${t} with ID: ${e}`);const i=this.parseAzureRefusalError(t);this.langfuse._updateGeneration({id:e,traceId:this.traceId,level:"ERROR",statusMessage:t.toString()+i,endTime:new Date,version:this.version}),this.updateTrace(e,s,t.toString()+i)}catch(i){this._log(i)}}parseAzureRefusalError(t){let e="";if(typeof t=="object"&&"error"in t)try{e=`
2
+
3
+ Error details:
4
+ `+JSON.stringify(t.error,null,2)}catch{}return e}updateTrace(t,e,s){const i=this.traceUpdates.get(t);this.traceUpdates.delete(t),!e&&this.traceId&&this.traceId===t&&this.langfuse.trace({id:this.traceId,output:s,...i}),!e&&this.traceId&&this.rootProvided&&this.updateRoot&&(this.rootObservationId?this.langfuse._updateSpan({id:this.rootObservationId,traceId:this.traceId,output:s}):this.langfuse.trace({id:this.traceId,output:s,...i}))}joinTagsAndMetaData(t,e,s){const i={};return t&&t.length>0&&(i.tags=t),e&&Object.assign(i,e),s&&Object.assign(i,s),this.stripLangfuseKeysFromMetadata(i)}stripLangfuseKeysFromMetadata(t){if(!t)return;const e=["langfusePrompt","langfuseUserId","langfuseSessionId"];return Object.fromEntries(Object.entries(t).filter(([s,i])=>!e.includes(s)))}}const C=async g=>{const{runName:t,item:e,langfuseClient:s,options:i}=g,n={dataset_item_id:e.id,dataset_id:e.datasetId,dataset_run_name:t},a=s.trace();return await e.link(a,t,{description:i?.runDescription,metadata:i?.runMetadata}),{handler:new k({root:a,updateRoot:!0,metadata:n}),trace:a}};export{k as CallbackHandler,T as Langfuse,C as createDatasetItemHandler,k as default};
@@ -0,0 +1 @@
1
+ import{m as B}from"./langfuse-YA2S23SM-CxwiV0VJ.js";import"./index-DvNb1_yp.js";import"./zodToJsonSchema-DueTETVe.js";import"./deep-compare-strict-DtUHXpbW.js";import"./v4-BKrj-4V8.js";var J={};class ge{constructor(){this.events={},this.events={}}on(e,t){return this.events[e]||(this.events[e]=[]),this.events[e].push(t),()=>{this.events[e]=this.events[e].filter(s=>s!==t)}}emit(e,t){for(const s of this.events[e]||[])s(t);for(const s of this.events["*"]||[])s(e,t)}}const ye=60;class be{constructor(e,t){this.value=e,this._expiry=Date.now()+t*1e3}get isExpired(){return Date.now()>this._expiry}}class _e{constructor(){this._cache=new Map,this._defaultTtlSeconds=ye,this._refreshingKeys=new Map}getIncludingExpired(e){return this._cache.get(e)??null}set(e,t,s){const n=s??this._defaultTtlSeconds;this._cache.set(e,new be(t,n))}addRefreshingPromise(e,t){this._refreshingKeys.set(e,t),t.then(()=>{this._refreshingKeys.delete(e)}).catch(()=>{this._refreshingKeys.delete(e)})}isRefreshing(e){return this._refreshingKeys.has(e)}invalidate(e){console.log("invalidating",e,this._cache.keys());for(const t of this._cache.keys())t.startsWith(e)&&this._cache.delete(t)}}var I;(function(r){r.Props="props",r.Queue="queue",r.OptedOut="opted_out"})(I||(I={}));var b;(function(r){r.ChatMessage="chatmessage",r.Placeholder="placeholder"})(b||(b={}));B.escape=function(r){return r};class ee{constructor(e,t=!1,s){this.name=e.name,this.version=e.version,this.config=e.config,this.labels=e.labels,this.tags=e.tags,this.isFallback=t,this.type=s,this.commitMessage=e.commitMessage}_transformToLangchainVariables(e){return this.escapeJsonForLangchain(e).replace(/\{\{(\w+)\}\}/g,"{$1}")}escapeJsonForLangchain(e){const t=[],s=[];let n=0;const o=e.length;for(;n<o;){const a=e[n];if(a==="{"){if(n+1<o&&e[n+1]==="{"){t.push("{{"),n+=2;continue}let c=n+1;for(;c<o&&/\s/.test(e[c]);)c++;const i=c<o&&(e[c]==="'"||e[c]==='"');t.push(i?"{{":"{"),s.push(i),n+=1;continue}if(a==="}"){if(n+1<o&&e[n+1]==="}"){t.push("}}"),n+=2;continue}const c=s.pop()??!1;t.push(c?"}}":"}"),n+=1;continue}t.push(a),n+=1}return t.join("")}}class k extends ee{constructor(e,t=!1){super(e,t,"text"),this.promptResponse=e,this.prompt=e.prompt}compile(e,t){return B.render(this.promptResponse.prompt,e??{})}getLangchainPrompt(e){return this._transformToLangchainVariables(this.prompt)}toJSON(){return JSON.stringify({name:this.name,prompt:this.prompt,version:this.version,isFallback:this.isFallback,tags:this.tags,labels:this.labels,type:this.type,config:this.config})}}class O extends ee{constructor(e,t=!1){const s=O.normalizePrompt(e.prompt),n={...e,prompt:s};super(n,t,"chat"),this.promptResponse=n,this.prompt=s}static normalizePrompt(e){return e.map(t=>"type"in t?t:{type:b.ChatMessage,...t})}compile(e,t){const s=[],n=t??{};for(const o of this.prompt)if("type"in o&&o.type===b.Placeholder){const a=n[o.name];Array.isArray(a)&&a.length>0&&a.every(c=>typeof c=="object"&&"role"in c&&"content"in c)?s.push(...a):Array.isArray(a)&&a.length===0||(a!==void 0?s.push(JSON.stringify(a)):s.push(o))}else"role"in o&&"content"in o&&o.type===b.ChatMessage&&s.push({role:o.role,content:o.content});return s.map(o=>typeof o=="object"&&o!==null&&"role"in o&&"content"in o?{...o,content:B.render(o.content,e??{})}:o)}getLangchainPrompt(e){const t=[],s=e?.placeholders??{};for(const n of this.prompt)if("type"in n&&n.type===b.Placeholder){const o=s[n.name];Array.isArray(o)&&o.length>0&&o.every(a=>typeof a=="object"&&"role"in a&&"content"in a)?t.push(...o.map(a=>({role:a.role,content:this._transformToLangchainVariables(a.content)}))):Array.isArray(o)&&o.length===0||(o!==void 0?t.push(JSON.stringify(o)):t.push({variableName:n.name,optional:!1}))}else"role"in n&&"content"in n&&n.type===b.ChatMessage&&t.push({role:n.role,content:this._transformToLangchainVariables(n.content)});return t}toJSON(){return JSON.stringify({name:this.name,prompt:this.promptResponse.prompt.map(e=>{if("type"in e&&e.type===b.ChatMessage){const{type:t,...s}=e;return s}return e}),version:this.version,isFallback:this.isFallback,tags:this.tags,labels:this.labels,type:this.type,config:this.config})}}function Ee(r,e){if(!r)throw new Error(e)}function te(r){return r?.replace(/\/+$/,"")}async function F(r,e={},t){const{retryCount:s=3,retryDelay:n=5e3,retryCheck:o=()=>!0}=e;let a=null;for(let c=0;c<s+1;c++){c>0&&(await new Promise(i=>setTimeout(i,n)),t(`Retrying ${c+1} of ${s+1}`));try{return await r()}catch(i){if(a=i,!o(i))throw i;t(`Retriable error: ${JSON.stringify(i)}`)}}throw a}function w(r){let e=new Date().getTime(),t=r&&r.performance&&r.performance.now&&r.performance.now()*1e3||0;return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(s){let n=Math.random()*16;return e>0?(n=(e+n)%16|0,e=Math.floor(e/16)):(n=(t+n)%16|0,t=Math.floor(t/16)),(s==="x"?n:n&3|8).toString(16)})}function we(){return new Date().getTime()}function se(){return new Date().toISOString()}function re(r,e){const t=setTimeout(r,e);return t?.unref&&t?.unref(),t}function g(r){if(typeof process<"u"&&J[r])return J[r];if(typeof globalThis<"u")return globalThis[r]}function Se(r,e=!0){const{publicKey:t,secretKey:s,...n}=r??{},o=t??g("LANGFUSE_PUBLIC_KEY"),a=e?s??g("LANGFUSE_SECRET_KEY"):void 0,c=n.baseUrl??g("LANGFUSE_BASEURL"),i={...n,baseUrl:c};return{publicKey:o,...e?{secretKey:a}:void 0,...i}}const C=r=>{const e=new URLSearchParams;return Object.entries(r??{}).forEach(([t,s])=>{s!=null&&(s instanceof Date?e.append(t,s.toISOString()):e.append(t,s.toString()))}),e.toString()};var ne=Object.freeze({__proto__:null,assert:Ee,configLangfuseSDK:Se,currentISOTime:se,currentTimestamp:we,encodeQueryParams:C,generateUUID:w,getEnv:g,removeTrailingSlash:te,retriable:F,safeSetTimeout:re});const ve=["VERCEL_GIT_COMMIT_SHA","NEXT_PUBLIC_VERCEL_GIT_COMMIT_SHA","COMMIT_REF","RENDER_GIT_COMMIT","CI_COMMIT_SHA","CIRCLE_SHA1","CF_PAGES_COMMIT_SHA","REACT_APP_GIT_SHA","SOURCE_VERSION","TRIGGER_DEPLOYMENT_ID"];function Te(){for(const r of ve){const e=g(r);if(e)return e}}let P=null,$=null;const j=r=>import(r);typeof globalThis.Deno<"u"?Promise.all([j("node:fs"),j("node:crypto")]).then(([r,e])=>{P=r,$=e}).catch():typeof process<"u"&&process.versions?.node?Promise.all([j("fs"),j("crypto")]).then(([r,e])=>{P=r,$=e}).catch():typeof crypto<"u"&&($=crypto);class v{constructor(e){const{obj:t,base64DataUri:s,contentType:n,contentBytes:o,filePath:a}=e;if(this.obj=t,this._mediaId=void 0,s){const[c,i]=this.parseBase64DataUri(s);this._contentBytes=c,this._contentType=i,this._source="base64_data_uri"}else if(o&&n)this._contentBytes=o,this._contentType=n,this._source="bytes";else if(a&&n){if(!P)throw new Error("File system support is not available in this environment");if(!P.existsSync(a))throw new Error(`File at path ${a} does not exist`);this._contentBytes=this.readFile(a),this._contentType=this._contentBytes?n:void 0,this._source=this._contentBytes?"file":void 0}else console.error("base64DataUri, or contentBytes and contentType, or filePath must be provided to LangfuseMedia")}readFile(e){try{if(!P)throw new Error("File system support is not available in this environment");return P.readFileSync(e)}catch(t){console.error(`Error reading file at path ${e}`,t);return}}parseBase64DataUri(e){try{if(!e||typeof e!="string")throw new Error("Data URI is not a string");if(!e.startsWith("data:"))throw new Error("Data URI does not start with 'data:'");const[t,s]=e.slice(5).split(",",2);if(!t||!s)throw new Error("Invalid URI");const n=t.split(";");if(!n.includes("base64"))throw new Error("Data is not base64 encoded");const o=n[0];if(!o)throw new Error("Content type is empty");return[Buffer.from(s,"base64"),o]}catch(t){return console.error("Error parsing base64 data URI",t),[void 0,void 0]}}get contentLength(){return this._contentBytes?.length}get contentSha256Hash(){if(!this._contentBytes)return;if(!$){console.error("Crypto support is not available in this environment");return}return $.createHash("sha256").update(this._contentBytes).digest("base64")}toJSON(){return!this._contentType||!this._source||!this._mediaId?`<Upload handling failed for LangfuseMedia of type ${this._contentType}>`:`@@@langfuseMedia:type=${this._contentType}|id=${this._mediaId}|source=${this._source}@@@`}static parseReferenceString(e){const t="@@@langfuseMedia:";if(!e.startsWith(t))throw new Error("Reference string does not start with '@@@langfuseMedia:type='");if(!e.endsWith("@@@"))throw new Error("Reference string does not end with '@@@'");const o=e.slice(t.length,-3).split("|"),a={};for(const c of o){const[i,u]=c.split("=",2);a[i]=u}if(!("type"in a&&"id"in a&&"source"in a))throw new Error("Missing required fields in reference string");return{mediaId:a.id,source:a.source,contentType:a.type}}static async resolveMediaReferences(e){const{obj:t,langfuseClient:s,maxDepth:n=10}=e;async function o(a,c){if(c>n)return a;if(typeof a=="string"){const i=/@@@langfuseMedia:.+?@@@/g,u=a.match(i);if(!u)return a;let h=a;const l=new Map;await Promise.all(u.map(async p=>{try{const m=v.parseReferenceString(p),y=await s.fetchMedia(m.mediaId),_=await s.fetch(y.url,{method:"GET",headers:{}});if(_.status!==200)throw new Error("Failed to fetch media content");const E=Buffer.from(await _.arrayBuffer()).toString("base64"),f=`data:${y.contentType};base64,${E}`;l.set(p,f)}catch(m){console.warn("Error fetching media content for reference string",p,m)}}));for(const[p,m]of l.entries())h=h.replaceAll(p,m);return h}return Array.isArray(a)?Promise.all(a.map(async i=>await o(i,c+1))):typeof a=="object"&&a!==null?Object.fromEntries(await Promise.all(Object.entries(a).map(async([i,u])=>[i,await o(u,c+1)]))):a}return o(t,0)}}function Ie(r,e){return e===void 0?!0:e===0?!1:e<0||e>1||isNaN(e)?(console.warn("Sample rate must be between 0 and 1. Ignoring setting."),!0):Pe(r)<e}function Pe(r){let e=0;const t=31;for(let s=0;s<r.length;s++)e=e*t+r.charCodeAt(s)>>>0;return e=(e>>>16^e)*73244475,e=(e>>>16^e)*73244475,e=e>>>16^e,Math.abs(e)/2147483647}const z=g("LANGFUSE_MAX_EVENT_SIZE_BYTES")?Number(g("LANGFUSE_MAX_EVENT_SIZE_BYTES")):1e6,Le=g("LANGFUSE_MAX_BATCH_SIZE_BYTES")?Number(g("LANGFUSE_MAX_BATCH_SIZE_BYTES")):25e5,H=/^(?!langfuse)[a-z0-9_-]+$/,Ae=["langfuse-prompt-experiment"];class U extends Error{constructor(e,t){super("HTTP error while fetching Langfuse: "+e.status+" and body: "+t),this.response=e,this.name="LangfuseFetchHttpError"}}class M extends Error{constructor(e){super("Network error while fetching Langfuse",e instanceof Error?{cause:e}:{}),this.error=e,this.name="LangfuseFetchNetworkError"}}function oe(r){return typeof r=="object"&&r.name==="LangfuseFetchHttpError"}function ae(r){return typeof r=="object"&&r.name==="LangfuseFetchNetworkError"}function Ce(r){return oe(r)||ae(r)}const D="https://langfuse.com/support",Oe="https://api.reference.langfuse.com",$e="https://langfuse.com/docs/rbac",Re="https://langfuse.com/docs/sdk/typescript/guide",je="https://langfuse.com/faq/all/api-limits",Ue="https://www.npmjs.com/package/langfuse",Q=`Make sure to keep your SDK updated, refer to ${Ue} for details.`,x=`This is an unusual occurrence and we are monitoring it closely. For help, please contact support: ${D}.`,V=`Unexpected error occurred. Please check your request and contact support: ${D}.`,xe=new Map([[500,`Internal server error occurred. For help, please contact support: ${D}`],[501,`Not implemented. Please check your request and contact support for help: ${D}.`],[502,`Bad gateway. ${x}`],[503,`Service unavailable. ${x}`],[504,`Gateway timeout. ${x}`],[404,`Internal error occurred. ${x}`],[400,`Bad request. Please check your request for any missing or incorrect parameters. Refer to our API docs: ${Oe} for details.`],[401,`Unauthorized. Please check your public/private host settings. Refer to our installation and setup guide: ${Re} for details on SDK configuration.`],[403,`Forbidden. Please check your access control settings. Refer to our RBAC docs: ${$e} for details.`],[429,`Rate limit exceeded. For more information on rate limits please see: ${je}`]]);function De(r){if(!r)return`${V} ${Q}`;const e=xe.get(r)||V;return`${r}: ${e} ${Q}`}function G(r){if(oe(r)){const e=r.response.status,t=De(e);console.error("[Langfuse SDK]",t,`Error details: ${r}`)}else ae(r)?console.error("[Langfuse SDK] Network error: ",r):console.error("[Langfuse SDK] Unknown error:",r)}class ie{constructor(e){this.additionalHeaders={},this.debugMode=!1,this.pendingEventProcessingPromises={},this.pendingIngestionPromises={},this.localEventExportMap=new Map,this._events=new ge;const{publicKey:t,secretKey:s,enabled:n,_projectId:o,_isLocalEventExportEnabled:a,...c}=e;if(this._events.on("error",i=>{console.error(`[Langfuse SDK] ${typeof i=="string"?i:JSON.stringify(i)}`)}),this.enabled=n!==!1,this.publicKey=t??"",this.secretKey=s,this.baseUrl=te(c?.baseUrl||"https://cloud.langfuse.com"),this.additionalHeaders=c?.additionalHeaders||{},this.flushAt=c?.flushAt?Math.max(c?.flushAt,1):15,this.flushInterval=c?.flushInterval??1e4,this.release=c?.release??g("LANGFUSE_RELEASE")??Te()??void 0,this.mask=c?.mask,this.sampleRate=c?.sampleRate??(g("LANGFUSE_SAMPLE_RATE")?Number(g("LANGFUSE_SAMPLE_RATE")):void 0),this.sampleRate&&this._events.emit("debug",`Langfuse trace sampling enabled with sampleRate ${this.sampleRate}.`),this.environment=c?.environment??g("LANGFUSE_TRACING_ENVIRONMENT"),this.environment&&!(H.test(this.environment)||Ae.includes(this.environment))&&this._events.emit("error",`Invalid tracing environment set: ${this.environment} . Environment must match regex ${H}. Events will be rejected by Langfuse server.`),this._retryOptions={retryCount:c?.fetchRetryCount??3,retryDelay:c?.fetchRetryDelay??3e3,retryCheck:Ce},this.requestTimeout=c?.requestTimeout??5e3,this.sdkIntegration=c?.sdkIntegration??"DEFAULT",this.isLocalEventExportEnabled=a??!1,this.isLocalEventExportEnabled&&!o){this._events.emit("error","Local event export is enabled, but no project ID was provided. Disabling local export."),this.isLocalEventExportEnabled=!1;return}else if(!this.isLocalEventExportEnabled&&o){this._events.emit("error","Local event export is disabled, but a project ID was provided. Disabling local export."),this.isLocalEventExportEnabled=!1;return}else this.projectId=o}getSdkIntegration(){return this.sdkIntegration}getCommonEventProperties(){return{$lib:this.getLibraryId(),$lib_version:this.getLibraryVersion()}}on(e,t){return this._events.on(e,t)}debug(e=!0){this.removeDebugCallback?.(),this.debugMode=e,e&&(this.removeDebugCallback=this.on("*",(t,s)=>{t!=="error"&&console.log("[Langfuse Debug]",t,JSON.stringify(s))}))}traceStateless(e){const{id:t,timestamp:s,release:n,...o}=e,a=t??w(),c=n??this.release,i={id:a,release:c,timestamp:s??new Date,environment:this.environment,...o};return this.enqueue("trace-create",i),a}eventStateless(e){const{id:t,startTime:s,...n}=e,o=t??w(),a={id:o,startTime:s??new Date,environment:this.environment,...n};return this.enqueue("event-create",a),o}spanStateless(e){const{id:t,startTime:s,...n}=e,o=t||w(),a={id:o,startTime:s??new Date,environment:this.environment,...n};return this.enqueue("span-create",a),o}generationStateless(e){const{id:t,startTime:s,prompt:n,...o}=e,a=n&&!n.isFallback?{promptName:n.name,promptVersion:n.version}:{},c=t||w(),i={id:c,startTime:s??new Date,environment:this.environment,...a,...o};return this.enqueue("generation-create",i),c}scoreStateless(e){const{id:t,...s}=e,n=t||w(),o={id:n,environment:this.environment,...s};return this.enqueue("score-create",o),n}updateSpanStateless(e){return this.enqueue("span-update",e),e.id}updateGenerationStateless(e){const{prompt:t,...s}=e,o={...t&&!t.isFallback?{promptName:t.name,promptVersion:t.version}:{},...s};return this.enqueue("generation-update",o),e.id}async _getDataset(e){const t=encodeURIComponent(e);return this.fetchAndLogErrors(`${this.baseUrl}/api/public/v2/datasets/${t}`,this._getFetchOptions({method:"GET"}))}async _getDatasetItems(e){const t=new URLSearchParams;return Object.entries(e??{}).forEach(([s,n])=>{n!=null&&t.append(s,n.toString())}),this.fetchAndLogErrors(`${this.baseUrl}/api/public/dataset-items?${t}`,this._getFetchOptions({method:"GET"}))}async _fetchMedia(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/media/${e}`,this._getFetchOptions({method:"GET"}))}async fetchTraces(e){const{data:t,meta:s}=await this.fetchAndLogErrors(`${this.baseUrl}/api/public/traces?${C(e)}`,this._getFetchOptions({method:"GET"}));return{data:t,meta:s}}async fetchTrace(e){return{data:await this.fetchAndLogErrors(`${this.baseUrl}/api/public/traces/${e}`,this._getFetchOptions({method:"GET"}))}}async fetchObservations(e){const{data:t,meta:s}=await this.fetchAndLogErrors(`${this.baseUrl}/api/public/observations?${C(e)}`,this._getFetchOptions({method:"GET"}));return{data:t,meta:s}}async fetchObservation(e){return{data:await this.fetchAndLogErrors(`${this.baseUrl}/api/public/observations/${e}`,this._getFetchOptions({method:"GET"}))}}async fetchSessions(e){const{data:t,meta:s}=await this.fetchAndLogErrors(`${this.baseUrl}/api/public/sessions?${C(e)}`,this._getFetchOptions({method:"GET"}));return{data:t,meta:s}}async getDatasetRun(e){const t=encodeURIComponent(e.datasetName),s=encodeURIComponent(e.runName);return this.fetchAndLogErrors(`${this.baseUrl}/api/public/datasets/${t}/runs/${s}`,this._getFetchOptions({method:"GET"}))}async getDatasetRuns(e,t){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/datasets/${encodeURIComponent(e)}/runs?${C(t)}`,this._getFetchOptions({method:"GET"}))}async createDatasetRunItem(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/dataset-run-items`,this._getFetchOptions({method:"POST",body:JSON.stringify(e)}))}async createDataset(e){const t=typeof e=="string"?{name:e}:e;return this.fetchAndLogErrors(`${this.baseUrl}/api/public/datasets`,this._getFetchOptions({method:"POST",body:JSON.stringify(t)}))}async createDatasetItem(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/dataset-items`,this._getFetchOptions({method:"POST",body:JSON.stringify(e)}))}async getDatasetItem(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/dataset-items/${e}`,this._getFetchOptions({method:"GET"}))}_parsePayload(e){try{return JSON.parse(e)}catch{return e}}async createPromptStateless(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/v2/prompts`,this._getFetchOptions({method:"POST",body:JSON.stringify(e)}))}async updatePromptStateless(e){return this.fetchAndLogErrors(`${this.baseUrl}/api/public/v2/prompts/${encodeURIComponent(e.name)}/versions/${encodeURIComponent(e.version)}`,this._getFetchOptions({method:"PATCH",body:JSON.stringify(e)}))}async getPromptStateless(e,t,s,n,o){const a=encodeURIComponent(e),c=new URLSearchParams;if(t&&s)throw new Error("Provide either version or label, not both.");t&&c.append("version",t.toString()),s&&c.append("label",s);const i=`${this.baseUrl}/api/public/v2/prompts/${a}${c.size?"?"+c:""}`,u=this._getBoundedMaxRetries({maxRetries:n,defaultMaxRetries:2,maxRetriesUpperBound:4}),h={...this._retryOptions,retryCount:u,retryDelay:500};return F(async()=>{const p=await this.fetch(i,this._getFetchOptions({method:"GET",fetchTimeout:o??this.requestTimeout})).catch(y=>{throw y.name==="AbortError"?new M("Fetch request timed out"):new M(y)});if(p.status>=500)throw new U(p,await p.text());const m=await p.json();return{fetchResult:p.status===200?"success":"failure",data:m}},h,p=>this._events.emit("retry",p+", "+i+", "+JSON.stringify(h)))}_getBoundedMaxRetries(e){const t=Math.max(e.defaultMaxRetries??2,0),s=Math.max(e.maxRetriesUpperBound??4,0);return e.maxRetries===void 0?t:Math.min(Math.max(e.maxRetries,0),s)}enqueue(e,t){if(!this.enabled)return;const s=this.parseTraceId(e,t);if(!s)this._events.emit("warning","Failed to parse traceID for sampling. Please open a Github issue in https://github.com/langfuse/langfuse/issues/new/choose");else if(!Ie(s,this.sampleRate)){this._events.emit("debug",`Event with trace ID ${s} is out of sample. Skipping.`);return}const n=this.processEnqueueEvent(e,t),o=w();this.pendingEventProcessingPromises[o]=n,n.catch(a=>{this._events.emit("error",a)}).finally(()=>{delete this.pendingEventProcessingPromises[o]})}async processEnqueueEvent(e,t){this.maskEventBodyInPlace(t),await this.processMediaInEvent(e,t);const s=this.truncateEventBody(t,z);try{JSON.stringify(s)}catch(o){this._events.emit("error",`Event Body for ${e} is not JSON-serializable: ${o}`);return}const n=this.getPersistedProperty(I.Queue)||[];n.push({id:w(),type:e,timestamp:se(),body:s,metadata:void 0}),this.setPersistedProperty(I.Queue,n),this._events.emit(e,s),n.length>=this.flushAt&&this.flush(),this.flushInterval&&!this._flushTimer&&(this._flushTimer=re(()=>this.flush(),this.flushInterval))}maskEventBodyInPlace(e){if(!this.mask)return;const t=["input","output"];for(const s of t)if(s in e)try{e[s]=this.mask({data:e[s]})}catch(n){this._events.emit("error",`Error masking ${s}: ${n}`),e[s]="<fully masked due to failed mask function>"}}truncateEventBody(e,t){const s=this.getByteSize(e);if(s<=t)return e;this._events.emit("warning",`Event Body is too large (${s} bytes) and will be truncated`);const o=["input","output","metadata"].map(i=>({key:i,size:i in e?this.getByteSize(e[i]):0})).sort((i,u)=>u.size-i.size);let a={...e},c=s;for(const{key:i,size:u}of o)c>t&&Object.prototype.hasOwnProperty.call(a,i)&&(a={...a,[i]:"<truncated due to size exceeding limit>"},this._events.emit("warning",`Truncated ${i} due to total size exceeding limit`),c-=u);return a}getByteSize(e){const t=JSON.stringify(e);return typeof TextEncoder<"u"?new TextEncoder().encode(t).length:encodeURIComponent(t).replace(/%[A-F\d]{2}/g,"U").length}async processMediaInEvent(e,t){if(!t)return;const s=this.parseTraceId(e,t);if(!s){this._events.emit("warning","traceId is required for media upload");return}const n=(e.includes("generation")||e.includes("span"))&&t.id?t.id:void 0;await Promise.all(["input","output","metadata"].map(async o=>{t[o]&&(t[o]=await this.findAndProcessMedia({data:t[o],traceId:s,observationId:n,field:o}).catch(a=>{this._events.emit("error",`Error processing multimodal event: ${a}`)})??t[o])}))}parseTraceId(e,t){return"traceId"in t?t.traceId:e.includes("trace")?t.id:void 0}async findAndProcessMedia({data:e,traceId:t,observationId:s,field:n}){const o=new WeakMap,a=10,c=async(i,u)=>{if(typeof i=="string"&&i.startsWith("data:")){const h=new v({base64DataUri:i});return await this.processMediaItem({media:h,traceId:t,observationId:s,field:n}),h}if(typeof i!="object"||i===null||o.has(i)||u>a)return i;if(o.set(i,!0),i instanceof v||Object.prototype.toString.call(i)==="[object LangfuseMedia]")return await this.processMediaItem({media:i,traceId:t,observationId:s,field:n}),i;if(Array.isArray(i))return await Promise.all(i.map(h=>c(h,u+1)));if(typeof i=="object"&&i!==null){if("input_audio"in i&&typeof i.input_audio=="object"&&"data"in i.input_audio){const h=new v({base64DataUri:`data:audio/${i.input_audio.format||"wav"};base64,${i.input_audio.data}`});return await this.processMediaItem({media:h,traceId:t,observationId:s,field:n}),{...i,input_audio:{...i.input_audio,data:h}}}if("audio"in i&&typeof i.audio=="object"&&"data"in i.audio){const h=new v({base64DataUri:`data:audio/${i.audio.format||"wav"};base64,${i.audio.data}`});return await this.processMediaItem({media:h,traceId:t,observationId:s,field:n}),{...i,audio:{...i.audio,data:h}}}return Object.fromEntries(await Promise.all(Object.entries(i).map(async([h,l])=>[h,await c(l,u+1)])))}return i};return await c(e,1)}async processMediaItem({media:e,traceId:t,observationId:s,field:n}){try{if(!e.contentLength||!e._contentType||!e.contentSha256Hash||!e._contentBytes)return;const o={contentLength:e.contentLength,traceId:t,observationId:s,field:n,contentType:e._contentType,sha256Hash:e.contentSha256Hash},c=await(await this.fetch(`${this.baseUrl}/api/public/media`,this._getFetchOptions({method:"POST",body:JSON.stringify(o)}))).json(),{uploadUrl:i,mediaId:u}=c;if(e._mediaId=u,i){this._events.emit("debug",`Uploading media ${u}`);const h=Date.now(),l=await this.uploadMediaWithBackoff({uploadUrl:i,contentBytes:e._contentBytes,contentType:e._contentType,contentSha256Hash:e.contentSha256Hash,maxRetries:3,baseDelay:1e3});if(!l)throw Error("Media upload process failed");const p={uploadedAt:new Date().toISOString(),uploadHttpStatus:l.status,uploadHttpError:await l.text(),uploadTimeMs:Date.now()-h};await this.fetch(`${this.baseUrl}/api/public/media/${u}`,this._getFetchOptions({method:"PATCH",body:JSON.stringify(p)})),this._events.emit("debug",`Media upload status reported for ${u}`)}else this._events.emit("debug",`Media ${u} already uploaded`)}catch(o){this._events.emit("error",`Error processing media item: ${o}`)}}async uploadMediaWithBackoff(e){const{uploadUrl:t,contentType:s,contentSha256Hash:n,contentBytes:o,maxRetries:a,baseDelay:c}=e;for(let i=0;i<=a;i++)try{const u=await this.fetch(t,{method:"PUT",body:o,headers:{"Content-Type":s,"x-amz-checksum-sha256":n,"x-ms-blob-type":"BlockBlob"}});if(i<a&&u.status!==200&&u.status!==201)throw new Error(`Upload failed with status ${u.status}`);return u}catch(u){if(i===a)throw u;const h=c*Math.pow(2,i),l=Math.random()*1e3;await new Promise(p=>setTimeout(p,h+l))}}async flushAsync(){return await Promise.all(Object.values(this.pendingEventProcessingPromises)).catch(e=>{G(e)}),new Promise((e,t)=>{try{this.flush((s,n)=>{s?(G(s),e()):e(n)})}catch(s){console.error("[Langfuse SDK] Error while flushing Langfuse",s)}})}flush(e){this._flushTimer&&(clearTimeout(this._flushTimer),this._flushTimer=null);const t=this.getPersistedProperty(I.Queue)||[];if(!t.length)return e?.();const s=t.splice(0,this.flushAt),{processedItems:n,remainingItems:o}=this.processQueueItems(s,z,Le);this.setPersistedProperty(I.Queue,[...o,...t]);const a=w(),c=p=>{p&&this._events.emit("warning",p),e?.(p,s),this._events.emit("flush",s)};if(this.isLocalEventExportEnabled&&this.projectId){this.localEventExportMap.has(this.projectId)?this.localEventExportMap.get(this.projectId)?.push(...s):this.localEventExportMap.set(this.projectId,[...s]),c();return}const i=JSON.stringify({batch:n,metadata:{batch_size:n.length,sdk_integration:this.sdkIntegration,sdk_version:this.getLibraryVersion(),sdk_variant:this.getLibraryId(),public_key:this.publicKey,sdk_name:"langfuse-js"}}),u=`${this.baseUrl}/api/public/ingestion`,h=this._getFetchOptions({method:"POST",body:i}),l=this.fetchWithRetry(u,h).then(()=>c()).catch(p=>{c(p)});this.pendingIngestionPromises[a]=l,l.finally(()=>{delete this.pendingIngestionPromises[a]})}processQueueItems(e,t,s){let n=0;const o=[],a=[];for(let c=0;c<e.length;c++)try{const i=new Blob([JSON.stringify(e[c])]).size;if(i>t){console.warn(`Item exceeds size limit (size: ${i}), dropping item.`);continue}if(n+i>=s){console.debug(`hit batch size limit (size: ${n+i})`),a.push(...e.slice(c)),console.log(`Remaining items: ${a.length}`),console.log(`processes items: ${o.length}`);break}n+=i,o.push(e[c])}catch(i){this._events.emit("error",i),a.push(...e.slice(c));break}return{processedItems:o,remainingItems:a}}_getFetchOptions(e){return{method:e.method,headers:{"Content-Type":"application/json","X-Langfuse-Sdk-Name":"langfuse-js","X-Langfuse-Sdk-Version":this.getLibraryVersion(),"X-Langfuse-Sdk-Variant":this.getLibraryId(),"X-Langfuse-Sdk-Integration":this.sdkIntegration,"X-Langfuse-Public-Key":this.publicKey,...this.additionalHeaders,...this.constructAuthorizationHeader(this.publicKey,this.secretKey)},body:e.body,...e.fetchTimeout!==void 0?{signal:AbortSignal.timeout(e.fetchTimeout)}:{}}}constructAuthorizationHeader(e,t){return t===void 0?{Authorization:"Bearer "+e}:{Authorization:"Basic "+(typeof btoa=="function"?btoa(e+":"+t):Buffer.from(e+":"+t).toString("base64"))}}async fetchWithRetry(e,t,s){return AbortSignal.timeout??=function(o){const a=new AbortController;return setTimeout(()=>a.abort(),o),a.signal},await F(async()=>{let n=null;try{n=await this.fetch(e,{signal:AbortSignal.timeout(this.requestTimeout),...t})}catch(a){throw new M(a)}if(n.status<200||n.status>=400){const a=await n.json();throw new U(n,JSON.stringify(a))}const o=await n.json();if(n.status===207&&o.errors.length>0)throw new U(n,JSON.stringify(o.errors));return n},{...this._retryOptions,...s},n=>this._events.emit("retry",n+", "+e+", "+JSON.stringify(t)))}async fetchAndLogErrors(e,t){const s=await this.fetch(e,t),n=s.status===429?await s.text():await s.json();return(s.status<200||s.status>=400)&&G(new U(s,JSON.stringify(n))),n}async shutdownAsync(){clearTimeout(this._flushTimer);try{await this.flushAsync(),await Promise.all(Object.values(this.pendingIngestionPromises).map(e=>e.catch(()=>{}))),await this.flushAsync()}catch(e){console.error("[Langfuse SDK] Error while shutting down Langfuse",e)}}async _exportLocalEvents(e){if(this.isLocalEventExportEnabled){clearTimeout(this._flushTimer),await this.flushAsync();const t=this.localEventExportMap.get(e)??[];return this.localEventExportMap.delete(e),t}else return this._events.emit("error","Local event exports are disabled, but _exportLocalEvents() was called."),[]}shutdown(){console.warn("shutdown() is deprecated. It does not wait for all events to be processed. Please use shutdownAsync() instead."),this.shutdownAsync()}async awaitAllQueuedAndPendingRequests(){clearTimeout(this._flushTimer),await this.flushAsync(),await Promise.all(Object.values(this.pendingIngestionPromises))}}class qe extends ie{constructor(e){const{flushAt:t,flushInterval:s,publicKey:n,enabled:o,...a}=e;let c=o!==!1;c&&!n&&(c=!1,console.warn("Langfuse public key not passed to constructor and not set as 'LANGFUSE_PUBLIC_KEY' environment variable. No observability data will be sent to Langfuse.")),super({...a,publicKey:n,flushAt:t??1,flushInterval:s??0,enabled:c})}async score(e){return this.scoreStateless(e),await this.awaitAllQueuedAndPendingRequests(),this}}class ke extends ie{constructor(e){const{publicKey:t,secretKey:s,enabled:n,_isLocalEventExportEnabled:o}=e;let a=n!==!1;o?a=!0:s?t||(a=!1,n!==!1&&console.warn("Langfuse public key was not passed to constructor or not set as 'LANGFUSE_PUBLIC_KEY' environment variable. No observability data will be sent to Langfuse.")):(a=!1,n!==!1&&console.warn("Langfuse secret key was not passed to constructor or not set as 'LANGFUSE_SECRET_KEY' environment variable. No observability data will be sent to Langfuse.")),super({...e,enabled:a}),this._promptCache=new _e}trace(e){const t=this.traceStateless(e??{}),s=new Me(this,t);if(g("DEFER")&&e)try{const n=g("__deferRuntime");n&&n.langfuseTraces([{id:t,name:e.name||"",url:s.getTraceUrl()}])}catch{}return s}span(e){const t=e.traceId||this.traceStateless({name:e.name}),s=this.spanStateless({...e,traceId:t});return new Ge(this,s,t)}generation(e){const t=e.traceId||this.traceStateless({name:e.name}),s=this.generationStateless({...e,traceId:t});return new Ne(this,s,t)}event(e){const t=e.traceId||this.traceStateless({name:e.name}),s=this.eventStateless({...e,traceId:t});return new Fe(this,s,t)}score(e){return this.scoreStateless(e),this}async getDataset(e,t){const s=await this._getDataset(e),n=[];let o=1;for(;;){const c=await this._getDatasetItems({datasetName:e,limit:t?.fetchItemsPageSize??50,page:o});if(n.push(...c.data),c.meta.totalPages<=o)break;o++}return{...s,description:s.description??void 0,metadata:s.metadata??void 0,items:n.map(c=>({...c,link:async(i,u,h)=>(await this.awaitAllQueuedAndPendingRequests(),await this.createDatasetRunItem({runName:u,datasetItemId:c.id,observationId:i.observationId,traceId:i.traceId,runDescription:h?.description,metadata:h?.metadata}))}))}}async createPrompt(e){const t=e.labels??[],s=e.type==="chat"?await this.createPromptStateless({...e,prompt:e.prompt.map(n=>"type"in n&&n.type===b.Placeholder?{type:b.Placeholder,name:n.name}:{type:b.ChatMessage,...n}),labels:e.isActive?[...new Set([...t,"production"])]:t}):await this.createPromptStateless({...e,type:e.type??"text",labels:e.isActive?[...new Set([...t,"production"])]:t});return s.type==="chat"?new O(s):new k(s)}async updatePrompt(e){const t=await this.updatePromptStateless(e);return this._promptCache.invalidate(e.name),t}async getPrompt(e,t,s){const n=this._getPromptCacheKey({name:e,version:t,label:s?.label}),o=this._promptCache.getIncludingExpired(n);if(!o||s?.cacheTtlSeconds===0)try{return await this._fetchPromptAndUpdateCache({name:e,version:t,label:s?.label,cacheTtlSeconds:s?.cacheTtlSeconds,maxRetries:s?.maxRetries,fetchTimeout:s?.fetchTimeoutMs})}catch(a){if(s?.fallback){const c={name:e,version:t??0,labels:s.label?[s.label]:[],cacheTtlSeconds:s?.cacheTtlSeconds,config:{},tags:[]};return s.type==="chat"?new O({...c,type:"chat",prompt:s.fallback.map(i=>({type:b.ChatMessage,...i}))},!0):new k({...c,type:"text",prompt:s.fallback},!0)}throw a}if(o.isExpired){if(!this._promptCache.isRefreshing(n)){const a=this._fetchPromptAndUpdateCache({name:e,version:t,label:s?.label,cacheTtlSeconds:s?.cacheTtlSeconds,maxRetries:s?.maxRetries,fetchTimeout:s?.fetchTimeoutMs}).catch(()=>{console.warn(`Failed to refresh prompt cache '${n}', stale cache will be used until next refresh succeeds.`)});this._promptCache.addRefreshingPromise(n,a)}return o.value}return o.value}_getPromptCacheKey(e){const{name:t,version:s,label:n}=e,o=[t];return s!==void 0?o.push("version:"+s.toString()):n!==void 0?o.push("label:"+n):o.push("label:production"),o.join("-")}async _fetchPromptAndUpdateCache(e){const t=this._getPromptCacheKey(e);try{const{name:s,version:n,cacheTtlSeconds:o,label:a,maxRetries:c,fetchTimeout:i}=e,{data:u,fetchResult:h}=await this.getPromptStateless(s,n,a,c,i);if(h==="failure")throw Error(u.message??"Internal error while fetching prompt");let l;return u.type==="chat"?l=new O(u):l=new k(u),this._promptCache.set(t,l,o),l}catch(s){throw console.error(`[Langfuse SDK] Error while fetching prompt '${t}':`,s),s}}async fetchMedia(e){return await this._fetchMedia(e)}async resolveMediaReferences(e){const{obj:t,...s}=e;return v.resolveMediaReferences({...s,langfuseClient:this,obj:t})}_updateSpan(e){return this.updateSpanStateless(e),this}_updateGeneration(e){return this.updateGenerationStateless(e),this}}class ce{constructor({client:e,id:t,traceId:s,observationId:n}){this.client=e,this.id=t,this.traceId=s,this.observationId=n}event(e){return this.client.event({...e,traceId:this.traceId,parentObservationId:this.observationId})}span(e){return this.client.span({...e,traceId:this.traceId,parentObservationId:this.observationId})}generation(e){return this.client.generation({...e,traceId:this.traceId,parentObservationId:this.observationId})}score(e){return this.client.score({...e,traceId:this.traceId,observationId:this.observationId}),this}getTraceUrl(){return`${this.client.baseUrl}/trace/${this.traceId}`}}class Me extends ce{constructor(e,t){super({client:e,id:t,traceId:t,observationId:null})}update(e){return this.client.trace({...e,id:this.id}),this}}class K extends ce{constructor(e,t,s){super({client:e,id:t,traceId:s,observationId:t})}}class Ge extends K{constructor(e,t,s){super(e,t,s)}update(e){return this.client._updateSpan({...e,id:this.id,traceId:this.traceId}),this}end(e){return this.client._updateSpan({...e,id:this.id,traceId:this.traceId,endTime:new Date}),this}}class Ne extends K{constructor(e,t,s){super(e,t,s)}update(e){return this.client._updateGeneration({...e,id:this.id,traceId:this.traceId}),this}end(e){return this.client._updateGeneration({...e,id:this.id,traceId:this.traceId,endTime:new Date}),this}}class Fe extends K{constructor(e,t,s){super(e,t,s)}}const ue={getItem(r){try{const e=r+"=",t=document.cookie.split(";");for(let s=0;s<t.length;s++){let n=t[s];for(;n.charAt(0)==" ";)n=n.substring(1,n.length);if(n.indexOf(e)===0)return decodeURIComponent(n.substring(e.length,n.length))}}catch{}return null},setItem(r,e){try{const o=r+"="+encodeURIComponent(e)+"; path=/";document.cookie=o}catch{return}},removeItem(r){try{ue.setItem(r,"")}catch{return}},clear(){document.cookie=""},getAllKeys(){const r=document.cookie.split(";"),e=[];for(let t=0;t<r.length;t++){let s=r[t];for(;s.charAt(0)==" ";)s=s.substring(1,s.length);e.push(s.split("=")[0])}return e}},W=r=>({getItem(e){return r.getItem(e)},setItem(e,t){r.setItem(e,t)},removeItem(e){r.removeItem(e)},clear(){r.clear()},getAllKeys(){const e=[];for(const t in localStorage)e.push(t);return e}}),X=(r,e="__mplssupport__")=>{if(!window)return!1;try{return r.setItem(e,"xyz"),r.getItem(e)!=="xyz"?!1:(r.removeItem(e),!0)}catch{return!1}};let N,L;const A=()=>{const r={};return{getItem(t){return r[t]},setItem(t,s){r[t]=s!==null?s:void 0},removeItem(t){delete r[t]},clear(){for(const t in r)delete r[t]},getAllKeys(){const t=[];for(const s in r)t.push(s);return t}}},q=(r,e)=>{if(typeof e!==void 0&&e){if(!localStorage){const t=W(e.localStorage);N=X(t)?t:void 0}if(!L){const t=W(e.sessionStorage);L=X(t)?t:void 0}}switch(r){case"cookie":return ue||N||L||A();case"localStorage":return N||L||A();case"sessionStorage":return L||A();case"memory":return A();default:return A()}};var d;(function(r){r.Json="application/json",r.FormData="multipart/form-data",r.UrlEncoded="application/x-www-form-urlencoded",r.Text="text/plain"})(d||(d={}));class Be{constructor(e={}){this.baseUrl="",this.securityData=null,this.abortControllers=new Map,this.customFetch=(...t)=>fetch(...t),this.baseApiParams={credentials:"same-origin",headers:{},redirect:"follow",referrerPolicy:"no-referrer"},this.setSecurityData=t=>{this.securityData=t},this.contentFormatters={[d.Json]:t=>t!==null&&(typeof t=="object"||typeof t=="string")?JSON.stringify(t):t,[d.Text]:t=>t!==null&&typeof t!="string"?JSON.stringify(t):t,[d.FormData]:t=>Object.keys(t||{}).reduce((s,n)=>{const o=t[n];return s.append(n,o instanceof Blob?o:typeof o=="object"&&o!==null?JSON.stringify(o):`${o}`),s},new FormData),[d.UrlEncoded]:t=>this.toQueryString(t)},this.createAbortSignal=t=>{if(this.abortControllers.has(t)){const n=this.abortControllers.get(t);return n?n.signal:void 0}const s=new AbortController;return this.abortControllers.set(t,s),s.signal},this.abortRequest=t=>{const s=this.abortControllers.get(t);s&&(s.abort(),this.abortControllers.delete(t))},this.request=async({body:t,secure:s,path:n,type:o,query:a,format:c,baseUrl:i,cancelToken:u,...h})=>{const l=(typeof s=="boolean"?s:this.baseApiParams.secure)&&this.securityWorker&&await this.securityWorker(this.securityData)||{},p=this.mergeRequestParams(h,l),m=a&&this.toQueryString(a),y=this.contentFormatters[o||d.Json],_=c||p.format;return this.customFetch(`${i||this.baseUrl||""}${n}${m?`?${m}`:""}`,{...p,headers:{...p.headers||{},...o&&o!==d.FormData?{"Content-Type":o}:{}},signal:(u?this.createAbortSignal(u):p.signal)||null,body:typeof t>"u"||t===null?null:y(t)}).then(async E=>{const f=E.clone();f.data=null,f.error=null;const R=_?await E[_]().then(T=>(f.ok?f.data=T:f.error=T,f)).catch(T=>(f.error=T,f)):f;if(u&&this.abortControllers.delete(u),!E.ok)throw R;return R.data})},Object.assign(this,e)}encodeQueryParam(e,t){return`${encodeURIComponent(e)}=${encodeURIComponent(typeof t=="number"?t:`${t}`)}`}addQueryParam(e,t){return this.encodeQueryParam(t,e[t])}addArrayQueryParam(e,t){return e[t].map(n=>this.encodeQueryParam(t,n)).join("&")}toQueryString(e){const t=e||{};return Object.keys(t).filter(n=>typeof t[n]<"u").map(n=>Array.isArray(t[n])?this.addArrayQueryParam(t,n):this.addQueryParam(t,n)).join("&")}addQueryParams(e){const t=this.toQueryString(e);return t?`?${t}`:""}mergeRequestParams(e,t){return{...this.baseApiParams,...e,...t||{},headers:{...this.baseApiParams.headers||{},...e.headers||{},...t&&t.headers||{}}}}}class Ke extends Be{constructor(){super(...arguments),this.api={annotationQueuesCreateQueueItem:(e,t,s={})=>this.request({path:`/api/public/annotation-queues/${e}/items`,method:"POST",body:t,secure:!0,type:d.Json,format:"json",...s}),annotationQueuesDeleteQueueItem:(e,t,s={})=>this.request({path:`/api/public/annotation-queues/${e}/items/${t}`,method:"DELETE",secure:!0,format:"json",...s}),annotationQueuesGetQueue:(e,t={})=>this.request({path:`/api/public/annotation-queues/${e}`,method:"GET",secure:!0,format:"json",...t}),annotationQueuesGetQueueItem:(e,t,s={})=>this.request({path:`/api/public/annotation-queues/${e}/items/${t}`,method:"GET",secure:!0,format:"json",...s}),annotationQueuesListQueueItems:({queueId:e,...t},s={})=>this.request({path:`/api/public/annotation-queues/${e}/items`,method:"GET",query:t,secure:!0,format:"json",...s}),annotationQueuesListQueues:(e,t={})=>this.request({path:"/api/public/annotation-queues",method:"GET",query:e,secure:!0,format:"json",...t}),annotationQueuesUpdateQueueItem:(e,t,s,n={})=>this.request({path:`/api/public/annotation-queues/${e}/items/${t}`,method:"PATCH",body:s,secure:!0,type:d.Json,format:"json",...n}),commentsCreate:(e,t={})=>this.request({path:"/api/public/comments",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),commentsGet:(e,t={})=>this.request({path:"/api/public/comments",method:"GET",query:e,secure:!0,format:"json",...t}),commentsGetById:(e,t={})=>this.request({path:`/api/public/comments/${e}`,method:"GET",secure:!0,format:"json",...t}),datasetItemsCreate:(e,t={})=>this.request({path:"/api/public/dataset-items",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),datasetItemsDelete:(e,t={})=>this.request({path:`/api/public/dataset-items/${e}`,method:"DELETE",secure:!0,format:"json",...t}),datasetItemsGet:(e,t={})=>this.request({path:`/api/public/dataset-items/${e}`,method:"GET",secure:!0,format:"json",...t}),datasetItemsList:(e,t={})=>this.request({path:"/api/public/dataset-items",method:"GET",query:e,secure:!0,format:"json",...t}),datasetRunItemsCreate:(e,t={})=>this.request({path:"/api/public/dataset-run-items",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),datasetRunItemsList:(e,t={})=>this.request({path:"/api/public/dataset-run-items",method:"GET",query:e,secure:!0,...t}),datasetsCreate:(e,t={})=>this.request({path:"/api/public/v2/datasets",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),datasetsDeleteRun:(e,t,s={})=>this.request({path:`/api/public/datasets/${e}/runs/${t}`,method:"DELETE",secure:!0,format:"json",...s}),datasetsGet:(e,t={})=>this.request({path:`/api/public/v2/datasets/${e}`,method:"GET",secure:!0,format:"json",...t}),datasetsGetRun:(e,t,s={})=>this.request({path:`/api/public/datasets/${e}/runs/${t}`,method:"GET",secure:!0,format:"json",...s}),datasetsGetRuns:({datasetName:e,...t},s={})=>this.request({path:`/api/public/datasets/${e}/runs`,method:"GET",query:t,secure:!0,format:"json",...s}),datasetsList:(e,t={})=>this.request({path:"/api/public/v2/datasets",method:"GET",query:e,secure:!0,format:"json",...t}),healthHealth:(e={})=>this.request({path:"/api/public/health",method:"GET",format:"json",...e}),ingestionBatch:(e,t={})=>this.request({path:"/api/public/ingestion",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),mediaGet:(e,t={})=>this.request({path:`/api/public/media/${e}`,method:"GET",secure:!0,format:"json",...t}),mediaGetUploadUrl:(e,t={})=>this.request({path:"/api/public/media",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),mediaPatch:(e,t,s={})=>this.request({path:`/api/public/media/${e}`,method:"PATCH",body:t,secure:!0,type:d.Json,...s}),metricsMetrics:(e,t={})=>this.request({path:"/api/public/metrics",method:"GET",query:e,secure:!0,format:"json",...t}),modelsCreate:(e,t={})=>this.request({path:"/api/public/models",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),modelsDelete:(e,t={})=>this.request({path:`/api/public/models/${e}`,method:"DELETE",secure:!0,...t}),modelsGet:(e,t={})=>this.request({path:`/api/public/models/${e}`,method:"GET",secure:!0,format:"json",...t}),modelsList:(e,t={})=>this.request({path:"/api/public/models",method:"GET",query:e,secure:!0,format:"json",...t}),observationsGet:(e,t={})=>this.request({path:`/api/public/observations/${e}`,method:"GET",secure:!0,format:"json",...t}),observationsGetMany:(e,t={})=>this.request({path:"/api/public/observations",method:"GET",query:e,secure:!0,format:"json",...t}),organizationsGetOrganizationMemberships:(e={})=>this.request({path:"/api/public/organizations/memberships",method:"GET",secure:!0,format:"json",...e}),organizationsGetOrganizationProjects:(e={})=>this.request({path:"/api/public/organizations/projects",method:"GET",secure:!0,format:"json",...e}),organizationsGetProjectMemberships:(e,t={})=>this.request({path:`/api/public/projects/${e}/memberships`,method:"GET",secure:!0,format:"json",...t}),organizationsUpdateOrganizationMembership:(e,t={})=>this.request({path:"/api/public/organizations/memberships",method:"PUT",body:e,secure:!0,type:d.Json,format:"json",...t}),organizationsUpdateProjectMembership:(e,t,s={})=>this.request({path:`/api/public/projects/${e}/memberships`,method:"PUT",body:t,secure:!0,type:d.Json,format:"json",...s}),projectsCreate:(e,t={})=>this.request({path:"/api/public/projects",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),projectsCreateApiKey:(e,t,s={})=>this.request({path:`/api/public/projects/${e}/apiKeys`,method:"POST",body:t,secure:!0,type:d.Json,format:"json",...s}),projectsDelete:(e,t={})=>this.request({path:`/api/public/projects/${e}`,method:"DELETE",secure:!0,format:"json",...t}),projectsDeleteApiKey:(e,t,s={})=>this.request({path:`/api/public/projects/${e}/apiKeys/${t}`,method:"DELETE",secure:!0,format:"json",...s}),projectsGet:(e={})=>this.request({path:"/api/public/projects",method:"GET",secure:!0,format:"json",...e}),projectsGetApiKeys:(e,t={})=>this.request({path:`/api/public/projects/${e}/apiKeys`,method:"GET",secure:!0,format:"json",...t}),projectsUpdate:(e,t,s={})=>this.request({path:`/api/public/projects/${e}`,method:"PUT",body:t,secure:!0,type:d.Json,format:"json",...s}),promptsCreate:(e,t={})=>this.request({path:"/api/public/v2/prompts",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),promptsGet:({promptName:e,...t},s={})=>this.request({path:`/api/public/v2/prompts/${e}`,method:"GET",query:t,secure:!0,format:"json",...s}),promptsList:(e,t={})=>this.request({path:"/api/public/v2/prompts",method:"GET",query:e,secure:!0,format:"json",...t}),promptVersionUpdate:(e,t,s,n={})=>this.request({path:`/api/public/v2/prompts/${e}/versions/${t}`,method:"PATCH",body:s,secure:!0,type:d.Json,format:"json",...n}),scimCreateUser:(e,t={})=>this.request({path:"/api/public/scim/Users",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),scimDeleteUser:(e,t={})=>this.request({path:`/api/public/scim/Users/${e}`,method:"DELETE",secure:!0,format:"json",...t}),scimGetResourceTypes:(e={})=>this.request({path:"/api/public/scim/ResourceTypes",method:"GET",secure:!0,format:"json",...e}),scimGetSchemas:(e={})=>this.request({path:"/api/public/scim/Schemas",method:"GET",secure:!0,format:"json",...e}),scimGetServiceProviderConfig:(e={})=>this.request({path:"/api/public/scim/ServiceProviderConfig",method:"GET",secure:!0,format:"json",...e}),scimGetUser:(e,t={})=>this.request({path:`/api/public/scim/Users/${e}`,method:"GET",secure:!0,format:"json",...t}),scimListUsers:(e,t={})=>this.request({path:"/api/public/scim/Users",method:"GET",query:e,secure:!0,format:"json",...t}),scoreConfigsCreate:(e,t={})=>this.request({path:"/api/public/score-configs",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),scoreConfigsGet:(e,t={})=>this.request({path:"/api/public/score-configs",method:"GET",query:e,secure:!0,format:"json",...t}),scoreConfigsGetById:(e,t={})=>this.request({path:`/api/public/score-configs/${e}`,method:"GET",secure:!0,format:"json",...t}),scoreCreate:(e,t={})=>this.request({path:"/api/public/scores",method:"POST",body:e,secure:!0,type:d.Json,format:"json",...t}),scoreDelete:(e,t={})=>this.request({path:`/api/public/scores/${e}`,method:"DELETE",secure:!0,...t}),scoreV2Get:(e,t={})=>this.request({path:"/api/public/v2/scores",method:"GET",query:e,secure:!0,format:"json",...t}),scoreV2GetById:(e,t={})=>this.request({path:`/api/public/v2/scores/${e}`,method:"GET",secure:!0,format:"json",...t}),sessionsGet:(e,t={})=>this.request({path:`/api/public/sessions/${e}`,method:"GET",secure:!0,format:"json",...t}),sessionsList:(e,t={})=>this.request({path:"/api/public/sessions",method:"GET",query:e,secure:!0,format:"json",...t}),traceDelete:(e,t={})=>this.request({path:`/api/public/traces/${e}`,method:"DELETE",secure:!0,format:"json",...t}),traceDeleteMultiple:(e,t={})=>this.request({path:"/api/public/traces",method:"DELETE",body:e,secure:!0,type:d.Json,format:"json",...t}),traceGet:(e,t={})=>this.request({path:`/api/public/traces/${e}`,method:"GET",secure:!0,format:"json",...t}),traceList:(e,t={})=>this.request({path:"/api/public/traces",method:"GET",query:e,secure:!0,format:"json",...t})}}}var le="3.38.5";class Je extends ke{constructor(e){const t=ne.configLangfuseSDK(e);super(t),typeof window<"u"&&!("Deno"in window)?(this._storageKey=e?.persistence_name?`lf_${e.persistence_name}`:`lf_${t.publicKey}_langfuse`,this._storage=q(e?.persistence||"localStorage",window)):(this._storageKey=`lf_${t.publicKey}_langfuse`,this._storage=q("memory",void 0)),this.api=new Ke({baseUrl:this.baseUrl,baseApiParams:{headers:{"X-Langfuse-Sdk-Name":"langfuse-js","X-Langfuse-Sdk-Version":this.getLibraryVersion(),"X-Langfuse-Sdk-Variant":this.getLibraryId(),"X-Langfuse-Sdk-Integration":this.sdkIntegration,"X-Langfuse-Public-Key":this.publicKey,...this.additionalHeaders,...this.constructAuthorizationHeader(this.publicKey,this.secretKey)}}}).api}getPersistedProperty(e){return this._storageCache||(this._storageCache=JSON.parse(this._storage.getItem(this._storageKey)||"{}")||{}),this._storageCache[e]}setPersistedProperty(e,t){this._storageCache||(this._storageCache=JSON.parse(this._storage.getItem(this._storageKey)||"{}")||{}),t===null?delete this._storageCache[e]:this._storageCache[e]=t,this._storage.setItem(this._storageKey,JSON.stringify(this._storageCache))}fetch(e,t){return fetch(e,t)}getLibraryId(){return"langfuse"}getLibraryVersion(){return le}getCustomUserAgent(){}}class nt extends qe{constructor(e){const t=ne.configLangfuseSDK(e,!1);super(t),typeof window<"u"?(this._storageKey=e?.persistence_name?`lf_${e.persistence_name}`:`lf_${t.publicKey}_langfuse`,this._storage=q(e?.persistence||"localStorage",window)):(this._storageKey=`lf_${t.publicKey}_langfuse`,this._storage=q("memory",void 0))}getPersistedProperty(e){return this._storageCache||(this._storageCache=JSON.parse(this._storage.getItem(this._storageKey)||"{}")||{}),this._storageCache[e]}setPersistedProperty(e,t){this._storageCache||(this._storageCache=JSON.parse(this._storage.getItem(this._storageKey)||"{}")||{}),t===null?delete this._storageCache[e]:this._storageCache[e]=t,this._storage.setItem(this._storageKey,JSON.stringify(this._storageCache))}fetch(e,t){return fetch(e,t)}getLibraryId(){return"langfuse-frontend"}getLibraryVersion(){return le}getCustomUserAgent(){}}class S{static getInstance(e){return S.instance||(S.instance=new Je(e)),S.instance}}S.instance=null;const ze=r=>{let e={};e={frequency_penalty:r.frequency_penalty,logit_bias:r.logit_bias,logprobs:r.logprobs,max_tokens:r.max_tokens,n:r.n,presence_penalty:r.presence_penalty,seed:r.seed,stop:r.stop,stream:r.stream,temperature:r.temperature,top_p:r.top_p,user:r.user,response_format:r.response_format,top_logprobs:r.top_logprobs};let t=r.input;return r&&typeof r=="object"&&!Array.isArray(r)&&"messages"in r?(t={},t.messages=r.messages,"function_call"in r&&(t.function_call=r.function_call),"functions"in r&&(t.functions=r.functions),"tools"in r&&(t.tools=r.tools),"tool_choice"in r&&(t.tool_choice=r.tool_choice)):t||(t=r.prompt),{model:r.model,input:t,modelParameters:e}},he=r=>{if(r instanceof Object&&"output_text"in r&&r.output_text!=="")return r.output_text;if(typeof r=="object"&&r&&"output"in r&&Array.isArray(r.output)){const e=r.output;return e.length>1?e:e.length===1?e[0]:null}return r instanceof Object&&"choices"in r&&Array.isArray(r.choices)?"message"in r.choices[0]?r.choices[0].message:r.choices[0].text??"":""},He=r=>{if(me(r)){const{prompt_tokens:e,completion_tokens:t,total_tokens:s}=r.usage;return{input:e,output:t,total:s}}},pe=r=>{if("prompt_tokens"in r){const{prompt_tokens:e,completion_tokens:t,total_tokens:s,completion_tokens_details:n,prompt_tokens_details:o}=r;return{input:e,output:t,total:s,...Object.fromEntries(Object.entries(o??{}).map(([a,c])=>[`input_${a}`,c])),...Object.fromEntries(Object.entries(n??{}).map(([a,c])=>[`output_${a}`,c]))}}else if("input_tokens"in r){const{input_tokens:e,output_tokens:t,total_tokens:s,input_tokens_details:n,output_tokens_details:o}=r;return{input:e,output:t,total:s,...Object.fromEntries(Object.entries(n??{}).map(([a,c])=>[`input_${a}`,c])),...Object.fromEntries(Object.entries(o??{}).map(([a,c])=>[`output_${a}`,c]))}}},de=r=>{if(me(r))return pe(r.usage)},Qe=r=>{let e=!1;const s=r?.choices?.[0];try{if("delta"in s&&"tool_calls"in s.delta&&Array.isArray(s.delta.tool_calls))return e=!0,{isToolCall:e,data:s.delta.tool_calls[0]};if("delta"in s)return{isToolCall:e,data:s.delta?.content||""};if("text"in s)return{isToolCall:e,data:s.text||""}}catch{}return{isToolCall:!1,data:""}};function me(r){return r instanceof Object&&"usage"in r&&r.usage instanceof Object&&(typeof r.usage.prompt_tokens=="number"&&typeof r.usage.completion_tokens=="number"&&typeof r.usage.total_tokens=="number"||typeof r.usage.input_tokens=="number"&&typeof r.usage.output_tokens=="number"&&typeof r.usage.total_tokens=="number")}const Ve=r=>{let e="",t="";for(const s of r)e=s.function?.name||e,t+=s.function?.arguments||"";return{tool_calls:[{function:{name:e,arguments:t}}]}},fe=r=>{if(typeof r!="object"||r===null)return{model:void 0,modelParameters:void 0,metadata:void 0};const e="model"in r?r.model:void 0,t={},s=["max_output_tokens","parallel_tool_calls","store","temperature","tool_choice","top_p","truncation","user"],n={},o=["reasoning","incomplete_details","instructions","previous_response_id","tools","metadata","status","error"];for(const a of s){const c=a in r?r[a]:null;c!=null&&(t[a]=c)}for(const a of o){const c=a in r?r[a]:null;c&&(n[a]=c)}return{model:e,modelParameters:Object.keys(t).length>0?t:void 0,metadata:Object.keys(n).length>0?n:void 0}},Y=r=>r!=null&&typeof r=="object"&&typeof r[Symbol.asyncIterator]=="function",We=(r,e)=>(...t)=>Xe(r,e,...t),Xe=(r,e,...t)=>{const{model:s,input:n,modelParameters:o}=ze(t[0]??{}),a={...o,response_format:null},c={...e?.metadata,response_format:"response_format"in o?o.response_format:void 0};let i={model:s,input:n,modelParameters:a,name:e?.generationName,startTime:new Date,promptName:e?.langfusePrompt?.name,promptVersion:e?.langfusePrompt?.version,metadata:c},u;const h=e&&"parent"in e;h?(u=e.parent,i={...{...e,parent:void 0},...i,promptName:e?.promptName??e?.langfusePrompt?.name,promptVersion:e?.promptVersion??e?.langfusePrompt?.version}):u=S.getInstance(e?.clientInitParams).trace({...e,...i,id:e?.traceId,name:e?.traceName,timestamp:i.startTime});try{const l=r(...t);return Y(l)?Z(l,u,h,i):l instanceof Promise?l.then(m=>{if(Y(m))return Z(m,u,h,i);const y=he(m),_=He(m),E=de(m),{model:f,modelParameters:R,metadata:T}=fe(m);return u.generation({...i,output:y,endTime:new Date,usage:_,usageDetails:E,model:f||i.model,modelParameters:{...i.modelParameters,...R},metadata:{...i.metadata,...T}}),h||u.update({output:y}),m}).catch(m=>{throw u.generation({...i,endTime:new Date,statusMessage:String(m),level:"ERROR",usage:{inputCost:0,outputCost:0,totalCost:0},costDetails:{input:0,output:0,total:0}}),m}):l}catch(l){throw u.generation({...i,endTime:new Date,statusMessage:String(l),level:"ERROR",usage:{inputCost:0,outputCost:0,totalCost:0},costDetails:{input:0,output:0,total:0}}),l}};function Z(r,e,t,s){async function*n(){const o=r,a=[],c=[];let i=null,u=null,h,l=null;for await(const p of o){if(i=i??new Date,typeof p=="object"&&p&&"response"in p){const y=p.response;l=he(y),h=de(y);const{model:_,modelParameters:E,metadata:f}=fe(y);s.model=_??s.model,s.modelParameters={...s.modelParameters,...E},s.metadata={...s.metadata,...f}}typeof p=="object"&&p!=null&&"usage"in p&&(u=p.usage);const m=Qe(p);m.isToolCall?c.push(m.data):a.push(m.data),yield p}l=l??(c.length>0?Ve(c):a.join("")),e.generation({...s,output:l,endTime:new Date,completionStartTime:i,usage:u?{input:"prompt_tokens"in u?u.prompt_tokens:void 0,output:"completion_tokens"in u?u.completion_tokens:void 0,total:"total_tokens"in u?u.total_tokens:void 0}:void 0,usageDetails:h??(u?pe(u):void 0)}),t||e.update({output:l})}return n()}const Ye=(r,e)=>new Proxy(r,{get(t,s,n){const o=t[s],a=`${r.constructor?.name}.${s.toString()}`,c=e?.generationName??a,i=e&&"traceName"in e?e.traceName:c,u={...e,generationName:c,traceName:i};if(s==="flushAsync"){let l;return e&&"parent"in e?l=e.parent.client:l=S.getInstance(),l.flushAsync.bind(l)}if(s==="shutdownAsync"){let l;return e&&"parent"in e?l=e.parent.client:l=S.getInstance(),l.shutdownAsync.bind(l)}return typeof o=="function"?We(o.bind(t),u):o&&!Array.isArray(o)&&!(o instanceof Date)&&typeof o=="object"?Ye(o,u):Reflect.get(t,s,n)}});export{Je as Langfuse,v as LangfuseMedia,nt as LangfuseWeb,Je as default,Ye as observeOpenAI};
@@ -0,0 +1,25 @@
1
+ import{r as An,O as mt,s as En,k as zt,H as gt,n as Pn,o as On,q as Vt,f as v,A as _t,u as Cn,v as jn,m as Nn,l as In,t as ye,d as yt,C as $n,R as wt,w as Bn}from"./types-CmQi9glY.js";import"./zodToJsonSchema-DueTETVe.js";import"./index-DvNb1_yp.js";function u(n,e,t,s,r){if(typeof e=="function"?n!==e||!0:!e.has(n))throw new TypeError("Cannot write private member to an object whose class did not declare it");return e.set(n,t),t}function o(n,e,t,s){if(t==="a"&&!s)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?n!==e||!s:!e.has(n))throw new TypeError("Cannot read private member from an object whose class did not declare it");return t==="m"?s:t==="a"?s.call(n):s?s.value:e.get(n)}let Qt=function(){const{crypto:n}=globalThis;if(n?.randomUUID)return Qt=n.randomUUID.bind(n),n.randomUUID();const e=new Uint8Array(1),t=n?()=>n.getRandomValues(e)[0]:()=>Math.random()*255&255;return"10000000-1000-4000-8000-100000000000".replace(/[018]/g,s=>(+s^t()&15>>+s/4).toString(16))};function de(n){return typeof n=="object"&&n!==null&&("name"in n&&n.name==="AbortError"||"message"in n&&String(n.message).includes("FetchRequestCanceledException"))}const tt=n=>{if(n instanceof Error)return n;if(typeof n=="object"&&n!==null){try{if(Object.prototype.toString.call(n)==="[object Error]"){const e=new Error(n.message,n.cause?{cause:n.cause}:{});return n.stack&&(e.stack=n.stack),n.cause&&!e.cause&&(e.cause=n.cause),n.name&&(e.name=n.name),e}}catch{}try{return new Error(JSON.stringify(n))}catch{}}return new Error(n)};class f extends Error{}class b extends f{constructor(e,t,s,r){super(`${b.makeMessage(e,t,s)}`),this.status=e,this.headers=r,this.requestID=r?.get("request-id"),this.error=t}static makeMessage(e,t,s){const r=t?.message?typeof t.message=="string"?t.message:JSON.stringify(t.message):t?JSON.stringify(t):s;return e&&r?`${e} ${r}`:e?`${e} status code (no body)`:r||"(no status code or body)"}static generate(e,t,s,r){if(!e||!r)return new Fe({message:s,cause:tt(t)});const i=t;return e===400?new Yt(e,i,s,r):e===401?new Zt(e,i,s,r):e===403?new en(e,i,s,r):e===404?new tn(e,i,s,r):e===409?new nn(e,i,s,r):e===422?new sn(e,i,s,r):e===429?new rn(e,i,s,r):e>=500?new an(e,i,s,r):new b(e,i,s,r)}}class A extends b{constructor({message:e}={}){super(void 0,void 0,e||"Request was aborted.",void 0)}}class Fe extends b{constructor({message:e,cause:t}){super(void 0,void 0,e||"Connection error.",void 0),t&&(this.cause=t)}}class Gt extends Fe{constructor({message:e}={}){super({message:e??"Request timed out."})}}class Yt extends b{}class Zt extends b{}class en extends b{}class tn extends b{}class nn extends b{}class sn extends b{}class rn extends b{}class an extends b{}const Ln=/^[a-z][a-z0-9+.-]*:/i,Un=n=>Ln.test(n);let nt=n=>(nt=Array.isArray,nt(n)),bt=nt;function St(n){return typeof n!="object"?{}:n??{}}function qn(n){if(!n)return!0;for(const e in n)return!1;return!0}function Wn(n,e){return Object.prototype.hasOwnProperty.call(n,e)}const Fn=(n,e)=>{if(typeof e!="number"||!Number.isInteger(e))throw new f(`${n} must be an integer`);if(e<0)throw new f(`${n} must be a positive integer`);return e},on=n=>{try{return JSON.parse(n)}catch{return}},Dn=n=>new Promise(e=>setTimeout(e,n)),z="0.65.0",Hn=()=>typeof window<"u"&&typeof window.document<"u"&&typeof navigator<"u";function Jn(){return typeof Deno<"u"&&Deno.build!=null?"deno":typeof EdgeRuntime<"u"?"edge":Object.prototype.toString.call(typeof globalThis.process<"u"?globalThis.process:0)==="[object process]"?"node":"unknown"}const Kn=()=>{const n=Jn();if(n==="deno")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":z,"X-Stainless-OS":kt(Deno.build.os),"X-Stainless-Arch":xt(Deno.build.arch),"X-Stainless-Runtime":"deno","X-Stainless-Runtime-Version":typeof Deno.version=="string"?Deno.version:Deno.version?.deno??"unknown"};if(typeof EdgeRuntime<"u")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":z,"X-Stainless-OS":"Unknown","X-Stainless-Arch":`other:${EdgeRuntime}`,"X-Stainless-Runtime":"edge","X-Stainless-Runtime-Version":globalThis.process.version};if(n==="node")return{"X-Stainless-Lang":"js","X-Stainless-Package-Version":z,"X-Stainless-OS":kt(globalThis.process.platform??"unknown"),"X-Stainless-Arch":xt(globalThis.process.arch??"unknown"),"X-Stainless-Runtime":"node","X-Stainless-Runtime-Version":globalThis.process.version??"unknown"};const e=Xn();return e?{"X-Stainless-Lang":"js","X-Stainless-Package-Version":z,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":`browser:${e.browser}`,"X-Stainless-Runtime-Version":e.version}:{"X-Stainless-Lang":"js","X-Stainless-Package-Version":z,"X-Stainless-OS":"Unknown","X-Stainless-Arch":"unknown","X-Stainless-Runtime":"unknown","X-Stainless-Runtime-Version":"unknown"}};function Xn(){if(typeof navigator>"u"||!navigator)return null;const n=[{key:"edge",pattern:/Edge(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/MSIE(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"ie",pattern:/Trident(?:.*rv\:(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"chrome",pattern:/Chrome(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"firefox",pattern:/Firefox(?:\W+(\d+)\.(\d+)(?:\.(\d+))?)?/},{key:"safari",pattern:/(?:Version\W+(\d+)\.(\d+)(?:\.(\d+))?)?(?:\W+Mobile\S*)?\W+Safari/}];for(const{key:e,pattern:t}of n){const s=t.exec(navigator.userAgent);if(s){const r=s[1]||0,i=s[2]||0,a=s[3]||0;return{browser:e,version:`${r}.${i}.${a}`}}}return null}const xt=n=>n==="x32"?"x32":n==="x86_64"||n==="x64"?"x64":n==="arm"?"arm":n==="aarch64"||n==="arm64"?"arm64":n?`other:${n}`:"unknown",kt=n=>(n=n.toLowerCase(),n.includes("ios")?"iOS":n==="android"?"Android":n==="darwin"?"MacOS":n==="win32"?"Windows":n==="freebsd"?"FreeBSD":n==="openbsd"?"OpenBSD":n==="linux"?"Linux":n?`Other:${n}`:"Unknown");let Mt;const zn=()=>Mt??(Mt=Kn());function Vn(){if(typeof fetch<"u")return fetch;throw new Error("`fetch` is not defined as a global; Either pass `fetch` to the client, `new Anthropic({ fetch })` or polyfill the global, `globalThis.fetch = fetch`")}function cn(...n){const e=globalThis.ReadableStream;if(typeof e>"u")throw new Error("`ReadableStream` is not defined as a global; You will need to polyfill it, `globalThis.ReadableStream = ReadableStream`");return new e(...n)}function ln(n){let e=Symbol.asyncIterator in n?n[Symbol.asyncIterator]():n[Symbol.iterator]();return cn({start(){},async pull(t){const{done:s,value:r}=await e.next();s?t.close():t.enqueue(r)},async cancel(){await e.return?.()}})}function ct(n){if(n[Symbol.asyncIterator])return n;const e=n.getReader();return{async next(){try{const t=await e.read();return t?.done&&e.releaseLock(),t}catch(t){throw e.releaseLock(),t}},async return(){const t=e.cancel();return e.releaseLock(),await t,{done:!0,value:void 0}},[Symbol.asyncIterator](){return this}}}async function Qn(n){if(n===null||typeof n!="object")return;if(n[Symbol.asyncIterator]){await n[Symbol.asyncIterator]().return?.();return}const e=n.getReader(),t=e.cancel();e.releaseLock(),await t}const Gn=({headers:n,body:e})=>({bodyHeaders:{"content-type":"application/json"},body:JSON.stringify(e)});function Yn(n){let e=0;for(const r of n)e+=r.length;const t=new Uint8Array(e);let s=0;for(const r of n)t.set(r,s),s+=r.length;return t}let Tt;function lt(n){let e;return(Tt??(e=new globalThis.TextEncoder,Tt=e.encode.bind(e)))(n)}let Rt;function vt(n){let e;return(Rt??(e=new globalThis.TextDecoder,Rt=e.decode.bind(e)))(n)}var k,M;class fe{constructor(){k.set(this,void 0),M.set(this,void 0),u(this,k,new Uint8Array),u(this,M,null)}decode(e){if(e==null)return[];const t=e instanceof ArrayBuffer?new Uint8Array(e):typeof e=="string"?lt(e):e;u(this,k,Yn([o(this,k,"f"),t]));const s=[];let r;for(;(r=Zn(o(this,k,"f"),o(this,M,"f")))!=null;){if(r.carriage&&o(this,M,"f")==null){u(this,M,r.index);continue}if(o(this,M,"f")!=null&&(r.index!==o(this,M,"f")+1||r.carriage)){s.push(vt(o(this,k,"f").subarray(0,o(this,M,"f")-1))),u(this,k,o(this,k,"f").subarray(o(this,M,"f"))),u(this,M,null);continue}const i=o(this,M,"f")!==null?r.preceding-1:r.preceding,a=vt(o(this,k,"f").subarray(0,i));s.push(a),u(this,k,o(this,k,"f").subarray(r.index)),u(this,M,null)}return s}flush(){return o(this,k,"f").length?this.decode(`
2
+ `):[]}}k=new WeakMap,M=new WeakMap;fe.NEWLINE_CHARS=new Set([`
3
+ `,"\r"]);fe.NEWLINE_REGEXP=/\r\n|[\n\r]/g;function Zn(n,e){for(let r=e??0;r<n.length;r++){if(n[r]===10)return{preceding:r,index:r+1,carriage:!1};if(n[r]===13)return{preceding:r,index:r+1,carriage:!0}}return null}function es(n){for(let s=0;s<n.length-1;s++){if(n[s]===10&&n[s+1]===10||n[s]===13&&n[s+1]===13)return s+2;if(n[s]===13&&n[s+1]===10&&s+3<n.length&&n[s+2]===13&&n[s+3]===10)return s+4}return-1}const Ue={off:0,error:200,warn:300,info:400,debug:500},At=(n,e,t)=>{if(n){if(Wn(Ue,n))return n;S(t).warn(`${e} was set to ${JSON.stringify(n)}, expected one of ${JSON.stringify(Object.keys(Ue))}`)}};function ue(){}function we(n,e,t){return!e||Ue[n]>Ue[t]?ue:e[n].bind(e)}const ts={error:ue,warn:ue,info:ue,debug:ue};let Et=new WeakMap;function S(n){const e=n.logger,t=n.logLevel??"off";if(!e)return ts;const s=Et.get(e);if(s&&s[0]===t)return s[1];const r={error:we("error",e,t),warn:we("warn",e,t),info:we("info",e,t),debug:we("debug",e,t)};return Et.set(e,[t,r]),r}const H=n=>(n.options&&(n.options={...n.options},delete n.options.headers),n.headers&&(n.headers=Object.fromEntries((n.headers instanceof Headers?[...n.headers]:Object.entries(n.headers)).map(([e,t])=>[e,e.toLowerCase()==="x-api-key"||e.toLowerCase()==="authorization"||e.toLowerCase()==="cookie"||e.toLowerCase()==="set-cookie"?"***":t]))),"retryOfRequestLogID"in n&&(n.retryOfRequestLogID&&(n.retryOf=n.retryOfRequestLogID),delete n.retryOfRequestLogID),n);var G;class C{constructor(e,t,s){this.iterator=e,G.set(this,void 0),this.controller=t,u(this,G,s)}static fromSSEResponse(e,t,s){let r=!1;const i=s?S(s):console;async function*a(){if(r)throw new f("Cannot iterate over a consumed stream, use `.tee()` to split the stream.");r=!0;let c=!1;try{for await(const l of ns(e,t)){if(l.event==="completion")try{yield JSON.parse(l.data)}catch(d){throw i.error("Could not parse message into JSON:",l.data),i.error("From chunk:",l.raw),d}if(l.event==="message_start"||l.event==="message_delta"||l.event==="message_stop"||l.event==="content_block_start"||l.event==="content_block_delta"||l.event==="content_block_stop")try{yield JSON.parse(l.data)}catch(d){throw i.error("Could not parse message into JSON:",l.data),i.error("From chunk:",l.raw),d}if(l.event!=="ping"&&l.event==="error")throw new b(void 0,on(l.data)??l.data,void 0,e.headers)}c=!0}catch(l){if(de(l))return;throw l}finally{c||t.abort()}}return new C(a,t,s)}static fromReadableStream(e,t,s){let r=!1;async function*i(){const c=new fe,l=ct(e);for await(const d of l)for(const p of c.decode(d))yield p;for(const d of c.flush())yield d}async function*a(){if(r)throw new f("Cannot iterate over a consumed stream, use `.tee()` to split the stream.");r=!0;let c=!1;try{for await(const l of i())c||l&&(yield JSON.parse(l));c=!0}catch(l){if(de(l))return;throw l}finally{c||t.abort()}}return new C(a,t,s)}[(G=new WeakMap,Symbol.asyncIterator)](){return this.iterator()}tee(){const e=[],t=[],s=this.iterator(),r=i=>({next:()=>{if(i.length===0){const a=s.next();e.push(a),t.push(a)}return i.shift()}});return[new C(()=>r(e),this.controller,o(this,G,"f")),new C(()=>r(t),this.controller,o(this,G,"f"))]}toReadableStream(){const e=this;let t;return cn({async start(){t=e[Symbol.asyncIterator]()},async pull(s){try{const{value:r,done:i}=await t.next();if(i)return s.close();const a=lt(JSON.stringify(r)+`
4
+ `);s.enqueue(a)}catch(r){s.error(r)}},async cancel(){await t.return?.()}})}}async function*ns(n,e){if(!n.body)throw e.abort(),typeof globalThis.navigator<"u"&&globalThis.navigator.product==="ReactNative"?new f("The default react-native fetch implementation does not support streaming. Please use expo/fetch: https://docs.expo.dev/versions/latest/sdk/expo/#expofetch-api"):new f("Attempted to iterate over a response with no body");const t=new rs,s=new fe,r=ct(n.body);for await(const i of ss(r))for(const a of s.decode(i)){const c=t.decode(a);c&&(yield c)}for(const i of s.flush()){const a=t.decode(i);a&&(yield a)}}async function*ss(n){let e=new Uint8Array;for await(const t of n){if(t==null)continue;const s=t instanceof ArrayBuffer?new Uint8Array(t):typeof t=="string"?lt(t):t;let r=new Uint8Array(e.length+s.length);r.set(e),r.set(s,e.length),e=r;let i;for(;(i=es(e))!==-1;)yield e.slice(0,i),e=e.slice(i)}e.length>0&&(yield e)}class rs{constructor(){this.event=null,this.data=[],this.chunks=[]}decode(e){if(e.endsWith("\r")&&(e=e.substring(0,e.length-1)),!e){if(!this.event&&!this.data.length)return null;const i={event:this.event,data:this.data.join(`
5
+ `),raw:this.chunks};return this.event=null,this.data=[],this.chunks=[],i}if(this.chunks.push(e),e.startsWith(":"))return null;let[t,s,r]=is(e,":");return r.startsWith(" ")&&(r=r.substring(1)),t==="event"?this.event=r:t==="data"&&this.data.push(r),null}}function is(n,e){const t=n.indexOf(e);return t!==-1?[n.substring(0,t),e,n.substring(t+e.length)]:[n,"",""]}async function un(n,e){const{response:t,requestLogID:s,retryOfRequestLogID:r,startTime:i}=e,a=await(async()=>{if(e.options.stream)return S(n).debug("response",t.status,t.url,t.headers,t.body),e.options.__streamClass?e.options.__streamClass.fromSSEResponse(t,e.controller):C.fromSSEResponse(t,e.controller);if(t.status===204)return null;if(e.options.__binaryResponse)return t;const l=t.headers.get("content-type")?.split(";")[0]?.trim();if(l?.includes("application/json")||l?.endsWith("+json")){const m=await t.json();return hn(m,t)}return await t.text()})();return S(n).debug(`[${s}] response parsed`,H({retryOfRequestLogID:r,url:t.url,status:t.status,body:a,durationMs:Date.now()-i})),a}function hn(n,e){return!n||typeof n!="object"||Array.isArray(n)?n:Object.defineProperty(n,"_request_id",{value:e.headers.get("request-id"),enumerable:!1})}var he;class De extends Promise{constructor(e,t,s=un){super(r=>{r(null)}),this.responsePromise=t,this.parseResponse=s,he.set(this,void 0),u(this,he,e)}_thenUnwrap(e){return new De(o(this,he,"f"),this.responsePromise,async(t,s)=>hn(e(await this.parseResponse(t,s),s),s.response))}asResponse(){return this.responsePromise.then(e=>e.response)}async withResponse(){const[e,t]=await Promise.all([this.parse(),this.asResponse()]);return{data:e,response:t,request_id:t.headers.get("request-id")}}parse(){return this.parsedPromise||(this.parsedPromise=this.responsePromise.then(e=>this.parseResponse(o(this,he,"f"),e))),this.parsedPromise}then(e,t){return this.parse().then(e,t)}catch(e){return this.parse().catch(e)}finally(e){return this.parse().finally(e)}}he=new WeakMap;var be;class as{constructor(e,t,s,r){be.set(this,void 0),u(this,be,e),this.options=r,this.response=t,this.body=s}hasNextPage(){return this.getPaginatedItems().length?this.nextPageRequestOptions()!=null:!1}async getNextPage(){const e=this.nextPageRequestOptions();if(!e)throw new f("No next page expected; please check `.hasNextPage()` before calling `.getNextPage()`.");return await o(this,be,"f").requestAPIList(this.constructor,e)}async*iterPages(){let e=this;for(yield e;e.hasNextPage();)e=await e.getNextPage(),yield e}async*[(be=new WeakMap,Symbol.asyncIterator)](){for await(const e of this.iterPages())for(const t of e.getPaginatedItems())yield t}}class os extends De{constructor(e,t,s){super(e,t,async(r,i)=>new s(r,i.response,await un(r,i),i.options))}async*[Symbol.asyncIterator](){const e=await this;for await(const t of e)yield t}}class pe extends as{constructor(e,t,s,r){super(e,t,s,r),this.data=s.data||[],this.has_more=s.has_more||!1,this.first_id=s.first_id||null,this.last_id=s.last_id||null}getPaginatedItems(){return this.data??[]}hasNextPage(){return this.has_more===!1?!1:super.hasNextPage()}nextPageRequestOptions(){if(this.options.query?.before_id){const t=this.first_id;return t?{...this.options,query:{...St(this.options.query),before_id:t}}:null}const e=this.last_id;return e?{...this.options,query:{...St(this.options.query),after_id:e}}:null}}const dn=()=>{if(typeof File>"u"){const{process:n}=globalThis,e=typeof n?.versions?.node=="string"&&parseInt(n.versions.node.split("."))<20;throw new Error("`File` is not defined as a global, which is required for file uploads."+(e?" Update to Node 20 LTS or newer, or set `globalThis.File` to `import('node:buffer').File`.":""))}};function Q(n,e,t){return dn(),new File(n,e??"unknown_file",t)}function Be(n){return(typeof n=="object"&&n!==null&&("name"in n&&n.name&&String(n.name)||"url"in n&&n.url&&String(n.url)||"filename"in n&&n.filename&&String(n.filename)||"path"in n&&n.path&&String(n.path))||"").split(/[\\/]/).pop()||void 0}const fn=n=>n!=null&&typeof n=="object"&&typeof n[Symbol.asyncIterator]=="function",cs=async(n,e)=>({...n,body:await us(n.body,e)}),Pt=new WeakMap;function ls(n){const e=typeof n=="function"?n:n.fetch,t=Pt.get(e);if(t)return t;const s=(async()=>{try{const r="Response"in e?e.Response:(await e("data:,")).constructor,i=new FormData;return i.toString()!==await new r(i).text()}catch{return!0}})();return Pt.set(e,s),s}const us=async(n,e)=>{if(!await ls(e))throw new TypeError("The provided fetch function does not support file uploads with the current global FormData class.");const t=new FormData;return await Promise.all(Object.entries(n||{}).map(([s,r])=>st(t,s,r))),t},hs=n=>n instanceof Blob&&"name"in n,st=async(n,e,t)=>{if(t!==void 0){if(t==null)throw new TypeError(`Received null for "${e}"; to pass null in FormData, you must use the string 'null'`);if(typeof t=="string"||typeof t=="number"||typeof t=="boolean")n.append(e,String(t));else if(t instanceof Response){let s={};const r=t.headers.get("Content-Type");r&&(s={type:r}),n.append(e,Q([await t.blob()],Be(t),s))}else if(fn(t))n.append(e,Q([await new Response(ln(t)).blob()],Be(t)));else if(hs(t))n.append(e,Q([t],Be(t),{type:t.type}));else if(Array.isArray(t))await Promise.all(t.map(s=>st(n,e+"[]",s)));else if(typeof t=="object")await Promise.all(Object.entries(t).map(([s,r])=>st(n,`${e}[${s}]`,r)));else throw new TypeError(`Invalid value given to form, expected a string, number, boolean, object, Array, File or Blob but got ${t} instead`)}},pn=n=>n!=null&&typeof n=="object"&&typeof n.size=="number"&&typeof n.type=="string"&&typeof n.text=="function"&&typeof n.slice=="function"&&typeof n.arrayBuffer=="function",ds=n=>n!=null&&typeof n=="object"&&typeof n.name=="string"&&typeof n.lastModified=="number"&&pn(n),fs=n=>n!=null&&typeof n=="object"&&typeof n.url=="string"&&typeof n.blob=="function";async function ps(n,e,t){if(dn(),n=await n,e||(e=Be(n)),ds(n))return n instanceof File&&e==null&&t==null?n:Q([await n.arrayBuffer()],e??n.name,{type:n.type,lastModified:n.lastModified,...t});if(fs(n)){const r=await n.blob();return e||(e=new URL(n.url).pathname.split(/[\\/]/).pop()),Q(await rt(r),e,t)}const s=await rt(n);if(!t?.type){const r=s.find(i=>typeof i=="object"&&"type"in i&&i.type);typeof r=="string"&&(t={...t,type:r})}return Q(s,e,t)}async function rt(n){let e=[];if(typeof n=="string"||ArrayBuffer.isView(n)||n instanceof ArrayBuffer)e.push(n);else if(pn(n))e.push(n instanceof Blob?n:await n.arrayBuffer());else if(fn(n))for await(const t of n)e.push(...await rt(t));else{const t=n?.constructor?.name;throw new Error(`Unexpected data type: ${typeof n}${t?`; constructor: ${t}`:""}${ms(n)}`)}return e}function ms(n){return typeof n!="object"||n===null?"":`; props: [${Object.getOwnPropertyNames(n).map(t=>`"${t}"`).join(", ")}]`}class B{constructor(e){this._client=e}}const mn=Symbol.for("brand.privateNullableHeaders");function*gs(n){if(!n)return;if(mn in n){const{values:s,nulls:r}=n;yield*s.entries();for(const i of r)yield[i,null];return}let e=!1,t;n instanceof Headers?t=n.entries():bt(n)?t=n:(e=!0,t=Object.entries(n??{}));for(let s of t){const r=s[0];if(typeof r!="string")throw new TypeError("expected header name to be a string");const i=bt(s[1])?s[1]:[s[1]];let a=!1;for(const c of i)c!==void 0&&(e&&!a&&(a=!0,yield[r,null]),yield[r,c])}}const _=n=>{const e=new Headers,t=new Set;for(const s of n){const r=new Set;for(const[i,a]of gs(s)){const c=i.toLowerCase();r.has(c)||(e.delete(i),r.add(c)),a===null?(e.delete(i),t.add(c)):(e.append(i,a),t.delete(c))}}return{[mn]:!0,values:e,nulls:t}};function gn(n){return n.replace(/[^A-Za-z0-9\-._~!$&'()*+,;=:@]+/g,encodeURIComponent)}const Ot=Object.freeze(Object.create(null)),_s=(n=gn)=>function(t,...s){if(t.length===1)return t[0];let r=!1;const i=[],a=t.reduce((p,m,y)=>{/[?#]/.test(m)&&(r=!0);const h=s[y];let g=(r?encodeURIComponent:n)(""+h);return y!==s.length&&(h==null||typeof h=="object"&&h.toString===Object.getPrototypeOf(Object.getPrototypeOf(h.hasOwnProperty??Ot)??Ot)?.toString)&&(g=h+"",i.push({start:p.length+m.length,length:g.length,error:`Value of type ${Object.prototype.toString.call(h).slice(8,-1)} is not a valid path parameter`})),p+m+(y===s.length?"":g)},""),c=a.split(/[?#]/,1)[0],l=new RegExp("(?<=^|\\/)(?:\\.|%2e){1,2}(?=\\/|$)","gi");let d;for(;(d=l.exec(c))!==null;)i.push({start:d.index,length:d[0].length,error:`Value "${d[0]}" can't be safely passed as a path parameter`});if(i.sort((p,m)=>p.start-m.start),i.length>0){let p=0;const m=i.reduce((y,h)=>{const g=" ".repeat(h.start-p),W="^".repeat(h.length);return p=h.start+h.length,y+g+W},"");throw new f(`Path parameters result in path with invalid segments:
6
+ ${i.map(y=>y.error).join(`
7
+ `)}
8
+ ${a}
9
+ ${m}`)}return a},E=_s(gn);class _n extends B{list(e={},t){const{betas:s,...r}=e??{};return this._client.getAPIList("/v1/files",pe,{query:r,...t,headers:_([{"anthropic-beta":[...s??[],"files-api-2025-04-14"].toString()},t?.headers])})}delete(e,t={},s){const{betas:r}=t??{};return this._client.delete(E`/v1/files/${e}`,{...s,headers:_([{"anthropic-beta":[...r??[],"files-api-2025-04-14"].toString()},s?.headers])})}download(e,t={},s){const{betas:r}=t??{};return this._client.get(E`/v1/files/${e}/content`,{...s,headers:_([{"anthropic-beta":[...r??[],"files-api-2025-04-14"].toString(),Accept:"application/binary"},s?.headers]),__binaryResponse:!0})}retrieveMetadata(e,t={},s){const{betas:r}=t??{};return this._client.get(E`/v1/files/${e}`,{...s,headers:_([{"anthropic-beta":[...r??[],"files-api-2025-04-14"].toString()},s?.headers])})}upload(e,t){const{betas:s,...r}=e;return this._client.post("/v1/files",cs({body:r,...t,headers:_([{"anthropic-beta":[...s??[],"files-api-2025-04-14"].toString()},t?.headers])},this._client))}}let yn=class extends B{retrieve(e,t={},s){const{betas:r}=t??{};return this._client.get(E`/v1/models/${e}?beta=true`,{...s,headers:_([{...r?.toString()!=null?{"anthropic-beta":r?.toString()}:void 0},s?.headers])})}list(e={},t){const{betas:s,...r}=e??{};return this._client.getAPIList("/v1/models?beta=true",pe,{query:r,...t,headers:_([{...s?.toString()!=null?{"anthropic-beta":s?.toString()}:void 0},t?.headers])})}};class He{constructor(e,t){this.iterator=e,this.controller=t}async*decoder(){const e=new fe;for await(const t of this.iterator)for(const s of e.decode(t))yield JSON.parse(s);for(const t of e.flush())yield JSON.parse(t)}[Symbol.asyncIterator](){return this.decoder()}static fromResponse(e,t){if(!e.body)throw t.abort(),typeof globalThis.navigator<"u"&&globalThis.navigator.product==="ReactNative"?new f("The default react-native fetch implementation does not support streaming. Please use expo/fetch: https://docs.expo.dev/versions/latest/sdk/expo/#expofetch-api"):new f("Attempted to iterate over a response with no body");return new He(ct(e.body),t)}}let wn=class extends B{create(e,t){const{betas:s,...r}=e;return this._client.post("/v1/messages/batches?beta=true",{body:r,...t,headers:_([{"anthropic-beta":[...s??[],"message-batches-2024-09-24"].toString()},t?.headers])})}retrieve(e,t={},s){const{betas:r}=t??{};return this._client.get(E`/v1/messages/batches/${e}?beta=true`,{...s,headers:_([{"anthropic-beta":[...r??[],"message-batches-2024-09-24"].toString()},s?.headers])})}list(e={},t){const{betas:s,...r}=e??{};return this._client.getAPIList("/v1/messages/batches?beta=true",pe,{query:r,...t,headers:_([{"anthropic-beta":[...s??[],"message-batches-2024-09-24"].toString()},t?.headers])})}delete(e,t={},s){const{betas:r}=t??{};return this._client.delete(E`/v1/messages/batches/${e}?beta=true`,{...s,headers:_([{"anthropic-beta":[...r??[],"message-batches-2024-09-24"].toString()},s?.headers])})}cancel(e,t={},s){const{betas:r}=t??{};return this._client.post(E`/v1/messages/batches/${e}/cancel?beta=true`,{...s,headers:_([{"anthropic-beta":[...r??[],"message-batches-2024-09-24"].toString()},s?.headers])})}async results(e,t={},s){const r=await this.retrieve(e);if(!r.results_url)throw new f(`No batch \`results_url\`; Has it finished processing? ${r.processing_status} - ${r.id}`);const{betas:i}=t??{};return this._client.get(r.results_url,{...s,headers:_([{"anthropic-beta":[...i??[],"message-batches-2024-09-24"].toString(),Accept:"application/binary"},s?.headers]),stream:!0,__binaryResponse:!0})._thenUnwrap((a,c)=>He.fromResponse(c.response,c.controller))}};const ys=n=>{let e=0,t=[];for(;e<n.length;){let s=n[e];if(s==="\\"){e++;continue}if(s==="{"){t.push({type:"brace",value:"{"}),e++;continue}if(s==="}"){t.push({type:"brace",value:"}"}),e++;continue}if(s==="["){t.push({type:"paren",value:"["}),e++;continue}if(s==="]"){t.push({type:"paren",value:"]"}),e++;continue}if(s===":"){t.push({type:"separator",value:":"}),e++;continue}if(s===","){t.push({type:"delimiter",value:","}),e++;continue}if(s==='"'){let c="",l=!1;for(s=n[++e];s!=='"';){if(e===n.length){l=!0;break}if(s==="\\"){if(e++,e===n.length){l=!0;break}c+=s+n[e],s=n[++e]}else c+=s,s=n[++e]}s=n[++e],l||t.push({type:"string",value:c});continue}if(s&&/\s/.test(s)){e++;continue}let i=/[0-9]/;if(s&&i.test(s)||s==="-"||s==="."){let c="";for(s==="-"&&(c+=s,s=n[++e]);s&&i.test(s)||s===".";)c+=s,s=n[++e];t.push({type:"number",value:c});continue}let a=/[a-z]/i;if(s&&a.test(s)){let c="";for(;s&&a.test(s)&&e!==n.length;)c+=s,s=n[++e];if(c=="true"||c=="false"||c==="null")t.push({type:"name",value:c});else{e++;continue}continue}e++}return t},V=n=>{if(n.length===0)return n;let e=n[n.length-1];switch(e.type){case"separator":return n=n.slice(0,n.length-1),V(n);case"number":let t=e.value[e.value.length-1];if(t==="."||t==="-")return n=n.slice(0,n.length-1),V(n);case"string":let s=n[n.length-2];if(s?.type==="delimiter")return n=n.slice(0,n.length-1),V(n);if(s?.type==="brace"&&s.value==="{")return n=n.slice(0,n.length-1),V(n);break;case"delimiter":return n=n.slice(0,n.length-1),V(n)}return n},ws=n=>{let e=[];return n.map(t=>{t.type==="brace"&&(t.value==="{"?e.push("}"):e.splice(e.lastIndexOf("}"),1)),t.type==="paren"&&(t.value==="["?e.push("]"):e.splice(e.lastIndexOf("]"),1))}),e.length>0&&e.reverse().map(t=>{t==="}"?n.push({type:"brace",value:"}"}):t==="]"&&n.push({type:"paren",value:"]"})}),n},bs=n=>{let e="";return n.map(t=>{switch(t.type){case"string":e+='"'+t.value+'"';break;default:e+=t.value;break}}),e},bn=n=>JSON.parse(bs(ws(V(ys(n)))));var T,L,Y,Se,Z,ee,xe,te,N,ne,ke,Me,J,Te,Re,Ke,Ct,ve,Xe,ze,Ve,jt;const Nt="__json_buf";function It(n){return n.type==="tool_use"||n.type==="server_tool_use"||n.type==="mcp_tool_use"}class qe{constructor(){T.add(this),this.messages=[],this.receivedMessages=[],L.set(this,void 0),this.controller=new AbortController,Y.set(this,void 0),Se.set(this,()=>{}),Z.set(this,()=>{}),ee.set(this,void 0),xe.set(this,()=>{}),te.set(this,()=>{}),N.set(this,{}),ne.set(this,!1),ke.set(this,!1),Me.set(this,!1),J.set(this,!1),Te.set(this,void 0),Re.set(this,void 0),ve.set(this,e=>{if(u(this,ke,!0),de(e)&&(e=new A),e instanceof A)return u(this,Me,!0),this._emit("abort",e);if(e instanceof f)return this._emit("error",e);if(e instanceof Error){const t=new f(e.message);return t.cause=e,this._emit("error",t)}return this._emit("error",new f(String(e)))}),u(this,Y,new Promise((e,t)=>{u(this,Se,e,"f"),u(this,Z,t,"f")})),u(this,ee,new Promise((e,t)=>{u(this,xe,e,"f"),u(this,te,t,"f")})),o(this,Y,"f").catch(()=>{}),o(this,ee,"f").catch(()=>{})}get response(){return o(this,Te,"f")}get request_id(){return o(this,Re,"f")}async withResponse(){const e=await o(this,Y,"f");if(!e)throw new Error("Could not resolve a `Response` object");return{data:this,response:e,request_id:e.headers.get("request-id")}}static fromReadableStream(e){const t=new qe;return t._run(()=>t._fromReadableStream(e)),t}static createMessage(e,t,s){const r=new qe;for(const i of t.messages)r._addMessageParam(i);return r._run(()=>r._createMessage(e,{...t,stream:!0},{...s,headers:{...s?.headers,"X-Stainless-Helper-Method":"stream"}})),r}_run(e){e().then(()=>{this._emitFinal(),this._emit("end")},o(this,ve,"f"))}_addMessageParam(e){this.messages.push(e)}_addMessage(e,t=!0){this.receivedMessages.push(e),t&&this._emit("message",e)}async _createMessage(e,t,s){const r=s?.signal;let i;r&&(r.aborted&&this.controller.abort(),i=this.controller.abort.bind(this.controller),r.addEventListener("abort",i));try{o(this,T,"m",Xe).call(this);const{response:a,data:c}=await e.create({...t,stream:!0},{...s,signal:this.controller.signal}).withResponse();this._connected(a);for await(const l of c)o(this,T,"m",ze).call(this,l);if(c.controller.signal?.aborted)throw new A;o(this,T,"m",Ve).call(this)}finally{r&&i&&r.removeEventListener("abort",i)}}_connected(e){this.ended||(u(this,Te,e),u(this,Re,e?.headers.get("request-id")),o(this,Se,"f").call(this,e),this._emit("connect"))}get ended(){return o(this,ne,"f")}get errored(){return o(this,ke,"f")}get aborted(){return o(this,Me,"f")}abort(){this.controller.abort()}on(e,t){return(o(this,N,"f")[e]||(o(this,N,"f")[e]=[])).push({listener:t}),this}off(e,t){const s=o(this,N,"f")[e];if(!s)return this;const r=s.findIndex(i=>i.listener===t);return r>=0&&s.splice(r,1),this}once(e,t){return(o(this,N,"f")[e]||(o(this,N,"f")[e]=[])).push({listener:t,once:!0}),this}emitted(e){return new Promise((t,s)=>{u(this,J,!0),e!=="error"&&this.once("error",s),this.once(e,t)})}async done(){u(this,J,!0),await o(this,ee,"f")}get currentMessage(){return o(this,L,"f")}async finalMessage(){return await this.done(),o(this,T,"m",Ke).call(this)}async finalText(){return await this.done(),o(this,T,"m",Ct).call(this)}_emit(e,...t){if(o(this,ne,"f"))return;e==="end"&&(u(this,ne,!0),o(this,xe,"f").call(this));const s=o(this,N,"f")[e];if(s&&(o(this,N,"f")[e]=s.filter(r=>!r.once),s.forEach(({listener:r})=>r(...t))),e==="abort"){const r=t[0];!o(this,J,"f")&&!s?.length&&Promise.reject(r),o(this,Z,"f").call(this,r),o(this,te,"f").call(this,r),this._emit("end");return}if(e==="error"){const r=t[0];!o(this,J,"f")&&!s?.length&&Promise.reject(r),o(this,Z,"f").call(this,r),o(this,te,"f").call(this,r),this._emit("end")}}_emitFinal(){this.receivedMessages.at(-1)&&this._emit("finalMessage",o(this,T,"m",Ke).call(this))}async _fromReadableStream(e,t){const s=t?.signal;let r;s&&(s.aborted&&this.controller.abort(),r=this.controller.abort.bind(this.controller),s.addEventListener("abort",r));try{o(this,T,"m",Xe).call(this),this._connected(null);const i=C.fromReadableStream(e,this.controller);for await(const a of i)o(this,T,"m",ze).call(this,a);if(i.controller.signal?.aborted)throw new A;o(this,T,"m",Ve).call(this)}finally{s&&r&&s.removeEventListener("abort",r)}}[(L=new WeakMap,Y=new WeakMap,Se=new WeakMap,Z=new WeakMap,ee=new WeakMap,xe=new WeakMap,te=new WeakMap,N=new WeakMap,ne=new WeakMap,ke=new WeakMap,Me=new WeakMap,J=new WeakMap,Te=new WeakMap,Re=new WeakMap,ve=new WeakMap,T=new WeakSet,Ke=function(){if(this.receivedMessages.length===0)throw new f("stream ended without producing a Message with role=assistant");return this.receivedMessages.at(-1)},Ct=function(){if(this.receivedMessages.length===0)throw new f("stream ended without producing a Message with role=assistant");const t=this.receivedMessages.at(-1).content.filter(s=>s.type==="text").map(s=>s.text);if(t.length===0)throw new f("stream ended without producing a content block with type=text");return t.join(" ")},Xe=function(){this.ended||u(this,L,void 0)},ze=function(t){if(this.ended)return;const s=o(this,T,"m",jt).call(this,t);switch(this._emit("streamEvent",t,s),t.type){case"content_block_delta":{const r=s.content.at(-1);switch(t.delta.type){case"text_delta":{r.type==="text"&&this._emit("text",t.delta.text,r.text||"");break}case"citations_delta":{r.type==="text"&&this._emit("citation",t.delta.citation,r.citations??[]);break}case"input_json_delta":{It(r)&&r.input&&this._emit("inputJson",t.delta.partial_json,r.input);break}case"thinking_delta":{r.type==="thinking"&&this._emit("thinking",t.delta.thinking,r.thinking);break}case"signature_delta":{r.type==="thinking"&&this._emit("signature",r.signature);break}default:t.delta}break}case"message_stop":{this._addMessageParam(s),this._addMessage(s,!0);break}case"content_block_stop":{this._emit("contentBlock",s.content.at(-1));break}case"message_start":{u(this,L,s);break}}},Ve=function(){if(this.ended)throw new f("stream has ended, this shouldn't happen");const t=o(this,L,"f");if(!t)throw new f("request ended without sending any chunks");return u(this,L,void 0),t},jt=function(t){let s=o(this,L,"f");if(t.type==="message_start"){if(s)throw new f(`Unexpected event order, got ${t.type} before receiving "message_stop"`);return t.message}if(!s)throw new f(`Unexpected event order, got ${t.type} before "message_start"`);switch(t.type){case"message_stop":return s;case"message_delta":return s.container=t.delta.container,s.stop_reason=t.delta.stop_reason,s.stop_sequence=t.delta.stop_sequence,s.usage.output_tokens=t.usage.output_tokens,s.context_management=t.context_management,t.usage.input_tokens!=null&&(s.usage.input_tokens=t.usage.input_tokens),t.usage.cache_creation_input_tokens!=null&&(s.usage.cache_creation_input_tokens=t.usage.cache_creation_input_tokens),t.usage.cache_read_input_tokens!=null&&(s.usage.cache_read_input_tokens=t.usage.cache_read_input_tokens),t.usage.server_tool_use!=null&&(s.usage.server_tool_use=t.usage.server_tool_use),s;case"content_block_start":return s.content.push(t.content_block),s;case"content_block_delta":{const r=s.content.at(t.index);switch(t.delta.type){case"text_delta":{r?.type==="text"&&(s.content[t.index]={...r,text:(r.text||"")+t.delta.text});break}case"citations_delta":{r?.type==="text"&&(s.content[t.index]={...r,citations:[...r.citations??[],t.delta.citation]});break}case"input_json_delta":{if(r&&It(r)){let i=r[Nt]||"";i+=t.delta.partial_json;const a={...r};if(Object.defineProperty(a,Nt,{value:i,enumerable:!1,writable:!0}),i)try{a.input=bn(i)}catch(c){const l=new f(`Unable to parse tool parameter JSON from model. Please retry your request or adjust your prompt. Error: ${c}. JSON: ${i}`);o(this,ve,"f").call(this,l)}s.content[t.index]=a}break}case"thinking_delta":{r?.type==="thinking"&&(s.content[t.index]={...r,thinking:r.thinking+t.delta.thinking});break}case"signature_delta":{r?.type==="thinking"&&(s.content[t.index]={...r,signature:t.delta.signature});break}default:t.delta}return s}case"content_block_stop":return s}},Symbol.asyncIterator)](){const e=[],t=[];let s=!1;return this.on("streamEvent",r=>{const i=t.shift();i?i.resolve(r):e.push(r)}),this.on("end",()=>{s=!0;for(const r of t)r.resolve(void 0);t.length=0}),this.on("abort",r=>{s=!0;for(const i of t)i.reject(r);t.length=0}),this.on("error",r=>{s=!0;for(const i of t)i.reject(r);t.length=0}),{next:async()=>e.length?{value:e.shift(),done:!1}:s?{value:void 0,done:!0}:new Promise((i,a)=>t.push({resolve:i,reject:a})).then(i=>i?{value:i,done:!1}:{value:void 0,done:!0}),return:async()=>(this.abort(),{value:void 0,done:!0})}}toReadableStream(){return new C(this[Symbol.asyncIterator].bind(this),this.controller).toReadableStream()}}const Sn={"claude-opus-4-20250514":8192,"claude-opus-4-0":8192,"claude-4-opus-20250514":8192,"anthropic.claude-opus-4-20250514-v1:0":8192,"claude-opus-4@20250514":8192,"claude-opus-4-1-20250805":8192,"anthropic.claude-opus-4-1-20250805-v1:0":8192,"claude-opus-4-1@20250805":8192};var Ae,K,D,x,se,O,$,U,re,it;function $t(){let n,e;return{promise:new Promise((s,r)=>{n=s,e=r}),resolve:n,reject:e}}class xn{constructor(e,t,s){Ae.add(this),this.client=e,K.set(this,!1),D.set(this,!1),x.set(this,void 0),se.set(this,void 0),O.set(this,void 0),$.set(this,void 0),U.set(this,void 0),re.set(this,0),u(this,x,{params:{...t,messages:structuredClone(t.messages)}}),u(this,se,{...s,headers:_([{"x-stainless-helper":"BetaToolRunner"},s?.headers])}),u(this,U,$t())}async*[(K=new WeakMap,D=new WeakMap,x=new WeakMap,se=new WeakMap,O=new WeakMap,$=new WeakMap,U=new WeakMap,re=new WeakMap,Ae=new WeakSet,Symbol.asyncIterator)](){var e;if(o(this,K,"f"))throw new f("Cannot iterate over a consumed stream");u(this,K,!0),u(this,D,!0),u(this,$,void 0);try{for(;;){let t;try{if(o(this,x,"f").params.max_iterations&&o(this,re,"f")>=o(this,x,"f").params.max_iterations)break;u(this,D,!1,"f"),u(this,O,void 0,"f"),u(this,$,void 0,"f"),u(this,re,(e=o(this,re,"f"),e++,e),"f");const{max_iterations:s,...r}=o(this,x,"f").params;if(r.stream?(t=this.client.beta.messages.stream({...r},o(this,se,"f")),u(this,O,t.finalMessage(),"f"),yield t):(u(this,O,this.client.beta.messages.create({...r,stream:!1},o(this,se,"f")),"f"),yield o(this,O,"f")),!o(this,D,"f")){const{role:a,content:c}=await o(this,O,"f");o(this,x,"f").params.messages.push({role:a,content:c})}const i=await o(this,Ae,"m",it).call(this,o(this,x,"f").params.messages.at(-1));if(i&&o(this,x,"f").params.messages.push(i),!i&&!o(this,D,"f"))break}finally{t&&t.abort()}}if(!o(this,O,"f"))throw new f("ToolRunner concluded without a message from the server");o(this,U,"f").resolve(await o(this,O,"f"))}catch(t){throw u(this,K,!1),o(this,U,"f").promise.catch(()=>{}),o(this,U,"f").reject(t),u(this,U,$t()),t}}setMessagesParams(e){typeof e=="function"?o(this,x,"f").params=e(o(this,x,"f").params):o(this,x,"f").params=e,u(this,D,!0),u(this,$,void 0)}async generateToolResponse(){const e=await o(this,O,"f")??this.params.messages.at(-1);return e?o(this,Ae,"m",it).call(this,e):null}done(){return o(this,U,"f").promise}async runUntilDone(){if(!o(this,K,"f"))for await(const e of this);return this.done()}get params(){return o(this,x,"f").params}pushMessages(...e){this.setMessagesParams(t=>({...t,messages:[...t.messages,...e]}))}then(e,t){return this.runUntilDone().then(e,t)}}it=async function(e){return o(this,$,"f")!==void 0?o(this,$,"f"):(u(this,$,Ss(o(this,x,"f").params,e)),o(this,$,"f"))};async function Ss(n,e=n.messages.at(-1)){if(!e||e.role!=="assistant"||!e.content||typeof e.content=="string")return null;const t=e.content.filter(r=>r.type==="tool_use");return t.length===0?null:{role:"user",content:await Promise.all(t.map(async r=>{const i=n.tools.find(a=>a.name===r.name);if(!i||!("run"in i))return{type:"tool_result",tool_use_id:r.id,content:`Error: Tool '${r.name}' not found`,is_error:!0};try{let a=r.input;"parse"in i&&i.parse&&(a=i.parse(a));const c=await i.run(a);return{type:"tool_result",tool_use_id:r.id,content:c}}catch(a){return{type:"tool_result",tool_use_id:r.id,content:`Error: ${a instanceof Error?a.message:String(a)}`,is_error:!0}}}))}}const Bt={"claude-1.3":"November 6th, 2024","claude-1.3-100k":"November 6th, 2024","claude-instant-1.1":"November 6th, 2024","claude-instant-1.1-100k":"November 6th, 2024","claude-instant-1.2":"November 6th, 2024","claude-3-sonnet-20240229":"July 21st, 2025","claude-3-opus-20240229":"January 5th, 2026","claude-2.1":"July 21st, 2025","claude-2.0":"July 21st, 2025","claude-3-5-sonnet-20241022":"October 22, 2025","claude-3-5-sonnet-20240620":"October 22, 2025"};let Je=class extends B{constructor(){super(...arguments),this.batches=new wn(this._client)}create(e,t){const{betas:s,...r}=e;r.model in Bt&&console.warn(`The model '${r.model}' is deprecated and will reach end-of-life on ${Bt[r.model]}
10
+ Please migrate to a newer model. Visit https://docs.anthropic.com/en/docs/resources/model-deprecations for more information.`);let i=this._client._options.timeout;if(!r.stream&&i==null){const a=Sn[r.model]??void 0;i=this._client.calculateNonstreamingTimeout(r.max_tokens,a)}return this._client.post("/v1/messages?beta=true",{body:r,timeout:i??6e5,...t,headers:_([{...s?.toString()!=null?{"anthropic-beta":s?.toString()}:void 0},t?.headers]),stream:e.stream??!1})}stream(e,t){return qe.createMessage(this,e,t)}countTokens(e,t){const{betas:s,...r}=e;return this._client.post("/v1/messages/count_tokens?beta=true",{body:r,...t,headers:_([{"anthropic-beta":[...s??[],"token-counting-2024-11-01"].toString()},t?.headers])})}toolRunner(e,t){return new xn(this._client,e,t)}};Je.Batches=wn;Je.BetaToolRunner=xn;class me extends B{constructor(){super(...arguments),this.models=new yn(this._client),this.messages=new Je(this._client),this.files=new _n(this._client)}}me.Models=yn;me.Messages=Je;me.Files=_n;class kn extends B{create(e,t){const{betas:s,...r}=e;return this._client.post("/v1/complete",{body:r,timeout:this._client._options.timeout??6e5,...t,headers:_([{...s?.toString()!=null?{"anthropic-beta":s?.toString()}:void 0},t?.headers]),stream:e.stream??!1})}}var R,q,ie,Ee,ae,oe,Pe,ce,I,le,Oe,Ce,X,je,Ne,Qe,Lt,Ge,Ye,Ze,et,Ut;const qt="__json_buf";function Wt(n){return n.type==="tool_use"||n.type==="server_tool_use"}class We{constructor(){R.add(this),this.messages=[],this.receivedMessages=[],q.set(this,void 0),this.controller=new AbortController,ie.set(this,void 0),Ee.set(this,()=>{}),ae.set(this,()=>{}),oe.set(this,void 0),Pe.set(this,()=>{}),ce.set(this,()=>{}),I.set(this,{}),le.set(this,!1),Oe.set(this,!1),Ce.set(this,!1),X.set(this,!1),je.set(this,void 0),Ne.set(this,void 0),Ge.set(this,e=>{if(u(this,Oe,!0),de(e)&&(e=new A),e instanceof A)return u(this,Ce,!0),this._emit("abort",e);if(e instanceof f)return this._emit("error",e);if(e instanceof Error){const t=new f(e.message);return t.cause=e,this._emit("error",t)}return this._emit("error",new f(String(e)))}),u(this,ie,new Promise((e,t)=>{u(this,Ee,e,"f"),u(this,ae,t,"f")})),u(this,oe,new Promise((e,t)=>{u(this,Pe,e,"f"),u(this,ce,t,"f")})),o(this,ie,"f").catch(()=>{}),o(this,oe,"f").catch(()=>{})}get response(){return o(this,je,"f")}get request_id(){return o(this,Ne,"f")}async withResponse(){const e=await o(this,ie,"f");if(!e)throw new Error("Could not resolve a `Response` object");return{data:this,response:e,request_id:e.headers.get("request-id")}}static fromReadableStream(e){const t=new We;return t._run(()=>t._fromReadableStream(e)),t}static createMessage(e,t,s){const r=new We;for(const i of t.messages)r._addMessageParam(i);return r._run(()=>r._createMessage(e,{...t,stream:!0},{...s,headers:{...s?.headers,"X-Stainless-Helper-Method":"stream"}})),r}_run(e){e().then(()=>{this._emitFinal(),this._emit("end")},o(this,Ge,"f"))}_addMessageParam(e){this.messages.push(e)}_addMessage(e,t=!0){this.receivedMessages.push(e),t&&this._emit("message",e)}async _createMessage(e,t,s){const r=s?.signal;let i;r&&(r.aborted&&this.controller.abort(),i=this.controller.abort.bind(this.controller),r.addEventListener("abort",i));try{o(this,R,"m",Ye).call(this);const{response:a,data:c}=await e.create({...t,stream:!0},{...s,signal:this.controller.signal}).withResponse();this._connected(a);for await(const l of c)o(this,R,"m",Ze).call(this,l);if(c.controller.signal?.aborted)throw new A;o(this,R,"m",et).call(this)}finally{r&&i&&r.removeEventListener("abort",i)}}_connected(e){this.ended||(u(this,je,e),u(this,Ne,e?.headers.get("request-id")),o(this,Ee,"f").call(this,e),this._emit("connect"))}get ended(){return o(this,le,"f")}get errored(){return o(this,Oe,"f")}get aborted(){return o(this,Ce,"f")}abort(){this.controller.abort()}on(e,t){return(o(this,I,"f")[e]||(o(this,I,"f")[e]=[])).push({listener:t}),this}off(e,t){const s=o(this,I,"f")[e];if(!s)return this;const r=s.findIndex(i=>i.listener===t);return r>=0&&s.splice(r,1),this}once(e,t){return(o(this,I,"f")[e]||(o(this,I,"f")[e]=[])).push({listener:t,once:!0}),this}emitted(e){return new Promise((t,s)=>{u(this,X,!0),e!=="error"&&this.once("error",s),this.once(e,t)})}async done(){u(this,X,!0),await o(this,oe,"f")}get currentMessage(){return o(this,q,"f")}async finalMessage(){return await this.done(),o(this,R,"m",Qe).call(this)}async finalText(){return await this.done(),o(this,R,"m",Lt).call(this)}_emit(e,...t){if(o(this,le,"f"))return;e==="end"&&(u(this,le,!0),o(this,Pe,"f").call(this));const s=o(this,I,"f")[e];if(s&&(o(this,I,"f")[e]=s.filter(r=>!r.once),s.forEach(({listener:r})=>r(...t))),e==="abort"){const r=t[0];!o(this,X,"f")&&!s?.length&&Promise.reject(r),o(this,ae,"f").call(this,r),o(this,ce,"f").call(this,r),this._emit("end");return}if(e==="error"){const r=t[0];!o(this,X,"f")&&!s?.length&&Promise.reject(r),o(this,ae,"f").call(this,r),o(this,ce,"f").call(this,r),this._emit("end")}}_emitFinal(){this.receivedMessages.at(-1)&&this._emit("finalMessage",o(this,R,"m",Qe).call(this))}async _fromReadableStream(e,t){const s=t?.signal;let r;s&&(s.aborted&&this.controller.abort(),r=this.controller.abort.bind(this.controller),s.addEventListener("abort",r));try{o(this,R,"m",Ye).call(this),this._connected(null);const i=C.fromReadableStream(e,this.controller);for await(const a of i)o(this,R,"m",Ze).call(this,a);if(i.controller.signal?.aborted)throw new A;o(this,R,"m",et).call(this)}finally{s&&r&&s.removeEventListener("abort",r)}}[(q=new WeakMap,ie=new WeakMap,Ee=new WeakMap,ae=new WeakMap,oe=new WeakMap,Pe=new WeakMap,ce=new WeakMap,I=new WeakMap,le=new WeakMap,Oe=new WeakMap,Ce=new WeakMap,X=new WeakMap,je=new WeakMap,Ne=new WeakMap,Ge=new WeakMap,R=new WeakSet,Qe=function(){if(this.receivedMessages.length===0)throw new f("stream ended without producing a Message with role=assistant");return this.receivedMessages.at(-1)},Lt=function(){if(this.receivedMessages.length===0)throw new f("stream ended without producing a Message with role=assistant");const t=this.receivedMessages.at(-1).content.filter(s=>s.type==="text").map(s=>s.text);if(t.length===0)throw new f("stream ended without producing a content block with type=text");return t.join(" ")},Ye=function(){this.ended||u(this,q,void 0)},Ze=function(t){if(this.ended)return;const s=o(this,R,"m",Ut).call(this,t);switch(this._emit("streamEvent",t,s),t.type){case"content_block_delta":{const r=s.content.at(-1);switch(t.delta.type){case"text_delta":{r.type==="text"&&this._emit("text",t.delta.text,r.text||"");break}case"citations_delta":{r.type==="text"&&this._emit("citation",t.delta.citation,r.citations??[]);break}case"input_json_delta":{Wt(r)&&r.input&&this._emit("inputJson",t.delta.partial_json,r.input);break}case"thinking_delta":{r.type==="thinking"&&this._emit("thinking",t.delta.thinking,r.thinking);break}case"signature_delta":{r.type==="thinking"&&this._emit("signature",r.signature);break}default:t.delta}break}case"message_stop":{this._addMessageParam(s),this._addMessage(s,!0);break}case"content_block_stop":{this._emit("contentBlock",s.content.at(-1));break}case"message_start":{u(this,q,s);break}}},et=function(){if(this.ended)throw new f("stream has ended, this shouldn't happen");const t=o(this,q,"f");if(!t)throw new f("request ended without sending any chunks");return u(this,q,void 0),t},Ut=function(t){let s=o(this,q,"f");if(t.type==="message_start"){if(s)throw new f(`Unexpected event order, got ${t.type} before receiving "message_stop"`);return t.message}if(!s)throw new f(`Unexpected event order, got ${t.type} before "message_start"`);switch(t.type){case"message_stop":return s;case"message_delta":return s.stop_reason=t.delta.stop_reason,s.stop_sequence=t.delta.stop_sequence,s.usage.output_tokens=t.usage.output_tokens,t.usage.input_tokens!=null&&(s.usage.input_tokens=t.usage.input_tokens),t.usage.cache_creation_input_tokens!=null&&(s.usage.cache_creation_input_tokens=t.usage.cache_creation_input_tokens),t.usage.cache_read_input_tokens!=null&&(s.usage.cache_read_input_tokens=t.usage.cache_read_input_tokens),t.usage.server_tool_use!=null&&(s.usage.server_tool_use=t.usage.server_tool_use),s;case"content_block_start":return s.content.push({...t.content_block}),s;case"content_block_delta":{const r=s.content.at(t.index);switch(t.delta.type){case"text_delta":{r?.type==="text"&&(s.content[t.index]={...r,text:(r.text||"")+t.delta.text});break}case"citations_delta":{r?.type==="text"&&(s.content[t.index]={...r,citations:[...r.citations??[],t.delta.citation]});break}case"input_json_delta":{if(r&&Wt(r)){let i=r[qt]||"";i+=t.delta.partial_json;const a={...r};Object.defineProperty(a,qt,{value:i,enumerable:!1,writable:!0}),i&&(a.input=bn(i)),s.content[t.index]=a}break}case"thinking_delta":{r?.type==="thinking"&&(s.content[t.index]={...r,thinking:r.thinking+t.delta.thinking});break}case"signature_delta":{r?.type==="thinking"&&(s.content[t.index]={...r,signature:t.delta.signature});break}default:t.delta}return s}case"content_block_stop":return s}},Symbol.asyncIterator)](){const e=[],t=[];let s=!1;return this.on("streamEvent",r=>{const i=t.shift();i?i.resolve(r):e.push(r)}),this.on("end",()=>{s=!0;for(const r of t)r.resolve(void 0);t.length=0}),this.on("abort",r=>{s=!0;for(const i of t)i.reject(r);t.length=0}),this.on("error",r=>{s=!0;for(const i of t)i.reject(r);t.length=0}),{next:async()=>e.length?{value:e.shift(),done:!1}:s?{value:void 0,done:!0}:new Promise((i,a)=>t.push({resolve:i,reject:a})).then(i=>i?{value:i,done:!1}:{value:void 0,done:!0}),return:async()=>(this.abort(),{value:void 0,done:!0})}}toReadableStream(){return new C(this[Symbol.asyncIterator].bind(this),this.controller).toReadableStream()}}class Mn extends B{create(e,t){return this._client.post("/v1/messages/batches",{body:e,...t})}retrieve(e,t){return this._client.get(E`/v1/messages/batches/${e}`,t)}list(e={},t){return this._client.getAPIList("/v1/messages/batches",pe,{query:e,...t})}delete(e,t){return this._client.delete(E`/v1/messages/batches/${e}`,t)}cancel(e,t){return this._client.post(E`/v1/messages/batches/${e}/cancel`,t)}async results(e,t){const s=await this.retrieve(e);if(!s.results_url)throw new f(`No batch \`results_url\`; Has it finished processing? ${s.processing_status} - ${s.id}`);return this._client.get(s.results_url,{...t,headers:_([{Accept:"application/binary"},t?.headers]),stream:!0,__binaryResponse:!0})._thenUnwrap((r,i)=>He.fromResponse(i.response,i.controller))}}class ut extends B{constructor(){super(...arguments),this.batches=new Mn(this._client)}create(e,t){e.model in Ft&&console.warn(`The model '${e.model}' is deprecated and will reach end-of-life on ${Ft[e.model]}
11
+ Please migrate to a newer model. Visit https://docs.anthropic.com/en/docs/resources/model-deprecations for more information.`);let s=this._client._options.timeout;if(!e.stream&&s==null){const r=Sn[e.model]??void 0;s=this._client.calculateNonstreamingTimeout(e.max_tokens,r)}return this._client.post("/v1/messages",{body:e,timeout:s??6e5,...t,stream:e.stream??!1})}stream(e,t){return We.createMessage(this,e,t)}countTokens(e,t){return this._client.post("/v1/messages/count_tokens",{body:e,...t})}}const Ft={"claude-1.3":"November 6th, 2024","claude-1.3-100k":"November 6th, 2024","claude-instant-1.1":"November 6th, 2024","claude-instant-1.1-100k":"November 6th, 2024","claude-instant-1.2":"November 6th, 2024","claude-3-sonnet-20240229":"July 21st, 2025","claude-3-opus-20240229":"January 5th, 2026","claude-2.1":"July 21st, 2025","claude-2.0":"July 21st, 2025","claude-3-5-sonnet-20241022":"October 22, 2025","claude-3-5-sonnet-20240620":"October 22, 2025"};ut.Batches=Mn;class Tn extends B{retrieve(e,t={},s){const{betas:r}=t??{};return this._client.get(E`/v1/models/${e}`,{...s,headers:_([{...r?.toString()!=null?{"anthropic-beta":r?.toString()}:void 0},s?.headers])})}list(e={},t){const{betas:s,...r}=e??{};return this._client.getAPIList("/v1/models",pe,{query:r,...t,headers:_([{...s?.toString()!=null?{"anthropic-beta":s?.toString()}:void 0},t?.headers])})}}var xs={};const Ie=n=>{if(typeof globalThis.process<"u")return xs?.[n]?.trim()??void 0;if(typeof globalThis.Deno<"u")return globalThis.Deno.env?.get?.(n)?.trim()};var at,ht,Le,Rn;const ks="\\n\\nHuman:",Ms="\\n\\nAssistant:";class w{constructor({baseURL:e=Ie("ANTHROPIC_BASE_URL"),apiKey:t=Ie("ANTHROPIC_API_KEY")??null,authToken:s=Ie("ANTHROPIC_AUTH_TOKEN")??null,...r}={}){at.add(this),Le.set(this,void 0);const i={apiKey:t,authToken:s,...r,baseURL:e||"https://api.anthropic.com"};if(!i.dangerouslyAllowBrowser&&Hn())throw new f(`It looks like you're running in a browser-like environment.
12
+
13
+ This is disabled by default, as it risks exposing your secret API credentials to attackers.
14
+ If you understand the risks and have appropriate mitigations in place,
15
+ you can set the \`dangerouslyAllowBrowser\` option to \`true\`, e.g.,
16
+
17
+ new Anthropic({ apiKey, dangerouslyAllowBrowser: true });
18
+ `);this.baseURL=i.baseURL,this.timeout=i.timeout??ht.DEFAULT_TIMEOUT,this.logger=i.logger??console;const a="warn";this.logLevel=a,this.logLevel=At(i.logLevel,"ClientOptions.logLevel",this)??At(Ie("ANTHROPIC_LOG"),"process.env['ANTHROPIC_LOG']",this)??a,this.fetchOptions=i.fetchOptions,this.maxRetries=i.maxRetries??2,this.fetch=i.fetch??Vn(),u(this,Le,Gn),this._options=i,this.apiKey=t,this.authToken=s}withOptions(e){return new this.constructor({...this._options,baseURL:this.baseURL,maxRetries:this.maxRetries,timeout:this.timeout,logger:this.logger,logLevel:this.logLevel,fetch:this.fetch,fetchOptions:this.fetchOptions,apiKey:this.apiKey,authToken:this.authToken,...e})}defaultQuery(){return this._options.defaultQuery}validateHeaders({values:e,nulls:t}){if(!(this.apiKey&&e.get("x-api-key"))&&!t.has("x-api-key")&&!(this.authToken&&e.get("authorization"))&&!t.has("authorization"))throw new Error('Could not resolve authentication method. Expected either apiKey or authToken to be set. Or for one of the "X-Api-Key" or "Authorization" headers to be explicitly omitted')}async authHeaders(e){return _([await this.apiKeyAuth(e),await this.bearerAuth(e)])}async apiKeyAuth(e){if(this.apiKey!=null)return _([{"X-Api-Key":this.apiKey}])}async bearerAuth(e){if(this.authToken!=null)return _([{Authorization:`Bearer ${this.authToken}`}])}stringifyQuery(e){return Object.entries(e).filter(([t,s])=>typeof s<"u").map(([t,s])=>{if(typeof s=="string"||typeof s=="number"||typeof s=="boolean")return`${encodeURIComponent(t)}=${encodeURIComponent(s)}`;if(s===null)return`${encodeURIComponent(t)}=`;throw new f(`Cannot stringify type ${typeof s}; Expected string, number, boolean, or null. If you need to pass nested query parameters, you can manually encode them, e.g. { query: { 'foo[key1]': value1, 'foo[key2]': value2 } }, and please open a GitHub issue requesting better support for your use case.`)}).join("&")}getUserAgent(){return`${this.constructor.name}/JS ${z}`}defaultIdempotencyKey(){return`stainless-node-retry-${Qt()}`}makeStatusError(e,t,s,r){return b.generate(e,t,s,r)}buildURL(e,t,s){const r=!o(this,at,"m",Rn).call(this)&&s||this.baseURL,i=Un(e)?new URL(e):new URL(r+(r.endsWith("/")&&e.startsWith("/")?e.slice(1):e)),a=this.defaultQuery();return qn(a)||(t={...a,...t}),typeof t=="object"&&t&&!Array.isArray(t)&&(i.search=this.stringifyQuery(t)),i.toString()}_calculateNonstreamingTimeout(e){if(3600*e/128e3>600)throw new f("Streaming is required for operations that may take longer than 10 minutes. See https://github.com/anthropics/anthropic-sdk-typescript#streaming-responses for more details");return 600*1e3}async prepareOptions(e){}async prepareRequest(e,{url:t,options:s}){}get(e,t){return this.methodRequest("get",e,t)}post(e,t){return this.methodRequest("post",e,t)}patch(e,t){return this.methodRequest("patch",e,t)}put(e,t){return this.methodRequest("put",e,t)}delete(e,t){return this.methodRequest("delete",e,t)}methodRequest(e,t,s){return this.request(Promise.resolve(s).then(r=>({method:e,path:t,...r})))}request(e,t=null){return new De(this,this.makeRequest(e,t,void 0))}async makeRequest(e,t,s){const r=await e,i=r.maxRetries??this.maxRetries;t==null&&(t=i),await this.prepareOptions(r);const{req:a,url:c,timeout:l}=await this.buildRequest(r,{retryCount:i-t});await this.prepareRequest(a,{url:c,options:r});const d="log_"+(Math.random()*(1<<24)|0).toString(16).padStart(6,"0"),p=s===void 0?"":`, retryOf: ${s}`,m=Date.now();if(S(this).debug(`[${d}] sending request`,H({retryOfRequestLogID:s,method:r.method,url:c,options:r,headers:a.headers})),r.signal?.aborted)throw new A;const y=new AbortController,h=await this.fetchWithTimeout(c,a,l,y).catch(tt),g=Date.now();if(h instanceof globalThis.Error){const j=`retrying, ${t} attempts remaining`;if(r.signal?.aborted)throw new A;const P=de(h)||/timed? ?out/i.test(String(h)+("cause"in h?String(h.cause):""));if(t)return S(this).info(`[${d}] connection ${P?"timed out":"failed"} - ${j}`),S(this).debug(`[${d}] connection ${P?"timed out":"failed"} (${j})`,H({retryOfRequestLogID:s,url:c,durationMs:g-m,message:h.message})),this.retryRequest(r,t,s??d);throw S(this).info(`[${d}] connection ${P?"timed out":"failed"} - error; no more retries left`),S(this).debug(`[${d}] connection ${P?"timed out":"failed"} (error; no more retries left)`,H({retryOfRequestLogID:s,url:c,durationMs:g-m,message:h.message})),P?new Gt:new Fe({cause:h})}const W=[...h.headers.entries()].filter(([j])=>j==="request-id").map(([j,P])=>", "+j+": "+JSON.stringify(P)).join(""),F=`[${d}${p}${W}] ${a.method} ${c} ${h.ok?"succeeded":"failed"} with status ${h.status} in ${g-m}ms`;if(!h.ok){const j=await this.shouldRetry(h);if(t&&j){const _e=`retrying, ${t} attempts remaining`;return await Qn(h.body),S(this).info(`${F} - ${_e}`),S(this).debug(`[${d}] response error (${_e})`,H({retryOfRequestLogID:s,url:h.url,status:h.status,headers:h.headers,durationMs:g-m})),this.retryRequest(r,t,s??d,h.headers)}const P=j?"error; no more retries left":"error; not retryable";S(this).info(`${F} - ${P}`);const dt=await h.text().catch(_e=>tt(_e).message),ft=on(dt),pt=ft?void 0:dt;throw S(this).debug(`[${d}] response error (${P})`,H({retryOfRequestLogID:s,url:h.url,status:h.status,headers:h.headers,message:pt,durationMs:Date.now()-m})),this.makeStatusError(h.status,ft,pt,h.headers)}return S(this).info(F),S(this).debug(`[${d}] response start`,H({retryOfRequestLogID:s,url:h.url,status:h.status,headers:h.headers,durationMs:g-m})),{response:h,options:r,controller:y,requestLogID:d,retryOfRequestLogID:s,startTime:m}}getAPIList(e,t,s){return this.requestAPIList(t,{method:"get",path:e,...s})}requestAPIList(e,t){const s=this.makeRequest(t,null,void 0);return new os(this,s,e)}async fetchWithTimeout(e,t,s,r){const{signal:i,method:a,...c}=t||{};i&&i.addEventListener("abort",()=>r.abort());const l=setTimeout(()=>r.abort(),s),d=globalThis.ReadableStream&&c.body instanceof globalThis.ReadableStream||typeof c.body=="object"&&c.body!==null&&Symbol.asyncIterator in c.body,p={signal:r.signal,...d?{duplex:"half"}:{},method:"GET",...c};a&&(p.method=a.toUpperCase());try{return await this.fetch.call(void 0,e,p)}finally{clearTimeout(l)}}async shouldRetry(e){const t=e.headers.get("x-should-retry");return t==="true"?!0:t==="false"?!1:e.status===408||e.status===409||e.status===429||e.status>=500}async retryRequest(e,t,s,r){let i;const a=r?.get("retry-after-ms");if(a){const l=parseFloat(a);Number.isNaN(l)||(i=l)}const c=r?.get("retry-after");if(c&&!i){const l=parseFloat(c);Number.isNaN(l)?i=Date.parse(c)-Date.now():i=l*1e3}if(!(i&&0<=i&&i<60*1e3)){const l=e.maxRetries??this.maxRetries;i=this.calculateDefaultRetryTimeoutMillis(t,l)}return await Dn(i),this.makeRequest(e,t-1,s)}calculateDefaultRetryTimeoutMillis(e,t){const i=t-e,a=Math.min(.5*Math.pow(2,i),8),c=1-Math.random()*.25;return a*c*1e3}calculateNonstreamingTimeout(e,t){if(36e5*e/128e3>6e5||t!=null&&e>t)throw new f("Streaming is required for operations that may take longer than 10 minutes. See https://github.com/anthropics/anthropic-sdk-typescript#long-requests for more details");return 6e5}async buildRequest(e,{retryCount:t=0}={}){const s={...e},{method:r,path:i,query:a,defaultBaseURL:c}=s,l=this.buildURL(i,a,c);"timeout"in s&&Fn("timeout",s.timeout),s.timeout=s.timeout??this.timeout;const{bodyHeaders:d,body:p}=this.buildBody({options:s}),m=await this.buildHeaders({options:e,method:r,bodyHeaders:d,retryCount:t});return{req:{method:r,headers:m,...s.signal&&{signal:s.signal},...globalThis.ReadableStream&&p instanceof globalThis.ReadableStream&&{duplex:"half"},...p&&{body:p},...this.fetchOptions??{},...s.fetchOptions??{}},url:l,timeout:s.timeout}}async buildHeaders({options:e,method:t,bodyHeaders:s,retryCount:r}){let i={};this.idempotencyHeader&&t!=="get"&&(e.idempotencyKey||(e.idempotencyKey=this.defaultIdempotencyKey()),i[this.idempotencyHeader]=e.idempotencyKey);const a=_([i,{Accept:"application/json","User-Agent":this.getUserAgent(),"X-Stainless-Retry-Count":String(r),...e.timeout?{"X-Stainless-Timeout":String(Math.trunc(e.timeout/1e3))}:{},...zn(),...this._options.dangerouslyAllowBrowser?{"anthropic-dangerous-direct-browser-access":"true"}:void 0,"anthropic-version":"2023-06-01"},await this.authHeaders(e),this._options.defaultHeaders,s,e.headers]);return this.validateHeaders(a),a.values}buildBody({options:{body:e,headers:t}}){if(!e)return{bodyHeaders:void 0,body:void 0};const s=_([t]);return ArrayBuffer.isView(e)||e instanceof ArrayBuffer||e instanceof DataView||typeof e=="string"&&s.values.has("content-type")||globalThis.Blob&&e instanceof globalThis.Blob||e instanceof FormData||e instanceof URLSearchParams||globalThis.ReadableStream&&e instanceof globalThis.ReadableStream?{bodyHeaders:void 0,body:e}:typeof e=="object"&&(Symbol.asyncIterator in e||Symbol.iterator in e&&"next"in e&&typeof e.next=="function")?{bodyHeaders:void 0,body:ln(e)}:o(this,Le,"f").call(this,{body:e,headers:s})}}ht=w,Le=new WeakMap,at=new WeakSet,Rn=function(){return this.baseURL!=="https://api.anthropic.com"};w.Anthropic=ht;w.HUMAN_PROMPT=ks;w.AI_PROMPT=Ms;w.DEFAULT_TIMEOUT=6e5;w.AnthropicError=f;w.APIError=b;w.APIConnectionError=Fe;w.APIConnectionTimeoutError=Gt;w.APIUserAbortError=A;w.NotFoundError=tn;w.ConflictError=nn;w.RateLimitError=rn;w.BadRequestError=Yt;w.AuthenticationError=Zt;w.InternalServerError=an;w.PermissionDeniedError=en;w.UnprocessableEntityError=sn;w.toFile=ps;class ge extends w{constructor(){super(...arguments),this.completions=new kn(this),this.messages=new ut(this),this.models=new Tn(this),this.beta=new me(this)}}ge.Completions=kn;ge.Messages=ut;ge.Models=Tn;ge.Beta=me;class Dt extends An{static lc_name(){return"AnthropicToolsOutputParser"}constructor(e){super(e),Object.defineProperty(this,"lc_namespace",{enumerable:!0,configurable:!0,writable:!0,value:["langchain","anthropic","output_parsers"]}),Object.defineProperty(this,"returnId",{enumerable:!0,configurable:!0,writable:!0,value:!1}),Object.defineProperty(this,"keyName",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"returnSingle",{enumerable:!0,configurable:!0,writable:!0,value:!1}),Object.defineProperty(this,"zodSchema",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.keyName=e.keyName,this.returnSingle=e.returnSingle??this.returnSingle,this.zodSchema=e.zodSchema}async _validateResult(e){let t=e;if(typeof e=="string")try{t=JSON.parse(e)}catch(r){throw new mt(`Failed to parse. Text: "${JSON.stringify(e,null,2)}". Error: ${JSON.stringify(r.message)}`,e)}else t=e;if(this.zodSchema===void 0)return t;const s=await En(this.zodSchema,t);if(s.success)return s.data;throw new mt(`Failed to parse. Text: "${JSON.stringify(e,null,2)}". Error: ${JSON.stringify(s.error.issues)}`,JSON.stringify(t,null,2))}async parseResult(e){const t=e.flatMap(i=>{const{message:a}=i;return Array.isArray(a.content)?vn(a.content)[0]:[]});if(t[0]===void 0)throw new Error("No parseable tool calls provided to AnthropicToolsOutputParser.");const[s]=t;return await this._validateResult(s.args)}}function vn(n){const e=[];for(const t of n)t.type==="tool_use"&&e.push({name:t.name,args:t.input,id:t.id,type:"tool_call"});return e}function Ts(n){if(n)return n==="any"?{type:"any"}:n==="auto"?{type:"auto"}:n==="none"?{type:"none"}:typeof n=="string"?{type:"tool",name:n}:n}function Rs(n){return n==null||typeof n!="object"||!("type"in n)||n.type!=="image"||!("source"in n)||typeof n.source!="object"||n.source==null||!("type"in n.source)?!1:n.source.type==="base64"?!(!("media_type"in n.source)||typeof n.source.media_type!="string"||!("data"in n.source)||typeof n.source.data!="string"):n.source.type==="url"?!(!("url"in n.source)||typeof n.source.url!="string"):!1}function Ht(n){const e=Vt({dataUrl:n});if(e)return{type:"base64",media_type:e.mime_type,data:e.data};let t;try{t=new URL(n)}catch{throw new Error([`Malformed image URL: ${JSON.stringify(n)}. Content blocks of type 'image_url' must be a valid http, https, or base64-encoded data URL.`,"Example: data:image/png;base64,/9j/4AAQSk...","Example: https://example.com/image.jpg"].join(`
19
+
20
+ `))}if(t.protocol==="http:"||t.protocol==="https:")return{type:"url",url:n};throw new Error([`Invalid image URL protocol: ${JSON.stringify(t.protocol)}. Anthropic only supports images as http, https, or base64-encoded data URLs on 'image_url' content blocks.`,"Example: data:image/png;base64,/9j/4AAQSk...","Example: https://example.com/image.jpg"].join(`
21
+
22
+ `))}function vs(n){const e=[];for(const t of n)if(t._getType()==="tool")if(typeof t.content=="string"){const s=e[e.length-1];s?._getType()==="human"&&Array.isArray(s.content)&&"type"in s.content[0]&&s.content[0].type==="tool_result"?s.content.push({type:"tool_result",content:t.content,tool_use_id:t.tool_call_id}):e.push(new gt({content:[{type:"tool_result",content:t.content,tool_use_id:t.tool_call_id}]}))}else e.push(new gt({content:[{type:"tool_result",...t.content!=null?{content:ot(t)}:{},tool_use_id:t.tool_call_id}]}));else e.push(t);return e}function Jt(n){if(n.id===void 0)throw new Error('Anthropic requires all tool calls to have an "id".');return{type:"tool_use",id:n.id,name:n.name,input:n.args}}const As={providerName:"anthropic",fromStandardTextBlock(n){return{type:"text",text:n.text,..."citations"in(n.metadata??{})?{citations:n.metadata.citations}:{},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{}}},fromStandardImageBlock(n){if(n.source_type==="url"){const e=Vt({dataUrl:n.url,asTypedArray:!1});return e?{type:"image",source:{type:"base64",data:e.data,media_type:e.mime_type},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{}}:{type:"image",source:{type:"url",url:n.url},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{}}}else{if(n.source_type==="base64")return{type:"image",source:{type:"base64",data:n.data,media_type:n.mime_type??""},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{}};throw new Error(`Unsupported image source type: ${n.source_type}`)}},fromStandardFileBlock(n){const e=(n.mime_type??"").split(";")[0];if(n.source_type==="url"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"url",url:n.url,media_type:n.mime_type??""},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{},..."citations"in(n.metadata??{})?{citations:n.metadata.citations}:{},..."context"in(n.metadata??{})?{context:n.metadata.context}:{},..."title"in(n.metadata??{})?{title:n.metadata.title}:{}};throw new Error(`Unsupported file mime type for file url source: ${n.mime_type}`)}else if(n.source_type==="text"){if(e==="text/plain"||e==="")return{type:"document",source:{type:"text",data:n.text,media_type:n.mime_type??""},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{},..."citations"in(n.metadata??{})?{citations:n.metadata.citations}:{},..."context"in(n.metadata??{})?{context:n.metadata.context}:{},..."title"in(n.metadata??{})?{title:n.metadata.title}:{}};throw new Error(`Unsupported file mime type for file text source: ${n.mime_type}`)}else if(n.source_type==="base64"){if(e==="application/pdf"||e==="")return{type:"document",source:{type:"base64",data:n.data,media_type:"application/pdf"},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{},..."citations"in(n.metadata??{})?{citations:n.metadata.citations}:{},..."context"in(n.metadata??{})?{context:n.metadata.context}:{},..."title"in(n.metadata??{})?{title:n.metadata.title}:{}};if(["image/jpeg","image/png","image/gif","image/webp"].includes(e))return{type:"document",source:{type:"content",content:[{type:"image",source:{type:"base64",data:n.data,media_type:e}}]},..."cache_control"in(n.metadata??{})?{cache_control:n.metadata.cache_control}:{},..."citations"in(n.metadata??{})?{citations:n.metadata.citations}:{},..."context"in(n.metadata??{})?{context:n.metadata.context}:{},..."title"in(n.metadata??{})?{title:n.metadata.title}:{}};throw new Error(`Unsupported file mime type for file base64 source: ${n.mime_type}`)}else throw new Error(`Unsupported file source type: ${n.source_type}`)}};function ot(n){const e=["tool_use","tool_result","input_json_delta","server_tool_use","web_search_tool_result","web_search_result"],t=["text","text_delta"],{content:s}=n;return typeof s=="string"?s:s.map(i=>{if(Pn(i))return On(i,As);const a="cache_control"in i?i.cache_control:void 0;if(i.type==="image_url"){let c;return typeof i.image_url=="string"?c=Ht(i.image_url):c=Ht(i.image_url.url),{type:"image",source:c,...a?{cache_control:a}:{}}}else{if(Rs(i))return i;if(i.type==="document")return{...i,...a?{cache_control:a}:{}};if(i.type==="thinking")return{type:"thinking",thinking:i.thinking,signature:i.signature,...a?{cache_control:a}:{}};if(i.type==="redacted_thinking")return{type:"redacted_thinking",data:i.data,...a?{cache_control:a}:{}};if(i.type==="search_result")return{type:"search_result",title:i.title,source:i.source,..."cache_control"in i&&i.cache_control?{cache_control:i.cache_control}:{},..."citations"in i&&i.citations?{citations:i.citations}:{},content:i.content};if(t.find(c=>c===i.type)&&"text"in i)return{type:"text",text:i.text,...a?{cache_control:a}:{},..."citations"in i&&i.citations?{citations:i.citations}:{}};if(e.find(c=>c===i.type)){const c={...i};if("index"in c&&delete c.index,c.type==="input_json_delta"&&(c.type="tool_use"),"input"in c&&typeof c.input=="string")try{c.input=JSON.parse(c.input)}catch{c.input={}}return{...c,...a?{cache_control:a}:{}}}else if("functionCall"in i&&i.functionCall&&typeof i.functionCall=="object"&&zt(n)){const c=n.tool_calls?.find(l=>l.name===i.functionCall.name);if(!c)throw new Error(`Could not find tool call for function call ${i.functionCall.name}`);return{id:c.id,type:"tool_use",name:c.name,input:i.functionCall.args}}else throw new Error("Unsupported message content format")}})}function Kt(n){const e=vs(n);let t;e.length>0&&e[0]._getType()==="system"&&(t=n[0].content);const r=(t!==void 0?e.slice(1):e).map(i=>{let a;if(i._getType()==="human")a="user";else if(i._getType()==="ai")a="assistant";else if(i._getType()==="tool")a="user";else throw i._getType()==="system"?new Error("System messages are only permitted as the first passed message."):new Error(`Message type "${i._getType()}" is not supported.`);if(zt(i)&&i.tool_calls?.length){if(typeof i.content=="string")return i.content===""?{role:a,content:i.tool_calls.map(Jt)}:{role:a,content:[{type:"text",text:i.content},...i.tool_calls.map(Jt)]};{const{content:c}=i;return!i.tool_calls.every(d=>c.find(p=>(p.type==="tool_use"||p.type==="input_json_delta"||p.type==="server_tool_use")&&p.id===d.id))&&console.warn('The "tool_calls" field on a message is only respected if content is a string.'),{role:a,content:ot(i)}}}else return{role:a,content:ot(i)}});return{messages:Es(r),system:t}}function Es(n){if(!n||n.length<=1)return n;const e=[];let t=n[0];const s=i=>typeof i=="string"?[{type:"text",text:i}]:i,r=i=>i.role!=="user"||typeof i.content=="string"?!1:Array.isArray(i.content)&&i.content.every(a=>a.type==="tool_result");for(let i=1;i<n.length;i+=1){const a=n[i];r(t)&&r(a)?t={...t,content:[...s(t.content),...s(a.content)]}:(e.push(t),t=a)}return e.push(t),e}function Ps(n,e){if(n.type==="message_start"){const{content:t,usage:s,...r}=n.message,i={};for(const[p,m]of Object.entries(r))m!=null&&(i[p]=m);const{input_tokens:a,output_tokens:c,...l}=s??{},d={input_tokens:a,output_tokens:c,total_tokens:a+c,input_token_details:{cache_creation:l.cache_creation_input_tokens,cache_read:l.cache_read_input_tokens}};return{chunk:new v({content:e.coerceContentToString?"":[],additional_kwargs:i,usage_metadata:e.streamUsage?d:void 0,response_metadata:{usage:{...l}},id:n.message.id})}}else if(n.type==="message_delta"){const t={input_tokens:0,output_tokens:n.usage.output_tokens,total_tokens:n.usage.output_tokens,input_token_details:{cache_creation:n.usage.cache_creation_input_tokens,cache_read:n.usage.cache_read_input_tokens}},s="context_management"in n.delta?{context_management:n.delta.context_management}:void 0;return{chunk:new v({content:e.coerceContentToString?"":[],additional_kwargs:{...n.delta},usage_metadata:e.streamUsage?t:void 0,response_metadata:s})}}else if(n.type==="content_block_start"&&["tool_use","document","server_tool_use","web_search_tool_result"].includes(n.content_block.type)){const t=n.content_block;let s;return t.type==="tool_use"?s=[{id:t.id,index:n.index,name:t.name,args:""}]:s=[],{chunk:new v({content:e.coerceContentToString?"":[{index:n.index,...n.content_block,input:t.type==="server_tool_use"||t.type==="tool_use"?"":void 0}],additional_kwargs:{},tool_call_chunks:s})}}else if(n.type==="content_block_delta"&&["text_delta","citations_delta","thinking_delta","signature_delta"].includes(n.delta.type)){if(e.coerceContentToString&&"text"in n.delta)return{chunk:new v({content:n.delta.text})};{const t=n.delta;return"citation"in t&&(t.citations=[t.citation],delete t.citation),t.type==="thinking_delta"||t.type==="signature_delta"?{chunk:new v({content:[{index:n.index,...t,type:"thinking"}]})}:{chunk:new v({content:[{index:n.index,...t,type:"text"}]})}}}else{if(n.type==="content_block_delta"&&n.delta.type==="input_json_delta")return{chunk:new v({content:e.coerceContentToString?"":[{index:n.index,input:n.delta.partial_json,type:n.delta.type}],additional_kwargs:{},tool_call_chunks:[{index:n.index,args:n.delta.partial_json}]})};if(n.type==="content_block_start"&&n.content_block.type==="text"){const t=n.content_block?.text;if(t!==void 0)return{chunk:new v({content:e.coerceContentToString?t:[{index:n.index,...n.content_block}],additional_kwargs:{}})}}else{if(n.type==="content_block_start"&&n.content_block.type==="redacted_thinking")return{chunk:new v({content:e.coerceContentToString?"":[{index:n.index,...n.content_block}]})};if(n.type==="content_block_start"&&n.content_block.type==="thinking"){const t=n.content_block.thinking;return{chunk:new v({content:e.coerceContentToString?t:[{index:n.index,...n.content_block}]})}}}}return null}function Os(n,e){const t=e.usage,s=t!=null?{input_tokens:t.input_tokens??0,output_tokens:t.output_tokens??0,total_tokens:(t.input_tokens??0)+(t.output_tokens??0),input_token_details:{cache_creation:t.cache_creation_input_tokens,cache_read:t.cache_read_input_tokens}}:void 0;if(n.length===1&&n[0].type==="text")return[{text:n[0].text,message:new _t({content:n[0].text,additional_kwargs:e,usage_metadata:s,response_metadata:e,id:e.id})}];{const r=vn(n);return[{text:"",message:new _t({content:n,additional_kwargs:e,tool_calls:r,usage_metadata:s,response_metadata:e,id:e.id})}]}}function $e(n,e){return n.lc_error_code=e,n.message=`${n.message}
23
+
24
+ Troubleshooting URL: https://js.langchain.com/docs/troubleshooting/errors/${e}/
25
+ `,n}function Xt(n){let e;return n.status===400&&n.message.includes("tool")?e=$e(n,"INVALID_TOOL_RESULTS"):n.status===401?e=$e(n,"MODEL_AUTHENTICATION"):n.status===404?e=$e(n,"MODEL_NOT_FOUND"):n.status===429?e=$e(n,"MODEL_RATE_LIMIT"):e=n,e}function Cs(n){return!!(n.tools&&n.tools.length>0)}function js(n){for(const e of n.messages??[])if(typeof e.content!="string"){for(const t of e.content??[])if(typeof t=="object"&&t!=null&&t.type==="document"&&typeof t.citations=="object"&&t.citations?.enabled)return!0}return!1}function Ns(n){return!!(n.thinking&&n.thinking.type==="enabled")}function Is(n){return"input_schema"in n}function $s(n){const e=["text_editor_","computer_","bash_","web_search_","web_fetch_","str_replace_editor_","str_replace_based_edit_tool_","code_execution_","memory_"];return typeof n=="object"&&n!==null&&"type"in n&&"name"in n&&e.some(t=>typeof n.type=="string"&&n.type.startsWith(t))}function Bs(n){if(typeof n.content=="string")return n.content;if(Array.isArray(n.content)&&n.content.length>=1&&"input"in n.content[0])return typeof n.content[0].input=="string"?n.content[0].input:JSON.stringify(n.content[0].input);if(Array.isArray(n.content)&&n.content.length>=1&&"text"in n.content[0])return n.content[0].text}class Ls extends Cn{static lc_name(){return"ChatAnthropic"}get lc_secrets(){return{anthropicApiKey:"ANTHROPIC_API_KEY",apiKey:"ANTHROPIC_API_KEY"}}get lc_aliases(){return{modelName:"model"}}constructor(e){if(super(e??{}),Object.defineProperty(this,"lc_serializable",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"anthropicApiKey",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"apiKey",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"apiUrl",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"temperature",{enumerable:!0,configurable:!0,writable:!0,value:1}),Object.defineProperty(this,"topK",{enumerable:!0,configurable:!0,writable:!0,value:-1}),Object.defineProperty(this,"topP",{enumerable:!0,configurable:!0,writable:!0,value:-1}),Object.defineProperty(this,"maxTokens",{enumerable:!0,configurable:!0,writable:!0,value:2048}),Object.defineProperty(this,"modelName",{enumerable:!0,configurable:!0,writable:!0,value:"claude-2.1"}),Object.defineProperty(this,"model",{enumerable:!0,configurable:!0,writable:!0,value:"claude-2.1"}),Object.defineProperty(this,"invocationKwargs",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"stopSequences",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"streaming",{enumerable:!0,configurable:!0,writable:!0,value:!1}),Object.defineProperty(this,"clientOptions",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"thinking",{enumerable:!0,configurable:!0,writable:!0,value:{type:"disabled"}}),Object.defineProperty(this,"contextManagement",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"batchClient",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"streamingClient",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"streamUsage",{enumerable:!0,configurable:!0,writable:!0,value:!0}),Object.defineProperty(this,"createClient",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.anthropicApiKey=e?.apiKey??e?.anthropicApiKey??jn("ANTHROPIC_API_KEY"),!this.anthropicApiKey&&!e?.createClient)throw new Error("Anthropic API key not found");this.clientOptions=e?.clientOptions??{},this.apiKey=this.anthropicApiKey,this.apiUrl=e?.anthropicApiUrl,this.modelName=e?.model??e?.modelName??this.model,this.model=this.modelName,this.invocationKwargs=e?.invocationKwargs??{},this.model.includes("opus-4-1")||this.model.includes("sonnet-4-5")?this.topP=e?.topP===null?void 0:e?.topP:this.topP=e?.topP??this.topP,this.temperature=e?.temperature===null?void 0:e?.temperature??this.temperature,this.topK=e?.topK??this.topK,this.maxTokens=e?.maxTokensToSample??e?.maxTokens??this.maxTokens,this.stopSequences=e?.stopSequences??this.stopSequences,this.streaming=e?.streaming??!1,this.streamUsage=e?.streamUsage??this.streamUsage,this.thinking=e?.thinking??this.thinking,this.createClient=e?.createClient??(t=>new ge(t))}getLsParams(e){const t=this.invocationParams(e);return{ls_provider:"anthropic",ls_model_name:this.model,ls_model_type:"chat",ls_temperature:t.temperature??void 0,ls_max_tokens:t.max_tokens??void 0,ls_stop:e.stop}}formatStructuredToolToAnthropic(e){if(!(!e||!e.length))return e.map(t=>{if($s(t)||Is(t))return t;if(Nn(t))return{name:t.function.name,description:t.function.description,input_schema:t.function.parameters};if(In(t))return{name:t.name,description:t.description,input_schema:yt(t.schema)?ye(t.schema):t.schema};throw new Error(`Unknown tool type passed to ChatAnthropic: ${JSON.stringify(t,null,2)}`)})}bindTools(e,t){return this.withConfig({tools:this.formatStructuredToolToAnthropic(e),...t})}invocationParams(e){const t=Ts(e?.tool_choice);if(this.thinking.type==="enabled"){if(this.topK!==-1)throw new Error("topK is not supported when thinking is enabled");if(this.model.includes("opus-4-1")||this.model.includes("sonnet-4-5")?this.topP!==void 0:this.topP!==-1)throw new Error("topP is not supported when thinking is enabled");if(this.temperature!==1)throw new Error("temperature is not supported when thinking is enabled");return{model:this.model,stop_sequences:e?.stop??this.stopSequences,stream:this.streaming,max_tokens:this.maxTokens,tools:this.formatStructuredToolToAnthropic(e?.tools),tool_choice:t,thinking:this.thinking,...this.invocationKwargs}}return{model:this.model,temperature:this.temperature,top_k:this.topK,top_p:this.topP,stop_sequences:e?.stop??this.stopSequences,stream:this.streaming,max_tokens:this.maxTokens,tools:this.formatStructuredToolToAnthropic(e?.tools),tool_choice:t,thinking:this.thinking,context_management:this.contextManagement,...this.invocationKwargs}}_identifyingParams(){return{model_name:this.model,...this.invocationParams()}}identifyingParams(){return{model_name:this.model,...this.invocationParams()}}async*_streamResponseChunks(e,t,s){const r=this.invocationParams(t),i=Kt(e),a={...r,...i,stream:!0},c=!Cs(a)&&!js(a)&&!Ns(a),l=await this.createStreamWithRetry(a,{headers:t.headers});for await(const d of l){if(t.signal?.aborted)throw l.controller.abort(),new Error("AbortError: User aborted the request.");const p=this.streamUsage??t.streamUsage,m=Ps(d,{streamUsage:p,coerceContentToString:c});if(!m)continue;const{chunk:y}=m,h=Bs(y),g=new $n({message:new v({content:y.content,additional_kwargs:y.additional_kwargs,tool_call_chunks:y.tool_call_chunks,usage_metadata:p?y.usage_metadata:void 0,response_metadata:y.response_metadata,id:y.id}),text:h??""});yield g,await s?.handleLLMNewToken(h??"",void 0,void 0,void 0,void 0,{chunk:g})}}async _generateNonStreaming(e,t,s){const r=await this.completionWithRetry({...t,stream:!1,...Kt(e)},s),{content:i,...a}=r,c=Os(i,a),{role:l,type:d,...p}=a;return{generations:c,llmOutput:p}}async _generate(e,t,s){if(this.stopSequences&&t.stop)throw new Error('"stopSequence" parameter found in input and default params');const r=this.invocationParams(t);if(r.stream){let i;const a=this._streamResponseChunks(e,t,s);for await(const c of a)i===void 0?i=c:i=i.concat(c);if(i===void 0)throw new Error("No chunks returned from Anthropic API.");return{generations:[{text:i.text,message:i.message}]}}else return this._generateNonStreaming(e,r,{signal:t.signal,headers:t.headers})}async createStreamWithRetry(e,t){if(!this.streamingClient){const r=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.streamingClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...r,apiKey:this.apiKey,maxRetries:0})}const s=async()=>{try{return await this.streamingClient.messages.create({...e,...this.invocationKwargs,stream:!0},t)}catch(r){throw Xt(r)}};return this.caller.call(s)}async completionWithRetry(e,t){if(!this.batchClient){const r=this.apiUrl?{baseURL:this.apiUrl}:void 0;this.batchClient=this.createClient({dangerouslyAllowBrowser:!0,...this.clientOptions,...r,apiKey:this.apiKey,maxRetries:0})}const s=async()=>{try{return await this.batchClient.messages.create({...e,...this.invocationKwargs},t)}catch(r){throw Xt(r)}};return this.caller.callWithOptions({signal:t.signal??void 0},s)}_llmType(){return"anthropic"}withStructuredOutput(e,t){const s=e,r=t?.name,i=t?.method,a=t?.includeRaw;if(i==="jsonMode")throw new Error('Anthropic only supports "functionCalling" as a method.');let c=r??"extract",l,d;if(yt(s)){const g=ye(s);d=[{name:c,description:g.description??"A function available to call.",input_schema:g}],l=new Dt({returnSingle:!0,keyName:c,zodSchema:s})}else{let g;typeof s.name=="string"&&typeof s.description=="string"&&typeof s.input_schema=="object"&&s.input_schema!=null?(g=s,c=s.name):g={name:c,description:s.description??"",input_schema:s},d=[g],l=new Dt({returnSingle:!0,keyName:c})}let p;if(this.thinking?.type==="enabled"){const g="Anthropic structured output relies on forced tool calling, which is not supported when `thinking` is enabled. This method will raise OutputParserException if tool calls are not generated. Consider disabling `thinking` or adjust your prompt to ensure the tool is called.";console.warn(g),p=this.withConfig({tools:d,ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ye(s)}});const W=F=>{if(!F.tool_calls||F.tool_calls.length===0)throw new Error(g);return F};p=p.pipe(W)}else p=this.withConfig({tools:d,tool_choice:{type:"tool",name:c},ls_structured_output_format:{kwargs:{method:"functionCalling"},schema:ye(s)}});if(!a)return p.pipe(l).withConfig({runName:"ChatAnthropicStructuredOutput"});const m=wt.assign({parsed:(g,W)=>l.invoke(g.raw,W)}),y=wt.assign({parsed:()=>null}),h=m.withFallbacks({fallbacks:[y]});return Bn.from([{raw:p},h]).withConfig({runName:"StructuredOutputRunnable"})}}class Ks extends Ls{}export{Ks as ChatAnthropic,Ls as ChatAnthropicMessages};