promptfoo 0.120.26 → 0.121.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (366) hide show
  1. package/README.md +1 -1
  2. package/dist/drizzle/0023_wooden_mandrill.sql +2 -0
  3. package/dist/drizzle/meta/0023_snapshot.json +1496 -0
  4. package/dist/drizzle/meta/_journal.json +7 -0
  5. package/dist/src/{ListApp-D3DG0F8h.js → ListApp-Du7YVwj5.js} +2 -4
  6. package/dist/src/accounts-BgNJDBE6.js +206 -0
  7. package/dist/src/{accounts-BzEY8H3v.cjs → accounts-Bx-x3bmW.cjs} +99 -80
  8. package/dist/src/{accounts-DHHiXsy6.js → accounts-CMqkzrVf.js} +61 -36
  9. package/dist/src/{accounts-R3gfCR_g.js → accounts-xrUGFA6n.js} +60 -35
  10. package/dist/src/{agentic-utils-D6_gzOUF.js → agentic-utils-BKIN5PKu.js} +9 -10
  11. package/dist/src/{agents-CwM7re15.cjs → agents-B0f4HICh.cjs} +37 -40
  12. package/dist/src/{agents-Cnph5GLD.js → agents-C-dDThPK.js} +37 -37
  13. package/dist/src/{agents-C7BiinFI.cjs → agents-CErsqg5U.cjs} +19 -27
  14. package/dist/src/{agents-v4cW_ZgC.js → agents-CVIn-Utx.js} +19 -22
  15. package/dist/src/{agents-GiUianme.js → agents-CXknwsFX.js} +37 -40
  16. package/dist/src/{agents-DETIQHqF.js → agents-DeH4Gu94.js} +21 -28
  17. package/dist/src/{agents-DYIT-hQy.js → agents-Dy2YpZpa.js} +38 -41
  18. package/dist/src/{agents-Cao4i7AX.js → agents-aF4-T121.js} +19 -30
  19. package/dist/src/{aimlapi-DMF6v_vb.js → aimlapi-BAGZDo5G.js} +16 -18
  20. package/dist/src/{aimlapi-CMJpKK-B.js → aimlapi-BNfTBexL.js} +15 -17
  21. package/dist/src/{aimlapi-DtSf1ykJ.js → aimlapi-DHRKlBEA.js} +15 -4
  22. package/dist/src/{aimlapi-DoGLcQW_.cjs → aimlapi-tg0Gkcvr.cjs} +15 -16
  23. package/dist/src/app/assets/index-BFCZg7hQ.js +439 -0
  24. package/dist/src/app/assets/index-NCn4eVBv.css +1 -0
  25. package/dist/src/app/assets/{vendor-charts-CYyo8R8v.js → vendor-charts-CCl15Imd.js} +1 -1
  26. package/dist/src/app/assets/{vendor-markdown-DSmzq4Jh.js → vendor-markdown-0tekx3KX.js} +1 -1
  27. package/dist/src/app/index.html +4 -34
  28. package/dist/src/{audio-DUH4q0Xq.js → audio-BRODU0UK.js} +7 -9
  29. package/dist/src/{audio-BWjyvHn9.cjs → audio-BWeaWovU.cjs} +6 -7
  30. package/dist/src/{audio-U580w8jM.js → audio-CHQ4r-RV.js} +6 -5
  31. package/dist/src/{audio-BrJBFN2b.js → audio-tf_NBjlC.js} +6 -8
  32. package/dist/src/base-B0tcrnq_.js +193 -0
  33. package/dist/src/base-B4QJRyFS.js +194 -0
  34. package/dist/src/base-DBtwl2FR.cjs +222 -0
  35. package/dist/src/base-fEDN28WM.js +193 -0
  36. package/dist/src/{blobs-kt8v3UyH.js → blobs-BAU-dXan.js} +9 -12
  37. package/dist/src/{blobs-C9J2mVgo.js → blobs-Bpg5rH6i.js} +9 -12
  38. package/dist/src/{blobs-673H0jCl.cjs → blobs-DvS-O6be.cjs} +34 -37
  39. package/dist/src/blobs-qTYm-1PY.js +236 -0
  40. package/dist/src/{cache-BLLayYEN.js → cache-8XhNqPKW.js} +64 -67
  41. package/dist/src/cache-Bbn1Nyrd.cjs +5 -0
  42. package/dist/src/cache-BwsMSda7.js +6 -0
  43. package/dist/src/{cache-mIszOnuz.js → cache-CG0SlR1d.js} +64 -66
  44. package/dist/src/{cache-7xULbvt3.cjs → cache-COish3-W.cjs} +114 -117
  45. package/dist/src/cache-D3eqDYGU.js +739 -0
  46. package/dist/src/{chat-Fl6TZJRS.cjs → chat-2K608PeQ.cjs} +20 -21
  47. package/dist/src/chat-BKm79wib.js +764 -0
  48. package/dist/src/{chat-XPN9YHhr.js → chat-CM_kyI8B.js} +20 -9
  49. package/dist/src/{chat-DIywASPG.js → chat-CRWNNq73.js} +49 -49
  50. package/dist/src/{chat-C8Ei4f87.js → chat-CznLWr_D.js} +49 -49
  51. package/dist/src/{chat-CgyGj2hC.js → chat-DHMH-N64.js} +20 -22
  52. package/dist/src/{chat-C4zqjObh.cjs → chat-DaqekjFr.cjs} +69 -69
  53. package/dist/src/{chat-Cpz3O-Xl.js → chat-DxysjBvt.js} +21 -23
  54. package/dist/src/{chatkit-Dpxrq4eD.js → chatkit-65VXf5SR.js} +58 -58
  55. package/dist/src/{chatkit-DIrJX8xk.js → chatkit-Be-Q-a9F.js} +58 -60
  56. package/dist/src/{chatkit-DEls11hE.js → chatkit-BxFvW8KY.js} +58 -60
  57. package/dist/src/{chatkit-e25Ziu17.cjs → chatkit-DKyPi1Gs.cjs} +58 -60
  58. package/dist/src/chunk-DEq-mXcV.js +15 -0
  59. package/dist/src/chunk-DRamLcfz.js +16 -0
  60. package/dist/src/{claude-agent-sdk-6-xTaLwM.js → claude-agent-sdk-BLTu0WBO.js} +45 -31
  61. package/dist/src/{claude-agent-sdk-BzxF6NIJ.cjs → claude-agent-sdk-CJH22shf.cjs} +44 -29
  62. package/dist/src/{claude-agent-sdk-CmkTnKGH.js → claude-agent-sdk-D6_k9FKA.js} +45 -33
  63. package/dist/src/{claude-agent-sdk-rXCBLK_o.js → claude-agent-sdk-Dy5lT-Tx.js} +46 -21
  64. package/dist/src/{cloud-BMbRVJFw.js → cloud-Bc9526yV.js} +32 -12
  65. package/dist/src/cloud-DmE0EwsY.js +4 -0
  66. package/dist/src/{cloudflare-ai-CUg4BTcj.js → cloudflare-ai-C9r2sRhw.js} +16 -18
  67. package/dist/src/{cloudflare-ai-Z9X219gp.js → cloudflare-ai-CWWJCRim.js} +16 -4
  68. package/dist/src/{cloudflare-ai-BAQ0u_dg.cjs → cloudflare-ai-ClWSdor4.cjs} +16 -17
  69. package/dist/src/{cloudflare-ai-CobxMTR4.js → cloudflare-ai-ICsOuD-z.js} +17 -19
  70. package/dist/src/{cloudflare-gateway-C0sgfr_z.cjs → cloudflare-gateway-C2_-KG5o.cjs} +21 -22
  71. package/dist/src/{cloudflare-gateway-_itGuXry.js → cloudflare-gateway-D6O7AlYb.js} +23 -23
  72. package/dist/src/{cloudflare-gateway-D2_yi-Fh.js → cloudflare-gateway-D6xFc5pa.js} +21 -25
  73. package/dist/src/{cloudflare-gateway-Djf3F3_H.js → cloudflare-gateway-pXGHxJ47.js} +26 -14
  74. package/dist/src/{codex-sdk-ibXwdglL.js → codex-sdk-C6UMlxwV.js} +49 -32
  75. package/dist/src/{codex-sdk-BASDNkIl.js → codex-sdk-DUwKWezN.js} +49 -30
  76. package/dist/src/{codex-sdk-dSnGdgIp.js → codex-sdk-GGAw0qbD.js} +49 -32
  77. package/dist/src/{codex-sdk-wTEpMM_X.cjs → codex-sdk-fAO0c3yA.cjs} +49 -32
  78. package/dist/src/{cometapi-B01btbfb.js → cometapi-BasUi7-_.js} +17 -19
  79. package/dist/src/{cometapi-DHUAH6nK.js → cometapi-Bbjp5V4x.js} +16 -4
  80. package/dist/src/{cometapi-ChAaRjg5.js → cometapi-DkXrKi5z.js} +21 -24
  81. package/dist/src/{cometapi-JbvOJSCO.cjs → cometapi-vY6aDZgo.cjs} +21 -22
  82. package/dist/src/{completion-D9_MDlnd.js → completion-6Mx_iXxK.js} +11 -13
  83. package/dist/src/{completion-BBJ6zmG3.js → completion-C5rtR_9P.js} +11 -13
  84. package/dist/src/{completion-DDyL3Cb2.cjs → completion-CDOouNzq.cjs} +21 -23
  85. package/dist/src/completion-C_P3ypkJ.js +120 -0
  86. package/dist/src/createHash-CTQmL3G2.js +15 -0
  87. package/dist/src/createHash-CfZSc0b4.cjs +27 -0
  88. package/dist/src/createHash-Da8fMwqB.js +16 -0
  89. package/dist/src/createHash-DmPQkvBh.js +15 -0
  90. package/dist/src/{docker-JAAubMw3.js → docker-5KcG-_86.js} +18 -20
  91. package/dist/src/{docker-Ckw-j7Rr.cjs → docker-BwsKwxFs.cjs} +18 -19
  92. package/dist/src/{docker-vnOg96gi.js → docker-CZnqU1XV.js} +18 -7
  93. package/dist/src/{docker-BuButc4D.js → docker-DzxyDPIj.js} +19 -21
  94. package/dist/src/entrypoint.js +2 -3
  95. package/dist/src/{errors-DnGCbnx8.js → errors-P6ll7XSJ.js} +2 -2
  96. package/dist/src/{esm-CYhseqj4.js → esm-C03C-mv3.js} +17 -20
  97. package/dist/src/{esm-rDtG_2rg.js → esm-CaIwzWR5.js} +18 -21
  98. package/dist/src/esm-Cd1AjG1D.js +379 -0
  99. package/dist/src/{esm-BQkx5roy.cjs → esm-CnNt7sI4.cjs} +47 -49
  100. package/dist/src/eval-17JizQIv.js +15 -0
  101. package/dist/src/{eval-CYrbG57o.js → eval-DmFyWU7i.js} +49 -55
  102. package/dist/src/{evalResult-COsVttMA.js → evalResult-CDQiuUuf.js} +16 -12
  103. package/dist/src/{evalResult-6JaUIStC.js → evalResult-CTG2AHOS.js} +10 -11
  104. package/dist/src/evalResult-Cqj8pldJ.js +12 -0
  105. package/dist/src/{evalResult-DlRfu_Rq.cjs → evalResult-Dap2CekP.cjs} +20 -21
  106. package/dist/src/evalResult-DvcJAWJU.cjs +10 -0
  107. package/dist/src/evalResult-Hftn-S_i.js +10 -0
  108. package/dist/src/evaluator-B2CFNt-P.js +36 -0
  109. package/dist/src/{evaluator-3EJCMTs0.js → evaluator-DPFRbFIL.js} +210 -232
  110. package/dist/src/{extractor-LSYjrhK0.js → extractor-CFG6bcWJ.js} +23 -38
  111. package/dist/src/{extractor-DbhlYEeo.cjs → extractor-DX36oYEv.cjs} +37 -64
  112. package/dist/src/{extractor-Hs7la_19.js → extractor-M67RUtg6.js} +23 -38
  113. package/dist/src/extractor-YMU_Gvt8.js +374 -0
  114. package/dist/src/fetch-4M3YRaqL.js +780 -0
  115. package/dist/src/{fetch-18MuNu9i.js → fetch-60Gzydls.js} +60 -46
  116. package/dist/src/{fetch-SRsE6Ctl.js → fetch-BMv0O527.js} +41 -35
  117. package/dist/src/{fetch-ZMn_oemb.cjs → fetch-BxUk8odA.cjs} +268 -279
  118. package/dist/src/fetch-KV5kNASw.js +5 -0
  119. package/dist/src/{fileExtensions-ePDqouxn.js → fileExtensions-DnqA1y9x.js} +2 -2
  120. package/dist/src/{fileExtensions-BpuMmaFL.js → fileExtensions-Ds-foDzt.js} +2 -2
  121. package/dist/src/fileExtensions-LcDYkU4v.js +85 -0
  122. package/dist/src/{fileExtensions-DkJYkWUy.cjs → fileExtensions-bYh77CN8.cjs} +27 -28
  123. package/dist/src/{formatDuration-Doo0xq-z.js → formatDuration-DgBVMN65.js} +2 -2
  124. package/dist/src/{genaiTracer-Ce19n68P.js → genaiTracer-70Z8BIuV.js} +2 -3
  125. package/dist/src/{genaiTracer-CqNnnXrE.js → genaiTracer-C1rxGO8Q.js} +2 -3
  126. package/dist/src/genaiTracer-D3fD9dNV.js +256 -0
  127. package/dist/src/{genaiTracer-CQlpZkrp.cjs → genaiTracer-DN4dQywX.cjs} +13 -14
  128. package/dist/src/graders-Bu0H9nXi.js +32 -0
  129. package/dist/src/{graders-BaMCwIKp.js → graders-CHO8EPM4.js} +385 -417
  130. package/dist/src/graders-Cfhkvx-e.js +34 -0
  131. package/dist/src/{graders-QsALpIdy.js → graders-CpdqD9PI.js} +385 -417
  132. package/dist/src/graders-DClJVpGP.cjs +32 -0
  133. package/dist/src/{graders-DzUUnUjC.cjs → graders-DOXycdlG.cjs} +721 -753
  134. package/dist/src/graders-DcnJsrMO.js +32 -0
  135. package/dist/src/graders-R9rYUM0d.js +13466 -0
  136. package/dist/src/{image-BiEVdpdP.js → image-BmEZqVmk.js} +57 -18
  137. package/dist/src/{image-mhAGP07h.js → image-CBBVXWuT.js} +57 -18
  138. package/dist/src/{image-D10zEe1f.cjs → image-CDLQOcqT.cjs} +6 -7
  139. package/dist/src/{image-COCWy5dX.js → image-DJEvKveK.js} +6 -5
  140. package/dist/src/{image-C3BjJUAU.cjs → image-DTedmQPg.cjs} +77 -32
  141. package/dist/src/{image-DB4sHxdJ.js → image-gvmivTEe.js} +7 -9
  142. package/dist/src/image-pAX56tPG.js +257 -0
  143. package/dist/src/{image-BXt_7u0v.js → image-tL5hIOFh.js} +6 -8
  144. package/dist/src/index.cjs +696 -693
  145. package/dist/src/index.d.cts +113 -10
  146. package/dist/src/index.d.ts +113 -6
  147. package/dist/src/index.js +657 -658
  148. package/dist/src/{interactiveCheck-DU-MAhp5.js → interactiveCheck-BgLZUIt3.js} +7 -8
  149. package/dist/src/{invariant-DT20jrBd.js → invariant-BtWWVVhl.js} +2 -2
  150. package/dist/src/{invariant-1pAf2CD1.js → invariant-Ddh24eXh.js} +2 -2
  151. package/dist/src/{invariant-CKcJAQ6M.cjs → invariant-kfQ8Bu82.cjs} +7 -8
  152. package/dist/src/invariant-vgHWClmd.js +25 -0
  153. package/dist/src/{knowledgeBase-DotRBzUE.js → knowledgeBase-CLJybhnF.js} +19 -34
  154. package/dist/src/{knowledgeBase-XJQ0Qyez.js → knowledgeBase-CoU-UQBg.js} +17 -41
  155. package/dist/src/{knowledgeBase-CMvMlLZR.js → knowledgeBase-DjWPVqSb.js} +17 -43
  156. package/dist/src/{knowledgeBase-Bnb00xKs.cjs → knowledgeBase-wkxuRFhA.cjs} +17 -40
  157. package/dist/src/{litellm-CHrRmPAe.js → litellm-B9Hysuri.js} +16 -18
  158. package/dist/src/{litellm-CrLJrPIm.js → litellm-CTfa0hqi.js} +15 -17
  159. package/dist/src/{litellm-BrnZhMcL.cjs → litellm-NYpQ8RQu.cjs} +15 -16
  160. package/dist/src/{litellm-BECdjOTx.js → litellm-ePxtr9F1.js} +15 -4
  161. package/dist/src/{logger-w8Ozp0Td.js → logger-CT3IKMKA.js} +24 -41
  162. package/dist/src/{logger-BdZ-IqBc.cjs → logger-Cp1GPUjj.cjs} +166 -192
  163. package/dist/src/logger-DLcq4dWf.js +713 -0
  164. package/dist/src/{logger-BotXmWKW.js → logger-KkObSCzq.js} +27 -43
  165. package/dist/src/{luma-ray-C0RkI3lt.cjs → luma-ray-B0GGNRc1.cjs} +20 -21
  166. package/dist/src/{luma-ray-C-w6EsJm.js → luma-ray-BE2mOt6N.js} +20 -13
  167. package/dist/src/{luma-ray-BOeX-h0M.js → luma-ray-BW9IRGIc.js} +22 -21
  168. package/dist/src/{luma-ray-DgKLS0BF.js → luma-ray-Cm1KZBhs.js} +20 -23
  169. package/dist/src/main.js +1985 -2055
  170. package/dist/src/{messages-DXV3Qh8_.cjs → messages-1JrJs91T.cjs} +35 -34
  171. package/dist/src/{messages-D61tPFQo.js → messages-1x9atZmP.js} +25 -24
  172. package/dist/src/{messages-CDZYGNlS.js → messages-BLbWdsyt.js} +25 -24
  173. package/dist/src/messages-D8EA0oDc.js +240 -0
  174. package/dist/src/{meteor-P2rUE-Uz.js → meteor-44VjEACX.js} +3 -4
  175. package/dist/src/{meteor-SLNTgmXm.js → meteor-D-SotUw9.js} +3 -4
  176. package/dist/src/{meteor-odmwVbyG.cjs → meteor-DLZZ3osF.cjs} +3 -4
  177. package/dist/src/{meteor-Dj8cTkU_.js → meteor-DUiCJRC-.js} +3 -4
  178. package/dist/src/modelslab-C1OLRmVX.js +166 -0
  179. package/dist/src/modelslab-CqXBy3U8.js +168 -0
  180. package/dist/src/modelslab-DcOSFwKh.cjs +166 -0
  181. package/dist/src/modelslab-X5-4LroM.js +166 -0
  182. package/dist/src/{nova-reel-C2LFfVTf.js → nova-reel-BgS1ZWuK.js} +20 -13
  183. package/dist/src/{nova-reel-DtCjbD5O.js → nova-reel-D2ZkOSyr.js} +22 -21
  184. package/dist/src/{nova-reel-D9FXq3Mt.cjs → nova-reel-D9xfaMBs.cjs} +20 -21
  185. package/dist/src/{nova-reel-Bk5npr2q.js → nova-reel-DihqLeol.js} +20 -23
  186. package/dist/src/{nova-sonic-BoRSY_U6.cjs → nova-sonic-DVu3mMIy.cjs} +30 -31
  187. package/dist/src/{nova-sonic-D_qERM-K.js → nova-sonic-DezhVUYT.js} +30 -26
  188. package/dist/src/{nova-sonic-CgaWLDM1.js → nova-sonic-P-CdUMlV.js} +30 -31
  189. package/dist/src/{nova-sonic-BXRfQyF-.js → nova-sonic-Q3BOJeig.js} +31 -32
  190. package/dist/src/{openai-Bigwjgo1.cjs → openai-Cuif0GEt.cjs} +8 -9
  191. package/dist/src/{openai-Dz3surb_.js → openai-DElQ-fPX.js} +3 -4
  192. package/dist/src/{openai-CT5fwbve.js → openai-DhbB7eWK.js} +3 -4
  193. package/dist/src/openai-j-sE2O7r.js +44 -0
  194. package/dist/src/{openclaw-dHLcXUWZ.js → openclaw-BiSZPL7J.js} +20 -14
  195. package/dist/src/{openclaw-CpPrXwf6.js → openclaw-Bv1DINsX.js} +20 -27
  196. package/dist/src/{openclaw-B6XY2kUf.js → openclaw-D1D_ej1z.js} +21 -28
  197. package/dist/src/{openclaw-DDSfq5fp.cjs → openclaw-DAfWQn-o.cjs} +33 -39
  198. package/dist/src/opencode-sdk-C7m-wRfI.js +560 -0
  199. package/dist/src/opencode-sdk-CfaLN8PY.cjs +564 -0
  200. package/dist/src/opencode-sdk-D95s6SnR.js +562 -0
  201. package/dist/src/opencode-sdk-DxUPkLT7.js +560 -0
  202. package/dist/src/{otlpReceiver-DmRb0NBj.js → otlpReceiver--AIRW_S4.js} +53 -51
  203. package/dist/src/{otlpReceiver-Dg817agV.js → otlpReceiver-Bn5wGB1v.js} +53 -55
  204. package/dist/src/{otlpReceiver-B6Xo4KZM.cjs → otlpReceiver-Diec4cln.cjs} +53 -55
  205. package/dist/src/{otlpReceiver-BO0rbDzh.js → otlpReceiver-g3ByGaXs.js} +53 -55
  206. package/dist/src/{providerRegistry-Xf0qdqGQ.js → providerRegistry-B0RUOLI_.js} +7 -8
  207. package/dist/src/{providerRegistry-wCWd7sKQ.js → providerRegistry-CD8MEar9.js} +7 -8
  208. package/dist/src/{providerRegistry-lc7a7utN.cjs → providerRegistry-Civky8Ar.cjs} +12 -13
  209. package/dist/src/providerRegistry-DM8rZYol.js +45 -0
  210. package/dist/src/providers-B3HvufyI.js +33246 -0
  211. package/dist/src/{providers-BiNq_Iyc.js → providers-BKRJTjBz.js} +1743 -1795
  212. package/dist/src/providers-C1rOSHiR.js +32 -0
  213. package/dist/src/{providers-BlEhY5mi.js → providers-CFLy1_ji.js} +1750 -1802
  214. package/dist/src/{providers-BNKVY53V.cjs → providers-CFu-TZl-.cjs} +2111 -2163
  215. package/dist/src/providers-CxmDwEFf.cjs +31 -0
  216. package/dist/src/providers-Dodakqr0.js +30 -0
  217. package/dist/src/providers-GIQ2TcsA.js +30 -0
  218. package/dist/src/{pythonUtils-r1uBuA0n.js → pythonUtils-C3py6GC1.js} +18 -19
  219. package/dist/src/{pythonUtils-DZ6EbdY4.cjs → pythonUtils-CTU3Y3lw.cjs} +42 -43
  220. package/dist/src/{pythonUtils-vMlk9Qp5.js → pythonUtils-D5nxkQ0P.js} +18 -19
  221. package/dist/src/pythonUtils-D6fwaDSg.js +249 -0
  222. package/dist/src/quiverai-C2jVwbH1.js +213 -0
  223. package/dist/src/quiverai-CI6gYJVI.js +213 -0
  224. package/dist/src/quiverai-CLkWkyZc.cjs +213 -0
  225. package/dist/src/quiverai-MHSxbmmZ.js +215 -0
  226. package/dist/src/{render-CAZvKKkB.js → render-Drod8m7K.js} +4 -5
  227. package/dist/src/{responses-DLLjADw5.js → responses-BKqJmhhc.js} +34 -27
  228. package/dist/src/{responses-TsdODUpm.js → responses-CGw0DCzh.js} +34 -27
  229. package/dist/src/responses-jxdehPkC.js +660 -0
  230. package/dist/src/{responses-zOtKtnY_.cjs → responses-tD4Bd4dc.cjs} +49 -42
  231. package/dist/src/rubyUtils-BUHu6PhO.js +5 -0
  232. package/dist/src/{rubyUtils-Cs35SDYa.js → rubyUtils-BUVePouc.js} +27 -20
  233. package/dist/src/rubyUtils-BcuGX77l.js +222 -0
  234. package/dist/src/{rubyUtils-BtjlqyXt.js → rubyUtils-Boc4HZzX.js} +18 -19
  235. package/dist/src/rubyUtils-CP42kMvq.cjs +4 -0
  236. package/dist/src/{rubyUtils-DCVaJ3mc.cjs → rubyUtils-DhCAlxZr.cjs} +48 -50
  237. package/dist/src/{sagemaker-Du4LIR97.js → sagemaker-BK4Zb993.js} +75 -70
  238. package/dist/src/{sagemaker-CLdUAv5z.js → sagemaker-BfiWTmvn.js} +77 -77
  239. package/dist/src/{sagemaker-DwNnEVYt.cjs → sagemaker-CcQHM1jV.cjs} +75 -76
  240. package/dist/src/{sagemaker-BcgLu0U4.js → sagemaker-D2Q1c-sD.js} +75 -79
  241. package/dist/src/{scanner-Dyw21Wg_.js → scanner-J8CA3LsV.js} +149 -122
  242. package/dist/src/server/index.js +5620 -67302
  243. package/dist/src/{server-CgUQ25qW.cjs → server-B0PPuDw-.cjs} +57 -67
  244. package/dist/src/server-B1vi21hA.js +7 -0
  245. package/dist/src/{server-CbMTRQkg.js → server-BC7XJFgr.js} +19 -24
  246. package/dist/src/server-Cm9Kai_h.cjs +5 -0
  247. package/dist/src/{server-DWmZLfCy.js → server-DbFphssR.js} +26 -29
  248. package/dist/src/server-OAs3nBRT.js +229 -0
  249. package/dist/src/{signal-Bl32q42d.js → signal-BOTbd53Z.js} +9 -11
  250. package/dist/src/{slack-BtMkB6xP.cjs → slack-BmVAVGaK.cjs} +7 -8
  251. package/dist/src/{slack-OZYxoVON.js → slack-DCUPTzS2.js} +8 -8
  252. package/dist/src/{slack-DPqj42Ts.js → slack-DOdy_kyv.js} +7 -8
  253. package/dist/src/{slack-BfdBx2tO.js → slack-DXMKtA-f.js} +7 -9
  254. package/dist/src/store-BNmZ1KAz.cjs +5 -0
  255. package/dist/src/{store-BqwfFEyF.cjs → store-BSc-TF2w.cjs} +44 -45
  256. package/dist/src/store-BltJg2cd.js +6 -0
  257. package/dist/src/{store-D4gdn9ih.js → store-D1tv90v3.js} +34 -35
  258. package/dist/src/{store-2ocbYY9D.js → store-DQLEjuEO.js} +40 -36
  259. package/dist/src/store-Ub2vaGJ1.js +228 -0
  260. package/dist/src/{tables-D-NSwNIb.js → tables-5EvT_Bwn.js} +23 -23
  261. package/dist/src/{tables-B9E1kRp-.cjs → tables-C7K-XKWp.cjs} +93 -93
  262. package/dist/src/{tables-C7TT2XVn.js → tables-D36WTqKX.js} +25 -25
  263. package/dist/src/tables-xKANLRBD.js +288 -0
  264. package/dist/src/telemetry-5BCRNBbe.cjs +5 -0
  265. package/dist/src/{telemetry-DZ_7PaVq.js → telemetry-C15ziL8u.js} +17 -14
  266. package/dist/src/{telemetry-BXyVqyAg.js → telemetry-C2YDkUQH.js} +11 -13
  267. package/dist/src/{telemetry-D0_yFdtU.cjs → telemetry-CbrnxHp_.cjs} +21 -24
  268. package/dist/src/telemetry-D4W5hboe.js +7 -0
  269. package/dist/src/telemetry-DMb2Mpfm.js +171 -0
  270. package/dist/src/{text-Dm78AVGG.js → text-B_UCRPp2.js} +2 -2
  271. package/dist/src/{text-DF2hMKdg.cjs → text-CW1cyrwj.cjs} +12 -13
  272. package/dist/src/{text-DgMr_tiM.js → text-Db-Wt2u2.js} +2 -2
  273. package/dist/src/text-TIv0QYnd.js +22 -0
  274. package/dist/src/{tokenUsageUtils-FZd5O_4A.js → tokenUsageUtils-BDGe-iyI.js} +2 -2
  275. package/dist/src/{tokenUsageUtils-DmZSD2eU.js → tokenUsageUtils-DflFMjS0.js} +2 -2
  276. package/dist/src/tokenUsageUtils-NYT-WKS6.js +138 -0
  277. package/dist/src/{tokenUsageUtils-CXhxVj72.cjs → tokenUsageUtils-bVa1ga6f.cjs} +32 -33
  278. package/dist/src/{transcription-FNIz3YOe.cjs → transcription-CL78qbOU.cjs} +14 -15
  279. package/dist/src/{transcription-C-M81iDA.js → transcription-DAtxHhAM.js} +14 -7
  280. package/dist/src/{transcription-CYuY5sFO.js → transcription-LNZTNUUL.js} +14 -16
  281. package/dist/src/{transcription-Ch7S-LWw.js → transcription-QHh3AH6Z.js} +15 -17
  282. package/dist/src/{transform-CoP2bJ7P.js → transform-Cgi24fJ7.js} +94 -66
  283. package/dist/src/{transform-Kd6u-oNm.cjs → transform-CzK1Q0zl.cjs} +24 -26
  284. package/dist/src/{transform-D8dILpfZ.js → transform-DECvGmzp.js} +15 -13
  285. package/dist/src/{transform-DMaxQwDx.js → transform-DGLazrMm.js} +94 -66
  286. package/dist/src/transform-DGxXocjk.js +1506 -0
  287. package/dist/src/{transform-ivxEY4f7.cjs → transform-DOcQeLld.cjs} +234 -206
  288. package/dist/src/transform-DTGDnAzW.js +6 -0
  289. package/dist/src/{transform-CqTFr7KR.js → transform-DilY9wbS.js} +10 -12
  290. package/dist/src/transform-aa6tmVpZ.js +216 -0
  291. package/dist/src/transform-m3qNw4KP.cjs +5 -0
  292. package/dist/src/{transformersAvailability-DEU2naS1.js → transformersAvailability-CEVM2GNQ.js} +2 -2
  293. package/dist/src/{transformersAvailability-Bkep3ka7.cjs → transformersAvailability-CwayUSlh.cjs} +2 -3
  294. package/dist/src/{transformersAvailability-DwmezkVe.js → transformersAvailability-D6c6ROpT.js} +2 -2
  295. package/dist/src/{types-t52w-XsS.js → types-CH3Ge2sE.js} +103 -92
  296. package/dist/src/{types-DMVjYLpx.js → types-CLKiCBW3.js} +98 -91
  297. package/dist/src/types-CN_TZ2GJ.js +3260 -0
  298. package/dist/src/{types-BIfttHrT.cjs → types-LJ0r3wbR.cjs} +573 -566
  299. package/dist/src/util-5cB-L7U3.js +1430 -0
  300. package/dist/src/util-6-GqIvzS.js +599 -0
  301. package/dist/src/{util-vjscpUzy.js → util-B7T3SiBS.js} +5 -6
  302. package/dist/src/{util-Cl0zfT3V.js → util-Betm42rL.js} +44 -17
  303. package/dist/src/{util-CUEt0Vum.js → util-C-PPYSMq.js} +44 -17
  304. package/dist/src/{util-DkFTvieG.cjs → util-CchiqXh_.cjs} +35 -36
  305. package/dist/src/{util-mJ58qbbw.js → util-DaWTWKBK.js} +5 -6
  306. package/dist/src/{util-C08Kns6-.cjs → util-Db0a0AFH.cjs} +89 -62
  307. package/dist/src/{util-DiCePfDu.js → util-Dlz_Wvgm.js} +102 -53
  308. package/dist/src/{util-BSh4a_Q8.js → util-YT5HPZaS.js} +102 -53
  309. package/dist/src/{util-DUYOvxAy.cjs → util-Yz-1aEhW.cjs} +274 -219
  310. package/dist/src/util-ZZH-3QZz.js +293 -0
  311. package/dist/src/{utils-DFaZa6Rf.cjs → utils-Cz9qXqII.cjs} +32 -35
  312. package/dist/src/{utils-CVzb4YiI.js → utils-XiOAgly5.js} +4 -7
  313. package/dist/src/utils-dLokC-eR.js +94 -0
  314. package/dist/src/{utils-JaY9veb5.js → utils-f2-Moju7.js} +4 -7
  315. package/dist/tsconfig.tsbuildinfo +1 -1
  316. package/package.json +59 -53
  317. package/dist/src/app/assets/index-BOgkICuY.css +0 -1
  318. package/dist/src/app/assets/index-CSgqn_Vd.js +0 -428
  319. package/dist/src/app/tsconfig.app.tsbuildinfo +0 -1
  320. package/dist/src/base-BaXmtXYp.js +0 -107
  321. package/dist/src/base-Dtp8b4_N.js +0 -106
  322. package/dist/src/base-f71xxWai.cjs +0 -111
  323. package/dist/src/cache-BUPcq0Ad.js +0 -6
  324. package/dist/src/cache-CVfRb-HD.cjs +0 -6
  325. package/dist/src/cache-O4EuX2JV.js +0 -8
  326. package/dist/src/chunk-DHDDz29n.js +0 -22
  327. package/dist/src/chunk-FhC4c-0y.js +0 -21
  328. package/dist/src/cloud-CZ4hytdm.js +0 -5
  329. package/dist/src/eval-CKHWqG9f.js +0 -16
  330. package/dist/src/evalResult-CxTP-LMm.cjs +0 -11
  331. package/dist/src/evalResult-CzLURDcP.js +0 -13
  332. package/dist/src/evalResult-DyttNQ_G.js +0 -11
  333. package/dist/src/evaluator-0PvfeBYh.js +0 -38
  334. package/dist/src/fetch-Bi0o-fdp.js +0 -4
  335. package/dist/src/fetch-CMptBDVg.cjs +0 -4
  336. package/dist/src/fetch-DAZkv3gV.js +0 -6
  337. package/dist/src/graders-BCytzXrb.js +0 -34
  338. package/dist/src/graders-CGZQShfJ.cjs +0 -33
  339. package/dist/src/graders-spkuVC-E.js +0 -36
  340. package/dist/src/opencode-sdk-CImWVqy9.js +0 -382
  341. package/dist/src/opencode-sdk-CuCztr4P.js +0 -380
  342. package/dist/src/opencode-sdk-DhcfRbBH.js +0 -376
  343. package/dist/src/opencode-sdk-mqF-Oj3f.cjs +0 -383
  344. package/dist/src/providers-BMZZmPBJ.cjs +0 -32
  345. package/dist/src/providers-CQQrNaJk.js +0 -32
  346. package/dist/src/providers-Ck8HyrC-.js +0 -34
  347. package/dist/src/quiverai-BNfIwKCO.cjs +0 -54
  348. package/dist/src/quiverai-BQigKdIH.js +0 -57
  349. package/dist/src/quiverai-Bfy2WnE2.js +0 -55
  350. package/dist/src/quiverai-CedIP0PJ.js +0 -43
  351. package/dist/src/rubyUtils-D7--T12C.js +0 -6
  352. package/dist/src/rubyUtils-DRRiMFV2.js +0 -5
  353. package/dist/src/rubyUtils-vb8OYFC-.cjs +0 -5
  354. package/dist/src/server-BUbS0Qfh.js +0 -6
  355. package/dist/src/server-XpGXFHkS.cjs +0 -6
  356. package/dist/src/server-gfOx5Zrk.js +0 -8
  357. package/dist/src/store-5u2yriTV.js +0 -7
  358. package/dist/src/store-D_lq_8oQ.js +0 -6
  359. package/dist/src/store-m5KT6Ly7.cjs +0 -6
  360. package/dist/src/telemetry-5RHFoCJh.js +0 -6
  361. package/dist/src/telemetry-Do8wMnA-.js +0 -8
  362. package/dist/src/telemetry-LojxPoFq.cjs +0 -6
  363. package/dist/src/transform-8eGmaH-7.js +0 -7
  364. package/dist/src/transform-BRVvWaG4.cjs +0 -6
  365. package/dist/src/transform-GybT0X0u.js +0 -8
  366. package/dist/src/transformersAvailability-DkAWaK5B.js +0 -35
