promptfoo 0.121.5 → 0.121.7
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.
- package/dist/src/{ListApp-BRUsT43Y.js → ListApp-DLmM02JS.js} +1 -1
- package/dist/src/{accounts-CaLNYnf7.js → accounts-Ca7WIoPY.js} +12 -7
- package/dist/src/{accounts-CLJHCDDb.js → accounts-CjFnOPmb.js} +13 -8
- package/dist/src/{accounts-BIFntVWB.cjs → accounts-CmWzeD2d.cjs} +16 -10
- package/dist/src/{accounts-bnyHT7Ju.js → accounts-DanM1wq_.js} +12 -7
- package/dist/src/{agentic-utils-BclbiXiq.js → agentic-utils-CJ0j3fBi.js} +2 -2
- package/dist/src/{agentic-utils-B5krlibj.js → agentic-utils-DDEGRV9v.js} +2 -2
- package/dist/src/{agentic-utils-D2x0wGhB.cjs → agentic-utils-DvPWSUpb.cjs} +8 -7
- package/dist/src/{agentic-utils-Ba67xmgs.js → agentic-utils-TxUEMPYS.js} +2 -2
- package/dist/src/{agents-WULPVjbH.cjs → agents-B4sRuXg3.cjs} +7 -6
- package/dist/src/{agents-DhxWMCtH.js → agents-B8q7h_ek.js} +4 -4
- package/dist/src/{agents-BGqaTDnr.js → agents-CBgJvRkB.js} +20 -9
- package/dist/src/{agents-n6vPqV3i.js → agents-CYn2n3QP.js} +4 -4
- package/dist/src/{agents-BV9yFpXX.js → agents-D-vDNFx4.js} +20 -9
- package/dist/src/{agents-BYdMl1UE.js → agents-LrHuQqr1.js} +20 -9
- package/dist/src/{agents-emVcx3yh.js → agents-QGg76OF-.js} +2 -2
- package/dist/src/{agents-DiWmQYH9.cjs → agents-eHZ9nlgA.cjs} +21 -10
- package/dist/src/{aimlapi-uPGp0Zdo.js → aimlapi-CJEbQ0o6.js} +6 -6
- package/dist/src/{aimlapi-DR4pgeiC.js → aimlapi-D5HXzZ0s.js} +6 -6
- package/dist/src/{aimlapi-BzLjZI_m.cjs → aimlapi-T6HGNxNe.cjs} +7 -7
- package/dist/src/{aimlapi-BxqK9HF_.js → aimlapi-eYv3a_DK.js} +6 -6
- package/dist/src/app/app/tsconfig.app.tsbuildinfo +1 -1
- package/dist/src/app/assets/Report-BNHJKN35.js +1 -0
- package/dist/src/app/assets/index-BnT6P6sF.js +388 -0
- package/dist/src/app/assets/index-yhM8y1PP.css +1 -0
- package/dist/src/app/assets/{scroll-timeline-D9IT_e8Z.js → scroll-timeline-RpeTwOvs.js} +1 -1
- package/dist/src/app/assets/sync-5gq6fmG4.js +4 -0
- package/dist/src/app/assets/vendor-charts-BL9OMNU7.js +36 -0
- package/dist/src/app/assets/{vendor-markdown-Ch00wnNI.js → vendor-markdown-BYsQqn7Z.js} +10 -10
- package/dist/src/app/assets/{vendor-react-CVvmk1UB.js → vendor-react-CqWgVW6T.js} +2 -2
- package/dist/src/app/assets/{vendor-utils-BnEYbx2Q.js → vendor-utils-BHPO71pu.js} +1 -1
- package/dist/src/app/index.html +6 -6
- package/dist/src/{audio-Da8U9IS5.js → audio-BqnRvcWG.js} +3 -3
- package/dist/src/{audio-BvpTOArF.js → audio-CPMtV1yR.js} +3 -3
- package/dist/src/{audio-CScmnmEB.js → audio-DyiebVB3.js} +3 -3
- package/dist/src/{audio-C0vDeS0j.cjs → audio-FnxbEnSE.cjs} +4 -4
- package/dist/src/authoritativeMarkupInjection-BZIywVjG.js +74 -0
- package/dist/src/authoritativeMarkupInjection-DyAXAsSr.js +75 -0
- package/dist/src/authoritativeMarkupInjection-F2gBw0lN.cjs +74 -0
- package/dist/src/authoritativeMarkupInjection-QEQmFS83.js +74 -0
- package/dist/src/{base-BTux96b1.js → base-CKLo890h.js} +4 -3
- package/dist/src/{base-BOMaNEes.js → base-Co80MMCi.js} +4 -3
- package/dist/src/{base-Tw6uhH8K.cjs → base-DGJW48uz.cjs} +5 -4
- package/dist/src/{base-dYsl2hmL.js → base-E9I8zXjz.js} +4 -3
- package/dist/src/bestOfN-B3wNzjSB.js +137 -0
- package/dist/src/bestOfN-BBsO41z4.js +136 -0
- package/dist/src/bestOfN-CAwmg5UL.cjs +140 -0
- package/dist/src/bestOfN-_kTi8Bxe.js +136 -0
- package/dist/src/{blobs-B95F_7vE.cjs → blobs-B0977K1O.cjs} +7 -6
- package/dist/src/{blobs-D_gg8nbm.js → blobs-CeFdPn_T.js} +2 -2
- package/dist/src/{blobs-DjLby-uP.js → blobs-DODuTK-a.js} +2 -2
- package/dist/src/{blobs-BW4U31ue.js → blobs-Dwef1Ao1.js} +2 -2
- package/dist/src/{cache-DGg-yTZG.cjs → cache-CPGUA4Yl.cjs} +135 -25
- package/dist/src/cache-Cf7b4pWE.js +3 -0
- package/dist/src/{cache-Bzttsk0X.js → cache-DIXbtkNO.js} +125 -10
- package/dist/src/{cache-BI5BY7ey.js → cache-DpPWrkTE.js} +127 -11
- package/dist/src/{cache-Cr-qWIbP.js → cache-roFAE0cI.js} +125 -10
- package/dist/src/{chat-DChSH_Es.js → chat-CUCorGiL.js} +9 -9
- package/dist/src/{chat-DH97tVV9.cjs → chat-DG1wG4w0.cjs} +6 -6
- package/dist/src/{chat-Cx_LkwvZ.js → chat-Dabu84Br.js} +11 -11
- package/dist/src/{chat-BLOdH60v.js → chat-DqUFcWI0.js} +11 -11
- package/dist/src/{chat-vYqqv1gP.cjs → chat-DxTDQ83C.cjs} +14 -13
- package/dist/src/{chat-DG2LkwLq.js → chat-GmlolEwo.js} +4 -4
- package/dist/src/{chat-aMQZw6R7.js → chat-TP8Qifkh.js} +4 -4
- package/dist/src/{chat-D9nudO9b.js → chat-iwaM5UTQ.js} +4 -4
- package/dist/src/{chatkit-B8X34dQc.js → chatkit-B6DWi70Q.js} +3 -3
- package/dist/src/{chatkit-D44VyUyB.cjs → chatkit-BYveR48_.cjs} +6 -5
- package/dist/src/{chatkit-BXu42Qwt.js → chatkit-fARZwEfV.js} +3 -3
- package/dist/src/{chatkit-CbMRoeYw.js → chatkit-lb6FK02w.js} +1 -1
- package/dist/src/{claude-agent-sdk-BzNZeZ0N.js → claude-agent-sdk-BQNp_y-F.js} +209 -64
- package/dist/src/{claude-agent-sdk-BjriSVRZ.js → claude-agent-sdk-D5Jl0SDh.js} +210 -65
- package/dist/src/{claude-agent-sdk-BRq0bbIK.cjs → claude-agent-sdk-DH416NBD.cjs} +216 -70
- package/dist/src/{claude-agent-sdk-DYv_AJ8u.js → claude-agent-sdk-x1XJ1-pU.js} +210 -65
- package/dist/src/{cloud-Da0bofJd.js → cloud-D3DiFqH6.js} +2 -2
- package/dist/src/cloud-p96PA4MH.js +3 -0
- package/dist/src/{cloudflare-ai-CXC4b1EU.js → cloudflare-ai-B6NVI3ax.js} +4 -4
- package/dist/src/{cloudflare-ai-DJv5qnyb.cjs → cloudflare-ai-CEAW-xQa.cjs} +6 -6
- package/dist/src/{cloudflare-ai-CyBoIs1Q.js → cloudflare-ai-RFSojyXG.js} +4 -4
- package/dist/src/{cloudflare-ai-DGOwgexC.js → cloudflare-ai-r4tbYmWU.js} +4 -4
- package/dist/src/{cloudflare-gateway-D-dnkzCF.js → cloudflare-gateway-BCkLouto.js} +3 -3
- package/dist/src/{cloudflare-gateway-TJkVrZlB.js → cloudflare-gateway-BaZ4insB.js} +3 -3
- package/dist/src/{cloudflare-gateway-1sAoOyft.js → cloudflare-gateway-CF-Vb-2Z.js} +3 -3
- package/dist/src/{cloudflare-gateway-DKVjkDav.cjs → cloudflare-gateway-TJMLBj6I.cjs} +5 -5
- package/dist/src/{codex-app-server-CCe0TiDc.js → codex-app-server-B8KHEiF4.js} +5 -5
- package/dist/src/{codex-app-server-VMRnjZ68.cjs → codex-app-server-CnrLBCeA.cjs} +12 -11
- package/dist/src/{codex-app-server-CCLjqCh9.js → codex-app-server-DIXZ230V.js} +4 -4
- package/dist/src/{codex-app-server-CPW1LFwh.js → codex-app-server-Dd22dC_N.js} +5 -5
- package/dist/src/{codex-sdk-BgEFQ70r.js → codex-sdk-B6Wah8Pa.js} +5 -5
- package/dist/src/codex-sdk-BGjVAk23.js +3 -0
- package/dist/src/{codex-sdk-Bd8UbO9q.cjs → codex-sdk-CFF6gUyi.cjs} +18 -10
- package/dist/src/{codex-sdk-Bzb_TqX9.js → codex-sdk-CmQABzV3.js} +3 -3
- package/dist/src/{codex-sdk-DfvDTN33.js → codex-sdk-D2d54RL8.js} +5 -5
- package/dist/src/{cometapi-B5ImDlSm.js → cometapi-Bu9B8NUY.js} +7 -7
- package/dist/src/{cometapi-CCbpHkuF.js → cometapi-CtzNCHKu.js} +7 -7
- package/dist/src/{cometapi-BgAkuYCw.cjs → cometapi-DHCDlQUI.cjs} +8 -8
- package/dist/src/{cometapi-CC7hWxmX.js → cometapi-OBILPLlu.js} +7 -7
- package/dist/src/{completion-Vq_ad618.js → completion-CO2e1_62.js} +4 -4
- package/dist/src/{completion-DtQ72Bm3.cjs → completion-CSYfl2cd.cjs} +6 -6
- package/dist/src/{completion-2iuYVxwi.js → completion-DZNxcyfG.js} +5 -5
- package/dist/src/{completion-CrD6MQ93.js → completion-sNvCLTAP.js} +5 -5
- package/dist/src/constants-BjJV0cRr.js +6 -0
- package/dist/src/constants-DH5XYLKZ.js +7 -0
- package/dist/src/constants-DZGEFLsu.js +6 -0
- package/dist/src/constants-a2kYssQk.cjs +11 -0
- package/dist/src/{createHash-4gFQpDDv.js → createHash-BtbSX3mj.js} +1 -1
- package/dist/src/{createHash-Un4Q_huE.js → createHash-CGVzWdjj.js} +1 -1
- package/dist/src/{createHash-VvBIc-AW.cjs → createHash-CSiqnK5P.cjs} +2 -2
- package/dist/src/{createHash-DPpsZgFF.js → createHash-CgRvs4Fn.js} +1 -1
- package/dist/src/crescendo-BXEJK_bi.cjs +704 -0
- package/dist/src/crescendo-CU_Y2i-m.js +702 -0
- package/dist/src/crescendo-J1Xx4_zb.js +703 -0
- package/dist/src/crescendo-QiaSLW0d.js +701 -0
- package/dist/src/custom-BJfP00Bh.js +619 -0
- package/dist/src/custom-CZVn-1-r.js +620 -0
- package/dist/src/custom-Cqia7M0D.cjs +621 -0
- package/dist/src/custom-notggYVl.js +618 -0
- package/dist/src/{docker--3qzPa-6.js → docker-4D1eL6Gq.js} +5 -5
- package/dist/src/{docker-Dorv4_Dg.js → docker-BBv1WUDu.js} +5 -5
- package/dist/src/{docker-D3AY-5F5.cjs → docker-D06JUoe2.cjs} +6 -6
- package/dist/src/{docker-DCsCDvwM.js → docker-DdJQBxK9.js} +5 -5
- package/dist/src/{embedding-DNRvZwRN.js → embedding--UZVe4_7.js} +5 -5
- package/dist/src/{embedding-BXhN5lCH.cjs → embedding-BbrwopfX.cjs} +6 -6
- package/dist/src/{embedding-ChS1ivFS.js → embedding-Bi3rxrZF.js} +5 -5
- package/dist/src/{embedding-D_bI4NDq.js → embedding-C251p1-8.js} +4 -4
- package/dist/src/{errors-DFHe4L-n.js → errors-9PcUL8BC.js} +1 -1
- package/dist/src/{esm-B_rGuPTo.cjs → esm-BIKakvNa.cjs} +8 -7
- package/dist/src/{esm-BRkfNsYs.js → esm-BTK1W7lG.js} +1 -1
- package/dist/src/{esm-BX8fwlAO.js → esm-Bexx2PFc.js} +1 -1
- package/dist/src/{eval-DJ_4A-tr.js → eval-0VRANImH.js} +19 -19
- package/dist/src/{eval-BQPLBJbw.js → eval-DscR5iOM.js} +1 -1
- package/dist/src/{evalResult-pSvGWFMo.js → evalResult-2RRJvFyB.js} +18 -11
- package/dist/src/{evalResult-Cx-8OWkb.cjs → evalResult-CvtS8h8u.cjs} +29 -11
- package/dist/src/evalResult-DqzsS6_W.js +3 -0
- package/dist/src/{evalResult-D6P5I5il.js → evalResult-eUkJv9Ko.js} +17 -10
- package/dist/src/evaluator-DNdJF1Gv.js +3 -0
- package/dist/src/{evaluator-D-UIbbYq.js → evaluator-DRoiYB2q.js} +258 -132
- package/dist/src/evaluatorHelpers-BsYP_muT.js +511 -0
- package/dist/src/evaluatorHelpers-CRqTvSux.cjs +537 -0
- package/dist/src/evaluatorHelpers-DuqFFfq7.js +510 -0
- package/dist/src/{extractor-YlZbUMsL.js → extractor-BR7XAzAL.js} +5 -5
- package/dist/src/{extractor-Dxr2J_wK.cjs → extractor-BdxEtt3J.cjs} +6 -6
- package/dist/src/{extractor-DxyiFhPk.js → extractor-CIW3iN-b.js} +5 -5
- package/dist/src/{extractor-BM3jRERL.js → extractor-CxRtnaHl.js} +5 -5
- package/dist/src/{fetch-Y5qX_kST.js → fetch-BufrQtvR.js} +90 -26
- package/dist/src/{fetch-B6ch2nU2.js → fetch-DXUnXkVU.js} +86 -26
- package/dist/src/{fetch-NuqXW1Xb.cjs → fetch-Dw4XZHjj.cjs} +115 -32
- package/dist/src/{fetch-D9xxyC1p.js → fetch-It34O8Ur.js} +90 -26
- package/dist/src/fetch-_YgGd2qv.js +3 -0
- package/dist/src/{fileExtensions-D9h-8Wxg.cjs → fileExtensions-BhdwzYaD.cjs} +24 -1
- package/dist/src/{fileExtensions-BGh-W-HT.js → fileExtensions-CXRfY3Ss.js} +12 -2
- package/dist/src/{fileExtensions-DysCsxNG.js → fileExtensions-D4GCJ67J.js} +12 -2
- package/dist/src/{formatDuration-Ch4A7G3o.js → formatDuration-CMVNrYvE.js} +1 -1
- package/dist/src/{genaiTracer-BokHC-MW.cjs → genaiTracer-14nugQQx.cjs} +14 -2
- package/dist/src/{genaiTracer-C3ZPQU60.js → genaiTracer-BPVvltoW.js} +2 -2
- package/dist/src/{genaiTracer-DxODqT9e.js → genaiTracer-D18lYzhB.js} +2 -2
- package/dist/src/{genaiTracer-CFny3gOy.js → genaiTracer-jJKYsnjc.js} +2 -2
- package/dist/src/goat-Ckd3q3AY.js +467 -0
- package/dist/src/goat-Qgurm-NP.js +466 -0
- package/dist/src/goat-ghadEDdy.js +465 -0
- package/dist/src/goat-una6pZGP.cjs +469 -0
- package/dist/src/graders-BDT7dif6.js +3 -0
- package/dist/src/{graders-CgPn32yp.js → graders-BGP99PdK.js} +1017 -84
- package/dist/src/{graders-BoUqsCEm.js → graders-BX0f2tvS.js} +1022 -84
- package/dist/src/{graders-CwrbifOo.js → graders-C0nXU_ZP.js} +1020 -82
- package/dist/src/{graders-Bw1wk_21.cjs → graders-ClrU2fnd.cjs} +1085 -128
- package/dist/src/hydra-BSNZZm2M.js +543 -0
- package/dist/src/hydra-BxdG4nkg.js +541 -0
- package/dist/src/hydra-DE4xWwyc.js +542 -0
- package/dist/src/hydra-DrJttnvw.cjs +542 -0
- package/dist/src/image-B4oBtu6J.js +443 -0
- package/dist/src/{image-Dr_3I3nK.js → image-BN-hjLL9.js} +3 -3
- package/dist/src/{image-BeWaInPF.js → image-B_fPIwdg.js} +3 -3
- package/dist/src/image-BvUAW344.js +442 -0
- package/dist/src/image-Cvjwx1uY.js +442 -0
- package/dist/src/{image-D10dNAav.cjs → image-DfVCGPbI.cjs} +4 -4
- package/dist/src/{image-qjO6FWPs.js → image-QzmydkiG.js} +3 -3
- package/dist/src/image-X0oY4350.cjs +465 -0
- package/dist/src/index.cjs +688 -313
- package/dist/src/index.d.cts +3152 -1617
- package/dist/src/index.d.ts +3151 -1616
- package/dist/src/index.js +582 -223
- package/dist/src/indirectWebPwn-02ZIghCS.js +259 -0
- package/dist/src/indirectWebPwn-BJ22AbQa.cjs +397 -0
- package/dist/src/indirectWebPwn-CbjUG0rh.js +385 -0
- package/dist/src/indirectWebPwn-CfQJt3gk.cjs +260 -0
- package/dist/src/indirectWebPwn-DBQhOjoD.js +260 -0
- package/dist/src/indirectWebPwn-OsXnKejv.js +259 -0
- package/dist/src/indirectWebPwn-tNx9OZ35.js +385 -0
- package/dist/src/indirectWebPwn-uyWdHx04.js +386 -0
- package/dist/src/inputVariables-B0qUChbV.js +467 -0
- package/dist/src/inputVariables-DUGMb9Ka.js +464 -0
- package/dist/src/inputVariables-DXFdi7AI.js +468 -0
- package/dist/src/inputVariables-Dq9W-Z3a.cjs +475 -0
- package/dist/src/{interactiveCheck-CCICw2cy.js → interactiveCheck-C4QlIuoR.js} +1 -1
- package/dist/src/{invariant-kfQ8Bu82.cjs → invariant-QtnLD03y.cjs} +1 -1
- package/dist/src/iterative-CpU6i2As.js +490 -0
- package/dist/src/iterative-DJQEQpG3.js +491 -0
- package/dist/src/iterative-DQBuWM-j.cjs +493 -0
- package/dist/src/iterative-FTS4Bz67.js +492 -0
- package/dist/src/iterativeImage-BUABMVOA.js +413 -0
- package/dist/src/iterativeImage-ByFWkxax.cjs +415 -0
- package/dist/src/iterativeImage-BzUapOUi.js +414 -0
- package/dist/src/iterativeImage-Doz8mgxF.js +413 -0
- package/dist/src/iterativeMeta-B3YiAOc8.js +386 -0
- package/dist/src/iterativeMeta-C7APE_P1.js +385 -0
- package/dist/src/iterativeMeta-CSS8M6Ds.cjs +385 -0
- package/dist/src/iterativeMeta-DgoQ7bLh.js +384 -0
- package/dist/src/iterativeTree-B5zxBBSW.js +769 -0
- package/dist/src/iterativeTree-CNyIk0Yn.js +768 -0
- package/dist/src/iterativeTree-CPMF10ve.cjs +771 -0
- package/dist/src/iterativeTree-DvZ7GBwt.js +770 -0
- package/dist/src/{knowledgeBase-Dr3Kib7F.js → knowledgeBase-BadkINlJ.js} +24 -10
- package/dist/src/{knowledgeBase-BBETc5-S.js → knowledgeBase-Bi_8sV-H.js} +23 -9
- package/dist/src/{knowledgeBase-CzAi2rUI.js → knowledgeBase-CkMljjdg.js} +24 -10
- package/dist/src/{knowledgeBase-C8qOo26M.cjs → knowledgeBase-DUh34xba.cjs} +25 -11
- package/dist/src/{litellm-DRc4qWfc.js → litellm-BKBo0jpC.js} +4 -4
- package/dist/src/{litellm-BLSiANhk.js → litellm-BXyn5kZK.js} +4 -4
- package/dist/src/{litellm-DQGo_juI.js → litellm-CNcfbCfa.js} +4 -4
- package/dist/src/{litellm-CaUmV7Mk.cjs → litellm-CtAr7bKG.cjs} +5 -5
- package/dist/src/{logger-COuQb2xB.cjs → logger-cfNpzI4o.cjs} +13 -55
- package/dist/src/{luma-ray-B-tNZzqW.js → luma-ray-BMX1iEB6.js} +5 -5
- package/dist/src/{luma-ray-CtS3OlGq.js → luma-ray-CR5TSpp4.js} +5 -5
- package/dist/src/{luma-ray-if-Ml4R9.cjs → luma-ray-D3FUc2K3.cjs} +9 -8
- package/dist/src/{luma-ray-PJJgUjOc.js → luma-ray-OEMmS1RB.js} +5 -5
- package/dist/src/main.js +704 -208
- package/dist/src/memoryPoisoning-CM83NWYl.js +107 -0
- package/dist/src/memoryPoisoning-D8h9gXJF.js +106 -0
- package/dist/src/memoryPoisoning-Dp-btinn.cjs +106 -0
- package/dist/src/memoryPoisoning-cLuCoTuJ.js +106 -0
- package/dist/src/{messages-CewuNcNS.js → messages-BabO-cX8.js} +17 -9
- package/dist/src/{messages-BnsVHUnm.cjs → messages-DBPir0TQ.cjs} +24 -15
- package/dist/src/{messages-B9dSjrNf.js → messages-DGUlSNU7.js} +18 -10
- package/dist/src/{messages-CI69Lasb.js → messages-vsE_-Lv0.js} +18 -10
- package/dist/src/{meteor-CeGo0Lu2.js → meteor--TZYICTI.js} +1 -1
- package/dist/src/{meteor-BBGcGeCa.cjs → meteor-CR226f7Z.cjs} +2 -2
- package/dist/src/{meteor-Wc_aUVvu.js → meteor-Cl_yd7rJ.js} +1 -1
- package/dist/src/{meteor-BKTM-7KS.js → meteor-Dce-_zGQ.js} +1 -1
- package/dist/src/mischievousUser-0l8GD7Dp.js +46 -0
- package/dist/src/mischievousUser-BUOP9W5r.js +46 -0
- package/dist/src/mischievousUser-frFYKxu6.js +47 -0
- package/dist/src/mischievousUser-olGgHIVR.cjs +46 -0
- package/dist/src/{modelslab-BkapYJhh.cjs → modelslab-CNV5bMSk.cjs} +7 -7
- package/dist/src/{modelslab-zpz9JcK0.js → modelslab-Cogmu4mG.js} +6 -6
- package/dist/src/{modelslab-D73OnKSx.js → modelslab-Dzst7VTU.js} +6 -6
- package/dist/src/{modelslab-BCLOtfek.js → modelslab-EyDczZ5A.js} +6 -6
- package/dist/src/{nova-reel-B8F_TK5w.js → nova-reel-BGPNBOMS.js} +5 -5
- package/dist/src/{nova-reel-Bx0NFV2f.js → nova-reel-B_5NKFu1.js} +5 -5
- package/dist/src/{nova-reel-CNGJTLtG.js → nova-reel-C4eUJGse.js} +5 -5
- package/dist/src/{nova-reel-DkT7tnoB.cjs → nova-reel-CjJRxI1X.cjs} +9 -8
- package/dist/src/{nova-sonic-BaXRN1cr.js → nova-sonic-BNGmgfFz.js} +3 -3
- package/dist/src/{nova-sonic-BeTRaFOh.js → nova-sonic-ChPlh5na.js} +2 -2
- package/dist/src/{nova-sonic-CL7Zqv0G.js → nova-sonic-CrV0iaY_.js} +3 -3
- package/dist/src/{nova-sonic-YT426juD.cjs → nova-sonic-DuOG9Aun.cjs} +5 -4
- package/dist/src/{openai-Cy1XLs0c.cjs → openai-C3uXv8wS.cjs} +2 -2
- package/dist/src/{openai-BT-JvDse.js → openai-CJrsh9n4.js} +1 -1
- package/dist/src/{openai-D4fxGvRx.js → openai-zgwBb4Ff.js} +1 -1
- package/dist/src/{openclaw-Bq7RVR3k.js → openclaw-BIHlu_36.js} +9 -8
- package/dist/src/{openclaw-DObVgpjC.js → openclaw-CF7fMido.js} +9 -8
- package/dist/src/{openclaw-DUBZP3GL.cjs → openclaw-Dphc01BY.cjs} +17 -15
- package/dist/src/{openclaw-DA8U4DsD.js → openclaw-zIJAsz3P.js} +9 -8
- package/dist/src/{opencode-sdk-BB40Wir1.js → opencode-sdk-B3vlPLsp.js} +38 -3
- package/dist/src/{opencode-sdk-ChdK7F7z.js → opencode-sdk-D05JSgMQ.js} +39 -4
- package/dist/src/{opencode-sdk-CeqiOcOU.cjs → opencode-sdk-DoY6GbWw.cjs} +45 -9
- package/dist/src/{opencode-sdk-BM1UAIv1.js → opencode-sdk-sRKYHGoI.js} +39 -4
- package/dist/src/{otlpReceiver-UYMQx3sy.js → otlpReceiver--gTpSagc.js} +119 -3
- package/dist/src/{otlpReceiver-C6thJRXi.js → otlpReceiver-B2eaKC8C.js} +118 -2
- package/dist/src/{otlpReceiver-CcdIikOu.js → otlpReceiver-BXjcRqAM.js} +119 -3
- package/dist/src/{otlpReceiver-DNSQj6bf.cjs → otlpReceiver-CvJdBGSc.cjs} +125 -7
- package/dist/src/packageParser--MWTSrPW.js +36 -0
- package/dist/src/packageParser-CgE-ziRo.js +35 -0
- package/dist/src/packageParser-QoCS1FMl.cjs +54 -0
- package/dist/src/packageParser-hwwSGnAZ.js +35 -0
- package/dist/src/processShim-BBxt7LKO.js +95 -0
- package/dist/src/processShim-BcGzU8fY.js +94 -0
- package/dist/src/processShim-C_z3aRvF.js +94 -0
- package/dist/src/processShim-DSY9BV2T.cjs +98 -0
- package/dist/src/promptLength-0qIHyhA5.js +71 -0
- package/dist/src/promptLength-4X-Wd8PG.js +72 -0
- package/dist/src/promptLength-B9nZEfO6.js +71 -0
- package/dist/src/promptLength-BbBbDHNj.cjs +94 -0
- package/dist/src/promptfoo-BDrfT30-.js +180 -0
- package/dist/src/promptfoo-Cm4hiy1Y.js +180 -0
- package/dist/src/promptfoo-Rjp-MeBb.js +181 -0
- package/dist/src/promptfoo-b-baRMj-.cjs +205 -0
- package/dist/src/prompts-BYMtqPCw.js +259 -0
- package/dist/src/prompts-C-bqE1Yp.js +260 -0
- package/dist/src/prompts-Cp_Qx5Ml.js +270 -0
- package/dist/src/prompts-DHhQsANy.js +259 -0
- package/dist/src/prompts-D_QpZ2Dm.js +271 -0
- package/dist/src/prompts-hNvWBD3z.cjs +284 -0
- package/dist/src/prompts-huDVH2CI.js +270 -0
- package/dist/src/prompts-p78Hul5i.cjs +289 -0
- package/dist/src/{providerRegistry-BESeALrr.cjs → providerRegistry-CZO_w7ue.cjs} +2 -2
- package/dist/src/{providerRegistry-DoACwqhD.js → providerRegistry-DHcFiVWX.js} +1 -1
- package/dist/src/{providerRegistry-PMsleEzs.js → providerRegistry-ReCd0sFa.js} +1 -1
- package/dist/src/{providers-DT-GtF2t.js → providers-B9KzWxAX.js} +739 -11919
- package/dist/src/{providers-DRrerKra.js → providers-BCCz6_IX.js} +813 -11944
- package/dist/src/{providers-eDShy16E.cjs → providers-BDVVIQM6.cjs} +787 -12132
- package/dist/src/{providers-Ctcc592x.js → providers-BYAn82cf.js} +1 -1
- package/dist/src/{providers-CJh7iriU.js → providers-DVYRZP4E.js} +746 -11866
- package/dist/src/{pythonUtils-C4tltmIn.js → pythonUtils-CLCgQ9tt.js} +1 -1
- package/dist/src/{pythonUtils-DNqbnRdx.js → pythonUtils-CgYxeSmO.js} +2 -2
- package/dist/src/{pythonUtils-CoLaCwNY.cjs → pythonUtils-Cokhluq3.cjs} +7 -6
- package/dist/src/{pythonUtils-DMO68Jg7.js → pythonUtils-D0BYebvX.js} +2 -2
- package/dist/src/{quiverai-Bpx6MZ7T.cjs → quiverai-BAp6iTZD.cjs} +4 -4
- package/dist/src/{quiverai-CPKhWgaT.js → quiverai-BvIhI_0l.js} +3 -3
- package/dist/src/{quiverai-BSS9a7wV.js → quiverai-CdTWPe-A.js} +3 -3
- package/dist/src/{quiverai-Bk1KrvL6.js → quiverai-Cv7rJKDz.js} +3 -3
- package/dist/src/registry-BUJrgjwv.js +124 -0
- package/dist/src/registry-DXm1t_x0.js +125 -0
- package/dist/src/registry-Dp5EqoXc.js +124 -0
- package/dist/src/registry-KCVF1CFC.cjs +124 -0
- package/dist/src/{server-ByxbqAcQ.js → remoteGeneration-B1_XsKXU.js} +16 -147
- package/dist/src/{server-gyd6d4Hc.js → remoteGeneration-COpWcmWd.js} +15 -108
- package/dist/src/{server-BEECpeGG.cjs → remoteGeneration-DS9N3pgB.cjs} +30 -119
- package/dist/src/remoteGeneration-DsaSwmG2.js +217 -0
- package/dist/src/render-BNTrbmBw.cjs +384 -0
- package/dist/src/render-CSP99NLm.js +348 -0
- package/dist/src/render-DFfDeYUK.js +347 -0
- package/dist/src/{render-nj-UaPdn.js → render-DznWrxGO.js} +2 -2
- package/dist/src/render-_6ur1fhE.js +347 -0
- package/dist/src/resourceAttributes-D1jP3kL5.js +17 -0
- package/dist/src/resourceAttributes-DQbBB--2.js +16 -0
- package/dist/src/resourceAttributes-ephgOvdR.cjs +27 -0
- package/dist/src/resourceAttributes-v6-I67fn.js +16 -0
- package/dist/src/{responses-CF-ayauu.cjs → responses-1UFFF9N_.cjs} +12 -11
- package/dist/src/{responses-B8haB-mD.js → responses-B3W2JvOQ.js} +9 -9
- package/dist/src/{responses-1ztiVYsx.js → responses-B6ktc3Ra.js} +7 -7
- package/dist/src/{responses-BiaBguAu.js → responses-URRzV8qE.js} +9 -9
- package/dist/src/rolldown-runtime-D_mwlA32.cjs +43 -0
- package/dist/src/rubyUtils-BYVlQ94c.js +3 -0
- package/dist/src/{rubyUtils-CIQFnVz4.js → rubyUtils-CXlFM2rR.js} +2 -2
- package/dist/src/{rubyUtils-BI0p46eZ.js → rubyUtils-CnlW8AYb.js} +2 -2
- package/dist/src/{rubyUtils-DoifqkiA.cjs → rubyUtils-CqUWBZAt.cjs} +16 -26
- package/dist/src/{rubyUtils-DGnoCYL2.js → rubyUtils-DdGojpfv.js} +1 -1
- package/dist/src/runtimeTransform-BJOpL9Yc.js +142 -0
- package/dist/src/runtimeTransform-Dgh_D7DU.js +143 -0
- package/dist/src/runtimeTransform-DigbjU1r.js +142 -0
- package/dist/src/runtimeTransform-ON3YYILw.cjs +147 -0
- package/dist/src/{sagemaker-ClS_NB07.js → sagemaker-CujrzP1a.js} +61 -50
- package/dist/src/{sagemaker-ljtY12VM.cjs → sagemaker-DzffAqo_.cjs} +65 -53
- package/dist/src/{sagemaker-C5T60MKf.js → sagemaker-vhtSV7JI.js} +61 -50
- package/dist/src/{sagemaker-BDLeW29y.js → sagemaker-yr1QKeBs.js} +61 -50
- package/dist/src/{scanner-nOCWNIXa.js → scanner-DS0109SS.js} +6 -6
- package/dist/src/server/index.js +4147 -449
- package/dist/src/server-B8rqV126.cjs +126 -0
- package/dist/src/server-BaLytskk.js +3 -0
- package/dist/src/server-CMJD10J4.js +107 -0
- package/dist/src/server-Ddp8GNMp.js +146 -0
- package/dist/src/server-DhMHosWj.js +182 -0
- package/dist/src/shared-7pmVZLNO.js +1334 -0
- package/dist/src/shared-9WHQ1oNE.js +1335 -0
- package/dist/src/{fileExtensions-8CjoL7vB.js → shared-BoG7qLMv.js} +12 -2
- package/dist/src/shared-D6IjElRI.js +1334 -0
- package/dist/src/shared-WkgnDkcg.cjs +1436 -0
- package/dist/src/{signal-DTtUuU3l.js → signal-CSurUUyV.js} +2 -2
- package/dist/src/simulatedUser-C9aQObBI.js +222 -0
- package/dist/src/simulatedUser-Cu601Dd4.cjs +227 -0
- package/dist/src/simulatedUser-U_qAHnuB.js +222 -0
- package/dist/src/simulatedUser-p3tACcmw.js +223 -0
- package/dist/src/{slack-Bamy_7te.js → slack-Bapo-7_8.js} +1 -1
- package/dist/src/{slack-BLlsDpfG.cjs → slack-DMC1QVEg.cjs} +3 -2
- package/dist/src/{slack-BPYLQLgb.js → slack-DTEFhrMn.js} +1 -1
- package/dist/src/{slack-4zZX1OKP.js → slack-k-_CP84Q.js} +1 -1
- package/dist/src/storage-BU4qcnOb.js +875 -0
- package/dist/src/storage-CA-v9V2v.cjs +911 -0
- package/dist/src/storage-CD-GWAdx.js +822 -0
- package/dist/src/storage-QdU-SmvD.js +834 -0
- package/dist/src/{store-2K0kDi80.cjs → store-B2NDDooM.cjs} +60 -24
- package/dist/src/{store-CPh25336.js → store-DKd5592Q.js} +50 -19
- package/dist/src/{store-BPkzEyFM.js → store-HpopRVzl.js} +50 -19
- package/dist/src/store-IbiRIF3k.js +3 -0
- package/dist/src/strategies-7CS3Alao.cjs +2360 -0
- package/dist/src/strategies-CiSeroPH.js +2331 -0
- package/dist/src/strategies-DRJjGTIY.js +2333 -0
- package/dist/src/{tables-WgdUZ8Ck.js → tables-CRSXQ2Ke.js} +2 -2
- package/dist/src/{tables-BMSOS2Gg.js → tables-CxjU7bBd.js} +2 -2
- package/dist/src/{tables-CXbaZ9y1.cjs → tables-DBIJU0WE.cjs} +6 -5
- package/dist/src/{tables-NlvH23ky.js → tables-DafUHOeh.js} +2 -2
- package/dist/src/{telemetry-DWdGHvEf.js → telemetry-00ezXr_t.js} +4 -4
- package/dist/src/telemetry-ByPqDcKC.js +3 -0
- package/dist/src/{telemetry-CEQxGnMZ.cjs → telemetry-CJ7FnCsc.cjs} +15 -9
- package/dist/src/{telemetry--iqaGyaS.js → telemetry-DmXYcJNV.js} +4 -4
- package/dist/src/{telemetry-CgdVGV8N.js → telemetry-DwX9XUN5.js} +4 -4
- package/dist/src/{text-DDQP0tuQ.js → text-CZr46tp_.js} +1 -1
- package/dist/src/{text-D4lz-Jg_.js → text-Db-Wt2u2.js} +1 -1
- package/dist/src/{text-NWvfMfkF.js → text-DwYK5EBn.js} +1 -1
- package/dist/src/{text-BiNME7QG.cjs → text-nywWsRBM.cjs} +1 -1
- package/dist/src/{tokenUsageUtils-2wIvAhB3.js → tokenUsageUtils-CDet74yk.js} +1 -1
- package/dist/src/{tokenUsageUtils-4c780gFd.js → tokenUsageUtils-CmnQ0G2m.js} +1 -1
- package/dist/src/{tokenUsageUtils-C9odhsbW.cjs → tokenUsageUtils-_B-P8IAi.cjs} +1 -1
- package/dist/src/toolAttributes-BAjwcBf0.cjs +103 -0
- package/dist/src/toolAttributes-COVgDrBG.js +87 -0
- package/dist/src/toolAttributes-DJ9ZEKXD.js +86 -0
- package/dist/src/tracingOptions-BnwKCkSB.js +221 -0
- package/dist/src/tracingOptions-Chi74lOD.js +219 -0
- package/dist/src/tracingOptions-DrbSFaKy.cjs +249 -0
- package/dist/src/tracingOptions-ji2OuXbT.js +220 -0
- package/dist/src/{transcription-84t4ALo2.js → transcription-B8uIgCYX.js} +5 -5
- package/dist/src/{transcription-Bm2emLmJ.js → transcription-CfU5loSq.js} +5 -5
- package/dist/src/{transcription-D7Q0vJsh.js → transcription-Dkd22_4K.js} +4 -4
- package/dist/src/{transcription-CZ4LG5hQ.cjs → transcription-mzuf18Mq.cjs} +9 -8
- package/dist/src/{transform-DtooZqYY.js → transform-BIMynQsA.js} +8 -8
- package/dist/src/transform-BnSTnFlp.js +187 -0
- package/dist/src/transform-BnSXWmU_2.cjs +221 -0
- package/dist/src/transform-CGt7Kt3y2.js +186 -0
- package/dist/src/transform-CrPGTsij.js +186 -0
- package/dist/src/{transform-Dg4LcO1Y.cjs → transform-DhNkAUs8.cjs} +12 -11
- package/dist/src/{transform-_DpNB4qp.js → transform-DmvYBRll.js} +8 -8
- package/dist/src/{transform-B-b6Cq-q.js → transform-EtD4jAWi.js} +8 -8
- package/dist/src/{transformersAvailability-lvCCvuPT.js → transformersAvailability-0ThtPved.js} +1 -1
- package/dist/src/transformersAvailability-BYydDE5U.js +35 -0
- package/dist/src/{transformersAvailability-rJGPccjr.js → transformersAvailability-BvyU9vDD.js} +1 -1
- package/dist/src/{transformersAvailability-B22swDxr.cjs → transformersAvailability-BytPvKUW.cjs} +1 -1
- package/dist/src/{types-BVH9hjgW.js → types-BFevViUY.js} +113 -19
- package/dist/src/{types-BDjGOq4E.js → types-BJQBBPTP.js} +113 -19
- package/dist/src/{types-CgG2rKiW.cjs → types-CxJvaY2S.cjs} +211 -28
- package/dist/src/{types-DNRZVOue.js → types-D6glLbdF.js} +125 -26
- package/dist/src/{util-DFPeFkiV.js → util--WMgw7wM.js} +28 -8
- package/dist/src/{util-C-kmRosx.js → util-5WnCSb0h.js} +9 -7
- package/dist/src/{util-A5_ZsQUn.cjs → util-BSIuSLVK.cjs} +12 -9
- package/dist/src/{util-Dub0f_ej.js → util-Bx677_k2.js} +17 -10
- package/dist/src/util-CN8om2rz.cjs +386 -0
- package/dist/src/{util-DN0-b81k.js → util-CoQWM76y.js} +28 -8
- package/dist/src/util-DNl96nNs.js +327 -0
- package/dist/src/{util-BQOCAHQC.js → util-DURocbYR.js} +46 -11
- package/dist/src/util-Df8YMvS1.js +327 -0
- package/dist/src/{util-BVXcTwXu.js → util-DiQ3QvBB.js} +28 -8
- package/dist/src/{util-3pBZZb_H.js → util-I-Rf-KaD.js} +45 -10
- package/dist/src/{util-Dpmm_dAI.cjs → util-IYzs5Y04.cjs} +33 -7
- package/dist/src/{util-BlFVL0UF.js → util-LKTmNsMQ.js} +9 -7
- package/dist/src/{util-DvpHnLt0.cjs → util-SPsvFONY.cjs} +29 -21
- package/dist/src/{util-B9CNhyac.js → util-efByNxcr.js} +9 -7
- package/dist/src/util-kDURhgJW.js +328 -0
- package/dist/src/{utils-BUMN8orw.js → utils-B0lzitHZ.js} +2 -2
- package/dist/src/{utils-kt7lv30R.js → utils-BFOh20Gb.js} +2 -2
- package/dist/src/{utils-o8S5huU2.js → utils-BGY69tk_.js} +2 -2
- package/dist/src/{utils-DkVeShIB.cjs → utils-Ve6kuJsa.cjs} +3 -3
- package/dist/src/{version-CbuBKu2U.js → version-BK20a4sw.js} +2 -2
- package/dist/src/{version-D9zu9FWB.cjs → version-BWCSaByA.cjs} +2 -2
- package/dist/src/{version-CbpiUINz.js → version-eRkNuGv8.js} +2 -2
- package/dist/src/{version-0frU0UTr.js → version-lpHV_53E.js} +2 -2
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +48 -22
- package/dist/src/app/assets/Report-vjzrbgce.js +0 -1
- package/dist/src/app/assets/index-B3NQ8HTd.js +0 -385
- package/dist/src/app/assets/index-Cli2yAXv.css +0 -1
- package/dist/src/app/assets/sync-IjzpWrOE.js +0 -4
- package/dist/src/app/assets/vendor-charts-BNdH8TCw.js +0 -36
- package/dist/src/cache-BRkhlH3k.cjs +0 -3
- package/dist/src/cache-BlC6aeJ0.js +0 -3
- package/dist/src/cloud-CoD5OacT.js +0 -3
- package/dist/src/codex-sdk-1jm_qPHf.js +0 -3
- package/dist/src/codex-sdk-Danroptg.cjs +0 -2
- package/dist/src/evalResult-BBJAHAtw.cjs +0 -2
- package/dist/src/evalResult-BBK58h2B.js +0 -3
- package/dist/src/evalResult-spPqh1G_.js +0 -2
- package/dist/src/evaluator-DgLKaZk8.js +0 -3
- package/dist/src/fetch-8viavNv8.js +0 -3
- package/dist/src/graders-C84JI-m5.js +0 -2
- package/dist/src/graders-CBbd0K0Q.cjs +0 -2
- package/dist/src/graders-CbQqpHSN.js +0 -3
- package/dist/src/graders-DS42d3ZG.js +0 -2
- package/dist/src/image-BmilRNqO.js +0 -258
- package/dist/src/image-CxJoa3aW.cjs +0 -280
- package/dist/src/image-DsGRlkh7.js +0 -257
- package/dist/src/image-a_SGUobh.js +0 -257
- package/dist/src/providers-BuyzKt7C.js +0 -2
- package/dist/src/providers-C7lNVBjX.cjs +0 -3
- package/dist/src/providers-CCE2COJi2.js +0 -2
- package/dist/src/render-7uNJ2V14.js +0 -135
- package/dist/src/render-DlscvAUJ.js +0 -135
- package/dist/src/render-eui5p5mL.js +0 -136
- package/dist/src/render-tG6ir9_g.cjs +0 -165
- package/dist/src/rubyUtils-4hjGxvju.js +0 -3
- package/dist/src/rubyUtils-CO-tuszQ.cjs +0 -2
- package/dist/src/server-ByiF3qlg.js +0 -386
- package/dist/src/server-C0XKRNB_.cjs +0 -2
- package/dist/src/server-C_15p79-.js +0 -3
- package/dist/src/store-2OXm_eBY.js +0 -240
- package/dist/src/store-BELqNwvz.js +0 -3
- package/dist/src/store-uQZ4AjPe.cjs +0 -2
- package/dist/src/telemetry-DjNoC_n3.cjs +0 -2
- package/dist/src/telemetry-ZdPZc0fm.js +0 -3
- package/dist/src/transform-BQt0BeAW.js +0 -3
- package/dist/src/transform-Bq5oqC0s.cjs +0 -2
- package/dist/src/transform-C9izGX54.cjs +0 -228
- package/dist/src/transform-CwbAZ84V.js +0 -216
- package/dist/src/transform-DzCF-wqV.js +0 -213
- package/dist/src/transform-eGiUAv86.js +0 -216
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
import { S as getEnvBool, T as getEnvString, k as state } from "./logger-Ct2S6Yx-.js";
|
|
2
|
+
import { w as CloudConfig } from "./fetch-It34O8Ur.js";
|
|
3
|
+
import { o as isLoggedIntoCloud } from "./accounts-Ca7WIoPY.js";
|
|
4
|
+
import { i as resolvePackageEntryPoint, t as getDirectory } from "./esm-BTK1W7lG.js";
|
|
5
|
+
import { t as OpenAICodexSDKProvider } from "./codex-sdk-D2d54RL8.js";
|
|
6
|
+
import fs from "fs";
|
|
7
|
+
import path from "path";
|
|
8
|
+
import os from "os";
|
|
9
|
+
//#region src/providers/openai/codexDefaults.ts
|
|
10
|
+
const CODEX_AUTH_FILENAME = "auth.json";
|
|
11
|
+
const CODEX_SDK_PACKAGE_NAME = "@openai/codex-sdk";
|
|
12
|
+
let codexDefaultWorkingDir;
|
|
13
|
+
const CODEX_GRADING_OUTPUT_SCHEMA = {
|
|
14
|
+
type: "object",
|
|
15
|
+
properties: {
|
|
16
|
+
pass: { type: "boolean" },
|
|
17
|
+
score: { type: "number" },
|
|
18
|
+
reason: { type: "string" }
|
|
19
|
+
},
|
|
20
|
+
required: [
|
|
21
|
+
"pass",
|
|
22
|
+
"score",
|
|
23
|
+
"reason"
|
|
24
|
+
],
|
|
25
|
+
additionalProperties: false
|
|
26
|
+
};
|
|
27
|
+
const codexDefaultProvidersByCacheKey = /* @__PURE__ */ new Map();
|
|
28
|
+
const codexSdkAvailabilityByBaseDir = /* @__PURE__ */ new Map();
|
|
29
|
+
function getCodexEnvString(env, key) {
|
|
30
|
+
return env?.[key] || getEnvString(key);
|
|
31
|
+
}
|
|
32
|
+
function getCodexHome(env) {
|
|
33
|
+
const homeDir = os.homedir?.();
|
|
34
|
+
const defaultHome = typeof homeDir === "string" && homeDir ? path.join(homeDir, ".codex") : void 0;
|
|
35
|
+
const codexHome = getCodexEnvString(env, "CODEX_HOME") || defaultHome || ".codex";
|
|
36
|
+
return path.resolve(codexHome);
|
|
37
|
+
}
|
|
38
|
+
function getTempDirectory() {
|
|
39
|
+
const tempDir = os.tmpdir?.();
|
|
40
|
+
return typeof tempDir === "string" && tempDir ? tempDir : process.cwd();
|
|
41
|
+
}
|
|
42
|
+
function getCodexDefaultWorkingDir() {
|
|
43
|
+
if (!codexDefaultWorkingDir) codexDefaultWorkingDir = fs.mkdtempSync(path.join(getTempDirectory(), "promptfoo-codex-default-"));
|
|
44
|
+
return codexDefaultWorkingDir;
|
|
45
|
+
}
|
|
46
|
+
function hasCodexAuthFile(env) {
|
|
47
|
+
try {
|
|
48
|
+
const stats = fs.statSync(path.join(getCodexHome(env), CODEX_AUTH_FILENAME));
|
|
49
|
+
return stats.isFile() && stats.size > 0;
|
|
50
|
+
} catch {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
function hasCodexSdkPackage(baseDir) {
|
|
55
|
+
const cached = codexSdkAvailabilityByBaseDir.get(baseDir);
|
|
56
|
+
if (cached !== void 0) return cached;
|
|
57
|
+
const hasPackage = resolvePackageEntryPoint(CODEX_SDK_PACKAGE_NAME, baseDir) !== null;
|
|
58
|
+
codexSdkAvailabilityByBaseDir.set(baseDir, hasPackage);
|
|
59
|
+
return hasPackage;
|
|
60
|
+
}
|
|
61
|
+
function canLoadCodexSdkPackage() {
|
|
62
|
+
return [process.cwd(), getDirectory()].some((baseDir) => hasCodexSdkPackage(baseDir));
|
|
63
|
+
}
|
|
64
|
+
function hasCodexDefaultCredentials(env) {
|
|
65
|
+
return (Boolean(getCodexEnvString(env, "CODEX_API_KEY")) || hasCodexAuthFile(env)) && canLoadCodexSdkPackage();
|
|
66
|
+
}
|
|
67
|
+
function getCodexDefaultProviderConfig(env, config, defaultWorkingDir = getCodexDefaultWorkingDir()) {
|
|
68
|
+
const codexHome = getCodexEnvString(env, "CODEX_HOME");
|
|
69
|
+
const workingDir = config?.working_dir || defaultWorkingDir;
|
|
70
|
+
fs.mkdirSync(workingDir, { recursive: true });
|
|
71
|
+
const cliEnv = {
|
|
72
|
+
...codexHome ? { CODEX_HOME: path.resolve(codexHome) } : {},
|
|
73
|
+
...config?.cli_env
|
|
74
|
+
};
|
|
75
|
+
return {
|
|
76
|
+
approval_policy: "never",
|
|
77
|
+
sandbox_mode: "read-only",
|
|
78
|
+
skip_git_repo_check: true,
|
|
79
|
+
working_dir: workingDir,
|
|
80
|
+
...config,
|
|
81
|
+
...Object.keys(cliEnv).length > 0 ? { cli_env: cliEnv } : {}
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
function getCodexDefaultProvidersCacheKey(env) {
|
|
85
|
+
return JSON.stringify({
|
|
86
|
+
CODEX_HOME: getCodexEnvString(env, "CODEX_HOME"),
|
|
87
|
+
hasCodexApiKey: Boolean(getCodexEnvString(env, "CODEX_API_KEY")),
|
|
88
|
+
hasOpenAiApiKey: Boolean(getCodexEnvString(env, "OPENAI_API_KEY"))
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
function getCodexDefaultProviders(env) {
|
|
92
|
+
const cacheKey = getCodexDefaultProvidersCacheKey(env);
|
|
93
|
+
const cachedProviders = codexDefaultProvidersByCacheKey.get(cacheKey);
|
|
94
|
+
if (cachedProviders) return cachedProviders;
|
|
95
|
+
const defaultWorkingDir = getCodexDefaultWorkingDir();
|
|
96
|
+
const gradingProvider = new OpenAICodexSDKProvider({
|
|
97
|
+
config: getCodexDefaultProviderConfig(env, void 0, defaultWorkingDir),
|
|
98
|
+
env
|
|
99
|
+
});
|
|
100
|
+
const gradingJsonProvider = new OpenAICodexSDKProvider({
|
|
101
|
+
config: getCodexDefaultProviderConfig(env, { output_schema: CODEX_GRADING_OUTPUT_SCHEMA }, defaultWorkingDir),
|
|
102
|
+
env
|
|
103
|
+
});
|
|
104
|
+
const providers = {
|
|
105
|
+
gradingJsonProvider,
|
|
106
|
+
gradingProvider,
|
|
107
|
+
llmRubricProvider: gradingJsonProvider,
|
|
108
|
+
suggestionsProvider: gradingProvider,
|
|
109
|
+
synthesizeProvider: gradingProvider,
|
|
110
|
+
webSearchProvider: new OpenAICodexSDKProvider({
|
|
111
|
+
config: getCodexDefaultProviderConfig(env, {
|
|
112
|
+
network_access_enabled: true,
|
|
113
|
+
output_schema: CODEX_GRADING_OUTPUT_SCHEMA,
|
|
114
|
+
web_search_mode: "live"
|
|
115
|
+
}, defaultWorkingDir),
|
|
116
|
+
env
|
|
117
|
+
})
|
|
118
|
+
};
|
|
119
|
+
codexDefaultProvidersByCacheKey.set(cacheKey, providers);
|
|
120
|
+
return providers;
|
|
121
|
+
}
|
|
122
|
+
//#endregion
|
|
123
|
+
//#region src/redteam/remoteGeneration.ts
|
|
124
|
+
/**
|
|
125
|
+
* Gets the remote generation API endpoint URL.
|
|
126
|
+
* Prioritizes: env var > cloud config > default endpoint.
|
|
127
|
+
* @returns The remote generation URL
|
|
128
|
+
*/
|
|
129
|
+
function getRemoteGenerationUrl() {
|
|
130
|
+
const envUrl = getEnvString("PROMPTFOO_REMOTE_GENERATION_URL");
|
|
131
|
+
if (envUrl) return envUrl;
|
|
132
|
+
const cloudConfig = new CloudConfig();
|
|
133
|
+
if (cloudConfig.isEnabled()) return cloudConfig.getApiHost() + "/api/v1/task";
|
|
134
|
+
return "https://api.promptfoo.app/api/v1/task";
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Check if remote generation should never be used.
|
|
138
|
+
* Respects both the general and redteam-specific disable flags.
|
|
139
|
+
* @returns true if remote generation is disabled
|
|
140
|
+
*/
|
|
141
|
+
function neverGenerateRemote() {
|
|
142
|
+
if (getEnvBool("PROMPTFOO_DISABLE_REMOTE_GENERATION")) return true;
|
|
143
|
+
return getEnvBool("PROMPTFOO_DISABLE_REDTEAM_REMOTE_GENERATION");
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Check if remote generation should never be used for non-redteam features.
|
|
147
|
+
* This allows granular control: disable redteam remote generation while allowing
|
|
148
|
+
* regular SimulatedUser to use remote generation.
|
|
149
|
+
* @returns true if ALL remote generation is disabled
|
|
150
|
+
*/
|
|
151
|
+
function neverGenerateRemoteForRegularEvals() {
|
|
152
|
+
return getEnvBool("PROMPTFOO_DISABLE_REMOTE_GENERATION");
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Builds a remote URL with a substituted pathname, honoring env vars / cloud config.
|
|
156
|
+
*/
|
|
157
|
+
function buildRemoteUrl(pathname, fallback) {
|
|
158
|
+
if (neverGenerateRemote()) return null;
|
|
159
|
+
const envUrl = getEnvString("PROMPTFOO_REMOTE_GENERATION_URL");
|
|
160
|
+
if (envUrl) try {
|
|
161
|
+
const url = new URL(envUrl);
|
|
162
|
+
url.pathname = pathname;
|
|
163
|
+
return url.toString();
|
|
164
|
+
} catch {
|
|
165
|
+
return fallback;
|
|
166
|
+
}
|
|
167
|
+
const cloudConfig = new CloudConfig();
|
|
168
|
+
if (cloudConfig.isEnabled()) return `${cloudConfig.getApiHost()}${pathname}`;
|
|
169
|
+
return fallback;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Gets the URL for checking remote API health based on configuration.
|
|
173
|
+
* @returns The health check URL, or null if remote generation is disabled.
|
|
174
|
+
*/
|
|
175
|
+
function getRemoteHealthUrl() {
|
|
176
|
+
return buildRemoteUrl("/health", "https://api.promptfoo.app/health");
|
|
177
|
+
}
|
|
178
|
+
/**
|
|
179
|
+
* Gets the URL for checking remote API version based on configuration.
|
|
180
|
+
* @returns The version check URL, or null if remote generation is disabled.
|
|
181
|
+
*/
|
|
182
|
+
function getRemoteVersionUrl() {
|
|
183
|
+
return buildRemoteUrl("/version", "https://api.promptfoo.app/version");
|
|
184
|
+
}
|
|
185
|
+
function getRemoteGenerationDisabledError(strategyName) {
|
|
186
|
+
return `${strategyName} requires remote generation, which is currently disabled for this configuration. To enable it, run with --remote, set PROMPTFOO_REMOTE_GENERATION_URL to a self-hosted endpoint, or log into Promptfoo Cloud with \`promptfoo auth login\`.`;
|
|
187
|
+
}
|
|
188
|
+
function getRemoteGenerationExplicitlyDisabledError(strategyName) {
|
|
189
|
+
const activeFlags = ["PROMPTFOO_DISABLE_REMOTE_GENERATION", "PROMPTFOO_DISABLE_REDTEAM_REMOTE_GENERATION"].filter((flag) => getEnvBool(flag));
|
|
190
|
+
return `${strategyName} requires remote generation, which has been explicitly disabled. To enable it, ${activeFlags.length > 0 ? `unset ${activeFlags.join(" and ")}` : "unset PROMPTFOO_DISABLE_REMOTE_GENERATION or PROMPTFOO_DISABLE_REDTEAM_REMOTE_GENERATION (whichever is set)"}. Once re-enabled, you can point at a self-hosted endpoint with PROMPTFOO_REMOTE_GENERATION_URL or use Promptfoo Cloud via \`promptfoo auth login\`.`;
|
|
191
|
+
}
|
|
192
|
+
/**
|
|
193
|
+
* Determines if remote generation should be used based on configuration.
|
|
194
|
+
* @returns true if remote generation should be used
|
|
195
|
+
*/
|
|
196
|
+
function shouldGenerateRemote(options) {
|
|
197
|
+
if (neverGenerateRemote()) return false;
|
|
198
|
+
if (getEnvString("PROMPTFOO_REMOTE_GENERATION_URL")) return true;
|
|
199
|
+
if (isLoggedIntoCloud()) return true;
|
|
200
|
+
return !(Boolean(getEnvString("OPENAI_API_KEY")) || options?.canUseCodexDefaultProvider && !options?.requireEmbeddingProvider && hasCodexDefaultCredentials()) || (state.remote ?? false);
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Gets the URL for unaligned model inference (harmful content generation).
|
|
204
|
+
* Prioritizes: env var > cloud config > default endpoint.
|
|
205
|
+
* @returns The unaligned inference URL
|
|
206
|
+
*/
|
|
207
|
+
function getRemoteGenerationUrlForUnaligned() {
|
|
208
|
+
const envUrl = getEnvString("PROMPTFOO_UNALIGNED_INFERENCE_ENDPOINT");
|
|
209
|
+
if (envUrl) return envUrl;
|
|
210
|
+
const cloudConfig = new CloudConfig();
|
|
211
|
+
if (cloudConfig.isEnabled()) return cloudConfig.getApiHost() + "/api/v1/task/harmful";
|
|
212
|
+
return "https://api.promptfoo.app/api/v1/task/harmful";
|
|
213
|
+
}
|
|
214
|
+
//#endregion
|
|
215
|
+
export { getRemoteHealthUrl as a, neverGenerateRemoteForRegularEvals as c, hasCodexDefaultCredentials as d, getRemoteGenerationUrlForUnaligned as i, shouldGenerateRemote as l, getRemoteGenerationExplicitlyDisabledError as n, getRemoteVersionUrl as o, getRemoteGenerationUrl as r, neverGenerateRemote as s, getRemoteGenerationDisabledError as t, getCodexDefaultProviders as u };
|
|
216
|
+
|
|
217
|
+
//# sourceMappingURL=remoteGeneration-DsaSwmG2.js.map
|
|
@@ -0,0 +1,384 @@
|
|
|
1
|
+
const require_rolldown_runtime = require("./rolldown-runtime-D_mwlA32.cjs");
|
|
2
|
+
const require_logger = require("./logger-cfNpzI4o.cjs");
|
|
3
|
+
let nunjucks = require("nunjucks");
|
|
4
|
+
nunjucks = require_rolldown_runtime.__toESM(nunjucks, 1);
|
|
5
|
+
//#region src/util/templates.ts
|
|
6
|
+
function isNunjucksAstNode(value) {
|
|
7
|
+
return Boolean(value && typeof value === "object" && typeof value.typename === "string");
|
|
8
|
+
}
|
|
9
|
+
function getNunjucksParser() {
|
|
10
|
+
return nunjucks.default.parser;
|
|
11
|
+
}
|
|
12
|
+
function parseNunjucksTemplate(template) {
|
|
13
|
+
const parser = getNunjucksParser();
|
|
14
|
+
if (!parser || typeof parser.parse !== "function") {
|
|
15
|
+
require_logger.logger.debug("[templates] nunjucks.parser.parse is not available; falling back to conservative detection");
|
|
16
|
+
return { ok: false };
|
|
17
|
+
}
|
|
18
|
+
try {
|
|
19
|
+
return {
|
|
20
|
+
ok: true,
|
|
21
|
+
ast: parser.parse(template)
|
|
22
|
+
};
|
|
23
|
+
} catch (err) {
|
|
24
|
+
require_logger.logger.debug("[templates] nunjucks parse failed; falling back to conservative detection", { error: err instanceof Error ? err.message : String(err) });
|
|
25
|
+
return { ok: false };
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
function isNonReferenceSymbol(parent) {
|
|
29
|
+
if (!parent) return false;
|
|
30
|
+
return parent.node.typename === "Pair" && parent.field === "key" || parent.node.typename === "Filter" && parent.field === "name" || parent.node.typename === "Is" && parent.field === "right" || parent.node.typename === "Set" && parent.field === "targets" || isForLikeNode(parent.node) && parent.field === "name" || parent.node.typename === "Macro" && parent.field === "name" || parent.node.typename === "Import" && parent.field === "target" || parent.node.typename === "FromImport" && parent.field === "names";
|
|
31
|
+
}
|
|
32
|
+
function getSymbolName(node) {
|
|
33
|
+
return isNunjucksAstNode(node) && node.typename === "Symbol" && typeof node.value === "string" ? node.value : void 0;
|
|
34
|
+
}
|
|
35
|
+
function collectBindingNames(node) {
|
|
36
|
+
if (Array.isArray(node)) return node.flatMap((item) => collectBindingNames(item));
|
|
37
|
+
const symbolName = getSymbolName(node);
|
|
38
|
+
if (symbolName) return [symbolName];
|
|
39
|
+
if (!isNunjucksAstNode(node) || !Array.isArray(node.children)) return [];
|
|
40
|
+
return node.children.flatMap((child) => collectBindingNames(child));
|
|
41
|
+
}
|
|
42
|
+
function addBindingNames(scope, node) {
|
|
43
|
+
const nextScope = new Set(scope);
|
|
44
|
+
for (const name of collectBindingNames(node)) nextScope.add(name);
|
|
45
|
+
return nextScope;
|
|
46
|
+
}
|
|
47
|
+
function addNamesToScope(scope, names) {
|
|
48
|
+
const nextScope = new Set(scope);
|
|
49
|
+
for (const name of names) nextScope.add(name);
|
|
50
|
+
return nextScope;
|
|
51
|
+
}
|
|
52
|
+
function collectFromImportBindingNames(namesNode) {
|
|
53
|
+
if (!isNunjucksAstNode(namesNode) || !Array.isArray(namesNode.children)) return [];
|
|
54
|
+
const names = [];
|
|
55
|
+
for (const child of namesNode.children) {
|
|
56
|
+
const plainImportName = getSymbolName(child);
|
|
57
|
+
if (plainImportName) {
|
|
58
|
+
names.push(plainImportName);
|
|
59
|
+
continue;
|
|
60
|
+
}
|
|
61
|
+
if (isNunjucksAstNode(child) && child.typename === "Pair") {
|
|
62
|
+
const aliasName = getSymbolName(child.value);
|
|
63
|
+
if (aliasName) names.push(aliasName);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return names;
|
|
67
|
+
}
|
|
68
|
+
function astNodeListReferencesVariable(nodes, variableName, parent, boundSymbols) {
|
|
69
|
+
let scope = new Set(boundSymbols);
|
|
70
|
+
for (const item of nodes) {
|
|
71
|
+
if (!isNunjucksAstNode(item)) continue;
|
|
72
|
+
if (astReferencesVariable(item, variableName, parent, scope)) return true;
|
|
73
|
+
if (item.typename === "Set") scope = addBindingNames(scope, item.targets);
|
|
74
|
+
else if (item.typename === "Macro") scope = addBindingNames(scope, item.name);
|
|
75
|
+
else if (item.typename === "Import") scope = addBindingNames(scope, item.target);
|
|
76
|
+
else if (item.typename === "FromImport") scope = addNamesToScope(scope, collectFromImportBindingNames(item.names));
|
|
77
|
+
}
|
|
78
|
+
return false;
|
|
79
|
+
}
|
|
80
|
+
function astChildReferencesVariable(node, field, variableName, boundSymbols) {
|
|
81
|
+
const child = node[field];
|
|
82
|
+
if (Array.isArray(child)) return child.some((item) => isNunjucksAstNode(item) && astReferencesVariable(item, variableName, {
|
|
83
|
+
field,
|
|
84
|
+
node
|
|
85
|
+
}, boundSymbols));
|
|
86
|
+
return isNunjucksAstNode(child) && astReferencesVariable(child, variableName, {
|
|
87
|
+
field,
|
|
88
|
+
node
|
|
89
|
+
}, boundSymbols);
|
|
90
|
+
}
|
|
91
|
+
function isForLikeNode(node) {
|
|
92
|
+
return node.typename === "For" || node.typename === "AsyncEach" || node.typename === "AsyncAll";
|
|
93
|
+
}
|
|
94
|
+
function forLikeNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
95
|
+
const loopScope = addBindingNames(boundSymbols, node.name);
|
|
96
|
+
return astChildReferencesVariable(node, "arr", variableName, boundSymbols) || astChildReferencesVariable(node, "body", variableName, loopScope) || astChildReferencesVariable(node, "else_", variableName, boundSymbols);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Walk a Nunjucks macro/caller signature left-to-right. Positional args and
|
|
100
|
+
* earlier keyword defaults are visible to later defaults, but the current
|
|
101
|
+
* keyword is not bound until its own default value has been evaluated.
|
|
102
|
+
*/
|
|
103
|
+
function analyzeSignatureArgs(argsNode, variableName, boundSymbols) {
|
|
104
|
+
const paramNames = [];
|
|
105
|
+
if (!isNunjucksAstNode(argsNode) || !Array.isArray(argsNode.children)) return {
|
|
106
|
+
paramNames,
|
|
107
|
+
referencesVariable: false
|
|
108
|
+
};
|
|
109
|
+
const defaultScope = new Set(boundSymbols);
|
|
110
|
+
for (const child of argsNode.children) {
|
|
111
|
+
if (!isNunjucksAstNode(child)) continue;
|
|
112
|
+
const positionalParamName = getSymbolName(child);
|
|
113
|
+
if (positionalParamName) {
|
|
114
|
+
paramNames.push(positionalParamName);
|
|
115
|
+
defaultScope.add(positionalParamName);
|
|
116
|
+
continue;
|
|
117
|
+
}
|
|
118
|
+
if (child.typename === "KeywordArgs" && Array.isArray(child.children)) {
|
|
119
|
+
for (const pair of child.children) {
|
|
120
|
+
const keywordParamName = isNunjucksAstNode(pair) && pair.typename === "Pair" ? getSymbolName(pair.key) : void 0;
|
|
121
|
+
if (isNunjucksAstNode(pair) && pair.typename === "Pair" && astChildReferencesVariable(pair, "value", variableName, defaultScope)) return {
|
|
122
|
+
paramNames,
|
|
123
|
+
referencesVariable: true
|
|
124
|
+
};
|
|
125
|
+
if (keywordParamName) {
|
|
126
|
+
paramNames.push(keywordParamName);
|
|
127
|
+
defaultScope.add(keywordParamName);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
if (astReferencesVariable(child, variableName, {
|
|
133
|
+
field: "children",
|
|
134
|
+
node: argsNode
|
|
135
|
+
}, defaultScope)) return {
|
|
136
|
+
paramNames,
|
|
137
|
+
referencesVariable: true
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
return {
|
|
141
|
+
paramNames,
|
|
142
|
+
referencesVariable: false
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
function macroNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
146
|
+
const { paramNames, referencesVariable } = analyzeSignatureArgs(node.args, variableName, boundSymbols);
|
|
147
|
+
if (referencesVariable) return true;
|
|
148
|
+
const macroScope = addNamesToScope(boundSymbols, paramNames);
|
|
149
|
+
const macroName = getSymbolName(node.name);
|
|
150
|
+
if (macroName) macroScope.add(macroName);
|
|
151
|
+
return astChildReferencesVariable(node, "body", variableName, macroScope);
|
|
152
|
+
}
|
|
153
|
+
function isNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
154
|
+
if (astChildReferencesVariable(node, "left", variableName, boundSymbols)) return true;
|
|
155
|
+
const right = node.right;
|
|
156
|
+
if (!isNunjucksAstNode(right)) return false;
|
|
157
|
+
if (right.typename === "FunCall") return astChildReferencesVariable(right, "args", variableName, boundSymbols);
|
|
158
|
+
return right.typename !== "Symbol" && astReferencesVariable(right, variableName, {
|
|
159
|
+
field: "right",
|
|
160
|
+
node
|
|
161
|
+
}, boundSymbols);
|
|
162
|
+
}
|
|
163
|
+
function setNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
164
|
+
return astChildReferencesVariable(node, "value", variableName, boundSymbols) || astChildReferencesVariable(node, "body", variableName, boundSymbols);
|
|
165
|
+
}
|
|
166
|
+
function fromImportNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
167
|
+
return astChildReferencesVariable(node, "template", variableName, boundSymbols);
|
|
168
|
+
}
|
|
169
|
+
function blockNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
170
|
+
return astChildReferencesVariable(node, "body", variableName, boundSymbols);
|
|
171
|
+
}
|
|
172
|
+
function callerNodeReferencesVariable(node, variableName, boundSymbols) {
|
|
173
|
+
const { paramNames, referencesVariable } = analyzeSignatureArgs(node.args, variableName, boundSymbols);
|
|
174
|
+
if (referencesVariable) return true;
|
|
175
|
+
return astChildReferencesVariable(node, "body", variableName, addNamesToScope(boundSymbols, paramNames));
|
|
176
|
+
}
|
|
177
|
+
function astFieldsReferenceVariable(node, variableName, boundSymbols) {
|
|
178
|
+
return (node.fields ?? []).some((field) => astChildReferencesVariable(node, field, variableName, boundSymbols));
|
|
179
|
+
}
|
|
180
|
+
function astReferencesVariable(node, variableName, parent, boundSymbols = /* @__PURE__ */ new Set()) {
|
|
181
|
+
if (node.typename === "Symbol" && node.value === variableName) return !boundSymbols.has(variableName) && !isNonReferenceSymbol(parent);
|
|
182
|
+
if ((node.typename === "Root" || node.typename === "NodeList") && Array.isArray(node.children)) return astNodeListReferencesVariable(node.children, variableName, {
|
|
183
|
+
field: "children",
|
|
184
|
+
node
|
|
185
|
+
}, boundSymbols);
|
|
186
|
+
if (isForLikeNode(node)) return forLikeNodeReferencesVariable(node, variableName, boundSymbols);
|
|
187
|
+
if (node.typename === "Macro") return macroNodeReferencesVariable(node, variableName, boundSymbols);
|
|
188
|
+
if (node.typename === "Is") return isNodeReferencesVariable(node, variableName, boundSymbols);
|
|
189
|
+
if (node.typename === "Set") return setNodeReferencesVariable(node, variableName, boundSymbols);
|
|
190
|
+
if (node.typename === "FromImport") return fromImportNodeReferencesVariable(node, variableName, boundSymbols);
|
|
191
|
+
if (node.typename === "Block") return blockNodeReferencesVariable(node, variableName, boundSymbols);
|
|
192
|
+
if (node.typename === "Caller") return callerNodeReferencesVariable(node, variableName, boundSymbols);
|
|
193
|
+
return astFieldsReferenceVariable(node, variableName, boundSymbols);
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Get a Nunjucks engine instance with optional filters and configuration.
|
|
197
|
+
* @param filters - Optional map of custom Nunjucks filters.
|
|
198
|
+
* @param throwOnUndefined - Whether to throw an error on undefined variables.
|
|
199
|
+
* @param isGrader - Whether this engine is being used in a grader context.
|
|
200
|
+
* Nunjucks is always enabled in grader mode.
|
|
201
|
+
* @returns A configured Nunjucks environment.
|
|
202
|
+
*/
|
|
203
|
+
function getNunjucksEngine(filters, throwOnUndefined = false, isGrader = false) {
|
|
204
|
+
if (!isGrader && require_logger.getEnvBool("PROMPTFOO_DISABLE_TEMPLATING")) return { renderString: (template) => template };
|
|
205
|
+
const env = nunjucks.default.configure({
|
|
206
|
+
autoescape: false,
|
|
207
|
+
throwOnUndefined
|
|
208
|
+
});
|
|
209
|
+
const envGlobals = {
|
|
210
|
+
...require_logger.getEnvBool("PROMPTFOO_DISABLE_TEMPLATE_ENV_VARS", require_logger.getEnvBool("PROMPTFOO_SELF_HOSTED", false)) ? {} : process.env,
|
|
211
|
+
...require_logger.state.config?.env
|
|
212
|
+
};
|
|
213
|
+
env.addGlobal("env", envGlobals);
|
|
214
|
+
env.addFilter("load", function(str) {
|
|
215
|
+
return JSON.parse(str);
|
|
216
|
+
});
|
|
217
|
+
if (filters) for (const [name, filter] of Object.entries(filters)) env.addFilter(name, filter);
|
|
218
|
+
return env;
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Parse Nunjucks template to extract variables.
|
|
222
|
+
* @param template - The Nunjucks template string.
|
|
223
|
+
* @returns An array of variables used in the template.
|
|
224
|
+
*/
|
|
225
|
+
function extractVariablesFromTemplate(template) {
|
|
226
|
+
const variableSet = /* @__PURE__ */ new Set();
|
|
227
|
+
const regex = /\{\{[\s]*([^{}\s|]+)[\s]*(?:\|[^}]+)?\}\}|\{%[\s]*(?:if|for)[\s]+([^{}\s]+)[\s]*.*?%\}/g;
|
|
228
|
+
template = template.replace(/\{#[\s\S]*?#\}/g, "");
|
|
229
|
+
let match;
|
|
230
|
+
while ((match = regex.exec(template)) !== null) {
|
|
231
|
+
const variable = match[1] || match[2];
|
|
232
|
+
if (variable) variableSet.add(variable);
|
|
233
|
+
}
|
|
234
|
+
const forLoopRegex = /\{%[\s]*for[\s]+(\w+)[\s]+in[\s]+(\w+)[\s]*%\}/g;
|
|
235
|
+
while ((match = forLoopRegex.exec(template)) !== null) {
|
|
236
|
+
variableSet.delete(match[1]);
|
|
237
|
+
variableSet.add(match[2]);
|
|
238
|
+
}
|
|
239
|
+
return Array.from(variableSet);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Extract variables from multiple Nunjucks templates.
|
|
243
|
+
* @param templates - An array of Nunjucks template strings.
|
|
244
|
+
* @returns An array of variables used in the templates.
|
|
245
|
+
*/
|
|
246
|
+
function extractVariablesFromTemplates(templates) {
|
|
247
|
+
const variableSet = /* @__PURE__ */ new Set();
|
|
248
|
+
for (const template of templates) extractVariablesFromTemplate(template).forEach((variable) => variableSet.add(variable));
|
|
249
|
+
return Array.from(variableSet);
|
|
250
|
+
}
|
|
251
|
+
/**
|
|
252
|
+
* Classify whether a template references `variableName` as a real Nunjucks
|
|
253
|
+
* expression symbol, and surface whether the template parsed successfully.
|
|
254
|
+
*
|
|
255
|
+
* Callers that cache results should avoid caching when `parsed` is `false`,
|
|
256
|
+
* otherwise a transient parse failure would poison the cache for the lifetime
|
|
257
|
+
* of the process.
|
|
258
|
+
*/
|
|
259
|
+
function analyzeTemplateReference(template, variableName) {
|
|
260
|
+
if (!variableName || !template.includes(variableName)) return {
|
|
261
|
+
referenced: false,
|
|
262
|
+
parsed: true
|
|
263
|
+
};
|
|
264
|
+
const parseResult = parseNunjucksTemplate(template);
|
|
265
|
+
if (!parseResult.ok) return {
|
|
266
|
+
referenced: true,
|
|
267
|
+
parsed: false
|
|
268
|
+
};
|
|
269
|
+
return {
|
|
270
|
+
referenced: astReferencesVariable(parseResult.ast, variableName),
|
|
271
|
+
parsed: true
|
|
272
|
+
};
|
|
273
|
+
}
|
|
274
|
+
//#endregion
|
|
275
|
+
//#region src/util/render.ts
|
|
276
|
+
/**
|
|
277
|
+
* Renders ONLY environment variable templates in an object, leaving all other templates untouched.
|
|
278
|
+
* This allows env vars to be resolved at provider load time while preserving runtime var templates.
|
|
279
|
+
*
|
|
280
|
+
* Supports full Nunjucks syntax for env vars including filters and expressions:
|
|
281
|
+
* - {{ env.VAR_NAME }}
|
|
282
|
+
* - {{ env['VAR-NAME'] }}
|
|
283
|
+
* - {{ env["VAR-NAME"] }}
|
|
284
|
+
* - {{ env.VAR | default('fallback') }}
|
|
285
|
+
* - {{ env.VAR | upper }}
|
|
286
|
+
*
|
|
287
|
+
* Preserves non-env templates for runtime rendering:
|
|
288
|
+
* - {{ vars.x }} - preserved as literal
|
|
289
|
+
* - {{ prompt }} - preserved as literal
|
|
290
|
+
*
|
|
291
|
+
* Implementation: Uses regex to find env templates, delegates to Nunjucks for rendering.
|
|
292
|
+
* This ensures full Nunjucks feature support while preserving non-env templates.
|
|
293
|
+
*
|
|
294
|
+
* @param obj - The object to process
|
|
295
|
+
* @param envOverrides - Optional env vars to merge with (or replace) the base env
|
|
296
|
+
* @param replaceBase - If true, envOverrides replaces the base env entirely instead of merging
|
|
297
|
+
* @returns The object with only env templates rendered
|
|
298
|
+
*/
|
|
299
|
+
function renderEnvOnlyInObject(obj, envOverrides, replaceBase) {
|
|
300
|
+
if (require_logger.getEnvBool("PROMPTFOO_DISABLE_TEMPLATING")) return obj;
|
|
301
|
+
if (typeof obj === "string") {
|
|
302
|
+
const nunjucks = getNunjucksEngine();
|
|
303
|
+
const baseEnvGlobals = nunjucks.getGlobal("env");
|
|
304
|
+
const envGlobals = replaceBase ? envOverrides ?? {} : envOverrides ? {
|
|
305
|
+
...baseEnvGlobals,
|
|
306
|
+
...envOverrides
|
|
307
|
+
} : baseEnvGlobals;
|
|
308
|
+
return obj.replace(/\{\{(?:[^}]|\}(?!\}))*\}\}/g, (match) => {
|
|
309
|
+
if (!match.match(/\benv\.|env\[/)) return match;
|
|
310
|
+
const varMatch = match.match(/env\.(\w+)|env\[['"]([^'"]+)['"]\]/);
|
|
311
|
+
const varName = varMatch?.[1] || varMatch?.[2];
|
|
312
|
+
if (match.includes("|") || varName && varName in envGlobals && envGlobals[varName] !== void 0) try {
|
|
313
|
+
return nunjucks.renderString(match, { env: envGlobals });
|
|
314
|
+
} catch (error) {
|
|
315
|
+
require_logger.logger.debug(`Failed to render env template "${match}": ${error instanceof Error ? error.message : String(error)}`);
|
|
316
|
+
return match;
|
|
317
|
+
}
|
|
318
|
+
return match;
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
if (Array.isArray(obj)) return obj.map((item) => renderEnvOnlyInObject(item, envOverrides, replaceBase));
|
|
322
|
+
if (typeof obj === "object" && obj !== null) {
|
|
323
|
+
const result = {};
|
|
324
|
+
for (const key in obj) {
|
|
325
|
+
if (key === "_conversation") {
|
|
326
|
+
result[key] = obj[key];
|
|
327
|
+
continue;
|
|
328
|
+
}
|
|
329
|
+
result[key] = renderEnvOnlyInObject(obj[key], envOverrides, replaceBase);
|
|
330
|
+
}
|
|
331
|
+
return result;
|
|
332
|
+
}
|
|
333
|
+
return obj;
|
|
334
|
+
}
|
|
335
|
+
function renderVarsInObject(obj, vars) {
|
|
336
|
+
if (!vars || require_logger.getEnvBool("PROMPTFOO_DISABLE_TEMPLATING")) return obj;
|
|
337
|
+
if (typeof obj === "string") return getNunjucksEngine().renderString(obj, vars);
|
|
338
|
+
if (Array.isArray(obj)) return obj.map((item) => renderVarsInObject(item, vars));
|
|
339
|
+
if (typeof obj === "object" && obj !== null) {
|
|
340
|
+
const result = {};
|
|
341
|
+
for (const key in obj) result[key] = renderVarsInObject(obj[key], vars);
|
|
342
|
+
return result;
|
|
343
|
+
} else if (typeof obj === "function") return renderVarsInObject(obj({ vars }));
|
|
344
|
+
return obj;
|
|
345
|
+
}
|
|
346
|
+
//#endregion
|
|
347
|
+
Object.defineProperty(exports, "analyzeTemplateReference", {
|
|
348
|
+
enumerable: true,
|
|
349
|
+
get: function() {
|
|
350
|
+
return analyzeTemplateReference;
|
|
351
|
+
}
|
|
352
|
+
});
|
|
353
|
+
Object.defineProperty(exports, "extractVariablesFromTemplate", {
|
|
354
|
+
enumerable: true,
|
|
355
|
+
get: function() {
|
|
356
|
+
return extractVariablesFromTemplate;
|
|
357
|
+
}
|
|
358
|
+
});
|
|
359
|
+
Object.defineProperty(exports, "extractVariablesFromTemplates", {
|
|
360
|
+
enumerable: true,
|
|
361
|
+
get: function() {
|
|
362
|
+
return extractVariablesFromTemplates;
|
|
363
|
+
}
|
|
364
|
+
});
|
|
365
|
+
Object.defineProperty(exports, "getNunjucksEngine", {
|
|
366
|
+
enumerable: true,
|
|
367
|
+
get: function() {
|
|
368
|
+
return getNunjucksEngine;
|
|
369
|
+
}
|
|
370
|
+
});
|
|
371
|
+
Object.defineProperty(exports, "renderEnvOnlyInObject", {
|
|
372
|
+
enumerable: true,
|
|
373
|
+
get: function() {
|
|
374
|
+
return renderEnvOnlyInObject;
|
|
375
|
+
}
|
|
376
|
+
});
|
|
377
|
+
Object.defineProperty(exports, "renderVarsInObject", {
|
|
378
|
+
enumerable: true,
|
|
379
|
+
get: function() {
|
|
380
|
+
return renderVarsInObject;
|
|
381
|
+
}
|
|
382
|
+
});
|
|
383
|
+
|
|
384
|
+
//# sourceMappingURL=render-BNTrbmBw.cjs.map
|