promptfoo 0.121.3 → 0.121.5

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 (394) hide show
  1. package/README.md +1 -1
  2. package/dist/src/{ListApp-Du7YVwj5.js → ListApp-BRUsT43Y.js} +1 -1
  3. package/dist/src/{accounts-BPyfpSeU.cjs → accounts-BIFntVWB.cjs} +5 -5
  4. package/dist/src/{accounts-CFLK3mnD.js → accounts-CLJHCDDb.js} +6 -6
  5. package/dist/src/{accounts-B2XmGjty.js → accounts-CaLNYnf7.js} +5 -5
  6. package/dist/src/{accounts-Xatc0RYb.js → accounts-bnyHT7Ju.js} +5 -5
  7. package/dist/src/{agentic-utils-36epdqwB.js → agentic-utils-B5krlibj.js} +3 -3
  8. package/dist/src/{agentic-utils-DIYAAYE7.js → agentic-utils-Ba67xmgs.js} +3 -3
  9. package/dist/src/{agentic-utils-D8yXo5Lm.js → agentic-utils-BclbiXiq.js} +4 -4
  10. package/dist/src/{agentic-utils-DAVsChuB.cjs → agentic-utils-D2x0wGhB.cjs} +3 -3
  11. package/dist/src/{agents-CLQ-P15P.js → agents-BGqaTDnr.js} +5 -7
  12. package/dist/src/{agents-wg3ohknq.js → agents-BV9yFpXX.js} +6 -7
  13. package/dist/src/{agents-CgBniSlI.js → agents-BYdMl1UE.js} +5 -9
  14. package/dist/src/{agents-Bqgfdokm.js → agents-DhxWMCtH.js} +35 -14
  15. package/dist/src/{agents-BBWxKSM0.cjs → agents-DiWmQYH9.cjs} +5 -7
  16. package/dist/src/{agents-CAYbM7qD.cjs → agents-WULPVjbH.cjs} +34 -12
  17. package/dist/src/{agents-DSSTV4bv.js → agents-emVcx3yh.js} +35 -13
  18. package/dist/src/{agents-BBVJCIYr.js → agents-n6vPqV3i.js} +35 -13
  19. package/dist/src/{aimlapi-BwGC1TtS.js → aimlapi-BxqK9HF_.js} +8 -14
  20. package/dist/src/{aimlapi-Bv8Fmc-b.cjs → aimlapi-BzLjZI_m.cjs} +8 -15
  21. package/dist/src/{aimlapi-MgSLdvy7.js → aimlapi-DR4pgeiC.js} +7 -14
  22. package/dist/src/{aimlapi-DaC3qZ-o.js → aimlapi-uPGp0Zdo.js} +7 -16
  23. package/dist/src/app/app/tsconfig.app.tsbuildinfo +1 -0
  24. package/dist/src/app/assets/Report-vjzrbgce.js +1 -0
  25. package/dist/src/app/assets/index-B3NQ8HTd.js +385 -0
  26. package/dist/src/app/assets/index-Cli2yAXv.css +1 -0
  27. package/dist/src/app/assets/rolldown-runtime-COnpUsM8.js +1 -0
  28. package/dist/src/app/assets/scroll-timeline-D9IT_e8Z.js +1 -0
  29. package/dist/src/app/assets/sync-IjzpWrOE.js +4 -0
  30. package/dist/src/app/assets/vendor-charts-BNdH8TCw.js +36 -0
  31. package/dist/src/app/assets/vendor-markdown-Ch00wnNI.js +29 -0
  32. package/dist/src/app/assets/vendor-react-CVvmk1UB.js +9 -0
  33. package/dist/src/app/assets/vendor-utils-BnEYbx2Q.js +37 -0
  34. package/dist/src/app/index.html +32 -7
  35. package/dist/src/{audio-Bn44pQxv.js → audio-BvpTOArF.js} +4 -4
  36. package/dist/src/{audio-DVFjQ67_.cjs → audio-C0vDeS0j.cjs} +4 -4
  37. package/dist/src/{audio-DjU9GswO.js → audio-CScmnmEB.js} +4 -5
  38. package/dist/src/{audio-DDA5WHdx.js → audio-Da8U9IS5.js} +4 -4
  39. package/dist/src/{base-CKjwebIH.js → base-BOMaNEes.js} +3 -3
  40. package/dist/src/{base-CqzQ4K8j.js → base-BTux96b1.js} +3 -3
  41. package/dist/src/{base-BboXIF_0.cjs → base-Tw6uhH8K.cjs} +3 -3
  42. package/dist/src/{base-Cz2ZC_iA.js → base-dYsl2hmL.js} +3 -3
  43. package/dist/src/{blobs-C6j0bvFz.cjs → blobs-B95F_7vE.cjs} +3 -3
  44. package/dist/src/{blobs-DXTl6J3H.js → blobs-BW4U31ue.js} +3 -3
  45. package/dist/src/{blobs-BUWmKWzo.js → blobs-D_gg8nbm.js} +4 -4
  46. package/dist/src/{blobs-B1JriOyi.js → blobs-DjLby-uP.js} +4 -4
  47. package/dist/src/cache-BI5BY7ey.js +280 -0
  48. package/dist/src/cache-BRkhlH3k.cjs +3 -0
  49. package/dist/src/cache-BlC6aeJ0.js +3 -0
  50. package/dist/src/cache-Bzttsk0X.js +310 -0
  51. package/dist/src/cache-Cr-qWIbP.js +310 -0
  52. package/dist/src/cache-DGg-yTZG.cjs +376 -0
  53. package/dist/src/{chat-BEwdgGEg.js → chat-BLOdH60v.js} +63 -37
  54. package/dist/src/{chat-B0iaWhoh.js → chat-Cx_LkwvZ.js} +63 -37
  55. package/dist/src/{chat-DK1U-eZ-.js → chat-D9nudO9b.js} +5 -14
  56. package/dist/src/{chat-pxmiVpWe.js → chat-DChSH_Es.js} +63 -37
  57. package/dist/src/{chat-B-52XYI1.js → chat-DG2LkwLq.js} +3 -13
  58. package/dist/src/{chat-BtIKkLKx.cjs → chat-DH97tVV9.cjs} +3 -13
  59. package/dist/src/{chat-BE0qTA8e.js → chat-aMQZw6R7.js} +4 -16
  60. package/dist/src/{chat-CM8qWR3_.cjs → chat-vYqqv1gP.cjs} +64 -38
  61. package/dist/src/{chatkit-_8eJqKcD.js → chatkit-B8X34dQc.js} +4 -4
  62. package/dist/src/{chatkit-BYGQlHlV.js → chatkit-BXu42Qwt.js} +4 -4
  63. package/dist/src/{chatkit-a2D6mY6s.js → chatkit-CbMRoeYw.js} +4 -4
  64. package/dist/src/{chatkit-Cx174XI3.cjs → chatkit-D44VyUyB.cjs} +4 -4
  65. package/dist/src/{claude-agent-sdk-8ddRp1L2.cjs → claude-agent-sdk-BRq0bbIK.cjs} +23 -18
  66. package/dist/src/{claude-agent-sdk-CMjh4LFH.js → claude-agent-sdk-BjriSVRZ.js} +20 -15
  67. package/dist/src/{claude-agent-sdk-HgbFioFw.js → claude-agent-sdk-BzNZeZ0N.js} +20 -15
  68. package/dist/src/{claude-agent-sdk-Bq5EArsX.js → claude-agent-sdk-DYv_AJ8u.js} +21 -17
  69. package/dist/src/cloud-CoD5OacT.js +3 -0
  70. package/dist/src/{cloud-z8KZpUoa.js → cloud-Da0bofJd.js} +25 -13
  71. package/dist/src/{cloudflare-ai-Bbp26N0L.js → cloudflare-ai-CXC4b1EU.js} +5 -14
  72. package/dist/src/{cloudflare-ai-BGyXlpXJ.js → cloudflare-ai-CyBoIs1Q.js} +7 -15
  73. package/dist/src/{cloudflare-ai-DdKP9TKT.js → cloudflare-ai-DGOwgexC.js} +6 -17
  74. package/dist/src/{cloudflare-ai-C62x6MQG.cjs → cloudflare-ai-DJv5qnyb.cjs} +6 -15
  75. package/dist/src/{cloudflare-gateway-DXhtXDRb.js → cloudflare-gateway-1sAoOyft.js} +6 -16
  76. package/dist/src/{cloudflare-gateway-D-e9i1Sn.js → cloudflare-gateway-D-dnkzCF.js} +5 -18
  77. package/dist/src/{cloudflare-gateway-Dx36ftqF.cjs → cloudflare-gateway-DKVjkDav.cjs} +4 -15
  78. package/dist/src/{cloudflare-gateway-BwAaUgeW.js → cloudflare-gateway-TJkVrZlB.js} +4 -15
  79. package/dist/src/codex-app-server-CCLjqCh9.js +1915 -0
  80. package/dist/src/codex-app-server-CCe0TiDc.js +1915 -0
  81. package/dist/src/codex-app-server-CPW1LFwh.js +1916 -0
  82. package/dist/src/codex-app-server-VMRnjZ68.cjs +1920 -0
  83. package/dist/src/codex-sdk-1jm_qPHf.js +3 -0
  84. package/dist/src/codex-sdk-Bd8UbO9q.cjs +1172 -0
  85. package/dist/src/codex-sdk-BgEFQ70r.js +1164 -0
  86. package/dist/src/codex-sdk-Bzb_TqX9.js +1165 -0
  87. package/dist/src/codex-sdk-Danroptg.cjs +2 -0
  88. package/dist/src/codex-sdk-DfvDTN33.js +1165 -0
  89. package/dist/src/{cometapi-BDyV-NNm.js → cometapi-B5ImDlSm.js} +9 -15
  90. package/dist/src/{cometapi-C3hOlM7-.cjs → cometapi-BgAkuYCw.cjs} +9 -16
  91. package/dist/src/{cometapi-hhL4TAh3.js → cometapi-CC7hWxmX.js} +8 -15
  92. package/dist/src/{cometapi-sp7sJpBD.js → cometapi-CCbpHkuF.js} +8 -17
  93. package/dist/src/{completion-DoYy49ti.js → completion-2iuYVxwi.js} +8 -57
  94. package/dist/src/{completion-BCimtq-h.js → completion-CrD6MQ93.js} +8 -57
  95. package/dist/src/{completion-DlXUhj5c.cjs → completion-DtQ72Bm3.cjs} +7 -62
  96. package/dist/src/{completion-DCjv7RZ3.js → completion-Vq_ad618.js} +8 -57
  97. package/dist/src/{createHash-CTQmL3G2.js → createHash-4gFQpDDv.js} +3 -3
  98. package/dist/src/{createHash-Da8fMwqB.js → createHash-DPpsZgFF.js} +3 -3
  99. package/dist/src/{createHash-DmPQkvBh.js → createHash-Un4Q_huE.js} +3 -3
  100. package/dist/src/{createHash-BYwImsYv.cjs → createHash-VvBIc-AW.cjs} +4 -4
  101. package/dist/src/{docker-CxCkwMzc.js → docker--3qzPa-6.js} +6 -14
  102. package/dist/src/{docker-Cqj2-QVi.cjs → docker-D3AY-5F5.cjs} +7 -15
  103. package/dist/src/{docker-FeBni2dw.js → docker-DCsCDvwM.js} +7 -14
  104. package/dist/src/{docker-DpguQj-w.js → docker-Dorv4_Dg.js} +6 -16
  105. package/dist/src/embedding-BXhN5lCH.cjs +63 -0
  106. package/dist/src/embedding-ChS1ivFS.js +58 -0
  107. package/dist/src/embedding-DNRvZwRN.js +59 -0
  108. package/dist/src/embedding-D_bI4NDq.js +58 -0
  109. package/dist/src/entrypoint.js +69 -6
  110. package/dist/src/{errors-P6ll7XSJ.js → errors-DFHe4L-n.js} +1 -1
  111. package/dist/src/{esm-SUNIX1x3.js → esm-B6whoAcf.js} +15 -6
  112. package/dist/src/{esm-CKWP3u_P.js → esm-BRkfNsYs.js} +16 -7
  113. package/dist/src/{esm-7UIl0pPM.js → esm-BX8fwlAO.js} +27 -18
  114. package/dist/src/{esm-CipptfDu.cjs → esm-B_rGuPTo.cjs} +15 -6
  115. package/dist/src/eval-BQPLBJbw.js +3 -0
  116. package/dist/src/{eval-BTqTn7lb.js → eval-DJ_4A-tr.js} +50 -21
  117. package/dist/src/evalResult-BBJAHAtw.cjs +2 -0
  118. package/dist/src/evalResult-BBK58h2B.js +3 -0
  119. package/dist/src/{evalResult-DpARzUCb.cjs → evalResult-Cx-8OWkb.cjs} +29 -11
  120. package/dist/src/{evalResult-DUDShQrm.js → evalResult-D6P5I5il.js} +29 -11
  121. package/dist/src/{evalResult-BkIhRdTe.js → evalResult-pSvGWFMo.js} +29 -11
  122. package/dist/src/evalResult-spPqh1G_.js +2 -0
  123. package/dist/src/{evaluator-BcvOGaam.js → evaluator-D-UIbbYq.js} +3975 -2152
  124. package/dist/src/evaluator-DgLKaZk8.js +3 -0
  125. package/dist/src/{extractor-D_wd8jxt.js → extractor-BM3jRERL.js} +6 -6
  126. package/dist/src/{extractor-DG3sSfXE.cjs → extractor-Dxr2J_wK.cjs} +6 -6
  127. package/dist/src/{extractor-CAZ2G3Kh.js → extractor-DxyiFhPk.js} +6 -6
  128. package/dist/src/{extractor-C8XwivI9.js → extractor-YlZbUMsL.js} +6 -6
  129. package/dist/src/fetch-8viavNv8.js +3 -0
  130. package/dist/src/{fetch-DoVRJZhJ.js → fetch-B6ch2nU2.js} +199 -60
  131. package/dist/src/{fetch-CVAtKnI3.js → fetch-D9xxyC1p.js} +404 -252
  132. package/dist/src/{fetch-BnR9wSnm.cjs → fetch-NuqXW1Xb.cjs} +415 -263
  133. package/dist/src/{fetch-BiYv2BZc.js → fetch-Y5qX_kST.js} +222 -70
  134. package/dist/src/{fileExtensions-LcDYkU4v.js → fileExtensions-8CjoL7vB.js} +1 -1
  135. package/dist/src/{fileExtensions-DnqA1y9x.js → fileExtensions-BGh-W-HT.js} +1 -1
  136. package/dist/src/{fileExtensions-bYh77CN8.cjs → fileExtensions-D9h-8Wxg.cjs} +1 -1
  137. package/dist/src/{fileExtensions-Ds-foDzt.js → fileExtensions-DysCsxNG.js} +1 -1
  138. package/dist/src/{formatDuration-DgBVMN65.js → formatDuration-Ch4A7G3o.js} +1 -1
  139. package/dist/src/{genaiTracer-BfxrvSUb.cjs → genaiTracer-BokHC-MW.cjs} +7 -3
  140. package/dist/src/{genaiTracer-C1rxGO8Q.js → genaiTracer-C3ZPQU60.js} +6 -2
  141. package/dist/src/{genaiTracer-70Z8BIuV.js → genaiTracer-CFny3gOy.js} +6 -2
  142. package/dist/src/{genaiTracer-D3fD9dNV.js → genaiTracer-DxODqT9e.js} +6 -2
  143. package/dist/src/golang/wrapper.go +1 -1
  144. package/dist/src/{graders-DG7mhg-b.js → graders-BoUqsCEm.js} +7402 -5699
  145. package/dist/src/{graders-BElhu9ZY.cjs → graders-Bw1wk_21.cjs} +5220 -3437
  146. package/dist/src/graders-C84JI-m5.js +2 -0
  147. package/dist/src/graders-CBbd0K0Q.cjs +2 -0
  148. package/dist/src/graders-CbQqpHSN.js +3 -0
  149. package/dist/src/{graders-RjHF8VfG.js → graders-CgPn32yp.js} +7400 -5697
  150. package/dist/src/{graders-BXAJ0sbS.js → graders-CwrbifOo.js} +6136 -4433
  151. package/dist/src/graders-DS42d3ZG.js +2 -0
  152. package/dist/src/{image-6WQXK8m8.js → image-BeWaInPF.js} +4 -4
  153. package/dist/src/{image-PoF6DN3x.js → image-BmilRNqO.js} +8 -8
  154. package/dist/src/{image--F58eEIn.cjs → image-CxJoa3aW.cjs} +8 -8
  155. package/dist/src/{image-fza3zuKs.cjs → image-D10dNAav.cjs} +4 -4
  156. package/dist/src/{image-DO0RYnjH.js → image-Dr_3I3nK.js} +4 -5
  157. package/dist/src/{image-B8b6f36E.js → image-DsGRlkh7.js} +8 -8
  158. package/dist/src/{image-CoxZp9PZ.js → image-a_SGUobh.js} +8 -8
  159. package/dist/src/{image-xNbw5ph2.js → image-qjO6FWPs.js} +4 -4
  160. package/dist/src/index.cjs +4835 -2582
  161. package/dist/src/index.d.cts +2782 -31
  162. package/dist/src/index.d.ts +2783 -32
  163. package/dist/src/index.js +4817 -2564
  164. package/dist/src/{interactiveCheck-BnMYOjMu.js → interactiveCheck-CCICw2cy.js} +2 -2
  165. package/dist/src/{invariant-BtWWVVhl.js → invariant-B2Rf6avk.js} +1 -1
  166. package/dist/src/{invariant-vgHWClmd.js → invariant-DIYf9sP1.js} +1 -1
  167. package/dist/src/{knowledgeBase-Bi7CmDbx.js → knowledgeBase-BBETc5-S.js} +6 -8
  168. package/dist/src/{knowledgeBase-DqrLX8fy.cjs → knowledgeBase-C8qOo26M.cjs} +6 -8
  169. package/dist/src/{knowledgeBase-DFRXPZl_.js → knowledgeBase-CzAi2rUI.js} +7 -8
  170. package/dist/src/{knowledgeBase-Ce3ofVan.js → knowledgeBase-Dr3Kib7F.js} +6 -10
  171. package/dist/src/{litellm-CKiAxnoM.js → litellm-BLSiANhk.js} +6 -14
  172. package/dist/src/{litellm-CnHI69aj.cjs → litellm-CaUmV7Mk.cjs} +6 -15
  173. package/dist/src/{litellm-Tc294Jhj.js → litellm-DQGo_juI.js} +5 -14
  174. package/dist/src/{litellm-Bo2gQXpo.js → litellm-DRc4qWfc.js} +5 -16
  175. package/dist/src/{logger-BcJBzSSA.js → logger-BbY6ypFL.js} +41 -12
  176. package/dist/src/{logger-D5iKBpu_.cjs → logger-COuQb2xB.cjs} +51 -10
  177. package/dist/src/{logger-DO8_zM18.js → logger-Ct2S6Yx-.js} +40 -11
  178. package/dist/src/{logger-BnkjG2jt.js → logger-KD8JjCRJ.js} +41 -12
  179. package/dist/src/{luma-ray-C9q8rdQe.js → luma-ray-B-tNZzqW.js} +6 -10
  180. package/dist/src/{luma-ray-DP0QA9qn.js → luma-ray-CtS3OlGq.js} +6 -10
  181. package/dist/src/{luma-ray-0ehMPt5N.js → luma-ray-PJJgUjOc.js} +6 -11
  182. package/dist/src/{luma-ray-m9Ku2meV.cjs → luma-ray-if-Ml4R9.cjs} +6 -10
  183. package/dist/src/main.d.ts +1 -26
  184. package/dist/src/main.js +1188 -679
  185. package/dist/src/messages-B9dSjrNf.js +544 -0
  186. package/dist/src/messages-BnsVHUnm.cjs +558 -0
  187. package/dist/src/messages-CI69Lasb.js +543 -0
  188. package/dist/src/messages-CewuNcNS.js +543 -0
  189. package/dist/src/{meteor-DLZZ3osF.cjs → meteor-BBGcGeCa.cjs} +1 -1
  190. package/dist/src/{meteor-DUiCJRC-.js → meteor-BKTM-7KS.js} +1 -1
  191. package/dist/src/{meteor-44VjEACX.js → meteor-CeGo0Lu2.js} +2 -2
  192. package/dist/src/{meteor-D-SotUw9.js → meteor-Wc_aUVvu.js} +2 -2
  193. package/dist/src/{modelslab-B5J-ZM5c.js → modelslab-BCLOtfek.js} +8 -10
  194. package/dist/src/{modelslab-IQbNg-r7.cjs → modelslab-BkapYJhh.cjs} +7 -10
  195. package/dist/src/{modelslab-BTOT8FUO.js → modelslab-D73OnKSx.js} +7 -10
  196. package/dist/src/{modelslab-BI458moT.js → modelslab-zpz9JcK0.js} +7 -12
  197. package/dist/src/{nova-reel-BZ9y-Y5s.js → nova-reel-B8F_TK5w.js} +7 -10
  198. package/dist/src/{nova-reel-Xw1SXLpg.js → nova-reel-Bx0NFV2f.js} +6 -10
  199. package/dist/src/{nova-reel-DEeQlnOJ.js → nova-reel-CNGJTLtG.js} +6 -12
  200. package/dist/src/{nova-reel-CE5etkv9.cjs → nova-reel-DkT7tnoB.cjs} +6 -10
  201. package/dist/src/{nova-sonic-Ogqf-csn.js → nova-sonic-BaXRN1cr.js} +5 -7
  202. package/dist/src/{nova-sonic-DXTLpi-r.js → nova-sonic-BeTRaFOh.js} +4 -7
  203. package/dist/src/{nova-sonic-DWswpN1E.js → nova-sonic-CL7Zqv0G.js} +4 -9
  204. package/dist/src/{nova-sonic-N0yCm0vb.cjs → nova-sonic-YT426juD.cjs} +4 -7
  205. package/dist/src/{openai-BcB5KlTk.js → openai-BMHD2Huo.js} +6 -3
  206. package/dist/src/{openai-BMcwgD5C.js → openai-BT-JvDse.js} +6 -3
  207. package/dist/src/{openai-CoxGAQwn.cjs → openai-Cy1XLs0c.cjs} +6 -3
  208. package/dist/src/{openai-D6wITiVn.js → openai-D4fxGvRx.js} +6 -3
  209. package/dist/src/openclaw-Bq7RVR3k.js +1200 -0
  210. package/dist/src/openclaw-DA8U4DsD.js +1201 -0
  211. package/dist/src/openclaw-DObVgpjC.js +1200 -0
  212. package/dist/src/openclaw-DUBZP3GL.cjs +1206 -0
  213. package/dist/src/{opencode-sdk-CHCs7dEb.js → opencode-sdk-BB40Wir1.js} +6 -8
  214. package/dist/src/{opencode-sdk-DDxj4QqH.js → opencode-sdk-BM1UAIv1.js} +6 -8
  215. package/dist/src/{opencode-sdk-WWJhnbKr.cjs → opencode-sdk-CeqiOcOU.cjs} +7 -9
  216. package/dist/src/{opencode-sdk-C71Z0ehR.js → opencode-sdk-ChdK7F7z.js} +6 -9
  217. package/dist/src/{otlpReceiver-CZL48YfC.js → otlpReceiver-C6thJRXi.js} +154 -98
  218. package/dist/src/{otlpReceiver-C9KlUtxh.js → otlpReceiver-CcdIikOu.js} +154 -98
  219. package/dist/src/{otlpReceiver-DHKqJlsz.cjs → otlpReceiver-DNSQj6bf.cjs} +154 -98
  220. package/dist/src/{otlpReceiver-CavGAA6k.js → otlpReceiver-UYMQx3sy.js} +154 -98
  221. package/dist/src/{providerRegistry-BkzVH5Ba.js → providerRegistry-1gB5vtzQ.js} +2 -2
  222. package/dist/src/{providerRegistry-BTDgfV5h.cjs → providerRegistry-BESeALrr.cjs} +2 -2
  223. package/dist/src/{providerRegistry-CUWki5mQ.js → providerRegistry-DoACwqhD.js} +2 -2
  224. package/dist/src/{providerRegistry-B9lh-_tx.js → providerRegistry-PMsleEzs.js} +2 -2
  225. package/dist/src/providers-BuyzKt7C.js +2 -0
  226. package/dist/src/providers-C7lNVBjX.cjs +3 -0
  227. package/dist/src/providers-CCE2COJi2.js +2 -0
  228. package/dist/src/{providers-Cn73d5sr.js → providers-CJh7iriU.js} +17180 -16823
  229. package/dist/src/providers-Ctcc592x.js +3 -0
  230. package/dist/src/{providers-DvddrgxL.js → providers-DRrerKra.js} +1052 -695
  231. package/dist/src/{providers-Ch6Mr0gn.js → providers-DT-GtF2t.js} +16716 -16359
  232. package/dist/src/{providers-CScd1wN6.cjs → providers-eDShy16E.cjs} +19893 -19506
  233. package/dist/src/python/persistent_wrapper.py +0 -5
  234. package/dist/src/{pythonUtils-Cpo0Ez1p.js → pythonUtils-C4tltmIn.js} +4 -4
  235. package/dist/src/{pythonUtils-dAVigVK-.cjs → pythonUtils-CoLaCwNY.cjs} +4 -4
  236. package/dist/src/{pythonUtils-Bzwbgpbg.js → pythonUtils-DMO68Jg7.js} +3 -3
  237. package/dist/src/{pythonUtils-wIqk7zAf.js → pythonUtils-DNqbnRdx.js} +3 -3
  238. package/dist/src/{quiverai-BeofbLVc.js → quiverai-BSS9a7wV.js} +4 -4
  239. package/dist/src/{quiverai-DVSEqJiq.js → quiverai-Bk1KrvL6.js} +4 -4
  240. package/dist/src/{quiverai-CcUhPIBg.cjs → quiverai-Bpx6MZ7T.cjs} +4 -4
  241. package/dist/src/{quiverai-CCQn73lq.js → quiverai-CPKhWgaT.js} +4 -5
  242. package/dist/src/render-7uNJ2V14.js +135 -0
  243. package/dist/src/render-DlscvAUJ.js +135 -0
  244. package/dist/src/render-eui5p5mL.js +136 -0
  245. package/dist/src/{render-BHl6QVq9.js → render-nj-UaPdn.js} +2 -3
  246. package/dist/src/render-tG6ir9_g.cjs +165 -0
  247. package/dist/src/{responses-CgNyTPsY.js → responses-1ztiVYsx.js} +56 -17
  248. package/dist/src/{responses-BKP_WYis.js → responses-B8haB-mD.js} +56 -17
  249. package/dist/src/{responses-CQb1Tj69.js → responses-BiaBguAu.js} +56 -17
  250. package/dist/src/{responses-mo0KQDbu.cjs → responses-CF-ayauu.cjs} +56 -17
  251. package/dist/src/rubyUtils-4hjGxvju.js +3 -0
  252. package/dist/src/{rubyUtils-DECSbsfY.js → rubyUtils-BI0p46eZ.js} +3 -3
  253. package/dist/src/{rubyUtils-CiVfln3g.js → rubyUtils-CIQFnVz4.js} +3 -3
  254. package/dist/src/rubyUtils-CO-tuszQ.cjs +2 -0
  255. package/dist/src/{rubyUtils-PgU-gHmx.js → rubyUtils-DGnoCYL2.js} +4 -4
  256. package/dist/src/{rubyUtils-CGeUtCfW.cjs → rubyUtils-DoifqkiA.cjs} +5 -4
  257. package/dist/src/{sagemaker-CqeASYE5.js → sagemaker-BDLeW29y.js} +14 -18
  258. package/dist/src/{sagemaker-MUbD5V3v.js → sagemaker-C5T60MKf.js} +14 -19
  259. package/dist/src/{sagemaker-CVv8W7so.js → sagemaker-ClS_NB07.js} +14 -18
  260. package/dist/src/{sagemaker-jiw1wQa-.cjs → sagemaker-ljtY12VM.cjs} +14 -18
  261. package/dist/src/{scanner-DVDeUz1r.js → scanner-nOCWNIXa.js} +130 -35
  262. package/dist/src/server/golang/wrapper.go +1 -1
  263. package/dist/src/server/index.js +4829 -2529
  264. package/dist/src/server/python/persistent_wrapper.py +0 -5
  265. package/dist/src/{server-BtoCXeXI.cjs → server-BEECpeGG.cjs} +140 -6
  266. package/dist/src/{server-DZ9MtCn0.js → server-ByiF3qlg.js} +129 -9
  267. package/dist/src/{server-Cns05F1j.js → server-ByxbqAcQ.js} +128 -8
  268. package/dist/src/server-C0XKRNB_.cjs +2 -0
  269. package/dist/src/server-C_15p79-.js +3 -0
  270. package/dist/src/{server-CP9qKM40.js → server-gyd6d4Hc.js} +126 -7
  271. package/dist/src/{signal-C3ZTsUgi.js → signal-DTtUuU3l.js} +3 -3
  272. package/dist/src/{slack-DCEV-vWP.js → slack-4zZX1OKP.js} +2 -2
  273. package/dist/src/{slack-94iG3T0s.cjs → slack-BLlsDpfG.cjs} +2 -2
  274. package/dist/src/{slack-BR0HtO3K.js → slack-BPYLQLgb.js} +2 -2
  275. package/dist/src/{slack-2sdpGzbt.js → slack-Bamy_7te.js} +2 -2
  276. package/dist/src/{store-CLyU7AtI.cjs → store-2K0kDi80.cjs} +3 -3
  277. package/dist/src/{store-VB0GP46K.js → store-2OXm_eBY.js} +3 -3
  278. package/dist/src/store-BELqNwvz.js +3 -0
  279. package/dist/src/{store-Cj258DgL.js → store-BPkzEyFM.js} +3 -3
  280. package/dist/src/{store-P8OKm19S.js → store-CPh25336.js} +3 -3
  281. package/dist/src/store-uQZ4AjPe.cjs +2 -0
  282. package/dist/src/{tables-BEIFz2tM.js → tables-BMSOS2Gg.js} +3 -3
  283. package/dist/src/{tables-BdZQEpRz.cjs → tables-CXbaZ9y1.cjs} +3 -3
  284. package/dist/src/{tables-DmzvLbeZ.js → tables-NlvH23ky.js} +3 -3
  285. package/dist/src/{tables-kC7R5kiK.js → tables-WgdUZ8Ck.js} +3 -3
  286. package/dist/src/{telemetry-DPXLd7UE.js → telemetry--iqaGyaS.js} +5 -4
  287. package/dist/src/{telemetry-re627Lre.cjs → telemetry-CEQxGnMZ.cjs} +8 -7
  288. package/dist/src/{telemetry-BugWqKiu.js → telemetry-CgdVGV8N.js} +5 -4
  289. package/dist/src/{telemetry-BnH5VJAU.js → telemetry-DWdGHvEf.js} +5 -4
  290. package/dist/src/telemetry-DjNoC_n3.cjs +2 -0
  291. package/dist/src/telemetry-ZdPZc0fm.js +3 -0
  292. package/dist/src/{text-CW1cyrwj.cjs → text-BiNME7QG.cjs} +1 -1
  293. package/dist/src/{text-Db-Wt2u2.js → text-D4lz-Jg_.js} +1 -1
  294. package/dist/src/{text-TIv0QYnd.js → text-DDQP0tuQ.js} +1 -1
  295. package/dist/src/{text-B_UCRPp2.js → text-NWvfMfkF.js} +1 -1
  296. package/dist/src/{tokenUsageUtils-DflFMjS0.js → tokenUsageUtils-2wIvAhB3.js} +7 -3
  297. package/dist/src/{tokenUsageUtils-BDGe-iyI.js → tokenUsageUtils-4c780gFd.js} +7 -3
  298. package/dist/src/{tokenUsageUtils-NYT-WKS6.js → tokenUsageUtils-BjVkdk18.js} +7 -3
  299. package/dist/src/{tokenUsageUtils-bVa1ga6f.cjs → tokenUsageUtils-C9odhsbW.cjs} +7 -3
  300. package/dist/src/{transcription-CaMivnjG.js → transcription-84t4ALo2.js} +7 -11
  301. package/dist/src/{transcription-Hb3VnC4M.js → transcription-Bm2emLmJ.js} +8 -11
  302. package/dist/src/{transcription-BvtsrzRG.cjs → transcription-CZ4LG5hQ.cjs} +9 -13
  303. package/dist/src/{transcription-DOMMTu01.js → transcription-D7Q0vJsh.js} +7 -13
  304. package/dist/src/{transform-DrleutM3.js → transform-B-b6Cq-q.js} +8 -6
  305. package/dist/src/transform-BQt0BeAW.js +3 -0
  306. package/dist/src/transform-Bq5oqC0s.cjs +2 -0
  307. package/dist/src/{transform-ZrG2dvlo.cjs → transform-C9izGX54.cjs} +5 -5
  308. package/dist/src/{transform-BzK09Q_9.js → transform-CwbAZ84V.js} +5 -5
  309. package/dist/src/{transform-0BwoBsvO.cjs → transform-Dg4LcO1Y.cjs} +18 -10
  310. package/dist/src/{transform-B2-jIv68.js → transform-DtooZqYY.js} +8 -6
  311. package/dist/src/{transform-ljLYHEPh.js → transform-DzCF-wqV.js} +5 -5
  312. package/dist/src/{transform-DyDAwEpE.js → transform-_DpNB4qp.js} +9 -7
  313. package/dist/src/{transform-BqPkNPYm.js → transform-eGiUAv86.js} +5 -5
  314. package/dist/src/{transformersAvailability-DKoRtQLy.cjs → transformersAvailability-B22swDxr.cjs} +1 -1
  315. package/dist/src/{transformersAvailability-BGkzavwb.js → transformersAvailability-lvCCvuPT.js} +1 -1
  316. package/dist/src/{transformersAvailability-D6c6ROpT.js → transformersAvailability-rJGPccjr.js} +1 -1
  317. package/dist/src/{types-Cd3ygw8W.js → types-BDjGOq4E.js} +354 -24
  318. package/dist/src/{types-CIhFeUC4.js → types-BVH9hjgW.js} +364 -23
  319. package/dist/src/{types-D8cGDZbL.cjs → types-CgG2rKiW.cjs} +534 -167
  320. package/dist/src/{types-q8GXGF65.js → types-DNRZVOue.js} +498 -167
  321. package/dist/src/{util-BLvy9qfE.js → util-3pBZZb_H.js} +151 -149
  322. package/dist/src/{util-CFj4YKIn.cjs → util-A5_ZsQUn.cjs} +66 -44
  323. package/dist/src/{util-BtoGs5Cb.js → util-B9CNhyac.js} +66 -44
  324. package/dist/src/{util-Bm3E9jpK.js → util-BQOCAHQC.js} +692 -690
  325. package/dist/src/{util-vNmDL5DT.js → util-BVXcTwXu.js} +138 -36
  326. package/dist/src/{util-CgDCK4KI.js → util-BlFVL0UF.js} +66 -44
  327. package/dist/src/{util-DM2rTn_6.js → util-C-kmRosx.js} +66 -44
  328. package/dist/src/{util-DbVG-yZU.js → util-DFPeFkiV.js} +138 -36
  329. package/dist/src/{util-DMFeUvLz.js → util-DN0-b81k.js} +138 -36
  330. package/dist/src/{util--9u9UVCt.cjs → util-Dpmm_dAI.cjs} +143 -35
  331. package/dist/src/{util-CMMkIxfU.js → util-Dub0f_ej.js} +693 -691
  332. package/dist/src/{util-CuLo2pMR.cjs → util-DvpHnLt0.cjs} +714 -719
  333. package/dist/src/{utils-DOjD4dTC.js → utils-BUMN8orw.js} +6 -4
  334. package/dist/src/{utils-DKw8mrgr.cjs → utils-DkVeShIB.cjs} +6 -4
  335. package/dist/src/{utils-DEuL4VNB.js → utils-kt7lv30R.js} +6 -4
  336. package/dist/src/{utils-CFxO9KGo.js → utils-o8S5huU2.js} +6 -4
  337. package/dist/src/version-0frU0UTr.js +16 -0
  338. package/dist/src/version-CbpiUINz.js +17 -0
  339. package/dist/src/version-CbuBKu2U.js +16 -0
  340. package/dist/src/version-D9zu9FWB.cjs +27 -0
  341. package/dist/tsconfig.tsbuildinfo +1 -1
  342. package/package.json +57 -46
  343. package/dist/src/app/assets/index-B6l9CVVb.js +0 -439
  344. package/dist/src/app/assets/index-DyZ0Ep37.css +0 -1
  345. package/dist/src/app/assets/scroll-timeline-BdJZVXlz.js +0 -1
  346. package/dist/src/app/assets/sync-CStkzc6u.js +0 -4
  347. package/dist/src/app/assets/vendor-charts-BnDWwBlI.js +0 -36
  348. package/dist/src/app/assets/vendor-markdown-Bz7N-ca6.js +0 -29
  349. package/dist/src/app/assets/vendor-react-AtKqiNEf.js +0 -4
  350. package/dist/src/app/assets/vendor-syntax-D06x6TQF.js +0 -2
  351. package/dist/src/app/assets/vendor-utils-BvMHZmO7.js +0 -37
  352. package/dist/src/cache-C5yFZ4gC.cjs +0 -816
  353. package/dist/src/cache-CaT5tPgo.js +0 -756
  354. package/dist/src/cache-CyCanoMu.js +0 -6
  355. package/dist/src/cache-DSqR6ezl.js +0 -726
  356. package/dist/src/cache-Df_QFDNu.cjs +0 -5
  357. package/dist/src/cache-HP0NP4k3.js +0 -756
  358. package/dist/src/cloud-DE3t1-ZI.js +0 -4
  359. package/dist/src/codex-sdk-BQEw16R_.js +0 -834
  360. package/dist/src/codex-sdk-C_07GuVS.js +0 -834
  361. package/dist/src/codex-sdk-DE5G18dx.js +0 -835
  362. package/dist/src/codex-sdk-ZLKfDjqP.cjs +0 -838
  363. package/dist/src/eval-7aEqoMs3.js +0 -15
  364. package/dist/src/evalResult-CYNHkk5A.js +0 -12
  365. package/dist/src/evalResult-CuvJeNiM.js +0 -10
  366. package/dist/src/evalResult-tGdilrWt.cjs +0 -10
  367. package/dist/src/evaluator-BBUqRhz1.js +0 -36
  368. package/dist/src/fetch-UWU706qb.js +0 -5
  369. package/dist/src/graders-BxfEguVY.js +0 -32
  370. package/dist/src/graders-CzVMbEnv.js +0 -34
  371. package/dist/src/graders-DjCXfj0l.cjs +0 -32
  372. package/dist/src/graders-kHzIWOKu.js +0 -32
  373. package/dist/src/messages-DJNo37Ko.js +0 -246
  374. package/dist/src/messages-Dy9QecMs.js +0 -245
  375. package/dist/src/messages-HJsyEh4o.cjs +0 -257
  376. package/dist/src/messages-biC_ex-p.js +0 -245
  377. package/dist/src/openclaw-0Sv7AK3O.js +0 -580
  378. package/dist/src/openclaw-CXxbKgDH.cjs +0 -586
  379. package/dist/src/openclaw-D1FSCps-.js +0 -580
  380. package/dist/src/openclaw-D2ENvu7a.js +0 -582
  381. package/dist/src/providers-BSLEaIQG.js +0 -32
  382. package/dist/src/providers-D-FnDg8k.cjs +0 -31
  383. package/dist/src/providers-DEYiFVAo.js +0 -30
  384. package/dist/src/providers-sS2WI8YD.js +0 -30
  385. package/dist/src/rubyUtils-B1HXG4ej.cjs +0 -4
  386. package/dist/src/rubyUtils-Rt6pKA96.js +0 -5
  387. package/dist/src/server-B0Xh1Gx-.js +0 -7
  388. package/dist/src/server-DJTKu9IR.cjs +0 -5
  389. package/dist/src/store-C5u6MgC8.js +0 -6
  390. package/dist/src/store-CNHk-De4.cjs +0 -5
  391. package/dist/src/telemetry-Yig0Tino.js +0 -7
  392. package/dist/src/telemetry-p8Pwqm1i.cjs +0 -5
  393. package/dist/src/transform-ChNIpHz7.js +0 -6
  394. package/dist/src/transform-PtQ6rAE3.cjs +0 -5