@@ -0,0 +1,560 @@
1
+ import { b as getEnvString, i as logger, t as getLogLevel, w as state } from "./logger-CT3IKMKA.js";
2
+ import { r as importModule } from "./esm-Cd1AjG1D.js";
3
+ import "./fetch-60Gzydls.js";
4
+ import "./cache-8XhNqPKW.js";
5
+ import { i as initializeAgenticCache, n as generateCacheKey, r as getCachedResponse, t as cacheResponse } from "./cometapi-DkXrKi5z.js";
6
+ import { createRequire } from "node:module";
7
+ import fs from "fs";
8
+ import path from "path";
9
+ import os from "os";
10
+ import dedent from "dedent";
11
+ //#region src/providers/opencode-sdk.ts
12
+ /**
13
+ * Check if promptfoo is in debug mode
14
+ */
15
+ function isDebugMode() {
16
+ return getLogLevel() === "debug";
17
+ }
18
+ /**
19
+ * Maximum number of sessions to keep in memory to prevent unbounded growth
20
+ */
21
+ const MAX_SESSIONS = 100;
22
+ /**
23
+ * Resolve ESM-only package entry point by reading package.json exports
24
+ * Handles packages that only have "import" condition (no "require" condition)
25
+ *
26
+ * @param packageName - The package name (e.g., '@opencode-ai/sdk')
27
+ * @param basePath - Base path for resolution
28
+ * @returns Absolute path to the ESM entry point
29
+ */
30
+ function resolveEsmPackage(packageName, exportPath, basePath) {
31
+ const require = createRequire(path.join(basePath, "package.json"));
32
+ let packageJsonPath;
33
+ try {
34
+ packageJsonPath = require.resolve(`${packageName}/package.json`);
35
+ } catch {
36
+ packageJsonPath = path.join(basePath, "node_modules", ...packageName.split("/"), "package.json");
37
+ if (!fs.existsSync(packageJsonPath)) throw new Error(`Cannot find ${packageName}/package.json`);
38
+ }
39
+ const packageDir = path.dirname(packageJsonPath);
40
+ const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, "utf-8"));
41
+ let esmEntry;
42
+ if (packageJson.exports) {
43
+ const mainExport = packageJson.exports[exportPath] || (exportPath === "." ? packageJson.exports["."] || packageJson.exports : void 0);
44
+ if (typeof mainExport === "string") esmEntry = mainExport;
45
+ else if (typeof mainExport === "object") esmEntry = mainExport.import || mainExport.default;
46
+ }
47
+ if (!esmEntry) esmEntry = packageJson.module || packageJson.main;
48
+ if (!esmEntry) throw new Error(`Cannot find ESM entry point in ${packageName}/package.json`);
49
+ return path.join(packageDir, esmEntry);
50
+ }
51
+ function unwrapOpenCodeResult(result) {
52
+ if (!result) return;
53
+ if (typeof result === "object" && result !== null && "data" in result) return result.data;
54
+ return result;
55
+ }
56
+ function getSessionPath(sessionId) {
57
+ return {
58
+ id: sessionId,
59
+ sessionID: sessionId
60
+ };
61
+ }
62
+ function tryParseJson(value) {
63
+ try {
64
+ return JSON.stringify(JSON.parse(value));
65
+ } catch {
66
+ return;
67
+ }
68
+ }
69
+ function normalizeStructuredText(value) {
70
+ const trimmedValue = value.trim();
71
+ const directJson = tryParseJson(trimmedValue);
72
+ if (directJson) return directJson;
73
+ const fencedJsonMatch = trimmedValue.match(/^```(?:json)?\s*([\s\S]*?)\s*```$/i);
74
+ if (!fencedJsonMatch?.[1]) return;
75
+ return tryParseJson(fencedJsonMatch[1]);
76
+ }
77
+ /**
78
+ * Helper to load the OpenCode SDK ESM module
79
+ *
80
+ * Uses a two-phase approach:
81
+ * 1. Try simple dynamic import - works when SDK is in same node_modules tree
82
+ * 2. Fall back to smart ESM resolution for edge cases (pnpm, global installs, monorepos)
83
+ */
84
+ async function loadOpenCodeSDK() {
85
+ const directImports = [{
86
+ specifier: "@opencode-ai/sdk/v2",
87
+ exportPath: "./v2",
88
+ apiVersion: "v2"
89
+ }, {
90
+ specifier: "@opencode-ai/sdk",
91
+ exportPath: ".",
92
+ apiVersion: "v1"
93
+ }];
94
+ for (const candidate of directImports) try {
95
+ logger.debug(`Attempting dynamic import of ${candidate.specifier}`);
96
+ return {
97
+ ...await import(candidate.specifier),
98
+ apiVersion: candidate.apiVersion
99
+ };
100
+ } catch (error) {
101
+ logger.debug(`Dynamic import failed for ${candidate.specifier}`, { error });
102
+ }
103
+ const basePath = state.basePath && path.isAbsolute(state.basePath) ? state.basePath : process.cwd();
104
+ for (const candidate of directImports) try {
105
+ const modulePath = resolveEsmPackage("@opencode-ai/sdk", candidate.exportPath, basePath);
106
+ logger.debug(`Resolved OpenCode SDK path (${candidate.apiVersion}): ${modulePath}`);
107
+ return {
108
+ ...await importModule(modulePath),
109
+ apiVersion: candidate.apiVersion
110
+ };
111
+ } catch (error) {
112
+ logger.debug(`Smart resolution failed for ${candidate.specifier}`, { error });
113
+ }
114
+ const err = /* @__PURE__ */ new Error("Failed to resolve @opencode-ai/sdk");
115
+ logger.error(`Failed to load OpenCode SDK: ${err}`);
116
+ throw new Error(dedent`The @opencode-ai/sdk package is required but not installed.
117
+
118
+ To use the OpenCode SDK provider, install it with:
119
+ npm install @opencode-ai/sdk
120
+
121
+ For more information, see: https://www.promptfoo.dev/docs/providers/opencode-sdk/`);
122
+ }
123
+ var OpenCodeSDKProvider = class {
124
+ config;
125
+ env;
126
+ providerId = "opencode:sdk";
127
+ opencodeModule;
128
+ client;
129
+ server;
130
+ sessions = /* @__PURE__ */ new Map();
131
+ sessionOrder = [];
132
+ constructor(options = {}) {
133
+ const { config, env, id } = options;
134
+ this.config = config ?? {};
135
+ this.env = env;
136
+ this.providerId = id ?? this.providerId;
137
+ }
138
+ id() {
139
+ return this.providerId;
140
+ }
141
+ /**
142
+ * Get API key based on provider_id or common environment variables
143
+ */
144
+ getApiKey(config = this.config) {
145
+ if (config?.apiKey) return config.apiKey;
146
+ const providerId = config?.provider_id?.toLowerCase();
147
+ if (providerId === "anthropic") return this.env?.ANTHROPIC_API_KEY || getEnvString("ANTHROPIC_API_KEY");
148
+ if (providerId === "openai") return this.env?.OPENAI_API_KEY || getEnvString("OPENAI_API_KEY");
149
+ if (providerId === "google") return this.env?.GOOGLE_API_KEY || getEnvString("GOOGLE_API_KEY");
150
+ return this.env?.ANTHROPIC_API_KEY || getEnvString("ANTHROPIC_API_KEY") || this.env?.OPENAI_API_KEY || getEnvString("OPENAI_API_KEY");
151
+ }
152
+ toString() {
153
+ return "[OpenCode SDK Provider]";
154
+ }
155
+ async cleanup() {
156
+ for (const session of this.sessions.values()) try {
157
+ await this.deleteSession(session);
158
+ } catch (err) {
159
+ logger.debug(`Failed to delete persistent session ${session.id}: ${err}`);
160
+ }
161
+ this.sessions.clear();
162
+ this.sessionOrder = [];
163
+ if (this.server) {
164
+ try {
165
+ this.server.close();
166
+ } catch (err) {
167
+ logger.debug(`Failed to close OpenCode server: ${err}`);
168
+ }
169
+ this.server = void 0;
170
+ }
171
+ }
172
+ /**
173
+ * Build the tools configuration based on config and defaults
174
+ */
175
+ buildToolsConfig(config) {
176
+ if (config.tools) return config.tools;
177
+ if (!config.working_dir) return {
178
+ bash: false,
179
+ edit: false,
180
+ write: false,
181
+ read: false,
182
+ grep: false,
183
+ glob: false,
184
+ list: false,
185
+ patch: false,
186
+ todowrite: false,
187
+ todoread: false,
188
+ webfetch: false,
189
+ question: false,
190
+ skill: false,
191
+ lsp: false
192
+ };
193
+ return {
194
+ bash: false,
195
+ edit: false,
196
+ write: false,
197
+ read: true,
198
+ grep: true,
199
+ glob: true,
200
+ list: true,
201
+ patch: false,
202
+ todowrite: false,
203
+ todoread: false,
204
+ webfetch: false,
205
+ question: false,
206
+ skill: false,
207
+ lsp: false
208
+ };
209
+ }
210
+ buildQuery(config, workingDir) {
211
+ const query = {};
212
+ if (config.working_dir && workingDir) query.directory = workingDir;
213
+ if (config.workspace) query.workspace = config.workspace;
214
+ return Object.keys(query).length > 0 ? query : void 0;
215
+ }
216
+ buildSessionKey(config, workingDir) {
217
+ return generateCacheKey("opencode:sdk:session", {
218
+ baseUrl: config.baseUrl,
219
+ workingDir: config.working_dir ? workingDir : void 0,
220
+ workspace: config.workspace,
221
+ provider_id: config.provider_id,
222
+ model: config.model,
223
+ tools: this.buildToolsConfig(config),
224
+ permission: config.permission,
225
+ agent: config.agent,
226
+ custom_agent: config.custom_agent,
227
+ format: config.format,
228
+ variant: config.variant,
229
+ mcp: config.mcp
230
+ });
231
+ }
232
+ buildServerEnv(config) {
233
+ const serverEnv = {};
234
+ for (const [key, value] of Object.entries(process.env)) if (value !== void 0) serverEnv[key] = value;
235
+ if (this.env) for (const key of Object.keys(this.env).sort()) {
236
+ const value = this.env[key];
237
+ if (value !== void 0) serverEnv[key] = value;
238
+ }
239
+ if (config.log_level === "debug" || isDebugMode()) {
240
+ serverEnv.DEBUG = serverEnv.DEBUG || "opencode:*";
241
+ logger.debug("[OpenCode SDK] Debug mode enabled, synced from promptfoo log level");
242
+ }
243
+ const homeDir = os.homedir();
244
+ const opencodeBinPath = path.join(homeDir, ".opencode", "bin");
245
+ if (!serverEnv.PATH?.includes(opencodeBinPath)) {
246
+ serverEnv.PATH = `${opencodeBinPath}:${serverEnv.PATH ?? ""}`;
247
+ logger.debug(`Added ${opencodeBinPath} to PATH for OpenCode CLI`);
248
+ }
249
+ return serverEnv;
250
+ }
251
+ buildServerConfig(config) {
252
+ const serverConfig = {};
253
+ if (config.log_level) serverConfig.logLevel = config.log_level;
254
+ if (config.mcp && Object.keys(config.mcp).length > 0) {
255
+ serverConfig.mcp = config.mcp;
256
+ logger.debug(`[OpenCode SDK] Configuring MCP servers: ${Object.keys(config.mcp).join(", ")}`);
257
+ }
258
+ if (config.custom_agent) {
259
+ serverConfig.agent = { custom: {
260
+ description: config.custom_agent.description,
261
+ model: config.custom_agent.model,
262
+ temperature: config.custom_agent.temperature,
263
+ top_p: config.custom_agent.top_p,
264
+ tools: config.custom_agent.tools,
265
+ permission: config.custom_agent.permission,
266
+ prompt: config.custom_agent.prompt,
267
+ mode: config.custom_agent.mode ?? "primary",
268
+ maxSteps: config.custom_agent.steps ?? config.custom_agent.maxSteps,
269
+ color: config.custom_agent.color,
270
+ disable: config.custom_agent.disable,
271
+ hidden: config.custom_agent.hidden
272
+ } };
273
+ logger.debug(`[OpenCode SDK] Configuring custom agent: ${config.custom_agent.description}`);
274
+ }
275
+ if (config.permission) {
276
+ serverConfig.permission = config.permission;
277
+ logger.debug("[OpenCode SDK] Configuring global permissions");
278
+ }
279
+ const toolsConfig = this.buildToolsConfig(config);
280
+ if (toolsConfig) serverConfig.tools = toolsConfig;
281
+ if (config.provider_id && config.apiKey) {
282
+ serverConfig.provider = { [config.provider_id]: { options: { apiKey: config.apiKey } } };
283
+ logger.debug(`[OpenCode SDK] Injecting provider apiKey for ${config.provider_id}`);
284
+ }
285
+ return serverConfig;
286
+ }
287
+ warnOnIgnoredBaseUrlConfig(config) {
288
+ if (!config.baseUrl) return;
289
+ const ignoredSettings = [
290
+ config.hostname !== void 0 ? "hostname" : void 0,
291
+ config.port !== void 0 ? "port" : void 0,
292
+ config.timeout !== void 0 ? "timeout" : void 0,
293
+ config.log_level !== void 0 ? "log_level" : void 0,
294
+ config.mcp ? "mcp" : void 0,
295
+ config.custom_agent ? "custom_agent" : void 0,
296
+ config.apiKey ? "apiKey" : void 0
297
+ ].filter(Boolean);
298
+ if (ignoredSettings.length > 0) logger.warn(`[OpenCode SDK] baseUrl uses an existing OpenCode server. These config keys are ignored unless that server is preconfigured: ${ignoredSettings.join(", ")}`);
299
+ }
300
+ buildDeleteSessionParameters(session) {
301
+ if (!this.opencodeModule) throw new Error("OpenCode SDK module is not loaded");
302
+ if (this.opencodeModule.apiVersion === "v2") return {
303
+ sessionID: session.id,
304
+ ...session.query
305
+ };
306
+ return {
307
+ path: getSessionPath(session.id),
308
+ query: session.query
309
+ };
310
+ }
311
+ async deleteSession(session) {
312
+ if (!session || !this.client?.session?.delete) return;
313
+ await this.client.session.delete(this.buildDeleteSessionParameters(session));
314
+ }
315
+ /**
316
+ * Add a session to the cache with LRU eviction
317
+ */
318
+ addSession(cacheKey, session) {
319
+ while (this.sessions.size >= MAX_SESSIONS && this.sessionOrder.length > 0) {
320
+ const oldestKey = this.sessionOrder.shift();
321
+ if (oldestKey) {
322
+ const oldSession = this.sessions.get(oldestKey);
323
+ this.sessions.delete(oldestKey);
324
+ if (oldSession) this.deleteSession(oldSession).catch((err) => {
325
+ logger.debug(`Failed to delete evicted session ${oldSession.id}: ${err}`);
326
+ });
327
+ }
328
+ }
329
+ this.sessions.set(cacheKey, session);
330
+ this.sessionOrder.push(cacheKey);
331
+ }
332
+ prepareCall(context) {
333
+ const config = {
334
+ ...this.config,
335
+ ...context?.prompt?.config
336
+ };
337
+ if (config.workspace && !config.baseUrl && !config.working_dir) throw new Error("OpenCode SDK workspace support requires either baseUrl or working_dir");
338
+ if (config.apiKey && !config.provider_id && !config.baseUrl) logger.warn("[OpenCode SDK] apiKey is set without provider_id. Prefer setting provider_id so promptfoo can wire the credential into the spawned OpenCode server.");
339
+ this.warnOnIgnoredBaseUrlConfig(config);
340
+ if (config.working_dir) {
341
+ const workingDir = path.isAbsolute(config.working_dir) ? config.working_dir : path.resolve(process.cwd(), config.working_dir);
342
+ let stats;
343
+ try {
344
+ stats = fs.statSync(workingDir);
345
+ } catch (err) {
346
+ throw new Error(`Working directory ${config.working_dir} (resolved to ${workingDir}) does not exist or isn't accessible: ${err.message}`);
347
+ }
348
+ if (!stats.isDirectory()) throw new Error(`Working directory ${config.working_dir} (resolved to ${workingDir}) is not a directory`);
349
+ return {
350
+ config,
351
+ isTempDir: false,
352
+ workingDir
353
+ };
354
+ }
355
+ return {
356
+ config,
357
+ isTempDir: true,
358
+ workingDir: fs.mkdtempSync(path.join(os.tmpdir(), "promptfoo-opencode-sdk-"))
359
+ };
360
+ }
361
+ async ensureClient(config) {
362
+ if (!this.opencodeModule) this.opencodeModule = await loadOpenCodeSDK();
363
+ if (this.client) return;
364
+ const { createOpencode, createOpencodeClient } = this.opencodeModule;
365
+ if (config.baseUrl) {
366
+ this.client = createOpencodeClient({ baseUrl: config.baseUrl });
367
+ return;
368
+ }
369
+ const serverOptions = {
370
+ hostname: config.hostname ?? "127.0.0.1",
371
+ port: config.port ?? 0,
372
+ timeout: config.timeout ?? 3e4,
373
+ env: this.buildServerEnv(config)
374
+ };
375
+ const serverConfig = this.buildServerConfig(config);
376
+ if (Object.keys(serverConfig).length > 0) serverOptions.config = serverConfig;
377
+ const opencode = await createOpencode(serverOptions);
378
+ this.client = opencode.client;
379
+ this.server = opencode.server;
380
+ logger.debug(`OpenCode server started at ${opencode.server.url}`);
381
+ }
382
+ async getOrCreateSession(config, workingDir) {
383
+ if (!this.client || !this.opencodeModule) throw new Error("OpenCode SDK client is not initialized");
384
+ const sessionQuery = this.buildQuery(config, workingDir);
385
+ if (config.session_id) return {
386
+ sessionId: config.session_id,
387
+ sessionQuery
388
+ };
389
+ const sessionCacheKey = this.buildSessionKey(config, workingDir);
390
+ if (config.persist_sessions && this.sessions.has(sessionCacheKey)) return {
391
+ sessionId: this.sessions.get(sessionCacheKey).id,
392
+ sessionQuery
393
+ };
394
+ const createResult = await this.client.session.create(this.buildCreateSessionParameters(config, sessionQuery));
395
+ const sessionId = unwrapOpenCodeResult(createResult)?.id ?? createResult?.id;
396
+ if (!sessionId) throw new Error("Failed to get session ID from OpenCode SDK response");
397
+ const session = {
398
+ id: sessionId,
399
+ query: sessionQuery
400
+ };
401
+ if (config.persist_sessions) {
402
+ this.addSession(sessionCacheKey, session);
403
+ return {
404
+ sessionId,
405
+ sessionQuery
406
+ };
407
+ }
408
+ return {
409
+ sessionId,
410
+ sessionQuery,
411
+ ephemeralSession: session
412
+ };
413
+ }
414
+ buildPromptBody(config, prompt) {
415
+ if (!this.opencodeModule) throw new Error("OpenCode SDK module is not loaded");
416
+ const promptBody = { parts: [{
417
+ type: "text",
418
+ text: prompt
419
+ }] };
420
+ if (config.provider_id || config.model) promptBody.model = {
421
+ providerID: config.provider_id ?? "",
422
+ modelID: config.model ?? ""
423
+ };
424
+ const toolsConfig = this.buildToolsConfig(config);
425
+ if (toolsConfig) promptBody.tools = toolsConfig;
426
+ if (config.agent) promptBody.agent = config.agent;
427
+ else if (config.custom_agent) promptBody.agent = "custom";
428
+ if (config.custom_agent?.prompt) promptBody.system = config.custom_agent.prompt;
429
+ if (config.format) promptBody.format = config.format;
430
+ if (config.variant) promptBody.variant = config.variant;
431
+ if (config.permission && this.opencodeModule.apiVersion === "v1") promptBody.permission = config.permission;
432
+ return promptBody;
433
+ }
434
+ buildCreateSessionParameters(config, sessionQuery) {
435
+ if (!this.opencodeModule) throw new Error("OpenCode SDK module is not loaded");
436
+ const createBody = { title: `promptfoo-${Date.now()}` };
437
+ if (config.permission && this.opencodeModule.apiVersion === "v2") createBody.permission = config.permission;
438
+ if (this.opencodeModule.apiVersion === "v2") return {
439
+ ...sessionQuery,
440
+ ...createBody
441
+ };
442
+ return {
443
+ body: createBody,
444
+ query: sessionQuery
445
+ };
446
+ }
447
+ buildPromptParameters(config, prompt, sessionId, sessionQuery) {
448
+ if (!this.opencodeModule) throw new Error("OpenCode SDK module is not loaded");
449
+ const promptBody = this.buildPromptBody(config, prompt);
450
+ if (this.opencodeModule.apiVersion === "v2") return {
451
+ sessionID: sessionId,
452
+ ...sessionQuery,
453
+ ...promptBody
454
+ };
455
+ return {
456
+ path: getSessionPath(sessionId),
457
+ body: promptBody,
458
+ query: sessionQuery
459
+ };
460
+ }
461
+ buildProviderResponse(config, response, sessionId) {
462
+ const responseData = unwrapOpenCodeResult(response);
463
+ const assistantMessage = responseData?.info;
464
+ const parts = responseData?.parts ?? [];
465
+ let output = "";
466
+ for (const part of parts) if (part.type === "text" && part.text) output += (output ? "\n" : "") + part.text;
467
+ if (config.format?.type === "json_schema") if (assistantMessage?.structured !== void 0) output = JSON.stringify(assistantMessage.structured);
468
+ else output = normalizeStructuredText(output) ?? output;
469
+ const tokens = assistantMessage?.tokens;
470
+ return {
471
+ output,
472
+ tokenUsage: tokens ? {
473
+ prompt: tokens.input ?? 0,
474
+ completion: tokens.output ?? 0,
475
+ total: (tokens.input ?? 0) + (tokens.output ?? 0)
476
+ } : void 0,
477
+ cost: assistantMessage?.cost ?? 0,
478
+ raw: JSON.stringify(response),
479
+ sessionId
480
+ };
481
+ }
482
+ handleCallError(error, callOptions) {
483
+ if (error instanceof Error && error.name === "AbortError" || callOptions?.abortSignal?.aborted) {
484
+ logger.warn("OpenCode SDK call aborted");
485
+ return { error: "OpenCode SDK call aborted" };
486
+ }
487
+ if (error && typeof error === "object" && "code" in error && error.code === "ENOENT" && "message" in error && typeof error.message === "string" && error.message.includes("opencode")) {
488
+ const cliError = dedent`The OpenCode CLI is required but not installed.
489
+
490
+ The OpenCode SDK requires the 'opencode' CLI to be installed and available in your PATH.
491
+
492
+ Install it with:
493
+ curl -fsSL https://opencode.ai/install | bash
494
+
495
+ Or see: https://opencode.ai for other installation methods.`;
496
+ logger.error(cliError);
497
+ return { error: cliError };
498
+ }
499
+ const errorMessage = error instanceof Error ? error.message : String(error);
500
+ logger.error("Error calling OpenCode SDK", { error });
501
+ return { error: `Error calling OpenCode SDK: ${errorMessage}` };
502
+ }
503
+ async callApi(prompt, context, callOptions) {
504
+ const { config, isTempDir, workingDir } = this.prepareCall(context);
505
+ const mcpConfig = config.mcp && Object.keys(config.mcp).length > 0 ? config.mcp : void 0;
506
+ const cacheResult = await initializeAgenticCache({
507
+ cacheKeyPrefix: "opencode:sdk",
508
+ workingDir: config.working_dir ? workingDir : void 0,
509
+ bustCache: context?.bustCache,
510
+ mcp: mcpConfig,
511
+ cacheMcp: config.cache_mcp
512
+ }, {
513
+ prompt,
514
+ provider_id: config.provider_id,
515
+ model: config.model,
516
+ tools: this.buildToolsConfig(config),
517
+ permission: config.permission,
518
+ agent: config.agent,
519
+ custom_agent: config.custom_agent,
520
+ workspace: config.workspace,
521
+ format: config.format,
522
+ variant: config.variant
523
+ });
524
+ const cachedResponse = await getCachedResponse(cacheResult, "OpenCode SDK");
525
+ if (cachedResponse) return cachedResponse;
526
+ if (callOptions?.abortSignal?.aborted) return { error: "OpenCode SDK call aborted before it started" };
527
+ let ephemeralSession;
528
+ try {
529
+ await this.ensureClient(config);
530
+ const session = await this.getOrCreateSession(config, workingDir);
531
+ ephemeralSession = session.ephemeralSession;
532
+ const promptOptions = this.buildPromptParameters(config, prompt, session.sessionId, session.sessionQuery);
533
+ logger.debug(`OpenCode SDK prompt options:`, promptOptions);
534
+ const client = this.client;
535
+ if (!client) throw new Error("OpenCode SDK client is not initialized");
536
+ const response = await client.session.prompt(promptOptions);
537
+ logger.debug(`OpenCode SDK response received`);
538
+ const providerResponse = this.buildProviderResponse(config, response, session.sessionId);
539
+ await cacheResponse(cacheResult, providerResponse, "OpenCode SDK");
540
+ logger.debug(`OpenCode SDK response: ${providerResponse.output.slice(0, 100)}...`);
541
+ return providerResponse;
542
+ } catch (error) {
543
+ return this.handleCallError(error, callOptions);
544
+ } finally {
545
+ if (ephemeralSession) try {
546
+ await this.deleteSession(ephemeralSession);
547
+ } catch (err) {
548
+ logger.debug(`Failed to delete non-persistent session ${ephemeralSession.id}: ${err}`);
549
+ }
550
+ if (isTempDir && workingDir) fs.rmSync(workingDir, {
551
+ recursive: true,
552
+ force: true
553
+ });
554
+ }
555
+ }
556
+ };
557
+ //#endregion
558
+ export { OpenCodeSDKProvider };
559
+
560
+ //# sourceMappingURL=opencode-sdk-DxUPkLT7.js.map