promptfoo 0.120.27 → 0.121.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/src/{ListApp-8WOe2nT6.js → ListApp-Du7YVwj5.js} +2 -4
- package/dist/src/accounts-BgNJDBE6.js +206 -0
- package/dist/src/{accounts-Fl2J3_Fu.cjs → accounts-Bx-x3bmW.cjs} +77 -78
- package/dist/src/{accounts-DVINui-2.js → accounts-CMqkzrVf.js} +39 -34
- package/dist/src/{accounts-CPDRAMND.js → accounts-xrUGFA6n.js} +38 -33
- package/dist/src/{agentic-utils-D922n6mm.js → agentic-utils-BKIN5PKu.js} +9 -10
- package/dist/src/{agents-BO2n8Z0d.cjs → agents-B0f4HICh.cjs} +37 -40
- package/dist/src/{agents-BXLmVsxR.js → agents-C-dDThPK.js} +37 -37
- package/dist/src/{agents-DgJf2-ez.cjs → agents-CErsqg5U.cjs} +16 -17
- package/dist/src/{agents-BcsN_BgB.js → agents-CVIn-Utx.js} +16 -12
- package/dist/src/{agents-hqgSV-3o.js → agents-CXknwsFX.js} +37 -40
- package/dist/src/{agents-pMfppv9Z.js → agents-DeH4Gu94.js} +18 -18
- package/dist/src/{agents-BdUTAwi-.js → agents-Dy2YpZpa.js} +38 -41
- package/dist/src/{agents-DNvSH78i.js → agents-aF4-T121.js} +16 -20
- package/dist/src/{aimlapi-DOib86oE.js → aimlapi-BAGZDo5G.js} +16 -18
- package/dist/src/{aimlapi-DtgPI0nE.js → aimlapi-BNfTBexL.js} +15 -17
- package/dist/src/{aimlapi-DTPACCB1.js → aimlapi-DHRKlBEA.js} +15 -4
- package/dist/src/{aimlapi-BE_Tg9Fl.cjs → aimlapi-tg0Gkcvr.cjs} +15 -16
- package/dist/src/app/assets/index-BFCZg7hQ.js +439 -0
- package/dist/src/app/index.html +1 -1
- package/dist/src/{audio-BRYU0BFo.js → audio-BRODU0UK.js} +7 -9
- package/dist/src/{audio-Cwo68yZS.cjs → audio-BWeaWovU.cjs} +6 -7
- package/dist/src/{audio-BnRUGAm_.js → audio-CHQ4r-RV.js} +6 -5
- package/dist/src/{audio-MSRki4JU.js → audio-tf_NBjlC.js} +6 -8
- package/dist/src/{base-h961VXYk.js → base-B0tcrnq_.js} +11 -13
- package/dist/src/{base-XB2tDJrB.js → base-B4QJRyFS.js} +11 -13
- package/dist/src/{base-pGVmXNl4.cjs → base-DBtwl2FR.cjs} +36 -38
- package/dist/src/base-fEDN28WM.js +193 -0
- package/dist/src/{blobs-BM_e6hCa.js → blobs-BAU-dXan.js} +9 -12
- package/dist/src/{blobs-CR5C4Ihh.js → blobs-Bpg5rH6i.js} +9 -12
- package/dist/src/{blobs-B-KQAFhX.cjs → blobs-DvS-O6be.cjs} +34 -37
- package/dist/src/blobs-qTYm-1PY.js +236 -0
- package/dist/src/{cache-CIpsoBZR.js → cache-8XhNqPKW.js} +64 -67
- package/dist/src/cache-Bbn1Nyrd.cjs +5 -0
- package/dist/src/cache-BwsMSda7.js +6 -0
- package/dist/src/{cache-jsiwsAJv.js → cache-CG0SlR1d.js} +64 -66
- package/dist/src/{cache-BTVYfbka.cjs → cache-COish3-W.cjs} +114 -117
- package/dist/src/cache-D3eqDYGU.js +739 -0
- package/dist/src/{chat-D31K7C4u.cjs → chat-2K608PeQ.cjs} +20 -21
- package/dist/src/chat-BKm79wib.js +764 -0
- package/dist/src/{chat-B84t99NW.js → chat-CM_kyI8B.js} +20 -9
- package/dist/src/{chat-BcPjZXIp.js → chat-CRWNNq73.js} +41 -44
- package/dist/src/{chat-CcUCysjU.js → chat-CznLWr_D.js} +41 -44
- package/dist/src/{chat-DwWifjxi.js → chat-DHMH-N64.js} +20 -22
- package/dist/src/{chat-BE44YOc6.cjs → chat-DaqekjFr.cjs} +61 -64
- package/dist/src/{chat-DZM2GUHO.js → chat-DxysjBvt.js} +21 -23
- package/dist/src/{chatkit-D67HS_0b.js → chatkit-65VXf5SR.js} +58 -58
- package/dist/src/{chatkit-DAB_qfzI.js → chatkit-Be-Q-a9F.js} +58 -60
- package/dist/src/{chatkit-Biqb_wsD.js → chatkit-BxFvW8KY.js} +58 -60
- package/dist/src/{chatkit-PGG4ZYIn.cjs → chatkit-DKyPi1Gs.cjs} +58 -60
- package/dist/src/chunk-DEq-mXcV.js +15 -0
- package/dist/src/chunk-DRamLcfz.js +16 -0
- package/dist/src/{claude-agent-sdk-SVM6AdBu.js → claude-agent-sdk-BLTu0WBO.js} +31 -31
- package/dist/src/{claude-agent-sdk-C9SiaQub.cjs → claude-agent-sdk-CJH22shf.cjs} +31 -28
- package/dist/src/{claude-agent-sdk-C-IOTPfo.js → claude-agent-sdk-D6_k9FKA.js} +31 -29
- package/dist/src/{claude-agent-sdk-CiluSyW1.js → claude-agent-sdk-Dy5lT-Tx.js} +33 -20
- package/dist/src/{cloud-CZ-q9Ier.js → cloud-Bc9526yV.js} +7 -9
- package/dist/src/cloud-DmE0EwsY.js +4 -0
- package/dist/src/{cloudflare-ai-BahKHyhh.js → cloudflare-ai-C9r2sRhw.js} +16 -18
- package/dist/src/{cloudflare-ai-Dxyt50Nl.js → cloudflare-ai-CWWJCRim.js} +16 -4
- package/dist/src/{cloudflare-ai-Dfahv5SY.cjs → cloudflare-ai-ClWSdor4.cjs} +16 -17
- package/dist/src/{cloudflare-ai-v_qZD6_q.js → cloudflare-ai-ICsOuD-z.js} +17 -19
- package/dist/src/{cloudflare-gateway-BPWoZIzJ.cjs → cloudflare-gateway-C2_-KG5o.cjs} +21 -22
- package/dist/src/{cloudflare-gateway-Bi_FpOFy.js → cloudflare-gateway-D6O7AlYb.js} +23 -23
- package/dist/src/{cloudflare-gateway-btS7h1OZ.js → cloudflare-gateway-D6xFc5pa.js} +21 -25
- package/dist/src/{cloudflare-gateway-C0guUNwk.js → cloudflare-gateway-pXGHxJ47.js} +26 -14
- package/dist/src/{codex-sdk-DSxAnbfT.js → codex-sdk-C6UMlxwV.js} +28 -29
- package/dist/src/{codex-sdk-IYVi9fuM.js → codex-sdk-DUwKWezN.js} +28 -27
- package/dist/src/{codex-sdk-DulY0ZRq.js → codex-sdk-GGAw0qbD.js} +28 -29
- package/dist/src/{codex-sdk-DFKMtAyf.cjs → codex-sdk-fAO0c3yA.cjs} +28 -29
- package/dist/src/{cometapi-DkNBMk0G.js → cometapi-BasUi7-_.js} +17 -19
- package/dist/src/{cometapi-DzrR3SR_.js → cometapi-Bbjp5V4x.js} +16 -4
- package/dist/src/{cometapi-C9EEpJzT.js → cometapi-DkXrKi5z.js} +21 -24
- package/dist/src/{cometapi-DIO64tf4.cjs → cometapi-vY6aDZgo.cjs} +21 -22
- package/dist/src/{completion-CG29bfKX.js → completion-6Mx_iXxK.js} +11 -13
- package/dist/src/{completion-Bgf1VJoq.js → completion-C5rtR_9P.js} +11 -13
- package/dist/src/{completion-CCRT4kX1.cjs → completion-CDOouNzq.cjs} +21 -23
- package/dist/src/completion-C_P3ypkJ.js +120 -0
- package/dist/src/{createHash-Dw_iLu31.js → createHash-CTQmL3G2.js} +2 -3
- package/dist/src/{createHash-CYQy4YeL.cjs → createHash-CfZSc0b4.cjs} +13 -14
- package/dist/src/{createHash-CJcfskIZ.js → createHash-Da8fMwqB.js} +2 -3
- package/dist/src/createHash-DmPQkvBh.js +15 -0
- package/dist/src/{docker-D-ayp2FW.js → docker-5KcG-_86.js} +18 -20
- package/dist/src/{docker-DNcLR4Ig.cjs → docker-BwsKwxFs.cjs} +18 -19
- package/dist/src/{docker-egERKxCF.js → docker-CZnqU1XV.js} +18 -7
- package/dist/src/{docker-B81N0t4e.js → docker-DzxyDPIj.js} +19 -21
- package/dist/src/entrypoint.js +2 -3
- package/dist/src/{errors-DnGCbnx8.js → errors-P6ll7XSJ.js} +2 -2
- package/dist/src/{esm-B9dPm_BF.js → esm-C03C-mv3.js} +17 -20
- package/dist/src/{esm-D2pZ87fL.js → esm-CaIwzWR5.js} +18 -21
- package/dist/src/esm-Cd1AjG1D.js +379 -0
- package/dist/src/{esm-Ct-Joyue.cjs → esm-CnNt7sI4.cjs} +47 -49
- package/dist/src/eval-17JizQIv.js +15 -0
- package/dist/src/{eval-C-Nr6wX_.js → eval-DmFyWU7i.js} +47 -54
- package/dist/src/{evalResult-4BzI2tmj.js → evalResult-CDQiuUuf.js} +16 -12
- package/dist/src/{evalResult-DXMWJ3sx.js → evalResult-CTG2AHOS.js} +10 -11
- package/dist/src/evalResult-Cqj8pldJ.js +12 -0
- package/dist/src/{evalResult-CX8wQecI.cjs → evalResult-Dap2CekP.cjs} +20 -21
- package/dist/src/evalResult-DvcJAWJU.cjs +10 -0
- package/dist/src/evalResult-Hftn-S_i.js +10 -0
- package/dist/src/evaluator-B2CFNt-P.js +36 -0
- package/dist/src/{evaluator-8aGyV12L.js → evaluator-DPFRbFIL.js} +201 -229
- package/dist/src/{extractor-CD5yKL-G.js → extractor-CFG6bcWJ.js} +22 -24
- package/dist/src/{extractor-C031XmTA.cjs → extractor-DX36oYEv.cjs} +37 -39
- package/dist/src/{extractor-V5x_m1i0.js → extractor-M67RUtg6.js} +22 -24
- package/dist/src/extractor-YMU_Gvt8.js +374 -0
- package/dist/src/{fetch-D3OHf-lV.js → fetch-4M3YRaqL.js} +40 -45
- package/dist/src/fetch-60Gzydls.js +777 -0
- package/dist/src/{fetch-CXZI9RRr.js → fetch-BMv0O527.js} +23 -35
- package/dist/src/{fetch-BmbD-v1L.cjs → fetch-BxUk8odA.cjs} +244 -277
- package/dist/src/fetch-KV5kNASw.js +5 -0
- package/dist/src/{fileExtensions-ePDqouxn.js → fileExtensions-DnqA1y9x.js} +2 -2
- package/dist/src/{fileExtensions-BpuMmaFL.js → fileExtensions-Ds-foDzt.js} +2 -2
- package/dist/src/fileExtensions-LcDYkU4v.js +85 -0
- package/dist/src/{fileExtensions-DkJYkWUy.cjs → fileExtensions-bYh77CN8.cjs} +27 -28
- package/dist/src/{formatDuration-CdevI3An.js → formatDuration-DgBVMN65.js} +2 -2
- package/dist/src/{genaiTracer-Ce19n68P.js → genaiTracer-70Z8BIuV.js} +2 -3
- package/dist/src/{genaiTracer-CqNnnXrE.js → genaiTracer-C1rxGO8Q.js} +2 -3
- package/dist/src/genaiTracer-D3fD9dNV.js +256 -0
- package/dist/src/{genaiTracer-Dres3qrN.cjs → genaiTracer-DN4dQywX.cjs} +13 -14
- package/dist/src/graders-Bu0H9nXi.js +32 -0
- package/dist/src/{graders-DTeBrzWp.js → graders-CHO8EPM4.js} +349 -397
- package/dist/src/graders-Cfhkvx-e.js +34 -0
- package/dist/src/{graders--1y2u9HO.js → graders-CpdqD9PI.js} +349 -397
- package/dist/src/graders-DClJVpGP.cjs +32 -0
- package/dist/src/{graders-DohM2dir.cjs → graders-DOXycdlG.cjs} +684 -732
- package/dist/src/graders-DcnJsrMO.js +32 -0
- package/dist/src/graders-R9rYUM0d.js +13466 -0
- package/dist/src/{image-C3wHC9_h.js → image-BmEZqVmk.js} +9 -10
- package/dist/src/{image-O1u4bCFg.js → image-CBBVXWuT.js} +9 -10
- package/dist/src/{image-DpKl2F15.cjs → image-CDLQOcqT.cjs} +6 -7
- package/dist/src/{image-DmE-niFE.js → image-DJEvKveK.js} +6 -5
- package/dist/src/{image-CuKHuccK.cjs → image-DTedmQPg.cjs} +29 -30
- package/dist/src/{image-B0U4Hqll.js → image-gvmivTEe.js} +7 -9
- package/dist/src/image-pAX56tPG.js +257 -0
- package/dist/src/{image-DNEIf_aI.js → image-tL5hIOFh.js} +6 -8
- package/dist/src/index.cjs +605 -689
- package/dist/src/index.d.cts +11 -7
- package/dist/src/index.d.ts +11 -3
- package/dist/src/index.js +570 -658
- package/dist/src/{interactiveCheck-Bxj1Swex.js → interactiveCheck-BgLZUIt3.js} +7 -8
- package/dist/src/{invariant-DT20jrBd.js → invariant-BtWWVVhl.js} +2 -2
- package/dist/src/{invariant-1pAf2CD1.js → invariant-Ddh24eXh.js} +2 -2
- package/dist/src/{invariant-CKcJAQ6M.cjs → invariant-kfQ8Bu82.cjs} +7 -8
- package/dist/src/invariant-vgHWClmd.js +25 -0
- package/dist/src/{knowledgeBase-Be_zyW4L.js → knowledgeBase-CLJybhnF.js} +16 -16
- package/dist/src/{knowledgeBase-CEzQobWX.js → knowledgeBase-CoU-UQBg.js} +14 -9
- package/dist/src/{knowledgeBase-BZ41IFwq.js → knowledgeBase-DjWPVqSb.js} +14 -18
- package/dist/src/{knowledgeBase-D-5BMXlr.cjs → knowledgeBase-wkxuRFhA.cjs} +14 -15
- package/dist/src/{litellm-DnbRJ2if.js → litellm-B9Hysuri.js} +16 -18
- package/dist/src/{litellm-CRDqPhNI.js → litellm-CTfa0hqi.js} +15 -17
- package/dist/src/{litellm-hUSNM_M2.cjs → litellm-NYpQ8RQu.cjs} +15 -16
- package/dist/src/{litellm-9vR8zpfU.js → litellm-ePxtr9F1.js} +15 -4
- package/dist/src/{logger-CG1uZPbQ.js → logger-CT3IKMKA.js} +10 -29
- package/dist/src/{logger-B7sBeGa0.cjs → logger-Cp1GPUjj.cjs} +152 -180
- package/dist/src/logger-DLcq4dWf.js +713 -0
- package/dist/src/{logger-LSBxlt7a.js → logger-KkObSCzq.js} +13 -31
- package/dist/src/{luma-ray-Hm3d6VJE.cjs → luma-ray-B0GGNRc1.cjs} +20 -21
- package/dist/src/{luma-ray-drvgdpP9.js → luma-ray-BE2mOt6N.js} +20 -13
- package/dist/src/{luma-ray-4blv9iZ2.js → luma-ray-BW9IRGIc.js} +22 -21
- package/dist/src/{luma-ray-B2__8lYH.js → luma-ray-Cm1KZBhs.js} +20 -23
- package/dist/src/main.js +1170 -1321
- package/dist/src/{messages-XhiwCbi4.cjs → messages-1JrJs91T.cjs} +32 -34
- package/dist/src/{messages-CGPPidQr.js → messages-1x9atZmP.js} +22 -24
- package/dist/src/{messages-Uee41Mj5.js → messages-BLbWdsyt.js} +22 -24
- package/dist/src/messages-D8EA0oDc.js +240 -0
- package/dist/src/{meteor-BYykdXrV.js → meteor-44VjEACX.js} +3 -4
- package/dist/src/{meteor-CsopaHrH.js → meteor-D-SotUw9.js} +3 -4
- package/dist/src/{meteor-e-E-2vVl.cjs → meteor-DLZZ3osF.cjs} +3 -4
- package/dist/src/{meteor-C8lGP6P4.js → meteor-DUiCJRC-.js} +3 -4
- package/dist/src/{modelslab-yKz-ZNB4.js → modelslab-C1OLRmVX.js} +17 -10
- package/dist/src/{modelslab-E9gO-bYd.js → modelslab-CqXBy3U8.js} +18 -20
- package/dist/src/{modelslab-lUVW0cmB.cjs → modelslab-DcOSFwKh.cjs} +17 -18
- package/dist/src/{modelslab-ClBkr8_9.js → modelslab-X5-4LroM.js} +17 -19
- package/dist/src/{nova-reel-Dk8jNpId.js → nova-reel-BgS1ZWuK.js} +20 -13
- package/dist/src/{nova-reel-u2eF2Cxm.js → nova-reel-D2ZkOSyr.js} +22 -21
- package/dist/src/{nova-reel-D8CuO6QH.cjs → nova-reel-D9xfaMBs.cjs} +20 -21
- package/dist/src/{nova-reel-P9bwvtYX.js → nova-reel-DihqLeol.js} +20 -23
- package/dist/src/{nova-sonic-Ds1C-dpm.cjs → nova-sonic-DVu3mMIy.cjs} +30 -31
- package/dist/src/{nova-sonic-CK2rAiKi.js → nova-sonic-DezhVUYT.js} +30 -26
- package/dist/src/{nova-sonic-BaqWlkds.js → nova-sonic-P-CdUMlV.js} +30 -31
- package/dist/src/{nova-sonic-yZapPLv7.js → nova-sonic-Q3BOJeig.js} +31 -32
- package/dist/src/{openai-DUFopMrH.cjs → openai-Cuif0GEt.cjs} +8 -9
- package/dist/src/{openai-PblZ3jUE.js → openai-DElQ-fPX.js} +3 -4
- package/dist/src/{openai-CcN1B8Sb.js → openai-DhbB7eWK.js} +3 -4
- package/dist/src/openai-j-sE2O7r.js +44 -0
- package/dist/src/{openclaw-A-3_loM7.js → openclaw-BiSZPL7J.js} +20 -14
- package/dist/src/{openclaw-COn6QzDi.js → openclaw-Bv1DINsX.js} +20 -27
- package/dist/src/{openclaw-a3lylB-V.js → openclaw-D1D_ej1z.js} +21 -28
- package/dist/src/{openclaw-B6qqDr_u.cjs → openclaw-DAfWQn-o.cjs} +33 -39
- package/dist/src/opencode-sdk-C7m-wRfI.js +560 -0
- package/dist/src/opencode-sdk-CfaLN8PY.cjs +564 -0
- package/dist/src/opencode-sdk-D95s6SnR.js +562 -0
- package/dist/src/opencode-sdk-DxUPkLT7.js +560 -0
- package/dist/src/{otlpReceiver-oyf5wLGC.js → otlpReceiver--AIRW_S4.js} +53 -51
- package/dist/src/{otlpReceiver-BmmTiMjA.js → otlpReceiver-Bn5wGB1v.js} +53 -55
- package/dist/src/{otlpReceiver-lXsYVbpj.cjs → otlpReceiver-Diec4cln.cjs} +53 -55
- package/dist/src/{otlpReceiver-94URx7UW.js → otlpReceiver-g3ByGaXs.js} +53 -55
- package/dist/src/{providerRegistry-Cq_JK_CJ.js → providerRegistry-B0RUOLI_.js} +7 -8
- package/dist/src/{providerRegistry-DSSHjMKf.js → providerRegistry-CD8MEar9.js} +7 -8
- package/dist/src/{providerRegistry-CvHEVJad.cjs → providerRegistry-Civky8Ar.cjs} +12 -13
- package/dist/src/providerRegistry-DM8rZYol.js +45 -0
- package/dist/src/providers-B3HvufyI.js +33246 -0
- package/dist/src/{providers-BnFpbY_s.js → providers-BKRJTjBz.js} +1536 -1669
- package/dist/src/providers-C1rOSHiR.js +32 -0
- package/dist/src/{providers-Iil64vk9.js → providers-CFLy1_ji.js} +1543 -1676
- package/dist/src/{providers-DHbjzW2e.cjs → providers-CFu-TZl-.cjs} +1896 -2029
- package/dist/src/providers-CxmDwEFf.cjs +31 -0
- package/dist/src/providers-Dodakqr0.js +30 -0
- package/dist/src/providers-GIQ2TcsA.js +30 -0
- package/dist/src/{pythonUtils-CcT5LH1M.js → pythonUtils-C3py6GC1.js} +18 -19
- package/dist/src/{pythonUtils-DBbuI3QJ.cjs → pythonUtils-CTU3Y3lw.cjs} +42 -43
- package/dist/src/{pythonUtils-hZ8LeQLv.js → pythonUtils-D5nxkQ0P.js} +18 -19
- package/dist/src/pythonUtils-D6fwaDSg.js +249 -0
- package/dist/src/{quiverai-BuI0tE39.js → quiverai-C2jVwbH1.js} +8 -7
- package/dist/src/{quiverai-DCGSZt4U.js → quiverai-CI6gYJVI.js} +8 -10
- package/dist/src/{quiverai-DiMVJQDz.cjs → quiverai-CLkWkyZc.cjs} +8 -9
- package/dist/src/{quiverai-fQNkExW4.js → quiverai-MHSxbmmZ.js} +9 -11
- package/dist/src/{render-Dj1smHEb.js → render-Drod8m7K.js} +4 -5
- package/dist/src/{responses-DOAFFENS.js → responses-BKqJmhhc.js} +22 -25
- package/dist/src/{responses-CxzoQoBe.js → responses-CGw0DCzh.js} +22 -25
- package/dist/src/responses-jxdehPkC.js +660 -0
- package/dist/src/{responses-ghR3IOfy.cjs → responses-tD4Bd4dc.cjs} +37 -40
- package/dist/src/rubyUtils-BUHu6PhO.js +5 -0
- package/dist/src/{rubyUtils-CwbGmgYN.js → rubyUtils-BUVePouc.js} +27 -20
- package/dist/src/rubyUtils-BcuGX77l.js +222 -0
- package/dist/src/{rubyUtils-DudlFZed.js → rubyUtils-Boc4HZzX.js} +18 -19
- package/dist/src/rubyUtils-CP42kMvq.cjs +4 -0
- package/dist/src/{rubyUtils-C8MhKGHb.cjs → rubyUtils-DhCAlxZr.cjs} +48 -50
- package/dist/src/{sagemaker-gmskuyre.js → sagemaker-BK4Zb993.js} +75 -70
- package/dist/src/{sagemaker-DuM71dVU.js → sagemaker-BfiWTmvn.js} +77 -77
- package/dist/src/{sagemaker-77zbJ2Q2.cjs → sagemaker-CcQHM1jV.cjs} +75 -76
- package/dist/src/{sagemaker-CcxhlOAR.js → sagemaker-D2Q1c-sD.js} +75 -79
- package/dist/src/{scanner-DJYiSXQj.js → scanner-J8CA3LsV.js} +100 -121
- package/dist/src/server/index.js +5505 -67416
- package/dist/src/{server-B5v33lvE.cjs → server-B0PPuDw-.cjs} +57 -67
- package/dist/src/server-B1vi21hA.js +7 -0
- package/dist/src/{server-RV_i_YX5.js → server-BC7XJFgr.js} +19 -24
- package/dist/src/server-Cm9Kai_h.cjs +5 -0
- package/dist/src/{server-BJ4m4f1D.js → server-DbFphssR.js} +26 -29
- package/dist/src/server-OAs3nBRT.js +229 -0
- package/dist/src/{signal-BW33JuId.js → signal-BOTbd53Z.js} +9 -11
- package/dist/src/{slack-DEURelTy.cjs → slack-BmVAVGaK.cjs} +7 -8
- package/dist/src/{slack-BQYeW9L3.js → slack-DCUPTzS2.js} +8 -8
- package/dist/src/{slack-BB6yuZzp.js → slack-DOdy_kyv.js} +7 -8
- package/dist/src/{slack-2pRrhhgJ.js → slack-DXMKtA-f.js} +7 -9
- package/dist/src/store-BNmZ1KAz.cjs +5 -0
- package/dist/src/{store-D7CgQzAR.cjs → store-BSc-TF2w.cjs} +44 -45
- package/dist/src/store-BltJg2cd.js +6 -0
- package/dist/src/{store-s3SftUwF.js → store-D1tv90v3.js} +34 -35
- package/dist/src/{store-DJNsD1iC.js → store-DQLEjuEO.js} +40 -36
- package/dist/src/store-Ub2vaGJ1.js +228 -0
- package/dist/src/{tables-DfTsNN7X.js → tables-5EvT_Bwn.js} +19 -21
- package/dist/src/{tables-BKTmd6u7.cjs → tables-C7K-XKWp.cjs} +89 -91
- package/dist/src/{tables-DMegD0Xf.js → tables-D36WTqKX.js} +21 -23
- package/dist/src/tables-xKANLRBD.js +288 -0
- package/dist/src/telemetry-5BCRNBbe.cjs +5 -0
- package/dist/src/{telemetry-BedSm-bZ.js → telemetry-C15ziL8u.js} +17 -14
- package/dist/src/{telemetry--WAdAfVi.js → telemetry-C2YDkUQH.js} +11 -13
- package/dist/src/{telemetry-DQgVBCAb.cjs → telemetry-CbrnxHp_.cjs} +21 -24
- package/dist/src/telemetry-D4W5hboe.js +7 -0
- package/dist/src/telemetry-DMb2Mpfm.js +171 -0
- package/dist/src/{text-oiSbwSOI.js → text-B_UCRPp2.js} +2 -2
- package/dist/src/{text-oKzCBnK6.cjs → text-CW1cyrwj.cjs} +12 -13
- package/dist/src/{text-B_IrO4GZ.js → text-Db-Wt2u2.js} +2 -2
- package/dist/src/text-TIv0QYnd.js +22 -0
- package/dist/src/{tokenUsageUtils-FZd5O_4A.js → tokenUsageUtils-BDGe-iyI.js} +2 -2
- package/dist/src/{tokenUsageUtils-DmZSD2eU.js → tokenUsageUtils-DflFMjS0.js} +2 -2
- package/dist/src/tokenUsageUtils-NYT-WKS6.js +138 -0
- package/dist/src/{tokenUsageUtils-CXhxVj72.cjs → tokenUsageUtils-bVa1ga6f.cjs} +32 -33
- package/dist/src/{transcription-BO1AHegO.cjs → transcription-CL78qbOU.cjs} +14 -15
- package/dist/src/{transcription-mYS9vd5v.js → transcription-DAtxHhAM.js} +14 -7
- package/dist/src/{transcription-X2-B4vkX.js → transcription-LNZTNUUL.js} +14 -16
- package/dist/src/{transcription-lzBLiTFJ.js → transcription-QHh3AH6Z.js} +15 -17
- package/dist/src/{transform-DeGlxb0D.js → transform-Cgi24fJ7.js} +39 -47
- package/dist/src/{transform-B1Hi5lWS.cjs → transform-CzK1Q0zl.cjs} +24 -26
- package/dist/src/{transform-CYDILYDe.js → transform-DECvGmzp.js} +15 -13
- package/dist/src/{transform-Dfl89yi4.js → transform-DGLazrMm.js} +39 -47
- package/dist/src/transform-DGxXocjk.js +1506 -0
- package/dist/src/{transform-D5PjiWiZ.cjs → transform-DOcQeLld.cjs} +179 -187
- package/dist/src/transform-DTGDnAzW.js +6 -0
- package/dist/src/{transform-BEgStbHK.js → transform-DilY9wbS.js} +10 -12
- package/dist/src/transform-aa6tmVpZ.js +216 -0
- package/dist/src/transform-m3qNw4KP.cjs +5 -0
- package/dist/src/{transformersAvailability-SZnTS3pJ.js → transformersAvailability-CEVM2GNQ.js} +2 -2
- package/dist/src/{transformersAvailability-D-glmEy7.cjs → transformersAvailability-CwayUSlh.cjs} +2 -3
- package/dist/src/{transformersAvailability-CjeFXhuJ.js → transformersAvailability-D6c6ROpT.js} +2 -2
- package/dist/src/{types-CXQduE9o.js → types-CH3Ge2sE.js} +30 -90
- package/dist/src/{types-C5hEkb-x.js → types-CLKiCBW3.js} +25 -89
- package/dist/src/types-CN_TZ2GJ.js +3260 -0
- package/dist/src/{types-DWNf48sT.cjs → types-LJ0r3wbR.cjs} +500 -564
- package/dist/src/util-5cB-L7U3.js +1430 -0
- package/dist/src/util-6-GqIvzS.js +599 -0
- package/dist/src/{util-CoQjmE3u.js → util-B7T3SiBS.js} +4 -5
- package/dist/src/{util-D9eLdGfa.js → util-Betm42rL.js} +5 -6
- package/dist/src/{util-Bm_-UMD_.js → util-C-PPYSMq.js} +5 -6
- package/dist/src/{util-CyUdMzV0.cjs → util-CchiqXh_.cjs} +34 -35
- package/dist/src/{util-Du96oyYS.js → util-DaWTWKBK.js} +4 -5
- package/dist/src/{util-1wWM599Z.cjs → util-Db0a0AFH.cjs} +50 -51
- package/dist/src/{util-DQ984syk.js → util-Dlz_Wvgm.js} +37 -48
- package/dist/src/{util-_h4pVqrz.js → util-YT5HPZaS.js} +37 -48
- package/dist/src/{util-aLhtl3fe.cjs → util-Yz-1aEhW.cjs} +209 -220
- package/dist/src/util-ZZH-3QZz.js +293 -0
- package/dist/src/{utils-BjLy-Q72.cjs → utils-Cz9qXqII.cjs} +29 -32
- package/dist/src/{utils-CFMn2yHW.js → utils-XiOAgly5.js} +4 -7
- package/dist/src/utils-dLokC-eR.js +94 -0
- package/dist/src/{utils-DvWMzuMx.js → utils-f2-Moju7.js} +4 -7
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +30 -30
- package/dist/src/app/assets/index-B2D0bCSI.js +0 -439
- package/dist/src/app/tsconfig.app.tsbuildinfo +0 -1
- package/dist/src/cache-ChPcurj7.js +0 -6
- package/dist/src/cache-VVu_W-yg.js +0 -8
- package/dist/src/cache-YLNCFEM2.cjs +0 -6
- package/dist/src/chunk-DHDDz29n.js +0 -22
- package/dist/src/chunk-FhC4c-0y.js +0 -21
- package/dist/src/cloud-BndfXy4H.js +0 -5
- package/dist/src/eval-BhHvMY82.js +0 -17
- package/dist/src/evalResult-Dq2gFNQY.js +0 -12
- package/dist/src/evalResult-nmcP5VKH.cjs +0 -12
- package/dist/src/evalResult-trqZjVYh.js +0 -14
- package/dist/src/evaluator-CnfPstzT.js +0 -39
- package/dist/src/fetch-IDPDue6F.cjs +0 -4
- package/dist/src/fetch-hKJ-It8q.js +0 -6
- package/dist/src/fetch-ouKnrWK-.js +0 -4
- package/dist/src/graders-CQn7WUsd.cjs +0 -34
- package/dist/src/graders-DC6QAbpW.js +0 -35
- package/dist/src/graders-DUWz3Y7j.js +0 -37
- package/dist/src/opencode-sdk-4bL9n-Gk.js +0 -382
- package/dist/src/opencode-sdk-BfC2zWcR.js +0 -376
- package/dist/src/opencode-sdk-DMJyuwMg.js +0 -380
- package/dist/src/opencode-sdk-Da-9adza.cjs +0 -383
- package/dist/src/providers-CsXB2Ix-.js +0 -35
- package/dist/src/providers-DO8ltjLC.js +0 -33
- package/dist/src/providers-Dtq-xnXd.cjs +0 -33
- package/dist/src/rubyUtils-BUbcND2f.js +0 -6
- package/dist/src/rubyUtils-Cr55X_KE.js +0 -5
- package/dist/src/rubyUtils-DlIiqoYo.cjs +0 -5
- package/dist/src/server-C2eQH4Gu.js +0 -6
- package/dist/src/server-CXWycu7H.cjs +0 -6
- package/dist/src/server-Q6OGlxxT.js +0 -8
- package/dist/src/store-B3EDO9Q3.js +0 -7
- package/dist/src/store-Dl9F8aw5.js +0 -6
- package/dist/src/store-SnrGrlt9.cjs +0 -6
- package/dist/src/telemetry-BGhiPZtl.js +0 -8
- package/dist/src/telemetry-CFfiYan6.cjs +0 -6
- package/dist/src/telemetry-DHzEduxX.js +0 -6
- package/dist/src/transform-C1x1ZlMQ.cjs +0 -6
- package/dist/src/transform-DYHjFmQu.js +0 -8
- package/dist/src/transform-rmwJT5JQ.js +0 -7
- package/dist/src/transformersAvailability-eJooj0gX.js +0 -35
|
@@ -1,17 +1,16 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import { b as getEnvBool, o as
|
|
3
|
-
import { s as ResultFailureReason } from "./types-
|
|
2
|
+
import { b as getEnvBool, o as logger, v as getConfigDirectoryPath } from "./logger-KkObSCzq.js";
|
|
3
|
+
import { s as ResultFailureReason } from "./types-CH3Ge2sE.js";
|
|
4
4
|
import * as path$1 from "path";
|
|
5
5
|
import { relations, sql } from "drizzle-orm";
|
|
6
6
|
import Database from "better-sqlite3";
|
|
7
7
|
import { drizzle } from "drizzle-orm/better-sqlite3";
|
|
8
8
|
import { DefaultLogger } from "drizzle-orm/logger";
|
|
9
9
|
import { index, integer, primaryKey, real, sqliteTable, text, uniqueIndex } from "drizzle-orm/sqlite-core";
|
|
10
|
-
|
|
11
10
|
//#region src/database/index.ts
|
|
12
11
|
var DrizzleLogWriter = class {
|
|
13
12
|
write(message) {
|
|
14
|
-
if (getEnvBool("PROMPTFOO_ENABLE_DATABASE_LOGS", false))
|
|
13
|
+
if (getEnvBool("PROMPTFOO_ENABLE_DATABASE_LOGS", false)) logger.debug(`Drizzle: ${message}`);
|
|
15
14
|
}
|
|
16
15
|
};
|
|
17
16
|
let dbInstance = null;
|
|
@@ -30,12 +29,12 @@ function getDb() {
|
|
|
30
29
|
if (!isMemoryDb && !getEnvBool("PROMPTFOO_DISABLE_WAL_MODE", false)) try {
|
|
31
30
|
sqliteInstance.pragma("journal_mode = WAL");
|
|
32
31
|
const result = sqliteInstance.prepare("PRAGMA journal_mode").get();
|
|
33
|
-
if (result.journal_mode.toLowerCase() === "wal")
|
|
34
|
-
else
|
|
32
|
+
if (result.journal_mode.toLowerCase() === "wal") logger.debug("Successfully enabled SQLite WAL mode");
|
|
33
|
+
else logger.warn(`Failed to enable WAL mode (got '${result.journal_mode}'). Database performance may be reduced. This can happen on network filesystems. Set PROMPTFOO_DISABLE_WAL_MODE=true to suppress this warning.`);
|
|
35
34
|
sqliteInstance.pragma("wal_autocheckpoint = 1000");
|
|
36
35
|
sqliteInstance.pragma("synchronous = NORMAL");
|
|
37
36
|
} catch (err) {
|
|
38
|
-
|
|
37
|
+
logger.warn(`Error configuring SQLite WAL mode: ${err}. Database will use default journal mode. Performance may be reduced. This can happen on network filesystems or certain containerized environments. Set PROMPTFOO_DISABLE_WAL_MODE=true to suppress this warning.`);
|
|
39
38
|
}
|
|
40
39
|
const drizzleLogger = new DefaultLogger({ writer: new DrizzleLogWriter() });
|
|
41
40
|
dbInstance = drizzle(sqliteInstance, { logger: drizzleLogger });
|
|
@@ -46,14 +45,14 @@ function closeDb() {
|
|
|
46
45
|
if (sqliteInstance) try {
|
|
47
46
|
if (!getEnvBool("IS_TESTING") && !getEnvBool("PROMPTFOO_DISABLE_WAL_MODE", false)) try {
|
|
48
47
|
sqliteInstance.pragma("wal_checkpoint(TRUNCATE)");
|
|
49
|
-
|
|
48
|
+
logger.debug("Successfully checkpointed WAL file before closing");
|
|
50
49
|
} catch (err) {
|
|
51
|
-
|
|
50
|
+
logger.debug(`Could not checkpoint WAL file: ${err}`);
|
|
52
51
|
}
|
|
53
52
|
sqliteInstance.close();
|
|
54
|
-
|
|
53
|
+
logger.debug("Database connection closed successfully");
|
|
55
54
|
} catch (err) {
|
|
56
|
-
|
|
55
|
+
logger.error(`Error closing database connection: ${err}`);
|
|
57
56
|
} finally {
|
|
58
57
|
sqliteInstance = null;
|
|
59
58
|
dbInstance = null;
|
|
@@ -67,7 +66,6 @@ function closeDb() {
|
|
|
67
66
|
function closeDbIfOpen() {
|
|
68
67
|
if (sqliteInstance) closeDb();
|
|
69
68
|
}
|
|
70
|
-
|
|
71
69
|
//#endregion
|
|
72
70
|
//#region src/database/tables.ts
|
|
73
71
|
const promptsTable = sqliteTable("prompts", {
|
|
@@ -145,7 +143,7 @@ const evalsToPromptsTable = sqliteTable("evals_to_prompts", {
|
|
|
145
143
|
evalIdIdx: index("evals_to_prompts_eval_id_idx").on(t.evalId),
|
|
146
144
|
promptIdIdx: index("evals_to_prompts_prompt_id_idx").on(t.promptId)
|
|
147
145
|
}));
|
|
148
|
-
|
|
146
|
+
relations(promptsTable, ({ many }) => ({ evalsToPrompts: many(evalsToPromptsTable) }));
|
|
149
147
|
const evalsToTagsTable = sqliteTable("evals_to_tags", {
|
|
150
148
|
evalId: text("eval_id").notNull().references(() => evalsTable.id),
|
|
151
149
|
tagId: text("tag_id").notNull().references(() => tagsTable.id)
|
|
@@ -154,8 +152,8 @@ const evalsToTagsTable = sqliteTable("evals_to_tags", {
|
|
|
154
152
|
evalIdIdx: index("evals_to_tags_eval_id_idx").on(t.evalId),
|
|
155
153
|
tagIdIdx: index("evals_to_tags_tag_id_idx").on(t.tagId)
|
|
156
154
|
}));
|
|
157
|
-
|
|
158
|
-
|
|
155
|
+
relations(tagsTable, ({ many }) => ({ evalsToTags: many(evalsToTagsTable) }));
|
|
156
|
+
relations(evalsToTagsTable, ({ one }) => ({
|
|
159
157
|
eval: one(evalsTable, {
|
|
160
158
|
fields: [evalsToTagsTable.evalId],
|
|
161
159
|
references: [evalsTable.id]
|
|
@@ -203,13 +201,13 @@ const evalsToDatasetsTable = sqliteTable("evals_to_datasets", {
|
|
|
203
201
|
evalIdIdx: index("evals_to_datasets_eval_id_idx").on(t.evalId),
|
|
204
202
|
datasetIdIdx: index("evals_to_datasets_dataset_id_idx").on(t.datasetId)
|
|
205
203
|
}));
|
|
206
|
-
|
|
207
|
-
|
|
204
|
+
relations(datasetsTable, ({ many }) => ({ evalsToDatasets: many(evalsToDatasetsTable) }));
|
|
205
|
+
relations(evalsTable, ({ many }) => ({
|
|
208
206
|
evalsToPrompts: many(evalsToPromptsTable),
|
|
209
207
|
evalsToDatasets: many(evalsToDatasetsTable),
|
|
210
208
|
evalsToTags: many(evalsToTagsTable)
|
|
211
209
|
}));
|
|
212
|
-
|
|
210
|
+
relations(evalsToPromptsTable, ({ one }) => ({
|
|
213
211
|
eval: one(evalsTable, {
|
|
214
212
|
fields: [evalsToPromptsTable.evalId],
|
|
215
213
|
references: [evalsTable.id]
|
|
@@ -219,7 +217,7 @@ const evalsToPromptsRelations = relations(evalsToPromptsTable, ({ one }) => ({
|
|
|
219
217
|
references: [promptsTable.id]
|
|
220
218
|
})
|
|
221
219
|
}));
|
|
222
|
-
|
|
220
|
+
relations(evalsToDatasetsTable, ({ one }) => ({
|
|
223
221
|
eval: one(evalsTable, {
|
|
224
222
|
fields: [evalsToDatasetsTable.evalId],
|
|
225
223
|
references: [evalsTable.id]
|
|
@@ -299,18 +297,18 @@ const spansTable = sqliteTable("spans", {
|
|
|
299
297
|
traceIdIdx: index("spans_trace_id_idx").on(table.traceId),
|
|
300
298
|
spanIdIdx: index("spans_span_id_idx").on(table.spanId)
|
|
301
299
|
}));
|
|
302
|
-
|
|
300
|
+
relations(tracesTable, ({ one, many }) => ({
|
|
303
301
|
eval: one(evalsTable, {
|
|
304
302
|
fields: [tracesTable.evaluationId],
|
|
305
303
|
references: [evalsTable.id]
|
|
306
304
|
}),
|
|
307
305
|
spans: many(spansTable)
|
|
308
306
|
}));
|
|
309
|
-
|
|
307
|
+
relations(spansTable, ({ one }) => ({ trace: one(tracesTable, {
|
|
310
308
|
fields: [spansTable.traceId],
|
|
311
309
|
references: [tracesTable.traceId]
|
|
312
310
|
}) }));
|
|
313
|
-
|
|
314
311
|
//#endregion
|
|
315
312
|
export { getDbSignalPath as _, evalResultsTable as a, evalsToPromptsTable as c, promptsTable as d, spansTable as f, getDb as g, closeDbIfOpen as h, datasetsTable as i, evalsToTagsTable as l, tracesTable as m, blobReferencesTable as n, evalsTable as o, tagsTable as p, configsTable as r, evalsToDatasetsTable as s, blobAssetsTable as t, modelAuditsTable as u };
|
|
316
|
-
|
|
313
|
+
|
|
314
|
+
//# sourceMappingURL=tables-D36WTqKX.js.map
|
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
import { _ as getEnvBool, g as getConfigDirectoryPath, i as logger } from "./logger-DLcq4dWf.js";
|
|
2
|
+
import { s as ResultFailureReason } from "./types-CN_TZ2GJ.js";
|
|
3
|
+
import * as path$1 from "path";
|
|
4
|
+
import Database from "better-sqlite3";
|
|
5
|
+
import { drizzle } from "drizzle-orm/better-sqlite3";
|
|
6
|
+
import { DefaultLogger } from "drizzle-orm/logger";
|
|
7
|
+
import { relations, sql } from "drizzle-orm";
|
|
8
|
+
import { index, integer, primaryKey, real, sqliteTable, text, uniqueIndex } from "drizzle-orm/sqlite-core";
|
|
9
|
+
//#region src/database/index.ts
|
|
10
|
+
var DrizzleLogWriter = class {
|
|
11
|
+
write(message) {
|
|
12
|
+
if (getEnvBool("PROMPTFOO_ENABLE_DATABASE_LOGS", false)) logger.debug(`Drizzle: ${message}`);
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
let dbInstance = null;
|
|
16
|
+
let sqliteInstance = null;
|
|
17
|
+
function getDbPath() {
|
|
18
|
+
return path$1.resolve(getConfigDirectoryPath(true), "promptfoo.db");
|
|
19
|
+
}
|
|
20
|
+
function getDbSignalPath() {
|
|
21
|
+
return path$1.resolve(getConfigDirectoryPath(true), "evalLastWritten");
|
|
22
|
+
}
|
|
23
|
+
function getDb() {
|
|
24
|
+
if (!dbInstance) {
|
|
25
|
+
const isMemoryDb = getEnvBool("IS_TESTING");
|
|
26
|
+
sqliteInstance = new Database(isMemoryDb ? ":memory:" : getDbPath());
|
|
27
|
+
sqliteInstance.pragma("foreign_keys = ON");
|
|
28
|
+
if (!isMemoryDb && !getEnvBool("PROMPTFOO_DISABLE_WAL_MODE", false)) try {
|
|
29
|
+
sqliteInstance.pragma("journal_mode = WAL");
|
|
30
|
+
const result = sqliteInstance.prepare("PRAGMA journal_mode").get();
|
|
31
|
+
if (result.journal_mode.toLowerCase() === "wal") logger.debug("Successfully enabled SQLite WAL mode");
|
|
32
|
+
else logger.warn(`Failed to enable WAL mode (got '${result.journal_mode}'). Database performance may be reduced. This can happen on network filesystems. Set PROMPTFOO_DISABLE_WAL_MODE=true to suppress this warning.`);
|
|
33
|
+
sqliteInstance.pragma("wal_autocheckpoint = 1000");
|
|
34
|
+
sqliteInstance.pragma("synchronous = NORMAL");
|
|
35
|
+
} catch (err) {
|
|
36
|
+
logger.warn(`Error configuring SQLite WAL mode: ${err}. Database will use default journal mode. Performance may be reduced. This can happen on network filesystems or certain containerized environments. Set PROMPTFOO_DISABLE_WAL_MODE=true to suppress this warning.`);
|
|
37
|
+
}
|
|
38
|
+
const drizzleLogger = new DefaultLogger({ writer: new DrizzleLogWriter() });
|
|
39
|
+
dbInstance = drizzle(sqliteInstance, { logger: drizzleLogger });
|
|
40
|
+
}
|
|
41
|
+
return dbInstance;
|
|
42
|
+
}
|
|
43
|
+
//#endregion
|
|
44
|
+
//#region src/database/tables.ts
|
|
45
|
+
const promptsTable = sqliteTable("prompts", {
|
|
46
|
+
id: text("id").primaryKey(),
|
|
47
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
48
|
+
prompt: text("prompt").notNull()
|
|
49
|
+
}, (table) => ({ createdAtIdx: index("prompts_created_at_idx").on(table.createdAt) }));
|
|
50
|
+
const tagsTable = sqliteTable("tags", {
|
|
51
|
+
id: text("id").primaryKey(),
|
|
52
|
+
name: text("name").notNull(),
|
|
53
|
+
value: text("value").notNull()
|
|
54
|
+
}, (table) => ({
|
|
55
|
+
nameIdx: index("tags_name_idx").on(table.name),
|
|
56
|
+
uniqueNameValue: uniqueIndex("tags_name_value_unique").on(table.name, table.value)
|
|
57
|
+
}));
|
|
58
|
+
const evalsTable = sqliteTable("evals", {
|
|
59
|
+
id: text("id").primaryKey(),
|
|
60
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
61
|
+
author: text("author"),
|
|
62
|
+
description: text("description"),
|
|
63
|
+
results: text("results", { mode: "json" }).$type().notNull(),
|
|
64
|
+
config: text("config", { mode: "json" }).$type().notNull(),
|
|
65
|
+
prompts: text("prompts", { mode: "json" }).$type(),
|
|
66
|
+
vars: text("vars", { mode: "json" }).$type(),
|
|
67
|
+
runtimeOptions: text("runtime_options", { mode: "json" }).$type(),
|
|
68
|
+
isRedteam: integer("is_redteam", { mode: "boolean" }).notNull().default(false)
|
|
69
|
+
}, (table) => ({
|
|
70
|
+
createdAtIdx: index("evals_created_at_idx").on(table.createdAt),
|
|
71
|
+
authorIdx: index("evals_author_idx").on(table.author),
|
|
72
|
+
isRedteamIdx: index("evals_is_redteam_idx").on(table.isRedteam)
|
|
73
|
+
}));
|
|
74
|
+
const evalResultsTable = sqliteTable("eval_results", {
|
|
75
|
+
id: text("id").primaryKey(),
|
|
76
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
77
|
+
updatedAt: integer("updated_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
78
|
+
evalId: text("eval_id").notNull().references(() => evalsTable.id),
|
|
79
|
+
promptIdx: integer("prompt_idx").notNull(),
|
|
80
|
+
testIdx: integer("test_idx").notNull(),
|
|
81
|
+
testCase: text("test_case", { mode: "json" }).$type().notNull(),
|
|
82
|
+
prompt: text("prompt", { mode: "json" }).$type().notNull(),
|
|
83
|
+
promptId: text("prompt_id").references(() => promptsTable.id),
|
|
84
|
+
provider: text("provider", { mode: "json" }).$type().notNull(),
|
|
85
|
+
latencyMs: integer("latency_ms"),
|
|
86
|
+
cost: real("cost"),
|
|
87
|
+
response: text("response", { mode: "json" }).$type(),
|
|
88
|
+
error: text("error"),
|
|
89
|
+
failureReason: integer("failure_reason").default(ResultFailureReason.NONE).notNull(),
|
|
90
|
+
success: integer("success", { mode: "boolean" }).notNull(),
|
|
91
|
+
score: real("score").notNull(),
|
|
92
|
+
gradingResult: text("grading_result", { mode: "json" }).$type(),
|
|
93
|
+
namedScores: text("named_scores", { mode: "json" }).$type(),
|
|
94
|
+
metadata: text("metadata", { mode: "json" }).$type()
|
|
95
|
+
}, (table) => ({
|
|
96
|
+
evalIdIdx: index("eval_result_eval_id_idx").on(table.evalId),
|
|
97
|
+
testIdxIdx: index("eval_result_test_idx").on(table.testIdx),
|
|
98
|
+
evalTestIdx: index("eval_result_eval_test_idx").on(table.evalId, table.testIdx),
|
|
99
|
+
evalSuccessIdx: index("eval_result_eval_success_idx").on(table.evalId, table.success),
|
|
100
|
+
evalFailureIdx: index("eval_result_eval_failure_idx").on(table.evalId, table.failureReason),
|
|
101
|
+
evalTestSuccessIdx: index("eval_result_eval_test_success_idx").on(table.evalId, table.testIdx, table.success),
|
|
102
|
+
responseIdx: index("eval_result_response_idx").on(table.response),
|
|
103
|
+
gradingResultReasonIdx: index("eval_result_grading_result_reason_idx").on(sql`json_extract(${table.gradingResult}, '$.reason')`),
|
|
104
|
+
gradingResultCommentIdx: index("eval_result_grading_result_comment_idx").on(sql`json_extract(${table.gradingResult}, '$.comment')`),
|
|
105
|
+
testCaseVarsIdx: index("eval_result_test_case_vars_idx").on(sql`json_extract(${table.testCase}, '$.vars')`),
|
|
106
|
+
testCaseMetadataIdx: index("eval_result_test_case_metadata_idx").on(sql`json_extract(${table.metadata}, '$')`),
|
|
107
|
+
namedScoresIdx: index("eval_result_named_scores_idx").on(sql`json_extract(${table.namedScores}, '$')`),
|
|
108
|
+
metadataIdx: index("eval_result_metadata_idx").on(sql`json_extract(${table.metadata}, '$')`),
|
|
109
|
+
metadataPluginIdIdx: index("eval_result_metadata_plugin_id_idx").on(sql`json_extract(${table.metadata}, '$.pluginId')`),
|
|
110
|
+
metadataStrategyIdIdx: index("eval_result_metadata_strategy_id_idx").on(sql`json_extract(${table.metadata}, '$.strategyId')`)
|
|
111
|
+
}));
|
|
112
|
+
const evalsToPromptsTable = sqliteTable("evals_to_prompts", {
|
|
113
|
+
evalId: text("eval_id").notNull().references(() => evalsTable.id, { onDelete: "cascade" }),
|
|
114
|
+
promptId: text("prompt_id").notNull().references(() => promptsTable.id)
|
|
115
|
+
}, (t) => ({
|
|
116
|
+
pk: primaryKey({ columns: [t.evalId, t.promptId] }),
|
|
117
|
+
evalIdIdx: index("evals_to_prompts_eval_id_idx").on(t.evalId),
|
|
118
|
+
promptIdIdx: index("evals_to_prompts_prompt_id_idx").on(t.promptId)
|
|
119
|
+
}));
|
|
120
|
+
relations(promptsTable, ({ many }) => ({ evalsToPrompts: many(evalsToPromptsTable) }));
|
|
121
|
+
const evalsToTagsTable = sqliteTable("evals_to_tags", {
|
|
122
|
+
evalId: text("eval_id").notNull().references(() => evalsTable.id),
|
|
123
|
+
tagId: text("tag_id").notNull().references(() => tagsTable.id)
|
|
124
|
+
}, (t) => ({
|
|
125
|
+
pk: primaryKey({ columns: [t.evalId, t.tagId] }),
|
|
126
|
+
evalIdIdx: index("evals_to_tags_eval_id_idx").on(t.evalId),
|
|
127
|
+
tagIdIdx: index("evals_to_tags_tag_id_idx").on(t.tagId)
|
|
128
|
+
}));
|
|
129
|
+
relations(tagsTable, ({ many }) => ({ evalsToTags: many(evalsToTagsTable) }));
|
|
130
|
+
relations(evalsToTagsTable, ({ one }) => ({
|
|
131
|
+
eval: one(evalsTable, {
|
|
132
|
+
fields: [evalsToTagsTable.evalId],
|
|
133
|
+
references: [evalsTable.id]
|
|
134
|
+
}),
|
|
135
|
+
tag: one(tagsTable, {
|
|
136
|
+
fields: [evalsToTagsTable.tagId],
|
|
137
|
+
references: [tagsTable.id]
|
|
138
|
+
})
|
|
139
|
+
}));
|
|
140
|
+
const blobAssetsTable = sqliteTable("blob_assets", {
|
|
141
|
+
hash: text("hash").primaryKey(),
|
|
142
|
+
sizeBytes: integer("size_bytes").notNull(),
|
|
143
|
+
mimeType: text("mime_type").notNull(),
|
|
144
|
+
provider: text("provider").notNull(),
|
|
145
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`)
|
|
146
|
+
}, (table) => ({
|
|
147
|
+
providerIdx: index("blob_assets_provider_idx").on(table.provider),
|
|
148
|
+
createdAtIdx: index("blob_assets_created_at_idx").on(table.createdAt),
|
|
149
|
+
mimeTypeIdx: index("blob_assets_mime_type_idx").on(table.mimeType)
|
|
150
|
+
}));
|
|
151
|
+
const blobReferencesTable = sqliteTable("blob_references", {
|
|
152
|
+
id: text("id").primaryKey(),
|
|
153
|
+
blobHash: text("blob_hash").notNull().references(() => blobAssetsTable.hash, { onDelete: "cascade" }),
|
|
154
|
+
evalId: text("eval_id").notNull().references(() => evalsTable.id, { onDelete: "cascade" }),
|
|
155
|
+
testIdx: integer("test_idx"),
|
|
156
|
+
promptIdx: integer("prompt_idx"),
|
|
157
|
+
location: text("location"),
|
|
158
|
+
kind: text("kind"),
|
|
159
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`)
|
|
160
|
+
}, (table) => ({
|
|
161
|
+
blobIdx: index("blob_references_blob_idx").on(table.blobHash),
|
|
162
|
+
evalIdx: index("blob_references_eval_idx").on(table.evalId),
|
|
163
|
+
blobCreatedAtIdx: index("blob_references_blob_created_at_idx").on(table.blobHash, table.createdAt)
|
|
164
|
+
}));
|
|
165
|
+
const datasetsTable = sqliteTable("datasets", {
|
|
166
|
+
id: text("id").primaryKey(),
|
|
167
|
+
tests: text("tests", { mode: "json" }).$type(),
|
|
168
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`)
|
|
169
|
+
}, (table) => ({ createdAtIdx: index("datasets_created_at_idx").on(table.createdAt) }));
|
|
170
|
+
const evalsToDatasetsTable = sqliteTable("evals_to_datasets", {
|
|
171
|
+
evalId: text("eval_id").notNull().references(() => evalsTable.id),
|
|
172
|
+
datasetId: text("dataset_id").notNull().references(() => datasetsTable.id)
|
|
173
|
+
}, (t) => ({
|
|
174
|
+
pk: primaryKey({ columns: [t.evalId, t.datasetId] }),
|
|
175
|
+
evalIdIdx: index("evals_to_datasets_eval_id_idx").on(t.evalId),
|
|
176
|
+
datasetIdIdx: index("evals_to_datasets_dataset_id_idx").on(t.datasetId)
|
|
177
|
+
}));
|
|
178
|
+
relations(datasetsTable, ({ many }) => ({ evalsToDatasets: many(evalsToDatasetsTable) }));
|
|
179
|
+
relations(evalsTable, ({ many }) => ({
|
|
180
|
+
evalsToPrompts: many(evalsToPromptsTable),
|
|
181
|
+
evalsToDatasets: many(evalsToDatasetsTable),
|
|
182
|
+
evalsToTags: many(evalsToTagsTable)
|
|
183
|
+
}));
|
|
184
|
+
relations(evalsToPromptsTable, ({ one }) => ({
|
|
185
|
+
eval: one(evalsTable, {
|
|
186
|
+
fields: [evalsToPromptsTable.evalId],
|
|
187
|
+
references: [evalsTable.id]
|
|
188
|
+
}),
|
|
189
|
+
prompt: one(promptsTable, {
|
|
190
|
+
fields: [evalsToPromptsTable.promptId],
|
|
191
|
+
references: [promptsTable.id]
|
|
192
|
+
})
|
|
193
|
+
}));
|
|
194
|
+
relations(evalsToDatasetsTable, ({ one }) => ({
|
|
195
|
+
eval: one(evalsTable, {
|
|
196
|
+
fields: [evalsToDatasetsTable.evalId],
|
|
197
|
+
references: [evalsTable.id]
|
|
198
|
+
}),
|
|
199
|
+
dataset: one(datasetsTable, {
|
|
200
|
+
fields: [evalsToDatasetsTable.datasetId],
|
|
201
|
+
references: [datasetsTable.id]
|
|
202
|
+
})
|
|
203
|
+
}));
|
|
204
|
+
const configsTable = sqliteTable("configs", {
|
|
205
|
+
id: text("id").primaryKey(),
|
|
206
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
207
|
+
updatedAt: integer("updated_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
208
|
+
name: text("name").notNull(),
|
|
209
|
+
type: text("type").notNull(),
|
|
210
|
+
config: text("config", { mode: "json" }).notNull()
|
|
211
|
+
}, (table) => ({
|
|
212
|
+
createdAtIdx: index("configs_created_at_idx").on(table.createdAt),
|
|
213
|
+
typeIdx: index("configs_type_idx").on(table.type)
|
|
214
|
+
}));
|
|
215
|
+
const modelAuditsTable = sqliteTable("model_audits", {
|
|
216
|
+
id: text("id").primaryKey(),
|
|
217
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
218
|
+
updatedAt: integer("updated_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
219
|
+
name: text("name"),
|
|
220
|
+
author: text("author"),
|
|
221
|
+
modelPath: text("model_path").notNull(),
|
|
222
|
+
modelType: text("model_type"),
|
|
223
|
+
results: text("results", { mode: "json" }).$type().notNull(),
|
|
224
|
+
checks: text("checks", { mode: "json" }).$type(),
|
|
225
|
+
issues: text("issues", { mode: "json" }).$type(),
|
|
226
|
+
hasErrors: integer("has_errors", { mode: "boolean" }).notNull(),
|
|
227
|
+
totalChecks: integer("total_checks"),
|
|
228
|
+
passedChecks: integer("passed_checks"),
|
|
229
|
+
failedChecks: integer("failed_checks"),
|
|
230
|
+
metadata: text("metadata", { mode: "json" }).$type(),
|
|
231
|
+
modelId: text("model_id"),
|
|
232
|
+
revisionSha: text("revision_sha"),
|
|
233
|
+
contentHash: text("content_hash"),
|
|
234
|
+
modelSource: text("model_source"),
|
|
235
|
+
sourceLastModified: integer("source_last_modified"),
|
|
236
|
+
scannerVersion: text("scanner_version")
|
|
237
|
+
}, (table) => ({
|
|
238
|
+
createdAtIdx: index("model_audits_created_at_idx").on(table.createdAt),
|
|
239
|
+
modelPathIdx: index("model_audits_model_path_idx").on(table.modelPath),
|
|
240
|
+
hasErrorsIdx: index("model_audits_has_errors_idx").on(table.hasErrors),
|
|
241
|
+
modelTypeIdx: index("model_audits_model_type_idx").on(table.modelType),
|
|
242
|
+
modelIdIdx: index("model_audits_model_id_idx").on(table.modelId),
|
|
243
|
+
revisionShaIdx: index("model_audits_revision_sha_idx").on(table.revisionSha),
|
|
244
|
+
contentHashIdx: index("model_audits_content_hash_idx").on(table.contentHash),
|
|
245
|
+
modelRevisionIdx: index("model_audits_model_revision_idx").on(table.modelId, table.revisionSha),
|
|
246
|
+
modelContentIdx: index("model_audits_model_content_idx").on(table.modelId, table.contentHash)
|
|
247
|
+
}));
|
|
248
|
+
const tracesTable = sqliteTable("traces", {
|
|
249
|
+
id: text("id").primaryKey(),
|
|
250
|
+
traceId: text("trace_id").notNull().unique(),
|
|
251
|
+
evaluationId: text("evaluation_id").notNull().references(() => evalsTable.id),
|
|
252
|
+
testCaseId: text("test_case_id").notNull(),
|
|
253
|
+
createdAt: integer("created_at").notNull().default(sql`CURRENT_TIMESTAMP`),
|
|
254
|
+
metadata: text("metadata", { mode: "json" }).$type()
|
|
255
|
+
}, (table) => ({
|
|
256
|
+
evaluationIdx: index("traces_evaluation_idx").on(table.evaluationId),
|
|
257
|
+
traceIdIdx: index("traces_trace_id_idx").on(table.traceId)
|
|
258
|
+
}));
|
|
259
|
+
const spansTable = sqliteTable("spans", {
|
|
260
|
+
id: text("id").primaryKey(),
|
|
261
|
+
traceId: text("trace_id").notNull().references(() => tracesTable.traceId),
|
|
262
|
+
spanId: text("span_id").notNull(),
|
|
263
|
+
parentSpanId: text("parent_span_id"),
|
|
264
|
+
name: text("name").notNull(),
|
|
265
|
+
startTime: integer("start_time").notNull(),
|
|
266
|
+
endTime: integer("end_time"),
|
|
267
|
+
attributes: text("attributes", { mode: "json" }).$type(),
|
|
268
|
+
statusCode: integer("status_code"),
|
|
269
|
+
statusMessage: text("status_message")
|
|
270
|
+
}, (table) => ({
|
|
271
|
+
traceIdIdx: index("spans_trace_id_idx").on(table.traceId),
|
|
272
|
+
spanIdIdx: index("spans_span_id_idx").on(table.spanId)
|
|
273
|
+
}));
|
|
274
|
+
relations(tracesTable, ({ one, many }) => ({
|
|
275
|
+
eval: one(evalsTable, {
|
|
276
|
+
fields: [tracesTable.evaluationId],
|
|
277
|
+
references: [evalsTable.id]
|
|
278
|
+
}),
|
|
279
|
+
spans: many(spansTable)
|
|
280
|
+
}));
|
|
281
|
+
relations(spansTable, ({ one }) => ({ trace: one(tracesTable, {
|
|
282
|
+
fields: [spansTable.traceId],
|
|
283
|
+
references: [tracesTable.traceId]
|
|
284
|
+
}) }));
|
|
285
|
+
//#endregion
|
|
286
|
+
export { evalResultsTable as a, evalsToPromptsTable as c, promptsTable as d, spansTable as f, getDbSignalPath as g, getDb as h, datasetsTable as i, evalsToTagsTable as l, tracesTable as m, blobReferencesTable as n, evalsTable as o, tagsTable as p, configsTable as r, evalsToDatasetsTable as s, blobAssetsTable as t, modelAuditsTable as u };
|
|
287
|
+
|
|
288
|
+
//# sourceMappingURL=tables-xKANLRBD.js.map
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
1
|
+
import { t as __exportAll } from "./chunk-DEq-mXcV.js";
|
|
2
|
+
import { C as isCI, _ as getEnvBool, b as getEnvString, i as logger } from "./logger-CT3IKMKA.js";
|
|
3
|
+
import { D as R_ENDPOINT, E as EVENTS_ENDPOINT, M as POSTHOG_KEY, N as VERSION, T as CONSENT_ENDPOINT, r as fetchWithTimeout, t as fetchWithProxy } from "./fetch-60Gzydls.js";
|
|
4
|
+
import { a as getUserId, i as getUserEmail, n as getAuthMethod, o as isLoggedIntoCloud } from "./accounts-xrUGFA6n.js";
|
|
4
5
|
import { z } from "zod";
|
|
5
6
|
import { PostHog } from "posthog-node";
|
|
6
|
-
|
|
7
7
|
//#region src/telemetry.ts
|
|
8
|
-
|
|
8
|
+
var telemetry_exports = /* @__PURE__ */ __exportAll({
|
|
9
|
+
Telemetry: () => Telemetry,
|
|
10
|
+
default: () => telemetry
|
|
11
|
+
});
|
|
12
|
+
z.object({
|
|
9
13
|
event: z.enum([
|
|
10
14
|
"assertion_used",
|
|
11
15
|
"command_used",
|
|
@@ -36,7 +40,7 @@ let posthogClient = null;
|
|
|
36
40
|
let isShuttingDown = false;
|
|
37
41
|
function getPostHogClient() {
|
|
38
42
|
if (getEnvBool("PROMPTFOO_DISABLE_TELEMETRY") || getEnvBool("IS_TESTING")) return null;
|
|
39
|
-
if (posthogClient === null &&
|
|
43
|
+
if (posthogClient === null && "phc_E5n5uHnDo2eREJL1uqX1cIlbkoRby4yFWt3V94HqRRg") try {
|
|
40
44
|
posthogClient = new PostHog(POSTHOG_KEY, {
|
|
41
45
|
host: EVENTS_ENDPOINT,
|
|
42
46
|
fetch: fetchWithProxy,
|
|
@@ -72,7 +76,7 @@ var Telemetry = class {
|
|
|
72
76
|
});
|
|
73
77
|
client.flush().catch(() => {});
|
|
74
78
|
} catch (error) {
|
|
75
|
-
|
|
79
|
+
logger.debug(`PostHog identify error: ${error}`);
|
|
76
80
|
}
|
|
77
81
|
}
|
|
78
82
|
get disabled() {
|
|
@@ -103,7 +107,7 @@ var Telemetry = class {
|
|
|
103
107
|
});
|
|
104
108
|
client.flush().catch(() => {});
|
|
105
109
|
} catch (error) {
|
|
106
|
-
|
|
110
|
+
logger.debug(`PostHog capture error: ${error}`);
|
|
107
111
|
}
|
|
108
112
|
fetchWithProxy(R_ENDPOINT, {
|
|
109
113
|
method: "POST",
|
|
@@ -127,7 +131,7 @@ var Telemetry = class {
|
|
|
127
131
|
try {
|
|
128
132
|
await client.shutdown();
|
|
129
133
|
} catch (error) {
|
|
130
|
-
|
|
134
|
+
logger.debug(`PostHog shutdown error: ${error}`);
|
|
131
135
|
}
|
|
132
136
|
}
|
|
133
137
|
/**
|
|
@@ -145,7 +149,7 @@ var Telemetry = class {
|
|
|
145
149
|
}, TELEMETRY_TIMEOUT_MS);
|
|
146
150
|
if (!response.ok) throw new Error(`Failed to save consent: ${response.statusText}`);
|
|
147
151
|
} catch (err) {
|
|
148
|
-
|
|
152
|
+
logger.debug(`Failed to save consent: ${err.message}`);
|
|
149
153
|
}
|
|
150
154
|
}
|
|
151
155
|
};
|
|
@@ -160,8 +164,7 @@ if (!process[SHUTDOWN_HANDLER_KEY]) {
|
|
|
160
164
|
if (instance) instance.shutdown().catch(() => {});
|
|
161
165
|
});
|
|
162
166
|
}
|
|
163
|
-
var telemetry_default = telemetry;
|
|
164
|
-
|
|
165
167
|
//#endregion
|
|
166
|
-
export {
|
|
167
|
-
|
|
168
|
+
export { telemetry_exports as n, telemetry as t };
|
|
169
|
+
|
|
170
|
+
//# sourceMappingURL=telemetry-C15ziL8u.js.map
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import { C as getEnvString, E as isCI, b as getEnvBool, o as
|
|
3
|
-
import {
|
|
4
|
-
import { c as isLoggedIntoCloud, i as getAuthMethod, o as getUserEmail, s as getUserId } from "./accounts-
|
|
2
|
+
import { C as getEnvString, E as isCI, b as getEnvBool, o as logger } from "./logger-KkObSCzq.js";
|
|
3
|
+
import { E as R_ENDPOINT, M as POSTHOG_KEY, N as VERSION, T as EVENTS_ENDPOINT, i as fetchWithTimeout, n as fetchWithProxy, w as CONSENT_ENDPOINT } from "./fetch-BMv0O527.js";
|
|
4
|
+
import { c as isLoggedIntoCloud, i as getAuthMethod, o as getUserEmail, s as getUserId } from "./accounts-CMqkzrVf.js";
|
|
5
5
|
import { PostHog } from "posthog-node";
|
|
6
6
|
import { z } from "zod";
|
|
7
|
-
|
|
8
7
|
//#region src/telemetry.ts
|
|
9
8
|
const TelemetryEventSchema = z.object({
|
|
10
9
|
event: z.enum([
|
|
@@ -37,7 +36,7 @@ let posthogClient = null;
|
|
|
37
36
|
let isShuttingDown = false;
|
|
38
37
|
function getPostHogClient() {
|
|
39
38
|
if (getEnvBool("PROMPTFOO_DISABLE_TELEMETRY") || getEnvBool("IS_TESTING")) return null;
|
|
40
|
-
if (posthogClient === null &&
|
|
39
|
+
if (posthogClient === null && "phc_E5n5uHnDo2eREJL1uqX1cIlbkoRby4yFWt3V94HqRRg") try {
|
|
41
40
|
posthogClient = new PostHog(POSTHOG_KEY, {
|
|
42
41
|
host: EVENTS_ENDPOINT,
|
|
43
42
|
fetch: fetchWithProxy,
|
|
@@ -73,7 +72,7 @@ var Telemetry = class {
|
|
|
73
72
|
});
|
|
74
73
|
client.flush().catch(() => {});
|
|
75
74
|
} catch (error) {
|
|
76
|
-
|
|
75
|
+
logger.debug(`PostHog identify error: ${error}`);
|
|
77
76
|
}
|
|
78
77
|
}
|
|
79
78
|
get disabled() {
|
|
@@ -104,7 +103,7 @@ var Telemetry = class {
|
|
|
104
103
|
});
|
|
105
104
|
client.flush().catch(() => {});
|
|
106
105
|
} catch (error) {
|
|
107
|
-
|
|
106
|
+
logger.debug(`PostHog capture error: ${error}`);
|
|
108
107
|
}
|
|
109
108
|
fetchWithProxy(R_ENDPOINT, {
|
|
110
109
|
method: "POST",
|
|
@@ -128,7 +127,7 @@ var Telemetry = class {
|
|
|
128
127
|
try {
|
|
129
128
|
await client.shutdown();
|
|
130
129
|
} catch (error) {
|
|
131
|
-
|
|
130
|
+
logger.debug(`PostHog shutdown error: ${error}`);
|
|
132
131
|
}
|
|
133
132
|
}
|
|
134
133
|
/**
|
|
@@ -146,7 +145,7 @@ var Telemetry = class {
|
|
|
146
145
|
}, TELEMETRY_TIMEOUT_MS);
|
|
147
146
|
if (!response.ok) throw new Error(`Failed to save consent: ${response.statusText}`);
|
|
148
147
|
} catch (err) {
|
|
149
|
-
|
|
148
|
+
logger.debug(`Failed to save consent: ${err.message}`);
|
|
150
149
|
}
|
|
151
150
|
}
|
|
152
151
|
};
|
|
@@ -161,8 +160,7 @@ if (!process[SHUTDOWN_HANDLER_KEY]) {
|
|
|
161
160
|
if (instance) instance.shutdown().catch(() => {});
|
|
162
161
|
});
|
|
163
162
|
}
|
|
164
|
-
var telemetry_default = telemetry;
|
|
165
|
-
|
|
166
163
|
//#endregion
|
|
167
|
-
export { TelemetryEventSchema as n,
|
|
168
|
-
|
|
164
|
+
export { TelemetryEventSchema as n, telemetry as r, Telemetry as t };
|
|
165
|
+
|
|
166
|
+
//# sourceMappingURL=telemetry-C2YDkUQH.js.map
|
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
const require_logger = require(
|
|
2
|
-
const require_fetch = require(
|
|
3
|
-
const require_accounts = require(
|
|
1
|
+
const require_logger = require("./logger-Cp1GPUjj.cjs");
|
|
2
|
+
const require_fetch = require("./fetch-BxUk8odA.cjs");
|
|
3
|
+
const require_accounts = require("./accounts-Bx-x3bmW.cjs");
|
|
4
4
|
let zod = require("zod");
|
|
5
5
|
let posthog_node = require("posthog-node");
|
|
6
|
-
|
|
7
|
-
//#region src/telemetry.ts
|
|
8
|
-
const TelemetryEventSchema = zod.z.object({
|
|
6
|
+
zod.z.object({
|
|
9
7
|
event: zod.z.enum([
|
|
10
8
|
"assertion_used",
|
|
11
9
|
"command_used",
|
|
@@ -36,7 +34,7 @@ let posthogClient = null;
|
|
|
36
34
|
let isShuttingDown = false;
|
|
37
35
|
function getPostHogClient() {
|
|
38
36
|
if (require_logger.getEnvBool("PROMPTFOO_DISABLE_TELEMETRY") || require_logger.getEnvBool("IS_TESTING")) return null;
|
|
39
|
-
if (posthogClient === null &&
|
|
37
|
+
if (posthogClient === null && "phc_E5n5uHnDo2eREJL1uqX1cIlbkoRby4yFWt3V94HqRRg") try {
|
|
40
38
|
posthogClient = new posthog_node.PostHog(require_fetch.POSTHOG_KEY, {
|
|
41
39
|
host: require_fetch.EVENTS_ENDPOINT,
|
|
42
40
|
fetch: require_fetch.fetchWithProxy,
|
|
@@ -72,7 +70,7 @@ var Telemetry = class {
|
|
|
72
70
|
});
|
|
73
71
|
client.flush().catch(() => {});
|
|
74
72
|
} catch (error) {
|
|
75
|
-
require_logger.
|
|
73
|
+
require_logger.logger.debug(`PostHog identify error: ${error}`);
|
|
76
74
|
}
|
|
77
75
|
}
|
|
78
76
|
get disabled() {
|
|
@@ -103,7 +101,7 @@ var Telemetry = class {
|
|
|
103
101
|
});
|
|
104
102
|
client.flush().catch(() => {});
|
|
105
103
|
} catch (error) {
|
|
106
|
-
require_logger.
|
|
104
|
+
require_logger.logger.debug(`PostHog capture error: ${error}`);
|
|
107
105
|
}
|
|
108
106
|
require_fetch.fetchWithProxy(require_fetch.R_ENDPOINT, {
|
|
109
107
|
method: "POST",
|
|
@@ -127,7 +125,7 @@ var Telemetry = class {
|
|
|
127
125
|
try {
|
|
128
126
|
await client.shutdown();
|
|
129
127
|
} catch (error) {
|
|
130
|
-
require_logger.
|
|
128
|
+
require_logger.logger.debug(`PostHog shutdown error: ${error}`);
|
|
131
129
|
}
|
|
132
130
|
}
|
|
133
131
|
/**
|
|
@@ -145,7 +143,7 @@ var Telemetry = class {
|
|
|
145
143
|
}, TELEMETRY_TIMEOUT_MS);
|
|
146
144
|
if (!response.ok) throw new Error(`Failed to save consent: ${response.statusText}`);
|
|
147
145
|
} catch (err) {
|
|
148
|
-
require_logger.
|
|
146
|
+
require_logger.logger.debug(`Failed to save consent: ${err.message}`);
|
|
149
147
|
}
|
|
150
148
|
}
|
|
151
149
|
};
|
|
@@ -160,19 +158,18 @@ if (!process[SHUTDOWN_HANDLER_KEY]) {
|
|
|
160
158
|
if (instance) instance.shutdown().catch(() => {});
|
|
161
159
|
});
|
|
162
160
|
}
|
|
163
|
-
var telemetry_default = telemetry;
|
|
164
|
-
|
|
165
161
|
//#endregion
|
|
166
|
-
Object.defineProperty(exports,
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
162
|
+
Object.defineProperty(exports, "Telemetry", {
|
|
163
|
+
enumerable: true,
|
|
164
|
+
get: function() {
|
|
165
|
+
return Telemetry;
|
|
166
|
+
}
|
|
171
167
|
});
|
|
172
|
-
Object.defineProperty(exports,
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
168
|
+
Object.defineProperty(exports, "telemetry", {
|
|
169
|
+
enumerable: true,
|
|
170
|
+
get: function() {
|
|
171
|
+
return telemetry;
|
|
172
|
+
}
|
|
177
173
|
});
|
|
178
|
-
|
|
174
|
+
|
|
175
|
+
//# sourceMappingURL=telemetry-CbrnxHp_.cjs.map
|