@@ -0,0 +1,1201 @@
1
+ #!/usr/bin/env node
2
+ import { C as getConfigDirectoryPath, O as getEnvString, s as logger } from "./logger-BbY6ypFL.js";
3
+ import { m as REQUEST_TIMEOUT_MS, n as fetchWithProxy } from "./fetch-B6ch2nU2.js";
4
+ import { n as VERSION } from "./version-CbpiUINz.js";
5
+ import { t as OpenAiChatCompletionProvider } from "./chat-BLOdH60v.js";
6
+ import { t as OpenAiEmbeddingProvider } from "./embedding-DNRvZwRN.js";
7
+ import { t as OpenAiResponsesProvider } from "./responses-B8haB-mD.js";
8
+ import { n as sha256 } from "./createHash-DPpsZgFF.js";
9
+ import fs from "fs";
10
+ import path from "path";
11
+ import os from "os";
12
+ import crypto from "crypto";
13
+ import WebSocket from "ws";
14
+ import JSON5 from "json5";
15
+ //#region src/providers/openclaw/device-auth.ts
16
+ const DEFAULT_CLIENT_DIR = "openclaw";
17
+ const DEFAULT_DEVICE_IDENTITY_FILE = "device-identity.json";
18
+ const DEFAULT_DEVICE_AUTH_FILE = "device-auth.json";
19
+ function defaultOpenClawClientPath(fileName) {
20
+ return path.join(getConfigDirectoryPath(true), DEFAULT_CLIENT_DIR, fileName);
21
+ }
22
+ function getDefaultOpenClawDeviceIdentityPath() {
23
+ return defaultOpenClawClientPath(DEFAULT_DEVICE_IDENTITY_FILE);
24
+ }
25
+ function getDefaultOpenClawDeviceAuthPath() {
26
+ return defaultOpenClawClientPath(DEFAULT_DEVICE_AUTH_FILE);
27
+ }
28
+ function ensureParentDirectory(filePath) {
29
+ fs.mkdirSync(path.dirname(filePath), {
30
+ recursive: true,
31
+ mode: 448
32
+ });
33
+ }
34
+ function writeJsonSecure(filePath, value) {
35
+ ensureParentDirectory(filePath);
36
+ fs.writeFileSync(filePath, `${JSON.stringify(value, null, 2)}\n`, {
37
+ encoding: "utf-8",
38
+ mode: 384
39
+ });
40
+ fs.chmodSync(filePath, 384);
41
+ }
42
+ function parseJsonObject(raw) {
43
+ try {
44
+ const parsed = JSON.parse(raw);
45
+ return parsed && typeof parsed === "object" && !Array.isArray(parsed) ? parsed : void 0;
46
+ } catch (err) {
47
+ logger.debug("[OpenClaw Device Auth] Failed to parse JSON", {
48
+ err,
49
+ rawLength: raw.length,
50
+ rawPreview: raw.slice(0, 100)
51
+ });
52
+ return;
53
+ }
54
+ }
55
+ function normalizeDeviceMetadataValue(value) {
56
+ const trimmed = value?.trim();
57
+ if (!trimmed) return "";
58
+ return trimmed.replace(/[A-Z]/g, (letter) => letter.toLowerCase());
59
+ }
60
+ function normalizeScopes$1(scopes) {
61
+ const seen = /* @__PURE__ */ new Set();
62
+ for (const scope of scopes || []) {
63
+ const trimmed = scope.trim();
64
+ if (trimmed) seen.add(trimmed);
65
+ }
66
+ if (seen.has("operator.admin")) {
67
+ seen.add("operator.read");
68
+ seen.add("operator.write");
69
+ } else if (seen.has("operator.write")) seen.add("operator.read");
70
+ return Array.from(seen).sort();
71
+ }
72
+ function publicKeyBase64UrlFromPem(publicKeyPem) {
73
+ const publicKey = crypto.createPublicKey(publicKeyPem);
74
+ const jwk = publicKey.export({ format: "jwk" });
75
+ if (typeof jwk.x === "string" && jwk.x.trim()) return jwk.x;
76
+ const der = publicKey.export({
77
+ type: "spki",
78
+ format: "der"
79
+ });
80
+ return Buffer.from(der.subarray(Math.max(0, der.length - 32))).toString("base64url");
81
+ }
82
+ function deriveDeviceId(publicKeyPem) {
83
+ return sha256(Buffer.from(publicKeyBase64UrlFromPem(publicKeyPem), "base64url"));
84
+ }
85
+ function isValidIdentity(identity) {
86
+ try {
87
+ const publicKeyFromPrivateKey = crypto.createPublicKey(identity.privateKeyPem).export({
88
+ type: "spki",
89
+ format: "pem"
90
+ });
91
+ return identity.deviceId === deriveDeviceId(identity.publicKeyPem) && publicKeyBase64UrlFromPem(identity.publicKeyPem) === publicKeyBase64UrlFromPem(publicKeyFromPrivateKey);
92
+ } catch {
93
+ return false;
94
+ }
95
+ }
96
+ function parseIdentity(raw) {
97
+ const parsed = parseJsonObject(raw);
98
+ const identity = {
99
+ deviceId: typeof parsed?.deviceId === "string" ? parsed.deviceId : "",
100
+ publicKeyPem: typeof parsed?.publicKeyPem === "string" ? parsed.publicKeyPem : "",
101
+ privateKeyPem: typeof parsed?.privateKeyPem === "string" ? parsed.privateKeyPem : ""
102
+ };
103
+ return isValidIdentity(identity) ? identity : void 0;
104
+ }
105
+ function createDeviceIdentity() {
106
+ const keyPair = crypto.generateKeyPairSync("ed25519", {
107
+ publicKeyEncoding: {
108
+ type: "spki",
109
+ format: "pem"
110
+ },
111
+ privateKeyEncoding: {
112
+ type: "pkcs8",
113
+ format: "pem"
114
+ }
115
+ });
116
+ const publicKeyPem = keyPair.publicKey;
117
+ return {
118
+ deviceId: deriveDeviceId(publicKeyPem),
119
+ publicKeyPem,
120
+ privateKeyPem: keyPair.privateKey
121
+ };
122
+ }
123
+ function loadOrCreateOpenClawDeviceIdentity(filePath) {
124
+ const identityPath = filePath || getDefaultOpenClawDeviceIdentityPath();
125
+ try {
126
+ if (fs.existsSync(identityPath)) {
127
+ const identity = parseIdentity(fs.readFileSync(identityPath, "utf-8"));
128
+ if (identity) return identity;
129
+ }
130
+ } catch (err) {
131
+ logger.warn("[OpenClaw Device Auth] Failed to read device identity; generating new identity", {
132
+ err,
133
+ identityPath
134
+ });
135
+ }
136
+ const identity = createDeviceIdentity();
137
+ try {
138
+ writeJsonSecure(identityPath, identity);
139
+ } catch (err) {
140
+ logger.warn("[OpenClaw Device Auth] Failed to persist device identity", {
141
+ err,
142
+ identityPath
143
+ });
144
+ }
145
+ return identity;
146
+ }
147
+ function buildOpenClawDeviceAuthPayloadV3(params) {
148
+ return [
149
+ "v3",
150
+ params.deviceId,
151
+ params.clientId,
152
+ params.clientMode,
153
+ params.role,
154
+ params.scopes.join(","),
155
+ String(params.signedAtMs),
156
+ params.token ?? "",
157
+ params.nonce,
158
+ normalizeDeviceMetadataValue(params.platform),
159
+ normalizeDeviceMetadataValue(params.deviceFamily)
160
+ ].join("|");
161
+ }
162
+ function signOpenClawDevicePayload(privateKeyPem, payload) {
163
+ return crypto.sign(null, Buffer.from(payload), privateKeyPem).toString("base64url");
164
+ }
165
+ function buildSignedOpenClawDevice(params) {
166
+ const signedAt = params.nowMs ?? Date.now();
167
+ const payload = buildOpenClawDeviceAuthPayloadV3({
168
+ deviceId: params.identity.deviceId,
169
+ clientId: params.clientId,
170
+ clientMode: params.clientMode,
171
+ role: params.role,
172
+ scopes: params.scopes,
173
+ signedAtMs: signedAt,
174
+ token: params.token,
175
+ nonce: params.nonce,
176
+ platform: params.platform,
177
+ deviceFamily: params.deviceFamily
178
+ });
179
+ return {
180
+ id: params.identity.deviceId,
181
+ publicKey: publicKeyBase64UrlFromPem(params.identity.publicKeyPem),
182
+ signature: signOpenClawDevicePayload(params.identity.privateKeyPem, payload),
183
+ signedAt,
184
+ nonce: params.nonce
185
+ };
186
+ }
187
+ function parseDeviceAuthStore(raw) {
188
+ const parsed = parseJsonObject(raw);
189
+ if (!parsed || parsed.version !== 1 || typeof parsed.deviceId !== "string") return;
190
+ const tokens = {};
191
+ const rawTokens = parsed.tokens && typeof parsed.tokens === "object" && !Array.isArray(parsed.tokens) ? parsed.tokens : {};
192
+ for (const [role, tokenRecord] of Object.entries(rawTokens)) {
193
+ if (!tokenRecord || typeof tokenRecord !== "object" || Array.isArray(tokenRecord)) continue;
194
+ const record = tokenRecord;
195
+ if (typeof record.token !== "string" || !record.token.trim()) continue;
196
+ tokens[role] = {
197
+ token: record.token,
198
+ role: typeof record.role === "string" ? record.role : role,
199
+ scopes: Array.isArray(record.scopes) ? normalizeScopes$1(record.scopes.filter((scope) => typeof scope === "string")) : [],
200
+ updatedAtMs: typeof record.updatedAtMs === "number" ? record.updatedAtMs : 0
201
+ };
202
+ }
203
+ return {
204
+ version: 1,
205
+ deviceId: parsed.deviceId,
206
+ tokens
207
+ };
208
+ }
209
+ function readDeviceAuthStore(filePath) {
210
+ try {
211
+ if (!fs.existsSync(filePath)) return;
212
+ return parseDeviceAuthStore(fs.readFileSync(filePath, "utf-8"));
213
+ } catch (err) {
214
+ logger.debug("[OpenClaw Device Auth] Failed to read device auth store", {
215
+ err,
216
+ filePath
217
+ });
218
+ return;
219
+ }
220
+ }
221
+ function loadOpenClawDeviceAuthToken(params) {
222
+ const store = readDeviceAuthStore(params.filePath || getDefaultOpenClawDeviceAuthPath());
223
+ if (!store || store.deviceId !== params.deviceId) return;
224
+ const role = params.role.trim();
225
+ const tokenRecord = store.tokens[role];
226
+ const token = tokenRecord?.token.trim();
227
+ return token ? {
228
+ ...tokenRecord,
229
+ token
230
+ } : void 0;
231
+ }
232
+ function storeOpenClawDeviceAuthToken(params) {
233
+ const token = params.token.trim();
234
+ const role = params.role.trim();
235
+ if (!token || !role) return;
236
+ const authPath = params.filePath || getDefaultOpenClawDeviceAuthPath();
237
+ const existing = readDeviceAuthStore(authPath);
238
+ const store = existing && existing.deviceId === params.deviceId ? existing : {
239
+ version: 1,
240
+ deviceId: params.deviceId,
241
+ tokens: {}
242
+ };
243
+ store.tokens[role] = {
244
+ token,
245
+ role,
246
+ scopes: normalizeScopes$1(params.scopes),
247
+ updatedAtMs: Date.now()
248
+ };
249
+ try {
250
+ writeJsonSecure(authPath, store);
251
+ } catch (err) {
252
+ logger.warn("[OpenClaw Device Auth] Failed to persist device auth token", {
253
+ err,
254
+ authPath
255
+ });
256
+ }
257
+ }
258
+ function clearOpenClawDeviceAuthToken(params) {
259
+ const authPath = params.filePath || getDefaultOpenClawDeviceAuthPath();
260
+ const store = readDeviceAuthStore(authPath);
261
+ if (!store || store.deviceId !== params.deviceId) return;
262
+ delete store.tokens[params.role.trim()];
263
+ try {
264
+ writeJsonSecure(authPath, store);
265
+ } catch (err) {
266
+ logger.warn("[OpenClaw Device Auth] Failed to clear device auth token", {
267
+ err,
268
+ authPath
269
+ });
270
+ }
271
+ }
272
+ //#endregion
273
+ //#region src/providers/openclaw/shared.ts
274
+ const DEFAULT_GATEWAY_PORT = 18789;
275
+ const DEFAULT_GATEWAY_HOST = "127.0.0.1";
276
+ /**
277
+ * Cached config to avoid re-reading the file multiple times during provider init.
278
+ */
279
+ let cachedConfig;
280
+ let cachedConfigPath;
281
+ function resolveConfigPath(env) {
282
+ return env?.OPENCLAW_CONFIG_PATH || getEnvString("OPENCLAW_CONFIG_PATH") || path.join(os.homedir(), ".openclaw", "openclaw.json");
283
+ }
284
+ function normalizeGatewayUrl(url, transport) {
285
+ const trimmed = url.trim();
286
+ if (!trimmed) return;
287
+ if (transport === "http") {
288
+ if (trimmed.startsWith("wss://")) return `https://${trimmed.slice(6)}`;
289
+ if (trimmed.startsWith("ws://")) return `http://${trimmed.slice(5)}`;
290
+ return trimmed;
291
+ }
292
+ if (trimmed.startsWith("https://")) return `wss://${trimmed.slice(8)}`;
293
+ if (trimmed.startsWith("http://")) return `ws://${trimmed.slice(7)}`;
294
+ return trimmed;
295
+ }
296
+ function resolveGatewayHost(gatewayConfig) {
297
+ const bind = gatewayConfig?.bind?.trim();
298
+ const customBindHost = gatewayConfig?.customBindHost?.trim();
299
+ if (!bind || bind === "auto" || bind === "loopback" || bind === "lan" || bind === "tailnet" || bind === "0.0.0.0" || bind === "::" || bind === "127.0.0.1" || bind === "localhost" || bind === "::1") return DEFAULT_GATEWAY_HOST;
300
+ if (bind === "custom") {
301
+ if (!customBindHost || customBindHost === "0.0.0.0" || customBindHost === "::" || customBindHost === "127.0.0.1" || customBindHost === "localhost" || customBindHost === "::1") return DEFAULT_GATEWAY_HOST;
302
+ return customBindHost;
303
+ }
304
+ return bind;
305
+ }
306
+ function buildLocalGatewayUrl(gatewayConfig, transport, portOverride) {
307
+ const scheme = transport === "ws" ? gatewayConfig?.tls?.enabled ? "wss" : "ws" : gatewayConfig?.tls?.enabled ? "https" : "http";
308
+ const port = portOverride ?? gatewayConfig?.port ?? 18789;
309
+ return `${scheme}://${resolveGatewayHost(gatewayConfig)}:${port}`;
310
+ }
311
+ function resolveGatewayUrlFromConfig(openclawConfig, transport, portOverride) {
312
+ const gatewayConfig = openclawConfig?.gateway;
313
+ if (!gatewayConfig) return;
314
+ if (gatewayConfig.mode === "remote") {
315
+ const remoteUrl = normalizeGatewayUrl(gatewayConfig.remote?.url ?? "", transport);
316
+ if (remoteUrl) return remoteUrl;
317
+ }
318
+ return buildLocalGatewayUrl(gatewayConfig, transport, portOverride);
319
+ }
320
+ function resolveGatewayPortOverride(env) {
321
+ const trimmedPort = (env?.OPENCLAW_GATEWAY_PORT || getEnvString("OPENCLAW_GATEWAY_PORT"))?.trim();
322
+ if (!trimmedPort || !/^\d+$/.test(trimmedPort)) return;
323
+ const parsedPort = Number(trimmedPort);
324
+ return Number.isInteger(parsedPort) && parsedPort > 0 && parsedPort <= 65535 ? parsedPort : void 0;
325
+ }
326
+ function toAuthSecret(kind, value) {
327
+ const trimmed = value?.trim();
328
+ return trimmed ? {
329
+ kind,
330
+ value: trimmed
331
+ } : void 0;
332
+ }
333
+ function resolveAuthSecretFromConfig(openclawConfig) {
334
+ const gatewayConfig = openclawConfig?.gateway;
335
+ const authMode = gatewayConfig?.auth?.mode?.trim();
336
+ const preferRemoteCredentials = gatewayConfig?.mode === "remote";
337
+ const localToken = toAuthSecret("token", gatewayConfig?.auth?.token);
338
+ const localPassword = toAuthSecret("password", gatewayConfig?.auth?.password);
339
+ const remoteToken = toAuthSecret("token", gatewayConfig?.remote?.token);
340
+ const remotePassword = toAuthSecret("password", gatewayConfig?.remote?.password);
341
+ if (preferRemoteCredentials) {
342
+ if (authMode === "password") return remotePassword || localPassword || remoteToken || localToken;
343
+ if (authMode === "token") return remoteToken || localToken || remotePassword || localPassword;
344
+ return remoteToken || remotePassword || localToken || localPassword;
345
+ }
346
+ if (authMode === "password") return localPassword || remotePassword || localToken || remoteToken;
347
+ if (authMode === "token") return localToken || remoteToken || localPassword || remotePassword;
348
+ return localToken || localPassword || remoteToken || remotePassword;
349
+ }
350
+ /**
351
+ * Read and parse the active OpenClaw configuration file.
352
+ * Results are cached based on file modification time.
353
+ * Returns undefined if the file doesn't exist or can't be parsed.
354
+ */
355
+ function readOpenClawConfig(env) {
356
+ const configPath = resolveConfigPath(env);
357
+ try {
358
+ if (!fs.existsSync(configPath)) return;
359
+ const mtime = fs.statSync(configPath).mtimeMs;
360
+ if (cachedConfig && cachedConfigPath === configPath && cachedConfig.mtime === mtime) return cachedConfig.config;
361
+ const raw = fs.readFileSync(configPath, "utf-8");
362
+ const config = JSON5.parse(raw);
363
+ cachedConfig = {
364
+ config,
365
+ mtime
366
+ };
367
+ cachedConfigPath = configPath;
368
+ return config;
369
+ } catch (err) {
370
+ logger.warn(`Failed to read OpenClaw config at ${configPath}`, { err });
371
+ return;
372
+ }
373
+ }
374
+ /**
375
+ * Auto-detect the OpenClaw gateway URL from config, env overrides, or the active config file.
376
+ */
377
+ function resolveGatewayUrl(config, env) {
378
+ return resolveGatewayTransportUrl(config, env, "http");
379
+ }
380
+ function resolveGatewayWsUrl(config, env) {
381
+ return resolveGatewayTransportUrl(config, env, "ws");
382
+ }
383
+ function resolveGatewayTransportUrl(config, env, transport) {
384
+ const configUrl = config?.gateway_url?.trim();
385
+ if (configUrl) return normalizeGatewayUrl(configUrl, transport) || configUrl;
386
+ const trimmedEnvUrl = (env?.OPENCLAW_GATEWAY_URL || getEnvString("OPENCLAW_GATEWAY_URL") || env?.CLAWDBOT_GATEWAY_URL || getEnvString("CLAWDBOT_GATEWAY_URL"))?.trim();
387
+ if (trimmedEnvUrl) return normalizeGatewayUrl(trimmedEnvUrl, transport) || trimmedEnvUrl;
388
+ const portOverride = resolveGatewayPortOverride(env);
389
+ const resolvedUrl = resolveGatewayUrlFromConfig(readOpenClawConfig(env), transport, portOverride);
390
+ if (resolvedUrl) return resolvedUrl;
391
+ return `${transport === "ws" ? "ws" : "http"}://${DEFAULT_GATEWAY_HOST}:${portOverride ?? 18789}`;
392
+ }
393
+ function resolveAuthSecret(config, env) {
394
+ if (config?.auth_token) return {
395
+ kind: "token",
396
+ value: config.auth_token
397
+ };
398
+ if (config?.auth_password) return {
399
+ kind: "password",
400
+ value: config.auth_password
401
+ };
402
+ const envToken = env?.OPENCLAW_GATEWAY_TOKEN || getEnvString("OPENCLAW_GATEWAY_TOKEN") || env?.CLAWDBOT_GATEWAY_TOKEN || getEnvString("CLAWDBOT_GATEWAY_TOKEN");
403
+ if (envToken) return {
404
+ kind: "token",
405
+ value: envToken
406
+ };
407
+ const envPassword = env?.OPENCLAW_GATEWAY_PASSWORD || getEnvString("OPENCLAW_GATEWAY_PASSWORD") || env?.CLAWDBOT_GATEWAY_PASSWORD || getEnvString("CLAWDBOT_GATEWAY_PASSWORD");
408
+ if (envPassword) return {
409
+ kind: "password",
410
+ value: envPassword
411
+ };
412
+ return resolveAuthSecretFromConfig(readOpenClawConfig(env));
413
+ }
414
+ /**
415
+ * Auto-detect the OpenClaw gateway bearer secret from config, env overrides, or the active
416
+ * config file. OpenClaw accepts either a token or password as the HTTP bearer secret.
417
+ */
418
+ function resolveAuthToken(config, env) {
419
+ return resolveAuthSecret(config, env)?.value;
420
+ }
421
+ /**
422
+ * Build the canonical OpenClaw model id for OpenAI-compatible endpoints.
423
+ */
424
+ function buildOpenClawModelName(agentId) {
425
+ const trimmedAgentId = agentId.trim();
426
+ if (!trimmedAgentId || trimmedAgentId === "default" || trimmedAgentId === "openclaw") return "openclaw/default";
427
+ if (trimmedAgentId.startsWith("openclaw/")) {
428
+ const targetAgentId = trimmedAgentId.slice(9).trim();
429
+ return targetAgentId ? `openclaw/${targetAgentId}` : "openclaw/default";
430
+ }
431
+ if (trimmedAgentId.startsWith("openclaw:")) {
432
+ const targetAgentId = trimmedAgentId.slice(9).trim();
433
+ return targetAgentId ? `openclaw/${targetAgentId}` : "openclaw/default";
434
+ }
435
+ if (trimmedAgentId.startsWith("agent:")) {
436
+ const targetAgentId = trimmedAgentId.slice(6).trim();
437
+ return targetAgentId ? `openclaw/${targetAgentId}` : "openclaw/default";
438
+ }
439
+ return `openclaw/${trimmedAgentId}`;
440
+ }
441
+ function normalizeHeaderValue(value) {
442
+ return value?.trim() || void 0;
443
+ }
444
+ /**
445
+ * Build OpenClaw request context headers shared by HTTP-compatible endpoints.
446
+ */
447
+ function buildOpenClawContextHeaders(config) {
448
+ const headers = {};
449
+ const backendModel = normalizeHeaderValue(config?.backend_model || config?.model_override);
450
+ const messageChannel = normalizeHeaderValue(config?.message_channel);
451
+ const accountId = normalizeHeaderValue(config?.account_id);
452
+ const scopes = config?.scopes?.map((scope) => scope.trim()).filter(Boolean).join(",");
453
+ if (backendModel) headers["x-openclaw-model"] = backendModel;
454
+ if (messageChannel) headers["x-openclaw-message-channel"] = messageChannel;
455
+ if (accountId) headers["x-openclaw-account-id"] = accountId;
456
+ if (scopes) headers["x-openclaw-scopes"] = scopes;
457
+ return headers;
458
+ }
459
+ /**
460
+ * Build common OpenClaw headers for agent-id, session-key, and request context.
461
+ * Note: thinking_level is only supported by the WS Agent provider and is
462
+ * passed as an RPC param there, not as an HTTP header.
463
+ */
464
+ function buildOpenClawHeaders(agentId, config) {
465
+ const headers = { "x-openclaw-agent-id": agentId };
466
+ if (config?.session_key) headers["x-openclaw-session-key"] = config.session_key;
467
+ return {
468
+ ...headers,
469
+ ...buildOpenClawContextHeaders(config)
470
+ };
471
+ }
472
+ /**
473
+ * Build provider options for OpenAI-compatible OpenClaw providers (chat, responses).
474
+ * Resolves gateway URL, auth token, and merges OpenClaw-specific headers.
475
+ */
476
+ function buildOpenClawProviderOptions(agentId, providerOptions) {
477
+ const config = providerOptions.config || {};
478
+ const env = providerOptions.env;
479
+ const gatewayUrl = resolveGatewayUrl(config, env);
480
+ const authToken = resolveAuthToken(config, env);
481
+ return {
482
+ ...providerOptions,
483
+ config: {
484
+ ...config,
485
+ apiBaseUrl: `${gatewayUrl}/v1`,
486
+ ...authToken && { apiKey: authToken },
487
+ apiKeyRequired: false,
488
+ headers: {
489
+ ...config.headers,
490
+ ...buildOpenClawHeaders(agentId, config)
491
+ }
492
+ }
493
+ };
494
+ }
495
+ //#endregion
496
+ //#region src/providers/openclaw/agent.ts
497
+ const OPENCLAW_PROTOCOL_VERSION = 3;
498
+ const CLIENT_ID = "gateway-client";
499
+ const CLIENT_MODE = "cli";
500
+ const CLIENT_ROLE = "operator";
501
+ const DEFAULT_SCOPES = ["operator.read", "operator.write"];
502
+ function normalizeScopes(scopes) {
503
+ const seen = /* @__PURE__ */ new Set();
504
+ const normalized = [];
505
+ for (const scope of scopes || []) {
506
+ const trimmed = scope.trim();
507
+ if (trimmed && !seen.has(trimmed)) {
508
+ seen.add(trimmed);
509
+ normalized.push(trimmed);
510
+ }
511
+ }
512
+ return normalized;
513
+ }
514
+ function getStringArray(value) {
515
+ if (!Array.isArray(value)) return;
516
+ const strings = value.filter((item) => typeof item === "string");
517
+ return strings.length > 0 ? strings : void 0;
518
+ }
519
+ function stripRetryMarker(result) {
520
+ const { retryWithDeviceToken: _retryWithDeviceToken, ...providerResponse } = result;
521
+ return providerResponse;
522
+ }
523
+ function buildOpenClawAgentSessionKey(agentId, sessionKey) {
524
+ const trimmedSessionKey = sessionKey.trim();
525
+ if (!trimmedSessionKey || trimmedSessionKey.toLowerCase().startsWith("agent:")) return trimmedSessionKey;
526
+ const trimmedAgentId = agentId.trim();
527
+ if (!trimmedAgentId || trimmedAgentId.toLowerCase() === "main") return trimmedSessionKey;
528
+ return `agent:${trimmedAgentId}:${trimmedSessionKey}`;
529
+ }
530
+ /**
531
+ * OpenClaw WebSocket Agent Provider
532
+ *
533
+ * Custom provider that uses the native OpenClaw WS RPC protocol to invoke agents.
534
+ * Supports full streaming with event accumulation.
535
+ *
536
+ * Protocol flow:
537
+ * 1. Open WS connection to gateway
538
+ * 2. Receive connect.challenge event → send signed connect request
539
+ * 3. Receive connect response → persist device token and send agent request
540
+ * 4. Receive agent accepted response → send agent.wait
541
+ * 5. Accumulate streaming "agent" events (assistant text/delta, lifecycle errors, error streams)
542
+ * 6. Resolve on agent.wait response
543
+ *
544
+ * Usage:
545
+ * openclaw:agent - default agent (main)
546
+ * openclaw:agent:main - explicit agent ID
547
+ * openclaw:agent:my-agent - custom agent ID
548
+ */
549
+ var OpenClawAgentProvider = class {
550
+ agentId;
551
+ gatewayUrl;
552
+ authKind;
553
+ authSecret;
554
+ openclawConfig;
555
+ timeoutMs;
556
+ scopes;
557
+ hasExplicitScopes;
558
+ activeConnections = /* @__PURE__ */ new Set();
559
+ constructor(agentId, providerOptions = {}) {
560
+ this.agentId = agentId;
561
+ this.openclawConfig = providerOptions.config || {};
562
+ const env = providerOptions.env;
563
+ this.gatewayUrl = resolveGatewayWsUrl(this.openclawConfig, env);
564
+ const authSecret = resolveAuthSecret(this.openclawConfig, env);
565
+ this.authKind = authSecret?.kind;
566
+ this.authSecret = authSecret?.value;
567
+ this.timeoutMs = this.openclawConfig.timeoutMs ?? REQUEST_TIMEOUT_MS;
568
+ this.scopes = normalizeScopes(this.openclawConfig.scopes);
569
+ this.hasExplicitScopes = this.scopes.length > 0;
570
+ if (!this.hasExplicitScopes) this.scopes = [...DEFAULT_SCOPES];
571
+ }
572
+ id() {
573
+ return `openclaw:agent:${this.agentId}`;
574
+ }
575
+ toString() {
576
+ return `[OpenClaw Agent Provider ${this.agentId}]`;
577
+ }
578
+ toJSON() {
579
+ return { provider: this.id() };
580
+ }
581
+ async cleanup() {
582
+ for (const ws of this.activeConnections) ws.close();
583
+ this.activeConnections.clear();
584
+ }
585
+ async callApi(prompt) {
586
+ const sessionKey = buildOpenClawAgentSessionKey(this.agentId, this.openclawConfig.session_key || `promptfoo-${crypto.randomUUID()}`);
587
+ const firstResult = await this.callApiOnce(prompt, sessionKey);
588
+ if (firstResult.retryWithDeviceToken) {
589
+ const retryDeviceToken = this.resolveDeviceTokenForRetry();
590
+ if (retryDeviceToken) return stripRetryMarker(await this.callApiOnce(prompt, sessionKey, retryDeviceToken));
591
+ }
592
+ return stripRetryMarker(firstResult);
593
+ }
594
+ callApiOnce(prompt, sessionKey, retryDeviceToken) {
595
+ return new Promise((resolve) => {
596
+ const wsHeaders = this.buildWebSocketHeaders();
597
+ const ws = wsHeaders ? new WebSocket(this.gatewayUrl, { headers: wsHeaders }) : new WebSocket(this.gatewayUrl);
598
+ this.activeConnections.add(ws);
599
+ let resolved = false;
600
+ let timeout;
601
+ const finish = (result, closeSocket = true) => {
602
+ if (resolved) return;
603
+ resolved = true;
604
+ clearTimeout(timeout);
605
+ this.activeConnections.delete(ws);
606
+ if (closeSocket) ws.close();
607
+ resolve(result);
608
+ };
609
+ const state = {
610
+ agentRequestId: crypto.randomUUID(),
611
+ waitRequestId: crypto.randomUUID(),
612
+ idempotencyKey: crypto.randomUUID(),
613
+ lastText: "",
614
+ lastError: "",
615
+ connected: false,
616
+ prompt,
617
+ sessionKey,
618
+ ws,
619
+ finish,
620
+ retryDeviceToken
621
+ };
622
+ timeout = setTimeout(() => {
623
+ finish({ error: `OpenClaw agent request timed out after ${this.timeoutMs}ms` });
624
+ }, this.timeoutMs);
625
+ ws.on("error", (err) => {
626
+ finish({ error: `OpenClaw WebSocket error: ${err.message}` });
627
+ });
628
+ ws.on("close", () => {
629
+ this.activeConnections.delete(ws);
630
+ if (!resolved) finish({ error: "OpenClaw WebSocket connection closed unexpectedly" }, false);
631
+ });
632
+ ws.on("message", (data) => {
633
+ const frame = this.parseFrame(data);
634
+ if (frame) this.handleFrame(frame, state);
635
+ });
636
+ });
637
+ }
638
+ parseFrame(data) {
639
+ try {
640
+ const frame = JSON.parse(data.toString());
641
+ logger.debug("[OpenClaw Agent] Frame received", {
642
+ type: frame.type,
643
+ event: frame.event,
644
+ id: frame.id,
645
+ ok: frame.ok,
646
+ payloadStatus: frame.payload && typeof frame.payload.status === "string" ? frame.payload.status : void 0,
647
+ payloadStream: frame.payload && typeof frame.payload.stream === "string" ? frame.payload.stream : void 0
648
+ });
649
+ return frame;
650
+ } catch {
651
+ logger.debug("[OpenClaw Agent] Failed to parse WS frame");
652
+ return;
653
+ }
654
+ }
655
+ handleFrame(frame, state) {
656
+ try {
657
+ if (frame.type === "event" && frame.event === "connect.challenge") {
658
+ this.handleConnectChallenge(frame, state);
659
+ return;
660
+ }
661
+ if (frame.type === "res" && !state.connected) {
662
+ this.handleConnectResponse(frame, state);
663
+ return;
664
+ }
665
+ if (frame.type === "res" && frame.id === state.agentRequestId) {
666
+ this.handleAgentAccepted(frame, state);
667
+ return;
668
+ }
669
+ if (frame.type === "event" && frame.event === "agent") {
670
+ this.handleAgentEvent(frame, state);
671
+ return;
672
+ }
673
+ if (frame.type === "res" && frame.id === state.waitRequestId) this.handleAgentWaitResponse(frame, state);
674
+ } catch (err) {
675
+ state.finish({ error: `OpenClaw WebSocket error: ${err instanceof Error ? err.message : String(err)}` });
676
+ }
677
+ }
678
+ handleConnectChallenge(frame, state) {
679
+ state.connectAuthState = this.buildConnectAuthState(state.retryDeviceToken);
680
+ this.sendJson(state.ws, {
681
+ type: "req",
682
+ id: crypto.randomUUID(),
683
+ method: "connect",
684
+ params: this.buildConnectParams(frame, state.connectAuthState)
685
+ });
686
+ }
687
+ handleConnectResponse(frame, state) {
688
+ if (!frame.ok) {
689
+ this.clearStoredDeviceTokenOnFailure(state.connectAuthState, frame.error);
690
+ state.finish({
691
+ error: this.formatConnectError(frame.error),
692
+ retryWithDeviceToken: !state.retryDeviceToken && this.shouldRetryConnectWithDeviceToken(frame.error)
693
+ });
694
+ return;
695
+ }
696
+ state.connected = true;
697
+ this.storeDeviceTokenFromHello(frame.payload, state.connectAuthState);
698
+ this.sendJson(state.ws, {
699
+ type: "req",
700
+ id: state.agentRequestId,
701
+ method: "agent",
702
+ params: this.buildAgentRequestParams(state)
703
+ });
704
+ }
705
+ buildAgentRequestParams(state) {
706
+ return {
707
+ message: state.prompt,
708
+ agentId: this.agentId,
709
+ idempotencyKey: state.idempotencyKey,
710
+ sessionKey: state.sessionKey,
711
+ ...this.openclawConfig.message_channel && { channel: this.openclawConfig.message_channel },
712
+ ...this.openclawConfig.account_id && { accountId: this.openclawConfig.account_id },
713
+ ...this.openclawConfig.thinking_level && { thinking: this.openclawConfig.thinking_level },
714
+ ...this.openclawConfig.extra_system_prompt && { extraSystemPrompt: this.openclawConfig.extra_system_prompt }
715
+ };
716
+ }
717
+ handleAgentAccepted(frame, state) {
718
+ if (!frame.ok) {
719
+ state.finish({ error: `OpenClaw agent error: ${frame.error?.message || "unknown error"}` });
720
+ return;
721
+ }
722
+ const payload = frame.payload;
723
+ state.runId = typeof payload?.runId === "string" && payload.runId.trim() ? payload.runId : void 0;
724
+ if (!state.runId) {
725
+ logger.warn("[OpenClaw Agent] Missing runId in accepted response", {
726
+ agentId: this.agentId,
727
+ payload
728
+ });
729
+ state.finish({ error: "OpenClaw agent error: gateway accepted request without a runId" });
730
+ return;
731
+ }
732
+ this.sendJson(state.ws, {
733
+ type: "req",
734
+ id: state.waitRequestId,
735
+ method: "agent.wait",
736
+ params: {
737
+ runId: state.runId,
738
+ timeoutMs: this.timeoutMs
739
+ }
740
+ });
741
+ }
742
+ handleAgentEvent(frame, state) {
743
+ const payload = frame.payload;
744
+ if (payload?.runId && state.runId && payload.runId !== state.runId) return;
745
+ if (payload?.stream === "lifecycle" && payload.data?.phase === "error") {
746
+ state.lastError = payload.data.error || "OpenClaw agent lifecycle error";
747
+ return;
748
+ }
749
+ if (payload?.stream === "error") {
750
+ state.lastError = payload.data?.error || payload.data?.reason || "OpenClaw agent stream error";
751
+ return;
752
+ }
753
+ if (payload?.stream !== "assistant") return;
754
+ if (typeof payload?.data?.text === "string") {
755
+ state.lastText = payload.data.text;
756
+ state.lastError = "";
757
+ return;
758
+ }
759
+ if (typeof payload?.data?.delta === "string") {
760
+ state.lastText += payload.data.delta;
761
+ state.lastError = "";
762
+ }
763
+ }
764
+ handleAgentWaitResponse(frame, state) {
765
+ if (!frame.ok) {
766
+ state.finish({ error: `OpenClaw agent error: ${frame.error?.message || "unknown error"}` });
767
+ return;
768
+ }
769
+ const payload = frame.payload;
770
+ if (payload?.status === "error") {
771
+ state.finish({ error: `OpenClaw agent error: ${payload.error || "unknown error"}` });
772
+ return;
773
+ }
774
+ if (payload?.status === "timeout") {
775
+ state.finish({ error: `OpenClaw agent error: timed out waiting for run ${state.runId}` });
776
+ return;
777
+ }
778
+ const finalText = typeof payload?.output === "string" ? payload.output : typeof payload?.text === "string" ? payload.text : void 0;
779
+ if (state.lastText || finalText) {
780
+ state.finish({ output: state.lastText || finalText });
781
+ return;
782
+ }
783
+ if (state.lastError) {
784
+ state.finish({ error: `OpenClaw agent error: ${state.lastError}` });
785
+ return;
786
+ }
787
+ state.finish({ output: "No output from agent" });
788
+ }
789
+ sendJson(ws, payload) {
790
+ ws.send(JSON.stringify(payload));
791
+ }
792
+ buildWebSocketHeaders() {
793
+ const headers = {
794
+ ...this.openclawConfig.headers || {},
795
+ ...this.openclawConfig.ws_headers || {}
796
+ };
797
+ return Object.keys(headers).length > 0 ? headers : void 0;
798
+ }
799
+ buildConnectAuthState(retryDeviceToken) {
800
+ const deviceIdentity = this.loadDeviceIdentity();
801
+ const storedOrConfiguredDeviceToken = deviceIdentity ? this.resolveDeviceTokenForConnect(deviceIdentity) : void 0;
802
+ const deviceToken = retryDeviceToken || storedOrConfiguredDeviceToken;
803
+ if (retryDeviceToken) return {
804
+ auth: { deviceToken: retryDeviceToken.token },
805
+ deviceIdentity,
806
+ deviceTokenSource: retryDeviceToken.source,
807
+ kind: "deviceToken",
808
+ scopes: this.resolveScopesForDeviceToken(retryDeviceToken),
809
+ signatureToken: retryDeviceToken.token
810
+ };
811
+ if (this.authSecret && this.authKind) return {
812
+ auth: this.authKind === "password" ? { password: this.authSecret } : { token: this.authSecret },
813
+ deviceIdentity,
814
+ kind: this.authKind,
815
+ scopes: this.scopes,
816
+ signatureToken: this.authKind === "token" ? this.authSecret : null
817
+ };
818
+ if (deviceToken) return {
819
+ auth: { deviceToken: deviceToken.token },
820
+ deviceIdentity,
821
+ deviceTokenSource: deviceToken.source,
822
+ kind: "deviceToken",
823
+ scopes: this.resolveScopesForDeviceToken(deviceToken),
824
+ signatureToken: deviceToken.token
825
+ };
826
+ return {
827
+ deviceIdentity,
828
+ kind: "none",
829
+ scopes: this.scopes,
830
+ signatureToken: null
831
+ };
832
+ }
833
+ buildConnectParams(frame, authState) {
834
+ const nonce = this.extractChallengeNonce(frame);
835
+ const params = {
836
+ minProtocol: OPENCLAW_PROTOCOL_VERSION,
837
+ maxProtocol: OPENCLAW_PROTOCOL_VERSION,
838
+ client: {
839
+ id: CLIENT_ID,
840
+ displayName: "promptfoo",
841
+ version: VERSION,
842
+ platform: process.platform,
843
+ ...this.openclawConfig.device_family && { deviceFamily: this.openclawConfig.device_family },
844
+ mode: CLIENT_MODE
845
+ },
846
+ role: CLIENT_ROLE,
847
+ scopes: authState.scopes,
848
+ caps: [],
849
+ commands: [],
850
+ permissions: {},
851
+ ...authState.auth && { auth: authState.auth }
852
+ };
853
+ const device = this.buildSignedDevice(authState, nonce);
854
+ if (device) params.device = device;
855
+ return params;
856
+ }
857
+ buildSignedDevice(authState, nonce) {
858
+ if (!authState.deviceIdentity || this.openclawConfig.disable_device_auth) return;
859
+ try {
860
+ return buildSignedOpenClawDevice({
861
+ identity: authState.deviceIdentity,
862
+ clientId: CLIENT_ID,
863
+ clientMode: CLIENT_MODE,
864
+ role: CLIENT_ROLE,
865
+ scopes: authState.scopes,
866
+ nonce,
867
+ token: authState.signatureToken,
868
+ platform: process.platform,
869
+ deviceFamily: this.openclawConfig.device_family
870
+ });
871
+ } catch (err) {
872
+ logger.warn("[OpenClaw Agent] Failed to sign device identity; connecting without device auth", { err });
873
+ return;
874
+ }
875
+ }
876
+ loadDeviceIdentity() {
877
+ if (this.openclawConfig.disable_device_auth) return;
878
+ try {
879
+ return loadOrCreateOpenClawDeviceIdentity(this.openclawConfig.device_identity_path);
880
+ } catch (err) {
881
+ logger.warn("[OpenClaw Agent] Failed to load device identity", { err });
882
+ return;
883
+ }
884
+ }
885
+ resolveDeviceTokenForConnect(deviceIdentity) {
886
+ const configDeviceToken = this.openclawConfig.device_token?.trim();
887
+ if (configDeviceToken) return {
888
+ token: configDeviceToken,
889
+ scopes: this.scopes,
890
+ source: "config"
891
+ };
892
+ const storedDeviceToken = loadOpenClawDeviceAuthToken({
893
+ deviceId: deviceIdentity.deviceId,
894
+ role: CLIENT_ROLE,
895
+ filePath: this.openclawConfig.device_auth_path
896
+ });
897
+ if (!storedDeviceToken?.token) return;
898
+ return {
899
+ token: storedDeviceToken.token,
900
+ scopes: this.hasExplicitScopes ? this.scopes : storedDeviceToken.scopes,
901
+ source: "stored"
902
+ };
903
+ }
904
+ resolveDeviceTokenForRetry() {
905
+ const identity = this.loadDeviceIdentity();
906
+ if (!identity) return;
907
+ const deviceToken = this.resolveDeviceTokenForConnect(identity);
908
+ return deviceToken ? {
909
+ ...deviceToken,
910
+ source: "retry"
911
+ } : void 0;
912
+ }
913
+ resolveScopesForDeviceToken(deviceToken) {
914
+ if (this.hasExplicitScopes) return this.scopes;
915
+ return deviceToken.scopes && deviceToken.scopes.length > 0 ? deviceToken.scopes : this.scopes;
916
+ }
917
+ storeDeviceTokenFromHello(payload, authState) {
918
+ if (!authState?.deviceIdentity) return;
919
+ const authPayload = payload?.auth && typeof payload.auth === "object" && !Array.isArray(payload.auth) ? payload.auth : void 0;
920
+ const deviceToken = typeof authPayload?.deviceToken === "string" ? authPayload.deviceToken : "";
921
+ if (!deviceToken.trim()) return;
922
+ const scopes = getStringArray(authPayload?.scopes) || authState.scopes;
923
+ const role = typeof authPayload?.role === "string" && authPayload.role.trim() ? authPayload.role : CLIENT_ROLE;
924
+ storeOpenClawDeviceAuthToken({
925
+ deviceId: authState.deviceIdentity.deviceId,
926
+ role,
927
+ token: deviceToken,
928
+ scopes,
929
+ filePath: this.openclawConfig.device_auth_path
930
+ });
931
+ }
932
+ clearStoredDeviceTokenOnFailure(authState, error) {
933
+ if (!authState?.deviceIdentity || authState.kind !== "deviceToken" || authState.deviceTokenSource === "config") return;
934
+ const detailCode = this.getConnectErrorDetailCode(error);
935
+ const topLevelCode = error?.code;
936
+ if (detailCode !== "AUTH_DEVICE_TOKEN_MISMATCH" && topLevelCode !== "AUTH_DEVICE_TOKEN_MISMATCH") return;
937
+ clearOpenClawDeviceAuthToken({
938
+ deviceId: authState.deviceIdentity.deviceId,
939
+ role: CLIENT_ROLE,
940
+ filePath: this.openclawConfig.device_auth_path
941
+ });
942
+ }
943
+ extractChallengeNonce(frame) {
944
+ const nonce = frame.payload?.nonce;
945
+ return typeof nonce === "string" ? nonce : "";
946
+ }
947
+ getConnectErrorDetailCode(error) {
948
+ return error?.details?.code || error?.code;
949
+ }
950
+ shouldRetryConnectWithDeviceToken(error) {
951
+ const detailCode = this.getConnectErrorDetailCode(error);
952
+ const recommendedNextStep = error?.details?.recommendedNextStep;
953
+ return detailCode === "AUTH_TOKEN_MISMATCH" || error?.details?.canRetryWithDeviceToken === true || recommendedNextStep === "retry_with_device_token";
954
+ }
955
+ formatConnectError(error) {
956
+ const message = error?.message || "unknown error";
957
+ const detailCode = this.getConnectErrorDetailCode(error);
958
+ return detailCode && !message.includes(detailCode) ? `OpenClaw connect failed: ${message} (${detailCode})` : `OpenClaw connect failed: ${message}`;
959
+ }
960
+ };
961
+ //#endregion
962
+ //#region src/providers/openclaw/chat.ts
963
+ /**
964
+ * OpenClaw chat provider extends OpenAI chat completion provider.
965
+ *
966
+ * OpenClaw exposes an OpenAI-compatible HTTP API at /v1/chat/completions.
967
+ * This provider auto-detects gateway URL and bearer auth from:
968
+ * 1. Explicit config (gateway_url, auth_token, auth_password)
969
+ * 2. Environment variables (OPENCLAW_GATEWAY_URL, OPENCLAW_GATEWAY_TOKEN, OPENCLAW_GATEWAY_PASSWORD)
970
+ * 3. The active OpenClaw config file (OPENCLAW_CONFIG_PATH or ~/.openclaw/openclaw.json),
971
+ * including gateway.remote.url and gateway.tls.enabled
972
+ *
973
+ * Usage:
974
+ * openclaw - default agent (main)
975
+ * openclaw:main - specific agent
976
+ * openclaw:coding-agent - named agent
977
+ */
978
+ var OpenClawChatProvider = class extends OpenAiChatCompletionProvider {
979
+ agentId;
980
+ constructor(agentId, providerOptions = {}) {
981
+ super(buildOpenClawModelName(agentId), buildOpenClawProviderOptions(agentId, providerOptions));
982
+ this.agentId = agentId;
983
+ }
984
+ id() {
985
+ return `openclaw:${this.agentId}`;
986
+ }
987
+ toString() {
988
+ return `[OpenClaw Provider ${this.agentId}]`;
989
+ }
990
+ getApiUrlDefault() {
991
+ return `http://${DEFAULT_GATEWAY_HOST}:${DEFAULT_GATEWAY_PORT}/v1`;
992
+ }
993
+ getApiKey() {
994
+ return this.config.apiKey;
995
+ }
996
+ getApiUrl() {
997
+ return this.config.apiBaseUrl || this.getApiUrlDefault();
998
+ }
999
+ };
1000
+ //#endregion
1001
+ //#region src/providers/openclaw/embedding.ts
1002
+ /**
1003
+ * OpenClaw embedding provider extends the OpenAI-compatible embeddings provider.
1004
+ *
1005
+ * The OpenClaw gateway accepts agent-target model ids at /v1/embeddings and
1006
+ * optionally accepts x-openclaw-model as the backend embedding-model override.
1007
+ */
1008
+ var OpenClawEmbeddingProvider = class extends OpenAiEmbeddingProvider {
1009
+ agentId;
1010
+ constructor(agentId, providerOptions = {}) {
1011
+ super(buildOpenClawModelName(agentId), buildOpenClawProviderOptions(agentId, providerOptions));
1012
+ this.agentId = agentId;
1013
+ }
1014
+ id() {
1015
+ return `openclaw:embedding:${this.agentId}`;
1016
+ }
1017
+ toString() {
1018
+ return `[OpenClaw Embedding Provider ${this.agentId}]`;
1019
+ }
1020
+ getApiUrlDefault() {
1021
+ return `http://${DEFAULT_GATEWAY_HOST}:${DEFAULT_GATEWAY_PORT}/v1`;
1022
+ }
1023
+ getApiKey() {
1024
+ return this.config.apiKey;
1025
+ }
1026
+ getApiUrl() {
1027
+ return this.config.apiBaseUrl || this.getApiUrlDefault();
1028
+ }
1029
+ };
1030
+ //#endregion
1031
+ //#region src/providers/openclaw/responses.ts
1032
+ /**
1033
+ * OpenClaw Responses API Provider
1034
+ *
1035
+ * Extends OpenAI Responses API provider with OpenClaw-specific configuration.
1036
+ * Routes through the OpenClaw gateway's /v1/responses endpoint.
1037
+ *
1038
+ * Requires `gateway.http.endpoints.responses.enabled=true` in OpenClaw config.
1039
+ *
1040
+ * Usage:
1041
+ * openclaw:responses - default agent (main)
1042
+ * openclaw:responses:main - explicit agent ID
1043
+ * openclaw:responses:X - custom agent ID
1044
+ */
1045
+ var OpenClawResponsesProvider = class extends OpenAiResponsesProvider {
1046
+ agentId;
1047
+ constructor(agentId, providerOptions = {}) {
1048
+ super(buildOpenClawModelName(agentId), buildOpenClawProviderOptions(agentId, providerOptions));
1049
+ this.agentId = agentId;
1050
+ }
1051
+ id() {
1052
+ return `openclaw:responses:${this.agentId}`;
1053
+ }
1054
+ toString() {
1055
+ return `[OpenClaw Responses Provider ${this.agentId}]`;
1056
+ }
1057
+ getApiUrlDefault() {
1058
+ return `http://${DEFAULT_GATEWAY_HOST}:${DEFAULT_GATEWAY_PORT}/v1`;
1059
+ }
1060
+ getApiKey() {
1061
+ return this.config.apiKey;
1062
+ }
1063
+ getApiUrl() {
1064
+ return this.config.apiBaseUrl || this.getApiUrlDefault();
1065
+ }
1066
+ async getOpenAiBody(prompt, context, callApiOptions) {
1067
+ const result = await super.getOpenAiBody(prompt, context, callApiOptions);
1068
+ if ("text" in result.body) delete result.body.text;
1069
+ return result;
1070
+ }
1071
+ };
1072
+ //#endregion
1073
+ //#region src/providers/openclaw/tools.ts
1074
+ /**
1075
+ * OpenClaw Tool Invoke Provider
1076
+ *
1077
+ * Simple HTTP provider for direct tool invocation via POST /tools/invoke.
1078
+ * The tool name is extracted from the provider path:
1079
+ * openclaw:tools:sessions_list → tool="sessions_list"
1080
+ *
1081
+ * The prompt is parsed as JSON for tool arguments. If it's not valid JSON,
1082
+ * it's passed as a single `input` argument.
1083
+ *
1084
+ * Usage:
1085
+ * openclaw:tools:sessions_list - invoke the sessions_list tool
1086
+ * openclaw:tools:session_status - invoke the session_status tool
1087
+ *
1088
+ * Optional config:
1089
+ * action - tool sub-action, forwarded as body.action
1090
+ * dry_run - dry-run hint, forwarded as body.dryRun
1091
+ */
1092
+ var OpenClawToolInvokeProvider = class {
1093
+ toolName;
1094
+ gatewayUrl;
1095
+ authToken;
1096
+ openclawConfig;
1097
+ timeoutMs;
1098
+ constructor(toolName, providerOptions = {}) {
1099
+ this.toolName = toolName;
1100
+ this.openclawConfig = providerOptions.config || {};
1101
+ const env = providerOptions.env;
1102
+ this.gatewayUrl = resolveGatewayUrl(this.openclawConfig, env);
1103
+ this.authToken = resolveAuthToken(this.openclawConfig, env);
1104
+ this.timeoutMs = this.openclawConfig.timeoutMs ?? REQUEST_TIMEOUT_MS;
1105
+ }
1106
+ id() {
1107
+ return `openclaw:tools:${this.toolName}`;
1108
+ }
1109
+ toString() {
1110
+ return `[OpenClaw Tool Provider ${this.toolName}]`;
1111
+ }
1112
+ toJSON() {
1113
+ return { provider: this.id() };
1114
+ }
1115
+ async callApi(prompt) {
1116
+ let args;
1117
+ try {
1118
+ args = JSON.parse(prompt);
1119
+ } catch {
1120
+ args = { input: prompt };
1121
+ }
1122
+ const url = `${this.gatewayUrl}/tools/invoke`;
1123
+ const headers = {
1124
+ "Content-Type": "application/json",
1125
+ ...this.openclawConfig.headers || {},
1126
+ ...buildOpenClawContextHeaders(this.openclawConfig)
1127
+ };
1128
+ if (this.authToken) headers["Authorization"] = `Bearer ${this.authToken}`;
1129
+ const body = {
1130
+ tool: this.toolName,
1131
+ ...this.openclawConfig.action && { action: this.openclawConfig.action },
1132
+ args,
1133
+ ...typeof this.openclawConfig.dry_run === "boolean" && { dryRun: this.openclawConfig.dry_run },
1134
+ ...this.openclawConfig.session_key && { sessionKey: this.openclawConfig.session_key }
1135
+ };
1136
+ logger.debug(`[OpenClaw Tool] POST ${url}`, {
1137
+ tool: this.toolName,
1138
+ args
1139
+ });
1140
+ try {
1141
+ const controller = new AbortController();
1142
+ const fetchTimeout = setTimeout(() => controller.abort(), this.timeoutMs);
1143
+ const response = await fetchWithProxy(url, {
1144
+ method: "POST",
1145
+ headers,
1146
+ body: JSON.stringify(body),
1147
+ signal: controller.signal
1148
+ }).finally(() => clearTimeout(fetchTimeout));
1149
+ if (!response.ok) {
1150
+ const text = await response.text();
1151
+ return { error: `OpenClaw tool invoke failed (${response.status}): ${text}` };
1152
+ }
1153
+ const data = await response.json();
1154
+ if (data.ok) return { output: typeof data.result === "string" ? data.result : JSON.stringify(data.result) };
1155
+ if (typeof data.error === "string") return { error: data.error };
1156
+ return { error: data.error?.message || data.error?.type || data.error?.code || "Unknown tool error" };
1157
+ } catch (err) {
1158
+ return { error: `OpenClaw tool invoke error: ${err instanceof Error ? err.message : String(err)}` };
1159
+ }
1160
+ }
1161
+ };
1162
+ //#endregion
1163
+ //#region src/providers/openclaw/index.ts
1164
+ /**
1165
+ * Create an OpenClaw provider from a provider path string.
1166
+ *
1167
+ * Routing:
1168
+ * openclaw → OpenClawChatProvider('main')
1169
+ * openclaw:main → OpenClawChatProvider('main')
1170
+ * openclaw:my-agent → OpenClawChatProvider('my-agent')
1171
+ * openclaw:responses → OpenClawResponsesProvider('main')
1172
+ * openclaw:responses:X → OpenClawResponsesProvider('X')
1173
+ * openclaw:embedding → OpenClawEmbeddingProvider('main')
1174
+ * openclaw:embedding:X → OpenClawEmbeddingProvider('X')
1175
+ * openclaw:embeddings → OpenClawEmbeddingProvider('main')
1176
+ * openclaw:embeddings:X → OpenClawEmbeddingProvider('X')
1177
+ * openclaw:agent → OpenClawAgentProvider('main')
1178
+ * openclaw:agent:X → OpenClawAgentProvider('X')
1179
+ * openclaw:tools:sessions_list → OpenClawToolInvokeProvider('sessions_list')
1180
+ */
1181
+ function createOpenClawProvider(providerPath, providerOptions = {}, env) {
1182
+ const splits = providerPath.split(":");
1183
+ const keyword = splits[1];
1184
+ const opts = {
1185
+ ...providerOptions,
1186
+ env
1187
+ };
1188
+ if (keyword === "responses") return new OpenClawResponsesProvider(splits[2] || "main", opts);
1189
+ if (keyword === "embedding" || keyword === "embeddings") return new OpenClawEmbeddingProvider(splits[2] || "main", opts);
1190
+ if (keyword === "agent") return new OpenClawAgentProvider(splits[2] || "main", opts);
1191
+ if (keyword === "tools") {
1192
+ const toolName = splits.slice(2).join(":");
1193
+ if (!toolName) throw new Error("OpenClaw tools provider requires a tool name: openclaw:tools:<tool-name>");
1194
+ return new OpenClawToolInvokeProvider(toolName, opts);
1195
+ }
1196
+ return new OpenClawChatProvider(splits.length > 1 ? splits.slice(1).join(":") : "main", opts);
1197
+ }
1198
+ //#endregion
1199
+ export { createOpenClawProvider };
1200
+
1201
+ //# sourceMappingURL=openclaw-DA8U4DsD.js.map