decocms 3.4.0 → 3.4.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/dist/client/assets/{AlertCircle-C2xmuErv.js → AlertCircle-Bc3r3AGq.js} +1 -1
- package/dist/client/assets/{ArrowUpRight-DY3nGAjH.js → ArrowUpRight-DfEIENBd.js} +1 -1
- package/dist/client/assets/{Check-Bl0EnB2J.js → Check--VLhXi5l.js} +1 -1
- package/dist/client/assets/{CheckCircle-Bt38xVIy.js → CheckCircle-7xc6-R3M.js} +1 -1
- package/dist/client/assets/{ChevronDown-BYvseX6e.js → ChevronDown-66ErjaPf.js} +1 -1
- package/dist/client/assets/{ChevronLeft-DoUOCEbQ.js → ChevronLeft-DyW6EtsM.js} +1 -1
- package/dist/client/assets/{ChevronRight-CJPo14Wd.js → ChevronRight-C87PRbBa.js} +1 -1
- package/dist/client/assets/{ChevronUp-CoYKSGM9.js → ChevronUp-BuPeXu8C.js} +1 -1
- package/dist/client/assets/{Container-Bgm498uR.js → Container-cZo3l6OX.js} +1 -1
- package/dist/client/assets/{DotsVertical-DdI4UlQo.js → DotsVertical-CQgc8nSx.js} +1 -1
- package/dist/client/assets/{Eye-D-FtEtW8.js → Eye-DHHjYDbX.js} +1 -1
- package/dist/client/assets/{FilterLines-Bn2_q3W3.js → FilterLines-CWR_eJ7z.js} +1 -1
- package/dist/client/assets/{Globe01-5KEfDt4K.js → Globe01-B10jCcNH.js} +1 -1
- package/dist/client/assets/{HardDrive-Bq_J68ys.js → HardDrive-7KMC69UH.js} +1 -1
- package/dist/client/assets/{Key01-C484g3YO.js → Key01-CTKRB2Cd.js} +1 -1
- package/dist/client/assets/{LayoutLeft-CnXQOO58.js → LayoutLeft-SQH1HcmI.js} +1 -1
- package/dist/client/assets/{LinkExternal01-DSXCOuPf.js → LinkExternal01-CjT-4hM8.js} +1 -1
- package/dist/client/assets/{Monitor01-DxGBVT7-.js → Monitor01-svtG00ql.js} +1 -1
- package/dist/client/assets/{Palette-BL7llRL5.js → Palette-CA_16qMN.js} +1 -1
- package/dist/client/assets/{Play-COr2_UEr.js → Play-CrdarOgl.js} +1 -1
- package/dist/client/assets/{Plus-DyGCHsAC.js → Plus-C9icoBmX.js} +1 -1
- package/dist/client/assets/{RefreshCcw01-DwuEW87g.js → RefreshCcw01-D1tvoH2_.js} +1 -1
- package/dist/client/assets/{SearchMd-BvLcLD4O.js → SearchMd-Di6_vvQ1.js} +1 -1
- package/dist/client/assets/{Settings02-DdSNGnuW.js → Settings02-BylJiOHK.js} +1 -1
- package/dist/client/assets/{Shield01-B-jBzvZJ.js → Shield01-CDSs18-B.js} +1 -1
- package/dist/client/assets/{Star01-BWl4O-UT.js → Star01-D1DEXGAi.js} +1 -1
- package/dist/client/assets/{Stars01-cmM0sb2I.js → Stars01-UWs0NZ30.js} +1 -1
- package/dist/client/assets/{Stars02-BDvnLwBo.js → Stars02-CXAcgX2g.js} +1 -1
- package/dist/client/assets/{Sun-BumCYr1L.js → Sun-CCiXRotp.js} +1 -1
- package/dist/client/assets/{SwitchHorizontal01-DL7oI9Hg.js → SwitchHorizontal01-BU3C5ze8.js} +1 -1
- package/dist/client/assets/{Tool01-Cgf_tMbK.js → Tool01-BMk00CcA.js} +1 -1
- package/dist/client/assets/{Trash01-BWWRskAa.js → Trash01-MTKniuxn.js} +1 -1
- package/dist/client/assets/{Upload01-CufDtzzB.js → Upload01-DsrMMWgf.js} +1 -1
- package/dist/client/assets/{User01-CL8jgZE5.js → User01-DShN8gQ-.js} +1 -1
- package/dist/client/assets/{Users01-DVvuBAcj.js → Users01-Bvh39Ydu.js} +1 -1
- package/dist/client/assets/{Users03-DuD0whJZ.js → Users03--pQkY_Pm.js} +1 -1
- package/dist/client/assets/{X-Dnhh57X7.js → X-D-FyhysP.js} +1 -1
- package/dist/client/assets/{XCircle-M_oWnCac.js → XCircle-Pgrh_mFJ.js} +1 -1
- package/dist/client/assets/{XClose-tPJB8Sgg.js → XClose-CXixB7oH.js} +1 -1
- package/dist/client/assets/{Zap-C7nJc6zh.js → Zap-BcF-Iz_3.js} +1 -1
- package/dist/client/assets/{ZapSquare-D8HT6_jN.js → ZapSquare-BH297b52.js} +1 -1
- package/dist/client/assets/{ZoomOut-DvI5OdTo.js → ZoomOut-qupe1GUj.js} +1 -1
- package/dist/client/assets/{access-gate-DImJJoEr.js → access-gate-b8qBeVwB.js} +1 -1
- package/dist/client/assets/{accordion-7MLP1JmO.js → accordion-bX483Ztz.js} +1 -1
- package/dist/client/assets/{add-section-modal--OZiIc-7.js → add-section-modal-wMptfoHV.js} +1 -1
- package/dist/client/assets/{agent-capabilities-BPRMoWbD.js → agent-capabilities-ADaK_qqp.js} +1 -1
- package/dist/client/assets/{agent-icon-WacEkBrp.js → agent-icon-6l7Nwe2K.js} +1 -1
- package/dist/client/assets/{agent-icons-DSxNh1vt.js → agent-icons-BDS9BBHh.js} +1 -1
- package/dist/client/assets/{agents-list-C2v-b0Uw.js → agents-list-BdFiPs3r.js} +1 -1
- package/dist/client/assets/{ai-providers-BwZCii8q.js → ai-providers-lM-GGoBl.js} +1 -1
- package/dist/client/assets/{alert-B3xreeC3.js → alert-Ta86Z4_L.js} +1 -1
- package/dist/client/assets/{alert-dialog-DXWvjPm6.js → alert-dialog-_2G9ccD7.js} +1 -1
- package/dist/client/assets/app-editor-BJ_HJXFs.js +1 -0
- package/dist/client/assets/{auth-catchall-DkH2zPkq.js → auth-catchall-BdHpJwKo.js} +1 -1
- package/dist/client/assets/{auth-split-layout-a7pkbs3d.js → auth-split-layout-DVUC3dWq.js} +1 -1
- package/dist/client/assets/{automation-list-row-Co4RY6C0.js → automation-list-row-BNHDxEG_.js} +1 -1
- package/dist/client/assets/{automation-runs-89AdbVbs.js → automation-runs-BbNb5m5Z.js} +1 -1
- package/dist/client/assets/{automations-CpHR-q7K.js → automations-ChMgB7Hm.js} +1 -1
- package/dist/client/assets/{avatar-MwlGDSa1.js → avatar-KTqg6Pir.js} +1 -1
- package/dist/client/assets/{badge-CDV4_k2B.js → badge-jK5_JNPO.js} +1 -1
- package/dist/client/assets/{brand-context-CEbbgDr_.js → brand-context-D1YLW65X.js} +1 -1
- package/dist/client/assets/{buckets-B-c_g1Bu.js → buckets-CZodJDYe.js} +1 -1
- package/dist/client/assets/{calendar-_Z1zwZng.js → calendar-DFy-BKZq.js} +1 -1
- package/dist/client/assets/{capability-load-error-U6Dy8kIL.js → capability-load-error-DUP-Lw9V.js} +1 -1
- package/dist/client/assets/{card-BrXXg9xg.js → card-Ce7y-Nqu.js} +1 -1
- package/dist/client/assets/{chat-context-DKFtpKPJ.js → chat-context-CpKbwwmM.js} +1 -1
- package/dist/client/assets/{checkbox-COoWVOED.js → checkbox-MO2_GITU.js} +1 -1
- package/dist/client/assets/{cli-auth-success-CgA40pPN.js → cli-auth-success-XZzsr92m.js} +1 -1
- package/dist/client/assets/{collection-detail-BZkXi3bA.js → collection-detail-Bv6I7A_k.js} +1 -1
- package/dist/client/assets/{collection-display-button-BkPkMS-1.js → collection-display-button-DzXqmtbd.js} +1 -1
- package/dist/client/assets/{collection-search-HZ4Ln7Q2.js → collection-search-CPYfTi84.js} +1 -1
- package/dist/client/assets/{collection-table-wrapper-Bos1aSX0.js → collection-table-wrapper-DgzLrzuP.js} +1 -1
- package/dist/client/assets/{collection-tabs-Bt-TX4Xo.js → collection-tabs-CIsqNrxU.js} +1 -1
- package/dist/client/assets/{collections-DltZgEAo.js → collections-B-PXiD2Y.js} +1 -1
- package/dist/client/assets/{command-DScV9t-B.js → command-BHmAxNRB.js} +1 -1
- package/dist/client/assets/{connect-desktop-dialog-CLGlbMya.js → connect-desktop-dialog-BQZD1I8n.js} +1 -1
- package/dist/client/assets/{connection-card-BXL7SVUL.js → connection-card-BHzG8ppu.js} +1 -1
- package/dist/client/assets/{connection-detail-ZBj-b2U9.js → connection-detail-BlmixFGl.js} +1 -1
- package/dist/client/assets/{connection-form-helpers-ZyPV2_OX.js → connection-form-helpers-CgKn2eM9.js} +1 -1
- package/dist/client/assets/{connections-kRTrf7Rr.js → connections-D5zy3mYf.js} +1 -1
- package/dist/client/assets/{constants-7h1Iherr.js → constants-DI_u-hVk.js} +1 -1
- package/dist/client/assets/{decopilot-sse-pool-DENZDpL-.js → decopilot-sse-pool-DPWhf2bX.js} +1 -1
- package/dist/client/assets/{dialog-DrWcnTZj.js → dialog-Bt3zXcK6.js} +1 -1
- package/dist/client/assets/{domain-settings-ShrDeEq2.js → domain-settings-CZnFXOwr.js} +1 -1
- package/dist/client/assets/{drawer-Bfik0Ru5.js → drawer-DeHC5s3g.js} +1 -1
- package/dist/client/assets/{dropdown-menu-CZNwXuzY.js → dropdown-menu-SwrAlbwN.js} +1 -1
- package/dist/client/assets/{dynamic-plugin-layout-BP4187XS.js → dynamic-plugin-layout-WDrQTfck.js} +1 -1
- package/dist/client/assets/{empty-state-DKLTVUZK.js → empty-state-BJFB-AwN.js} +1 -1
- package/dist/client/assets/{empty-state-D3IZdm2e.js → empty-state-DlCayRAK.js} +1 -1
- package/dist/client/assets/{extract-connection-data-nTPi-bUk.js → extract-connection-data-CrMYEI5i.js} +1 -1
- package/dist/client/assets/{features-BLxt6ZXO.js → features-BgkDxOlu.js} +1 -1
- package/dist/client/assets/{file-explorer-qXYPqBrE.js → file-explorer-DrueRu5k.js} +1 -1
- package/dist/client/assets/{file-type-icon-CNGWzVav.js → file-type-icon-BHF_Ovux.js} +1 -1
- package/dist/client/assets/{files-DxicSOqn.js → files-BCcd3t2S.js} +1 -1
- package/dist/client/assets/{form-DZneHGBX.js → form-8jBGaVW7.js} +1 -1
- package/dist/client/assets/{general-BNlVKTyv.js → general-BJkPBrz3.js} +1 -1
- package/dist/client/assets/{generate-id-BKVk8ACt.js → generate-id-Bfx7nOJH.js} +1 -1
- package/dist/client/assets/{github-repo-picker-DhCzx3JE.js → github-repo-picker-F4vLHgJ-.js} +1 -1
- package/dist/client/assets/{header-tab-button-FYT24Mc0.js → header-tab-button-DCSg63Wl.js} +1 -1
- package/dist/client/assets/{hover-card-C3fFUxNZ.js → hover-card-DcJvwauT.js} +1 -1
- package/dist/client/assets/{image-field-BPpyMlFF.js → image-field-cind3dwC.js} +1 -1
- package/dist/client/assets/{index-D8CIGkco.js → index-BIANv7ur.js} +1 -1
- package/dist/client/assets/{index-BYABqu1-.js → index-Bac2tQWh.js} +1 -1
- package/dist/client/assets/{index-BGTvYbRH.js → index-BrIVZCzt.js} +1 -1
- package/dist/client/assets/{index-nja5uOPv.js → index-BzoFvbIH.js} +1 -1
- package/dist/client/assets/{index-BzQy6K9H.js → index-C0t_9xyr.js} +1 -1
- package/dist/client/assets/{index-CrU7PEoz.js → index-C1kxS2Io.js} +1 -1
- package/dist/client/assets/{index-CE8bhCJ-.js → index-C3tcbzRj.js} +1 -1
- package/dist/client/assets/{index-CHxlbuKY.js → index-C_oSBqFD.js} +3 -3
- package/dist/client/assets/{index-CO19ITRz.js → index-CfGIr4vM.js} +4 -4
- package/dist/client/assets/{index-DnL9bwru.js → index-ChzbgMa2.js} +1 -1
- package/dist/client/assets/{index-C7bMF1Zw.js → index-DEWYXjIf.js} +1 -1
- package/dist/client/assets/{index-DBPwWvUg.js → index-DML39Lt-.js} +1 -1
- package/dist/client/assets/{index-h-7ASBRq.js → index-DQj7btfC.js} +1 -1
- package/dist/client/assets/{index-1DdOMz-0.js → index-DlcvFOU2.js} +1 -1
- package/dist/client/assets/{index-fTzwyCrX.js → index-d7-A3CDs.js} +1 -1
- package/dist/client/assets/{index-redirect--DRbdQvu.js → index-redirect-KnAJlqvx.js} +1 -1
- package/dist/client/assets/{infiniteQueryObserver-ClvxtPxd.js → infiniteQueryObserver-w8EJyyrI.js} +1 -1
- package/dist/client/assets/{input-BqbhwOOI.js → input-Ct22kLSY.js} +1 -1
- package/dist/client/assets/{integration-icon-DsdPiq0I.js → integration-icon-CNf7sZ5b.js} +1 -1
- package/dist/client/assets/{label-DylEtHs-.js → label-CvDTa89d.js} +1 -1
- package/dist/client/assets/{layout-BNJzmBuH.js → layout-Dkxj2bFg.js} +1 -1
- package/dist/client/assets/{login-BqdS0wu4.js → login-Dv6Rz1bY.js} +1 -1
- package/dist/client/assets/{members-N8gPc_Ma.js → members-BQXsk1m4.js} +1 -1
- package/dist/client/assets/{monaco-editor-CJckn8Zg.js → monaco-editor-DR4yoUjc.js} +1 -1
- package/dist/client/assets/{monitoring-stats-row-C5BKUj6s.js → monitoring-stats-row-Co70p3-n.js} +1 -1
- package/dist/client/assets/{oauth-callback-DpOZwh96.js → oauth-callback-CQPHoHy-.js} +1 -1
- package/dist/client/assets/{oauth-callback-ai-provider-Bey7NKbP.js → oauth-callback-ai-provider-BJeYyFlX.js} +1 -1
- package/dist/client/assets/{onboarding-DX1TA4nG.js → onboarding-CzNreyu4.js} +1 -1
- package/dist/client/assets/{org-install-Dw27kVYm.js → org-install-aZxuYxoI.js} +1 -1
- package/dist/client/assets/{org-layout-BoYrXW7O.js → org-layout-CR6iFjC9.js} +1 -1
- package/dist/client/assets/{org-plugin-layout-BZ7QEYUH.js → org-plugin-layout-Ah6P36_M.js} +1 -1
- package/dist/client/assets/{page-seo-form-DBEtnmLl.js → page-seo-form-BzX1ts5p.js} +1 -1
- package/dist/client/assets/page-seo-sheet-v7xZnlYi.js +1 -0
- package/dist/client/assets/{pair-KHOH6ev_.js → pair--AN1yq4g.js} +1 -1
- package/dist/client/assets/{plugin-empty-state-z6EfkGXR.js → plugin-empty-state-CIZ1bBrP.js} +1 -1
- package/dist/client/assets/{plugin-header-CvmTO3qC.js → plugin-header-CExvgCKI.js} +1 -1
- package/dist/client/assets/{plugin-layout-d2cyKIK_.js → plugin-layout-DS-orBC-.js} +1 -1
- package/dist/client/assets/{popover-CThu0-ID.js → popover-DXn7orE4.js} +1 -1
- package/dist/client/assets/{post-editor-HwjfiT82.js → post-editor-bszZQHpg.js} +1 -1
- package/dist/client/assets/{primitives-DOyYgRDx.js → primitives-CIXky-Gt.js} +1 -1
- package/dist/client/assets/{profile-DoWLwgvz.js → profile-CZWeJMEP.js} +1 -1
- package/dist/client/assets/project-app-view-DJMvDwFa.js +1 -0
- package/dist/client/assets/record-editor-C5KWfSLg.js +1 -0
- package/dist/client/assets/registry-CX2hi2E3.js +2 -0
- package/dist/client/assets/{registry-layout-B_UkD5S0.js → registry-layout-DjFUi3yC.js} +1 -1
- package/dist/client/assets/{require-capability-BvInsc8R.js → require-capability-DDbNSPG5.js} +1 -1
- package/dist/client/assets/{required-auth-layout-LJYVUIeV.js → required-auth-layout-Bpv6G5uE.js} +1 -1
- package/dist/client/assets/{reset-password-DtCxXZ93.js → reset-password-D1T0PiTj.js} +1 -1
- package/dist/client/assets/{resizable-YbTIAmC6.js → resizable-Bi3jkg9o.js} +1 -1
- package/dist/client/assets/{roles-deRJzwzx.js → roles-BBWw8puD.js} +1 -1
- package/dist/client/assets/{save-status-CznZaqbg.js → save-status-PzXq6KUK.js} +1 -1
- package/dist/client/assets/{schema-form-Bz-Y2xaP.js → schema-form-CM7pfylQ.js} +1 -1
- package/dist/client/assets/{scroll-area-iVX_9hOT.js → scroll-area-BNzrPnq5.js} +1 -1
- package/dist/client/assets/{search-input-BV9iWpXU.js → search-input-C76EA-t6.js} +1 -1
- package/dist/client/assets/{secrets-DKrtTjxD.js → secrets-DMEa7GIW.js} +1 -1
- package/dist/client/assets/{sections-editor-wlO4Df3c.js → sections-editor--GuZPQzC.js} +1 -1
- package/dist/client/assets/{select-Ci_D4qpL.js → select-D_4UU9rK.js} +1 -1
- package/dist/client/assets/{select-model-B4DZz0S9.js → select-model-cV_VUU8G.js} +1 -1
- package/dist/client/assets/{seo-editor-03fUsq4w.js → seo-editor-fhccoPNR.js} +1 -1
- package/dist/client/assets/{settings-layout-DWP_Rn9K.js → settings-layout-DH37q17x.js} +1 -1
- package/dist/client/assets/{settings-section-DKmxECct.js → settings-section-DsXtuKDY.js} +1 -1
- package/dist/client/assets/{sheet-B9dMT6Ki.js → sheet-D01YX9h0.js} +1 -1
- package/dist/client/assets/{shell-controls-CCA2MPHn.js → shell-controls-CNVI6ZJJ.js} +1 -1
- package/dist/client/assets/{shell-layout-BNtK431X.js → shell-layout-xPMsY5hC.js} +1 -1
- package/dist/client/assets/{shell-route-loading-CaBu7gGK.js → shell-route-loading-jPQ9XajT.js} +1 -1
- package/dist/client/assets/{sidebar-rRN-0AxT.js → sidebar-CJNdWlwy.js} +1 -1
- package/dist/client/assets/{skeleton-IAM_o0Ys.js → skeleton-DEf5lpEA.js} +1 -1
- package/dist/client/assets/{sortable.esm-DRxiermK.js → sortable.esm-KhkNVCRe.js} +1 -1
- package/dist/client/assets/{spinner-ZLpPHnSU.js → spinner-srK7FwNe.js} +1 -1
- package/dist/client/assets/{sso-CdsNChqa.js → sso-BLXKmxlD.js} +1 -1
- package/dist/client/assets/{store-BgRTI4Rv.js → store-DydXTg6V.js} +1 -1
- package/dist/client/assets/store-registry-BJqdtxTv.js +2 -0
- package/dist/client/assets/{switch-B1bl8sNA.js → switch-Cbu6JSI9.js} +1 -1
- package/dist/client/assets/{tab-id-C5NSex1c.js → tab-id-CbYpEVAZ.js} +1 -1
- package/dist/client/assets/{table-DB1Kd-ou.js → table-dr9K2jWM.js} +1 -1
- package/dist/client/assets/{tabs-B3X9vNsm.js → tabs-CJU0nxr6.js} +1 -1
- package/dist/client/assets/{task-status-ClueOciL.js → task-status-Dyf8qaxz.js} +1 -1
- package/dist/client/assets/{textarea-DywxeOH3.js → textarea-BquesfD_.js} +1 -1
- package/dist/client/assets/{toggle-group-7kzOZFuJ.js → toggle-group-m3q7pubc.js} +1 -1
- package/dist/client/assets/{toolbar-l4lsSaSH.js → toolbar-Bkxu3n7s.js} +1 -1
- package/dist/client/assets/{tools-list-Dm1utA0x.js → tools-list-CG_BLK1j.js} +1 -1
- package/dist/client/assets/{tooltip-BFGyTrfa.js → tooltip-Bm-whGHF.js} +1 -1
- package/dist/client/assets/{types-ksHhVabW.js → types-Bkz2p_os.js} +1 -1
- package/dist/client/assets/{use-ai-providers-JirMLy_w.js → use-ai-providers-B82V9Np8.js} +1 -1
- package/dist/client/assets/{use-automations-3R13ZeSL.js → use-automations-B5qTxkL8.js} +1 -1
- package/dist/client/assets/{use-capability-CQt0iOwa.js → use-capability-DpFGw1TU.js} +1 -1
- package/dist/client/assets/{use-collections-hMeHX3z9.js → use-collections-iUV-5kFm.js} +1 -1
- package/dist/client/assets/{use-connection-_VO3kzZS.js → use-connection-DTKE65yR.js} +1 -1
- package/dist/client/assets/{use-copy-BNAf-Qgh.js → use-copy-Dr7XRETN.js} +1 -1
- package/dist/client/assets/{use-create-virtual-mcp-DpiN_bgM.js → use-create-virtual-mcp-DlMteKXP.js} +1 -1
- package/dist/client/assets/{use-debounced-autosave-kr27xY5y.js → use-debounced-autosave-DFapff8c.js} +1 -1
- package/dist/client/assets/{use-delete-connection-DFb9AulP.js → use-delete-connection-CU96IyMZ.js} +1 -1
- package/dist/client/assets/{use-file-configs-DrA_HE6r.js → use-file-configs-C8ipJXZL.js} +1 -1
- package/dist/client/assets/{use-infinite-scroll-DRY2R8kb.js → use-infinite-scroll-KU0QCoEE.js} +1 -1
- package/dist/client/assets/{use-list-state-CGdA9sk-.js → use-list-state-DtwRJx6R.js} +1 -1
- package/dist/client/assets/{use-mcp-prompts-BIC4osYX.js → use-mcp-prompts-aLA3FcF_.js} +1 -1
- package/dist/client/assets/{use-mcp-tools-BZZ0dcgP.js → use-mcp-tools-CK1DUQVb.js} +1 -1
- package/dist/client/assets/{use-members-DnfZ8tEp.js → use-members-C9apz-8a.js} +1 -1
- package/dist/client/assets/{use-navigate-to-agent-DWh1SzWc.js → use-navigate-to-agent-DRRtr51U.js} +1 -1
- package/dist/client/assets/{use-org-auth-client-CwWZc3xb.js → use-org-auth-client-CI8XyYuM.js} +1 -1
- package/dist/client/assets/{use-org-sso-BnGud85s.js → use-org-sso-CYBgAyDV.js} +1 -1
- package/dist/client/assets/{use-organization-roles-BIe6gEN_.js → use-organization-roles-C5ABG30J.js} +1 -1
- package/dist/client/assets/{use-organization-settings-Dy_wvkUU.js → use-organization-settings-B4ywx3QZ.js} +1 -1
- package/dist/client/assets/{use-registry-connections-DnATENDO.js → use-registry-connections-B-c9LId-.js} +1 -1
- package/dist/client/assets/{use-secrets-C4Hg3-p8.js → use-secrets-D3irvtLI.js} +1 -1
- package/dist/client/assets/{use-status-sounds-CCM_GgH8.js → use-status-sounds-BEbMXd3N.js} +1 -1
- package/dist/client/assets/{use-view-mode-DZhMkEJ1.js → use-view-mode-Jd_CE1Mx.js} +1 -1
- package/dist/client/assets/{use-virtual-mcp-BaoT8VIh.js → use-virtual-mcp-DsdNWb58.js} +1 -1
- package/dist/client/assets/useInfiniteQuery-DrZL_IGs.js +1 -0
- package/dist/client/assets/{useRouterState-DEBHW9gr.js → useRouterState-CU2GqlKv.js} +1 -1
- package/dist/client/assets/useSuspenseInfiniteQuery-CN1mQR7i.js +1 -0
- package/dist/client/assets/{user-CmhADXs_.js → user-sLZtiN2i.js} +1 -1
- package/dist/client/assets/{view-mode-toggle--g2MGXro.js → view-mode-toggle-DSmCr2tD.js} +1 -1
- package/dist/client/assets/{workflow-DuDgvcXi.js → workflow-BK9KKo6T.js} +1 -1
- package/dist/client/assets/workflow-detail-DzASvQVR.js +1 -0
- package/dist/client/index.html +1 -1
- package/dist/server/cli.js +2 -2
- package/dist/server/migrate.js +1 -1
- package/dist/server/server.js +1 -1
- package/package.json +1 -1
- package/dist/client/assets/app-editor-DaKe0gcW.js +0 -1
- package/dist/client/assets/page-seo-sheet-B66TXIq6.js +0 -1
- package/dist/client/assets/project-app-view-BA3JXk-V.js +0 -1
- package/dist/client/assets/record-editor-B09SHssY.js +0 -1
- package/dist/client/assets/registry-CVaj-aEQ.js +0 -2
- package/dist/client/assets/store-registry-CxNFeZZm.js +0 -2
- package/dist/client/assets/useInfiniteQuery-BdYHzHZ3.js +0 -1
- package/dist/client/assets/useSuspenseInfiniteQuery-KU_h5oCb.js +0 -1
- package/dist/client/assets/workflow-detail-C8cBg_ad.js +0 -1
package/dist/server/migrate.js
CHANGED
|
@@ -939,7 +939,7 @@ ${Y.stack}Host: ${B}`),Object.assign(K,G),K}throw new DG(Y)}return $.value}[Symb
|
|
|
939
939
|
DELETE FROM "organization" WHERE id = 'org_orgfs_public_skills'
|
|
940
940
|
`.execute($)}var WQ={};S(WQ,{up:()=>BM,down:()=>FM});async function BM($){await $.schema.alterTable("automations").addColumn("max_agent_steps","integer").execute()}async function FM($){await $.schema.alterTable("automations").dropColumn("max_agent_steps").execute()}var JQ={};S(JQ,{up:()=>DM,down:()=>VM});import{sql as $K}from"kysely";async function DM($){await $K`DROP INDEX IF EXISTS idx_tmp_run_seq`.execute($)}async function VM($){await $K`CREATE UNIQUE INDEX IF NOT EXISTS idx_tmp_run_seq ON thread_message_parts (run_id, seq)`.execute($)}var LM={"001-initial-schema":o$,"002-organization-settings":s$,"003-connection-schema-align":t$,"004-remove-models-binding":e$,"005-connection-configuration":$Z,"006-add-views-to-settings":ZZ,"007-monitoring-logs":YZ,"008-event-bus":QZ,"009-drop-audit-logs":XZ,"010-gateways":WZ,"011-gateway-icon":JZ,"012-gateway-tool-selection-mode":GZ,"013-monitoring-user-agent-gateway":KZ,"014-gateway-resources-prompts":HZ,"015-monitoring-properties":BZ,"016-downstream-token-client-info":FZ,"017-downstream-token-remove-userid":DZ,"018-drop-gateway-tool-selection-strategy":VZ,"019-remove-gateway-is-default":LZ,"020-enabled-plugins":UZ,"021-threads":jZ,"022-rename-gateway-to-virtual-mcp":AZ,"023-optimize-thread-indexes":zZ,"024-consolidate-virtual-mcp":OZ,"025-add-monitoring-virtual-mcp-id":qZ,"026-restrict-child-connection-delete":NZ,"027-update-management-mcp-url":PZ,"028-update-management-mcp-to-self":EZ,"029-add-updated-by-to-connections":RZ,"030-member-tags":_Z,"031-add-dependency-mode":CZ,"032-projects":IZ,"033-thread-status":fZ,"034-monitoring-dashboards":SZ,"035-project-connections":bZ,"036-update-registry-url":vZ,"037-ai-provider-keys":yZ,"038-oauth-pkce-states":TZ,"039-automations":kZ,"040-replace-next-run-at-with-last-run-at":xZ,"041-ai-provider-keys-unique-constraint":gZ,"042-rename-mesh-mcp-to-cms-mcp":uZ,"043-rename-cms-mcp-to-deco-cms":hZ,"044-drop-connections-tools-column":mZ,"045-thread-context-start-message":lZ,"046-remove-object-storage-plugin":iZ,"047-add-next-run-at":cZ,"048-merge-projects-agents":nZ,"049-remove-org-admin-projects":rZ,"050-durable-agent-runs":aZ,"051-org-sso":sZ,"052-thread-agent-ids":tZ,"053-registry-config":eZ,"054-connection-slug":ZY,"055-spaces":YY,"056-automation-project-scope":QY,"057-thread-virtual-mcp-id":XY,"058-trigger-callback-tokens":WY,"059-kv":JY,"060-member-index":GY,"061-downstream-token-connection-index":KY,"062-private-registry":HY,"063-event-subscriptions-enabled-boolean":BY,"064-brand-context":FY,"065-organization-domains":DY,"066-brand-context-structured":VY,"067-threads-metadata":LY,"068-threads-branch":UY,"069-sandbox-runner-state":jY,"070-model-categories":AY,"071-default-home-agents":zY,"072-ai-provider-key-preset-id":OY,"073-backfill-basic-usage-roles":qY,"074-sandbox-runner-state-handle-nonunique":NY,"075-thread-inflight-async-jobs":MY,"076-automations-drop-agent-json":PY,"077-tier-only-model-selection":EY,"078-automation-tool-call-kind":RY,"079-strip-legacy-freestyle-vm-map-entries":_Y,"080-async-research-jobs":CY,"081-async-research-jobs-result-content":IY,"082-secrets":fY,"083-thread-run-locally":SY,"084-drop-host-sandbox-rows":bY,"085-rename-runner-kind":vY,"086-thread-pins-and-vm-map-rekey":yY,"087-fix-vm-map-rekey":TY,"088-purge-cli-activate-keys":kY,"089-rename-remote-user-to-desktop":xY,"090-automation-webhook-triggers":gY,"091-organization-domains-allow-multi":uY,"092-sandbox-naming-uniformization":hY,"093-backfill-global-search-basic-usage":mY,"094-org-file-configs":pY,"095-remove-automation-tool-call-kind":iY,"096-org-file-configs-public-url-base":cY,"097-drop-local-docker-sandbox-state":nY,"098-thread-message-parts":rY,"099-run-fence":aY,"100-link-transport":oY,"101-cancel-requested-at":sY,"102-observational-agent":tY,"103-revert-observational-agent":eY,"104-agent-sandbox-provider-kind":ZQ,"105-org-fs":YQ,"106-automation-tools":QQ,"107-org-fs-public-org":XQ,"108-automation-max-agent-steps":WQ,"109-thread-message-parts-per-message-seq":JQ},GQ=LM;import{getMigrations as mM}from"better-auth/db";import{sso as lM}from"@better-auth/sso";import{organization as pM}from"@decocms/better-auth/plugins";import{admin as iM,apiKey as cM,jwt as dM,magicLink as nM,mcp as rM,openAPI as aM}from"better-auth/plugins";import{emailOTP as oM}from"better-auth/plugins/email-otp";import{Kysely as yM,PostgresDialect as FK}from"kysely";import{Pool as DK}from"pg";import{homedir as UM}from"os";function v9($){return $==="true"||$==="1"}function ZK($){if(!$)return null;try{let Y=new URL($).hostname;if(Y==="localhost"||Y==="127.0.0.1"||Y==="::1")return null;return $}catch{return null}}var jM=new Set(["agent-sandbox","user-desktop"]);function AM($){let Z=$&&$.length>0?$:"user-desktop";if(Z==="cluster")return"agent-sandbox";if(!jM.has(Z))throw Error(`Unknown STUDIO_SANDBOX_PROVIDER="${$}" \u2014 expected "agent-sandbox", legacy "cluster", or "user-desktop".`);return Z}function YK($,Z){let Y=$.home||Z.DATA_DIR||Z.DECOCMS_HOME||`${UM()}/deco`,Q=$.localMode,W=$.nodeEnv||Z.NODE_ENV||"development",J=Z.NATS_URL||"nats://localhost:4222";return{settings:{nodeEnv:W,port:Number($.port)||Number(Z.PORT)||3000,baseUrl:$.baseUrl||Z.BASE_URL,dataDir:Y,databasePgSsl:v9(Z.DATABASE_PG_SSL),databasePoolMax:Number(Z.DATABASE_POOL_MAX)||5,betterAuthSecret:Z.BETTER_AUTH_SECRET||"",encryptionKey:Z.ENCRYPTION_KEY||"",meshJwtSecret:Z.MESH_JWT_SECRET,localMode:Q,disableRateLimit:v9(Z.DISABLE_RATE_LIMIT),studioProvisionSecretKey:Z.STUDIO_PROVISION_SECRET_KEY,clickhouseUrl:Z.CLICKHOUSE_URL,monitoringOtlpEndpoint:Z.MONITORING_OTLP_ENDPOINT,otelServiceName:Z.OTEL_SERVICE_NAME||"studio",configPath:Z.CONFIG_PATH||"./config.json",aiGatewayEnabled:v9(Z.DECO_AI_GATEWAY_ENABLED),aiGatewayUrl:Z.DECO_AI_GATEWAY_URL||"https://ai-site.deco.site",enableDecoImport:v9(Z.ENABLE_DECO_IMPORT),orgFsClusterMounts:v9(Z.ORGFS_CLUSTER_MOUNTS),orgFsPublicSetsJson:Z.ORGFS_PUBLIC_SETS,s3Endpoint:Z.S3_ENDPOINT,s3Bucket:Z.S3_BUCKET,s3Region:Z.S3_REGION||"auto",s3AccessKeyId:Z.S3_ACCESS_KEY_ID,s3SecretAccessKey:Z.S3_SECRET_ACCESS_KEY,s3ForcePathStyle:Z.S3_FORCE_PATH_STYLE===void 0||Z.S3_FORCE_PATH_STYLE===""||Z.S3_FORCE_PATH_STYLE==="true"||Z.S3_FORCE_PATH_STYLE==="1",monitoringS3Bucket:Z.MONITORING_S3_BUCKET,monitoringS3Endpoint:Z.MONITORING_S3_ENDPOINT,monitoringS3Region:Z.MONITORING_S3_REGION,monitoringS3AccessKeyId:Z.MONITORING_S3_ACCESS_KEY_ID,monitoringS3SecretAccessKey:Z.MONITORING_S3_SECRET_ACCESS_KEY,monitoringS3Prefix:Z.MONITORING_S3_PREFIX,duckdbExtensionDirectory:Z.DUCKDB_EXTENSION_DIRECTORY||"/opt/duckdb/extensions",isCli:!0,noTui:$.noTui===!0,podName:Z.POD_NAME??crypto.randomUUID(),sandboxProviderKind:AM(Z.STUDIO_SANDBOX_PROVIDER),decoSupabaseUrl:Z.DECO_SUPABASE_URL,decoSupabaseServiceKey:Z.DECO_SUPABASE_SERVICE_KEY,firecrawlApiKey:Z.FIRECRAWL_API_KEY},externalDatabaseUrl:ZK(Z.DATABASE_URL),externalNatsUrl:ZK(J),skipMigrations:$.skipMigrations}}var H4=null;function b8(){if(!H4)zM();return H4}function zM(){if(H4)return;let $={...process.env},Z=YK({port:$.PORT||"3000",home:$.DATA_DIR||$.DECOCMS_HOME||"",localMode:$.DECOCMS_LOCAL_MODE==="true",skipMigrations:!0,noTui:$.DECO_NO_TUI==="true",vitePort:$.VITE_PORT,baseUrl:$.BASE_URL},$);H4=Object.freeze({...Z.settings,databaseUrl:$.DATABASE_URL??"postgresql://postgres:postgres@localhost:5432/postgres",natsUrls:($.NATS_URL||"nats://localhost:4222").split(",").map((Y)=>Y.trim()).filter(Boolean)})}import{createContextKey as wM,metrics as EM,propagation as Gp,ROOT_CONTEXT as Kp,SpanStatusCode as Hp,trace as RM}from"@opentelemetry/api";import{logs as _M,SeverityNumber as KQ}from"@opentelemetry/api-logs";import{OTLPLogExporter as Dp}from"@opentelemetry/exporter-logs-otlp-proto";import{PrometheusExporter as CM}from"@opentelemetry/exporter-prometheus";import{OTLPTraceExporter as Up}from"@opentelemetry/exporter-trace-otlp-proto";import{RuntimeNodeInstrumentation as Ap}from"@opentelemetry/instrumentation-runtime-node";import{context as Zl,propagation as Yl,SpanKind as Ql,SpanStatusCode as Xl}from"@opentelemetry/api";var Jl=globalThis.fetch;import{ExportResultCode as zl}from"@opentelemetry/core";import{ExportResultCode as B4}from"@opentelemetry/core";import{mkdir as OM,rename as qM,writeFile as NM}from"fs/promises";import{join as F4}from"path";class D4{bufferItems=[];bufferBytes=0;flushTimer=null;flushQueue=Promise.resolve();basePath;flushThreshold;maxBufferBytes;isShutdown=!1;knownDirs=new Set;partitionKey;constructor($){this.basePath=$.basePath,this.flushThreshold=$.flushThreshold??1000,this.maxBufferBytes=$.maxBufferBytes??10485760,this.partitionKey=$.partitionKey;let Z=$.flushIntervalMs??60000;if(Z>0&&Z<3600000){if(this.flushTimer=setInterval(()=>{this.flush().catch((Y)=>{console.error("[NDJSONExporter] Timer flush failed:",Y)})},Z),this.flushTimer&&typeof this.flushTimer==="object"&&"unref"in this.flushTimer)this.flushTimer.unref()}}exportRows($){if(this.isShutdown)return Promise.resolve({code:B4.FAILED});for(let Z of $){let Y=JSON.stringify(Z),Q=this.partitionKey?this.partitionKey(Z):"";this.bufferItems.push({partition:Q,json:Y}),this.bufferBytes+=Buffer.byteLength(Y,"utf8")+1}if(this.bufferItems.length>=this.flushThreshold||this.bufferBytes>=this.maxBufferBytes)return this.flush().then(()=>({code:B4.SUCCESS})).catch((Z)=>{return console.error("[NDJSONExporter] Flush failed:",Z),{code:B4.FAILED}});return Promise.resolve({code:B4.SUCCESS})}async shutdown(){if(this.isShutdown=!0,this.flushTimer)clearInterval(this.flushTimer),this.flushTimer=null;try{await this.flushQueue}catch{}if(this.bufferItems.length>0)await this.flush()}async forceFlush(){try{await this.flushQueue}catch{}if(this.bufferItems.length>0)await this.flush()}flush(){let Z=this.flushQueue.catch(()=>{}).then(()=>this.doFlush());return this.flushQueue=Z,Z}async doFlush(){if(this.bufferItems.length===0)return;let $=this.bufferItems;this.bufferItems=[],this.bufferBytes=0;let Z=new Map;for(let W of $){let J=Z.get(W.partition);if(!J)J=[],Z.set(W.partition,J);J.push(W.json)}let Y=await Promise.allSettled(Array.from(Z.entries()).map(([W,J])=>this.writeNDJSON(J,W).then(()=>W))),Q=Y.find((W)=>W.status==="rejected");if(Q){let W=new Set;for(let G of Y)if(G.status==="fulfilled")W.add(G.value);let J=$.filter((G)=>!W.has(G.partition));this.bufferItems=J.concat(this.bufferItems),this.bufferBytes=0;for(let G of this.bufferItems)this.bufferBytes+=Buffer.byteLength(G.json,"utf8")+1;throw Q.reason}}async writeNDJSON($,Z){let Y=new Date,Q=[String(Y.getUTCFullYear()),String(Y.getUTCMonth()+1).padStart(2,"0"),String(Y.getUTCDate()).padStart(2,"0"),String(Y.getUTCHours()).padStart(2,"0")],W=Z?F4(this.basePath,Z,...Q):F4(this.basePath,...Q);if(!this.knownDirs.has(W))await OM(W,{recursive:!0,mode:448}),this.knownDirs.add(W);let J=`${crypto.randomUUID()}.ndjson`,G=F4(W,`.${J}.tmp`),K=F4(W,J),B=$.join(`
|
|
941
941
|
`)+`
|
|
942
|
-
`;await NM(G,B,{mode:384}),await qM(G,K)}}import{ExportResultCode as Pl}from"@opentelemetry/core";import{AggregationTemporality as El,DataPointType as Rl}from"@opentelemetry/sdk-metrics";import{ExportResultCode as bl}from"@opentelemetry/core";var kl=Buffer.byteLength("... [TRUNCATED]","utf8");import{BatchLogRecordProcessor as Rp,LoggerProvider as _p}from"@opentelemetry/sdk-logs";import{detectResources as Ip,envDetector as fp,hostDetector as Sp,osDetector as bp,processDetector as vp,resourceFromAttributes as yp}from"@opentelemetry/resources";import{PeriodicExportingMetricReader as kp}from"@opentelemetry/sdk-metrics";import{NOOP_LOGGER as ul}from"@opentelemetry/api-logs";import{NodeSDK as up}from"@opentelemetry/sdk-node";import{BatchSpanProcessor as mp,SamplingDecision as v8}from"@opentelemetry/sdk-trace-base";import{SpanStatusCode as il}from"@opentelemetry/api";var IM="__d",fM=wM("Current request"),SM=1;var XK=($)=>{let Y=new URL($.url).searchParams.get(IM);if(Y==="")return crypto.randomUUID();if(!Y)Y=$.headers.get("x-trace-debug-id");return Y};class WK{inner;constructor($){this.inner=$}shouldSample($,Z,Y,Q,W,J){let G=$.getValue(fM);if(!G){if(this.inner)return this.inner.shouldSample($,Z,Y,Q,W,J);return{decision:v8.RECORD_AND_SAMPLED}}let K=XK(G);if(K)return{decision:v8.RECORD_AND_SAMPLED,attributes:{"trace.debug.id":K}};if(this.inner){let B=this.inner.shouldSample($,Z,Y,Q,W,J);if(B.decision===v8.RECORD_AND_SAMPLED){let D=crypto.randomUUID();B.attributes={...B.attributes??{},"trace.debug.id":D}}return B}return{decision:v8.NOT_RECORD}}toString(){return"DebugSampler"}}class JK{ratio;constructor($){this.ratio=$}shouldSample(){if(Math.random()<this.ratio)return{decision:v8.RECORD_AND_SAMPLED};return{decision:v8.NOT_RECORD}}toString(){return`RatioSampler(${this.ratio})`}}var pp=new CM({preventServerStart:!0}),ip=new WK(new JK(SM));var QK=RM.getTracer("studio","1.0.0"),V4=EM.getMeter("studio","1.0.0"),bM=_M.getLogger("studio","1.0.0"),HQ=($,Z,Y)=>{let Q={},W=Y,J=Y[Y.length-1];if(J!==null&&typeof J==="object"&&!Array.isArray(J)&&!(J instanceof Error)&&Object.getPrototypeOf(J)===Object.prototype)Q=J,W=Y.slice(0,-1);let G=W.map((K)=>{if(K instanceof Error)return`${K.name}: ${K.message}`;if(typeof K==="object")try{return JSON.stringify(K)}catch{return"[Object]"}return String(K)}).join(" ");bM.emit({severityNumber:$,severityText:Z,body:G,attributes:{"log.source":"console",...Q}})},BQ={error:console.error.bind(console),warn:console.warn.bind(console),debug:console.debug.bind(console)};console.error=(...$)=>{HQ(KQ.ERROR,"ERROR",$),BQ.error(...$)};console.warn=(...$)=>{HQ(KQ.WARN,"WARN",$),BQ.warn(...$)};console.debug=(...$)=>{HQ(KQ.DEBUG,"DEBUG",$),BQ.debug(...$)};var FQ,GK=0,DQ=500;function vM(){if(FQ)return;let $=performance.now()+DQ;FQ=setInterval(()=>{let Z=performance.now();GK=Math.max(0,Z-$),$=Z+DQ},DQ),FQ.unref?.()}function KK(){return vM(),GK}var TM=()=>V4.createHistogram("db.query.duration",{description:"Database query execution duration in milliseconds",unit:"ms"}),HK=()=>V4.createHistogram("db.pool.acquire.duration",{description:"Time spent waiting to acquire a connection from the pool",unit:"ms"}),BK=400,kM=100,xM=($)=>(Z)=>{let Y={"db.statement":Z.query.sql,"db.status":Z.level==="error"?"error":"success"};if(Z.queryDurationMillis>BK){let Q=KK(),W=Q>BK/2;console.error(W?"Slow query measurement \u2014 likely event-loop lag, not slow SQL:":"Slow query detected:",{durationMs:Z.queryDurationMillis,eventLoopLagMs:Math.round(Q),sql:Z.query.sql,pool:{total:$.totalCount,idle:$.idleCount,waiting:$.waitingCount,max:L4()}})}if(TM().record(Z.queryDurationMillis,Y),Z.level==="error")console.error("Query failed:",{durationMs:Z.queryDurationMillis,error:Z.error,sql:Z.query.sql})};function gM($){let Z=$.connect.bind($);return $.connect=(Y)=>{if(typeof Y==="function")return Z(Y);let Q=performance.now(),W=L4(),J=$.idleCount===0&&$.totalCount>=W,G=$.idleCount;return Z().then((K)=>{let B=performance.now()-Q;if(HK().record(B,{"db.pool.outcome":J?"contended":"available"}),B>kM)if(J)console.error("Slow pool acquire \u2014 pool saturated:",{waitMs:B,total:$.totalCount,idle:$.idleCount,waiting:$.waitingCount,max:W});else console.warn("Slow pool acquire \u2014 event-loop lag (not pool):",{waitMs:B,idleAtStart:G,total:$.totalCount,max:W});return K},(K)=>{throw HK().record(performance.now()-Q,{"db.pool.outcome":"error"}),K})},$}var VK={keepAlive:!0,keepAliveInitialDelayMillis:1e4,idleTimeoutMillis:300000,connectionTimeoutMillis:30000,allowExitOnIdle:!0};function LK(){try{return b8().databasePgSsl}catch{return!1}}function L4(){try{return b8().databasePoolMax}catch{return 10}}function uM($){let Z=gM(new DK({connectionString:$,max:L4(),ssl:LK(),...VK})),Y=new FK({pool:Z});return{type:"postgres",db:new yM({dialect:Y,log:xM(Z)}),pool:Z}}function T9(){return b8().databaseUrl}function UK($){let Z=$||T9();return new FK({pool:new DK({connectionString:Z,max:L4(),ssl:LK(),...VK})})}function hM($){let Z=$||T9();return uM(Z)}async function jK($){if(await $.db.destroy(),!$.pool.ended)await $.pool.end();if($===y9)y9=null}var y9=null;function VQ(){if(!y9)y9=hM(T9());return y9}async function AK($){let Y={database:UK($||T9()),plugins:[pM({dynamicAccessControl:{enabled:!0,enableCustomResources:!0}}),iM(),cM(),dM(),aM(),rM({loginPage:"/login"}),lM(),nM({sendMagicLink:async()=>{}}),oM({sendVerificationOTP:async()=>{}})]},{toBeAdded:Q,toBeCreated:W,runMigrations:J}=await mM(Y);if(!Q.length&&!W.length)return"up to date";return await J(),`${W.length+Q.length} table(s) migrated`}import{createContext as sM,useContext as Di}from"react";import{jsx as Ui}from"react/jsx-runtime";var Vi=sM(void 0);import $6 from"react";import Ni from"react-dom";function YP($){if(!$||typeof document>"u")return;let Z=document.head||document.getElementsByTagName("head")[0],Y=document.createElement("style");Y.type="text/css",Z.appendChild(Y),Y.styleSheet?Y.styleSheet.cssText=$:Y.appendChild(document.createTextNode($))}var Mi=Array(12).fill(0);var UQ=1;class zK{constructor(){this.subscribe=($)=>{return this.subscribers.push($),()=>{let Z=this.subscribers.indexOf($);this.subscribers.splice(Z,1)}},this.publish=($)=>{this.subscribers.forEach((Z)=>Z($))},this.addToast=($)=>{this.publish($),this.toasts=[...this.toasts,$]},this.create=($)=>{var Z;let{message:Y,...Q}=$,W=typeof($==null?void 0:$.id)==="number"||((Z=$.id)==null?void 0:Z.length)>0?$.id:UQ++,J=this.toasts.find((K)=>{return K.id===W}),G=$.dismissible===void 0?!0:$.dismissible;if(this.dismissedToasts.has(W))this.dismissedToasts.delete(W);if(J)this.toasts=this.toasts.map((K)=>{if(K.id===W)return this.publish({...K,...$,id:W,title:Y}),{...K,...$,id:W,dismissible:G,title:Y};return K});else this.addToast({title:Y,...Q,dismissible:G,id:W});return W},this.dismiss=($)=>{if($)this.dismissedToasts.add($),requestAnimationFrame(()=>this.subscribers.forEach((Z)=>Z({id:$,dismiss:!0})));else this.toasts.forEach((Z)=>{this.subscribers.forEach((Y)=>Y({id:Z.id,dismiss:!0}))});return $},this.message=($,Z)=>{return this.create({...Z,message:$})},this.error=($,Z)=>{return this.create({...Z,message:$,type:"error"})},this.success=($,Z)=>{return this.create({...Z,type:"success",message:$})},this.info=($,Z)=>{return this.create({...Z,type:"info",message:$})},this.warning=($,Z)=>{return this.create({...Z,type:"warning",message:$})},this.loading=($,Z)=>{return this.create({...Z,type:"loading",message:$})},this.promise=($,Z)=>{if(!Z)return;let Y=void 0;if(Z.loading!==void 0)Y=this.create({...Z,promise:$,type:"loading",message:Z.loading,description:typeof Z.description!=="function"?Z.description:void 0});let Q=Promise.resolve($ instanceof Function?$():$),W=Y!==void 0,J,G=Q.then(async(B)=>{if(J=["resolve",B],$6.isValidElement(B))W=!1,this.create({id:Y,type:"default",message:B});else if(XP(B)&&!B.ok){W=!1;let V=typeof Z.error==="function"?await Z.error(`HTTP error! status: ${B.status}`):Z.error,L=typeof Z.description==="function"?await Z.description(`HTTP error! status: ${B.status}`):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"error",description:L,...O})}else if(B instanceof Error){W=!1;let V=typeof Z.error==="function"?await Z.error(B):Z.error,L=typeof Z.description==="function"?await Z.description(B):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"error",description:L,...O})}else if(Z.success!==void 0){W=!1;let V=typeof Z.success==="function"?await Z.success(B):Z.success,L=typeof Z.description==="function"?await Z.description(B):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"success",description:L,...O})}}).catch(async(B)=>{if(J=["reject",B],Z.error!==void 0){W=!1;let D=typeof Z.error==="function"?await Z.error(B):Z.error,V=typeof Z.description==="function"?await Z.description(B):Z.description,A=typeof D==="object"&&!$6.isValidElement(D)?D:{message:D};this.create({id:Y,type:"error",description:V,...A})}}).finally(()=>{if(W)this.dismiss(Y),Y=void 0;Z.finally==null||Z.finally.call(Z)}),K=()=>new Promise((B,D)=>G.then(()=>J[0]==="reject"?D(J[1]):B(J[1])).catch(D));if(typeof Y!=="string"&&typeof Y!=="number")return{unwrap:K};else return Object.assign(Y,{unwrap:K})},this.custom=($,Z)=>{let Y=(Z==null?void 0:Z.id)||UQ++;return this.create({jsx:$(Y),id:Y,...Z}),Y},this.getActiveToasts=()=>{return this.toasts.filter(($)=>!this.dismissedToasts.has($.id))},this.subscribers=[],this.toasts=[],this.dismissedToasts=new Set}}var V0=new zK,QP=($,Z)=>{let Y=(Z==null?void 0:Z.id)||UQ++;return V0.addToast({title:$,...Z,id:Y}),Y},XP=($)=>{return $&&typeof $==="object"&&"ok"in $&&typeof $.ok==="boolean"&&"status"in $&&typeof $.status==="number"},WP=QP,JP=()=>V0.toasts,GP=()=>V0.getActiveToasts(),KP=Object.assign(WP,{success:V0.success,info:V0.info,warning:V0.warning,error:V0.error,custom:V0.custom,message:V0.message,promise:V0.promise,dismiss:V0.dismiss,loading:V0.loading},{getHistory:JP,getToasts:GP});YP("[data-sonner-toaster][dir=ltr],html[dir=ltr]{--toast-icon-margin-start:-3px;--toast-icon-margin-end:4px;--toast-svg-margin-start:-1px;--toast-svg-margin-end:0px;--toast-button-margin-start:auto;--toast-button-margin-end:0;--toast-close-button-start:0;--toast-close-button-end:unset;--toast-close-button-transform:translate(-35%, -35%)}[data-sonner-toaster][dir=rtl],html[dir=rtl]{--toast-icon-margin-start:4px;--toast-icon-margin-end:-3px;--toast-svg-margin-start:0px;--toast-svg-margin-end:-1px;--toast-button-margin-start:0;--toast-button-margin-end:auto;--toast-close-button-start:unset;--toast-close-button-end:0;--toast-close-button-transform:translate(35%, -35%)}[data-sonner-toaster]{position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1:hsl(0, 0%, 99%);--gray2:hsl(0, 0%, 97.3%);--gray3:hsl(0, 0%, 95.1%);--gray4:hsl(0, 0%, 93%);--gray5:hsl(0, 0%, 90.9%);--gray6:hsl(0, 0%, 88.7%);--gray7:hsl(0, 0%, 85.8%);--gray8:hsl(0, 0%, 78%);--gray9:hsl(0, 0%, 56.1%);--gray10:hsl(0, 0%, 52.3%);--gray11:hsl(0, 0%, 43.5%);--gray12:hsl(0, 0%, 9%);--border-radius:8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:0;z-index:999999999;transition:transform .4s ease}@media (hover:none) and (pointer:coarse){[data-sonner-toaster][data-lifted=true]{transform:none}}[data-sonner-toaster][data-x-position=right]{right:var(--offset-right)}[data-sonner-toaster][data-x-position=left]{left:var(--offset-left)}[data-sonner-toaster][data-x-position=center]{left:50%;transform:translateX(-50%)}[data-sonner-toaster][data-y-position=top]{top:var(--offset-top)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--offset-bottom)}[data-sonner-toast]{--y:translateY(100%);--lift-amount:calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:0;overflow-wrap:anywhere}[data-sonner-toast][data-styled=true]{padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px rgba(0,0,0,.1);width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}[data-sonner-toast]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-y-position=top]{top:0;--y:translateY(-100%);--lift:1;--lift-amount:calc(1 * var(--gap))}[data-sonner-toast][data-y-position=bottom]{bottom:0;--y:translateY(100%);--lift:-1;--lift-amount:calc(var(--lift) * var(--gap))}[data-sonner-toast][data-styled=true] [data-description]{font-weight:400;line-height:1.4;color:#3f3f3f}[data-rich-colors=true][data-sonner-toast][data-styled=true] [data-description]{color:inherit}[data-sonner-toaster][data-sonner-theme=dark] [data-description]{color:#e8e8e8}[data-sonner-toast][data-styled=true] [data-title]{font-weight:500;line-height:1.5;color:inherit}[data-sonner-toast][data-styled=true] [data-icon]{display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}[data-sonner-toast][data-promise=true] [data-icon]>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}[data-sonner-toast][data-styled=true] [data-icon]>*{flex-shrink:0}[data-sonner-toast][data-styled=true] [data-icon] svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}[data-sonner-toast][data-styled=true] [data-content]{display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;font-weight:500;cursor:pointer;outline:0;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}[data-sonner-toast][data-styled=true] [data-button]:focus-visible{box-shadow:0 0 0 2px rgba(0,0,0,.4)}[data-sonner-toast][data-styled=true] [data-button]:first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}[data-sonner-toast][data-styled=true] [data-cancel]{color:var(--normal-text);background:rgba(0,0,0,.08)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-styled=true] [data-cancel]{background:rgba(255,255,255,.3)}[data-sonner-toast][data-styled=true] [data-close-button]{position:absolute;left:var(--toast-close-button-start);right:var(--toast-close-button-end);top:0;height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);background:var(--normal-bg);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast][data-styled=true] [data-close-button]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-styled=true] [data-disabled=true]{cursor:not-allowed}[data-sonner-toast][data-styled=true]:hover [data-close-button]:hover{background:var(--gray2);border-color:var(--gray5)}[data-sonner-toast][data-swiping=true]::before{content:'';position:absolute;left:-100%;right:-100%;height:100%;z-index:-1}[data-sonner-toast][data-y-position=top][data-swiping=true]::before{bottom:50%;transform:scaleY(3) translateY(50%)}[data-sonner-toast][data-y-position=bottom][data-swiping=true]::before{top:50%;transform:scaleY(3) translateY(-50%)}[data-sonner-toast][data-swiping=false][data-removed=true]::before{content:'';position:absolute;inset:0;transform:scaleY(2)}[data-sonner-toast][data-expanded=true]::after{content:'';position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}[data-sonner-toast][data-mounted=true]{--y:translateY(0);opacity:1}[data-sonner-toast][data-expanded=false][data-front=false]{--scale:var(--toasts-before) * 0.05 + 1;--y:translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));height:var(--front-toast-height)}[data-sonner-toast]>*{transition:opacity .4s}[data-sonner-toast][data-x-position=right]{right:0}[data-sonner-toast][data-x-position=left]{left:0}[data-sonner-toast][data-expanded=false][data-front=false][data-styled=true]>*{opacity:0}[data-sonner-toast][data-visible=false]{opacity:0;pointer-events:none}[data-sonner-toast][data-mounted=true][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}[data-sonner-toast][data-removed=true][data-front=true][data-swipe-out=false]{--y:translateY(calc(var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=false]{--y:translateY(40%);opacity:0;transition:transform .5s,opacity .2s}[data-sonner-toast][data-removed=true][data-front=false]::before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y,0)) translateX(var(--swipe-amount-x,0));transition:none}[data-sonner-toast][data-swiped=true]{user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media (max-width:600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--mobile-offset-bottom)}[data-sonner-toaster][data-y-position=top]{top:var(--mobile-offset-top)}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-sonner-theme=light]{--normal-bg:#fff;--normal-border:var(--gray4);--normal-text:var(--gray12);--success-bg:hsl(143, 85%, 96%);--success-border:hsl(145, 92%, 87%);--success-text:hsl(140, 100%, 27%);--info-bg:hsl(208, 100%, 97%);--info-border:hsl(221, 91%, 93%);--info-text:hsl(210, 92%, 45%);--warning-bg:hsl(49, 100%, 97%);--warning-border:hsl(49, 91%, 84%);--warning-text:hsl(31, 92%, 45%);--error-bg:hsl(359, 100%, 97%);--error-border:hsl(359, 100%, 94%);--error-text:hsl(360, 100%, 45%)}[data-sonner-toaster][data-sonner-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg:#000;--normal-border:hsl(0, 0%, 20%);--normal-text:var(--gray1)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg:#fff;--normal-border:var(--gray3);--normal-text:var(--gray12)}[data-sonner-toaster][data-sonner-theme=dark]{--normal-bg:#000;--normal-bg-hover:hsl(0, 0%, 12%);--normal-border:hsl(0, 0%, 20%);--normal-border-hover:hsl(0, 0%, 25%);--normal-text:var(--gray1);--success-bg:hsl(150, 100%, 6%);--success-border:hsl(147, 100%, 12%);--success-text:hsl(150, 86%, 65%);--info-bg:hsl(215, 100%, 6%);--info-border:hsl(223, 43%, 17%);--info-text:hsl(216, 87%, 65%);--warning-bg:hsl(64, 100%, 6%);--warning-border:hsl(60, 100%, 9%);--warning-text:hsl(46, 87%, 65%);--error-bg:hsl(358, 76%, 10%);--error-border:hsl(357, 89%, 16%);--error-text:hsl(358, 100%, 81%)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size:16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:first-child{animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}100%{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}100%{opacity:.15}}@media (prefers-reduced-motion){.sonner-loading-bar,[data-sonner-toast],[data-sonner-toast]>*{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}");import*as HP from"zod/v3";import*as U4 from"zod/v4-mini";function d6($){return!!$._zod}function L0($,Z){if(d6($))return U4.safeParse($,Z);return $.safeParse(Z)}function T8($){if(!$)return;let Z;if(d6($))Z=$._zod?.def?.shape;else Z=$.shape;if(!Z)return;if(typeof Z==="function")try{return Z()}catch{return}return Z}function jQ($){if(d6($)){let J=$._zod?.def;if(J){if(J.value!==void 0)return J.value;if(Array.isArray(J.values)&&J.values.length>0)return J.values[0]}}let Y=$._def;if(Y){if(Y.value!==void 0)return Y.value;if(Array.isArray(Y.values)&&Y.values.length>0)return Y.values[0]}let Q=$.value;if(Q!==void 0)return Q;return}import*as F from"zod/v4";var n6="2025-11-25";var AQ=[n6,"2025-06-18","2025-03-26","2024-11-05","2024-10-07"],P6="io.modelcontextprotocol/related-task",A4="2.0",C1=F.custom(($)=>$!==null&&(typeof $==="object"||typeof $==="function")),OK=F.union([F.string(),F.number().int()]),qK=F.string(),Ii=F.looseObject({ttl:F.number().optional(),pollInterval:F.number().optional()}),BP=F.object({ttl:F.number().optional()}),FP=F.object({taskId:F.string()}),zQ=F.looseObject({progressToken:OK.optional(),[P6]:FP.optional()}),J0=F.object({_meta:zQ.optional()}),k9=J0.extend({task:BP.optional()}),NK=($)=>k9.safeParse($).success,y1=F.object({method:F.string(),params:J0.loose().optional()}),U0=F.object({_meta:zQ.optional()}),j0=F.object({method:F.string(),params:U0.loose().optional()}),T1=F.looseObject({_meta:zQ.optional()}),z4=F.union([F.string(),F.number().int()]),MK=F.object({jsonrpc:F.literal(A4),id:z4,...y1.shape}).strict(),x9=($)=>MK.safeParse($).success,PK=F.object({jsonrpc:F.literal(A4),...j0.shape}).strict(),wK=($)=>PK.safeParse($).success,OQ=F.object({jsonrpc:F.literal(A4),id:z4,result:T1}).strict(),r6=($)=>OQ.safeParse($).success;var d;(function($){$[$.ConnectionClosed=-32000]="ConnectionClosed",$[$.RequestTimeout=-32001]="RequestTimeout",$[$.ParseError=-32700]="ParseError",$[$.InvalidRequest=-32600]="InvalidRequest",$[$.MethodNotFound=-32601]="MethodNotFound",$[$.InvalidParams=-32602]="InvalidParams",$[$.InternalError=-32603]="InternalError",$[$.UrlElicitationRequired=-32042]="UrlElicitationRequired"})(d||(d={}));var qQ=F.object({jsonrpc:F.literal(A4),id:z4.optional(),error:F.object({code:F.number().int(),message:F.string(),data:F.unknown().optional()})}).strict();var EK=($)=>qQ.safeParse($).success;var w6=F.union([MK,PK,OQ,qQ]),fi=F.union([OQ,qQ]),E6=T1.strict(),DP=U0.extend({requestId:z4.optional(),reason:F.string().optional()}),O4=j0.extend({method:F.literal("notifications/cancelled"),params:DP}),VP=F.object({src:F.string(),mimeType:F.string().optional(),sizes:F.array(F.string()).optional(),theme:F.enum(["light","dark"]).optional()}),g9=F.object({icons:F.array(VP).optional()}),k8=F.object({name:F.string(),title:F.string().optional()}),RK=k8.extend({...k8.shape,...g9.shape,version:F.string(),websiteUrl:F.string().optional(),description:F.string().optional()}),LP=F.intersection(F.object({applyDefaults:F.boolean().optional()}),F.record(F.string(),F.unknown())),UP=F.preprocess(($)=>{if($&&typeof $==="object"&&!Array.isArray($)){if(Object.keys($).length===0)return{form:{}}}return $},F.intersection(F.object({form:LP.optional(),url:C1.optional()}),F.record(F.string(),F.unknown()).optional())),jP=F.looseObject({list:C1.optional(),cancel:C1.optional(),requests:F.looseObject({sampling:F.looseObject({createMessage:C1.optional()}).optional(),elicitation:F.looseObject({create:C1.optional()}).optional()}).optional()}),AP=F.looseObject({list:C1.optional(),cancel:C1.optional(),requests:F.looseObject({tools:F.looseObject({call:C1.optional()}).optional()}).optional()}),zP=F.object({experimental:F.record(F.string(),C1).optional(),sampling:F.object({context:C1.optional(),tools:C1.optional()}).optional(),elicitation:UP.optional(),roots:F.object({listChanged:F.boolean().optional()}).optional(),tasks:jP.optional(),extensions:F.record(F.string(),C1).optional()}),OP=J0.extend({protocolVersion:F.string(),capabilities:zP,clientInfo:RK}),_K=y1.extend({method:F.literal("initialize"),params:OP});var qP=F.object({experimental:F.record(F.string(),C1).optional(),logging:C1.optional(),completions:C1.optional(),prompts:F.object({listChanged:F.boolean().optional()}).optional(),resources:F.object({subscribe:F.boolean().optional(),listChanged:F.boolean().optional()}).optional(),tools:F.object({listChanged:F.boolean().optional()}).optional(),tasks:AP.optional(),extensions:F.record(F.string(),C1).optional()}),NQ=T1.extend({protocolVersion:F.string(),capabilities:qP,serverInfo:RK,instructions:F.string().optional()}),MQ=j0.extend({method:F.literal("notifications/initialized"),params:U0.optional()}),CK=($)=>MQ.safeParse($).success,q4=y1.extend({method:F.literal("ping"),params:J0.optional()}),NP=F.object({progress:F.number(),total:F.optional(F.number()),message:F.optional(F.string())}),MP=F.object({...U0.shape,...NP.shape,progressToken:OK}),N4=j0.extend({method:F.literal("notifications/progress"),params:MP}),PP=J0.extend({cursor:qK.optional()}),u9=y1.extend({params:PP.optional()}),h9=T1.extend({nextCursor:qK.optional()}),wP=F.enum(["working","input_required","completed","failed","cancelled"]),m9=F.object({taskId:F.string(),status:wP,ttl:F.union([F.number(),F.null()]),createdAt:F.string(),lastUpdatedAt:F.string(),pollInterval:F.optional(F.number()),statusMessage:F.optional(F.string())}),R6=T1.extend({task:m9}),EP=U0.merge(m9),l9=j0.extend({method:F.literal("notifications/tasks/status"),params:EP}),M4=y1.extend({method:F.literal("tasks/get"),params:J0.extend({taskId:F.string()})}),P4=T1.merge(m9),w4=y1.extend({method:F.literal("tasks/result"),params:J0.extend({taskId:F.string()})}),Si=T1.loose(),E4=u9.extend({method:F.literal("tasks/list")}),R4=h9.extend({tasks:F.array(m9)}),_4=y1.extend({method:F.literal("tasks/cancel"),params:J0.extend({taskId:F.string()})}),IK=T1.merge(m9),fK=F.object({uri:F.string(),mimeType:F.optional(F.string()),_meta:F.record(F.string(),F.unknown()).optional()}),SK=fK.extend({text:F.string()}),PQ=F.string().refine(($)=>{try{return atob($),!0}catch{return!1}},{message:"Invalid Base64 string"}),bK=fK.extend({blob:PQ}),p9=F.enum(["user","assistant"]),x8=F.object({audience:F.array(p9).optional(),priority:F.number().min(0).max(1).optional(),lastModified:F.iso.datetime({offset:!0}).optional()}),vK=F.object({...k8.shape,...g9.shape,uri:F.string(),description:F.optional(F.string()),mimeType:F.optional(F.string()),size:F.optional(F.number()),annotations:x8.optional(),_meta:F.optional(F.looseObject({}))}),RP=F.object({...k8.shape,...g9.shape,uriTemplate:F.string(),description:F.optional(F.string()),mimeType:F.optional(F.string()),annotations:x8.optional(),_meta:F.optional(F.looseObject({}))}),wQ=u9.extend({method:F.literal("resources/list")}),EQ=h9.extend({resources:F.array(vK)}),RQ=u9.extend({method:F.literal("resources/templates/list")}),_Q=h9.extend({resourceTemplates:F.array(RP)}),CQ=J0.extend({uri:F.string()}),_P=CQ,IQ=y1.extend({method:F.literal("resources/read"),params:_P}),fQ=T1.extend({contents:F.array(F.union([SK,bK]))}),SQ=j0.extend({method:F.literal("notifications/resources/list_changed"),params:U0.optional()}),CP=CQ,IP=y1.extend({method:F.literal("resources/subscribe"),params:CP}),fP=CQ,SP=y1.extend({method:F.literal("resources/unsubscribe"),params:fP}),bP=U0.extend({uri:F.string()}),vP=j0.extend({method:F.literal("notifications/resources/updated"),params:bP}),yP=F.object({name:F.string(),description:F.optional(F.string()),required:F.optional(F.boolean())}),TP=F.object({...k8.shape,...g9.shape,description:F.optional(F.string()),arguments:F.optional(F.array(yP)),_meta:F.optional(F.looseObject({}))}),bQ=u9.extend({method:F.literal("prompts/list")}),vQ=h9.extend({prompts:F.array(TP)}),kP=J0.extend({name:F.string(),arguments:F.record(F.string(),F.string()).optional()}),yQ=y1.extend({method:F.literal("prompts/get"),params:kP}),TQ=F.object({type:F.literal("text"),text:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),kQ=F.object({type:F.literal("image"),data:PQ,mimeType:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),xQ=F.object({type:F.literal("audio"),data:PQ,mimeType:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),xP=F.object({type:F.literal("tool_use"),name:F.string(),id:F.string(),input:F.record(F.string(),F.unknown()),_meta:F.record(F.string(),F.unknown()).optional()}),gP=F.object({type:F.literal("resource"),resource:F.union([SK,bK]),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),uP=vK.extend({type:F.literal("resource_link")}),gQ=F.union([TQ,kQ,xQ,uP,gP]),hP=F.object({role:p9,content:gQ}),uQ=T1.extend({description:F.string().optional(),messages:F.array(hP)}),hQ=j0.extend({method:F.literal("notifications/prompts/list_changed"),params:U0.optional()}),mP=F.object({title:F.string().optional(),readOnlyHint:F.boolean().optional(),destructiveHint:F.boolean().optional(),idempotentHint:F.boolean().optional(),openWorldHint:F.boolean().optional()}),lP=F.object({taskSupport:F.enum(["required","optional","forbidden"]).optional()}),C4=F.object({...k8.shape,...g9.shape,description:F.string().optional(),inputSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),C1).optional(),required:F.array(F.string()).optional()}).catchall(F.unknown()),outputSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),C1).optional(),required:F.array(F.string()).optional()}).catchall(F.unknown()).optional(),annotations:mP.optional(),execution:lP.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),mQ=u9.extend({method:F.literal("tools/list")}),i9=h9.extend({tools:F.array(C4)}),a6=T1.extend({content:F.array(gQ).default([]),structuredContent:F.record(F.string(),F.unknown()).optional(),isError:F.boolean().optional()}),bi=a6.or(T1.extend({toolResult:F.unknown()})),pP=k9.extend({name:F.string(),arguments:F.record(F.string(),F.unknown()).optional()}),I4=y1.extend({method:F.literal("tools/call"),params:pP}),lQ=j0.extend({method:F.literal("notifications/tools/list_changed"),params:U0.optional()}),yK=F.object({autoRefresh:F.boolean().default(!0),debounceMs:F.number().int().nonnegative().default(300)}),pQ=F.enum(["debug","info","notice","warning","error","critical","alert","emergency"]),iP=J0.extend({level:pQ}),TK=y1.extend({method:F.literal("logging/setLevel"),params:iP}),cP=U0.extend({level:pQ,logger:F.string().optional(),data:F.unknown()}),dP=j0.extend({method:F.literal("notifications/message"),params:cP}),nP=F.object({name:F.string().optional()}),rP=F.object({hints:F.array(nP).optional(),costPriority:F.number().min(0).max(1).optional(),speedPriority:F.number().min(0).max(1).optional(),intelligencePriority:F.number().min(0).max(1).optional()}),aP=F.object({mode:F.enum(["auto","required","none"]).optional()}),oP=F.object({type:F.literal("tool_result"),toolUseId:F.string().describe("The unique identifier for the corresponding tool call."),content:F.array(gQ).default([]),structuredContent:F.object({}).loose().optional(),isError:F.boolean().optional(),_meta:F.record(F.string(),F.unknown()).optional()}),sP=F.discriminatedUnion("type",[TQ,kQ,xQ]),j4=F.discriminatedUnion("type",[TQ,kQ,xQ,xP,oP]),tP=F.object({role:p9,content:F.union([j4,F.array(j4)]),_meta:F.record(F.string(),F.unknown()).optional()}),eP=k9.extend({messages:F.array(tP),modelPreferences:rP.optional(),systemPrompt:F.string().optional(),includeContext:F.enum(["none","thisServer","allServers"]).optional(),temperature:F.number().optional(),maxTokens:F.number().int(),stopSequences:F.array(F.string()).optional(),metadata:C1.optional(),tools:F.array(C4).optional(),toolChoice:aP.optional()}),iQ=y1.extend({method:F.literal("sampling/createMessage"),params:eP}),c9=T1.extend({model:F.string(),stopReason:F.optional(F.enum(["endTurn","stopSequence","maxTokens"]).or(F.string())),role:p9,content:sP}),f4=T1.extend({model:F.string(),stopReason:F.optional(F.enum(["endTurn","stopSequence","maxTokens","toolUse"]).or(F.string())),role:p9,content:F.union([j4,F.array(j4)])}),$w=F.object({type:F.literal("boolean"),title:F.string().optional(),description:F.string().optional(),default:F.boolean().optional()}),Zw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),minLength:F.number().optional(),maxLength:F.number().optional(),format:F.enum(["email","uri","date","date-time"]).optional(),default:F.string().optional()}),Yw=F.object({type:F.enum(["number","integer"]),title:F.string().optional(),description:F.string().optional(),minimum:F.number().optional(),maximum:F.number().optional(),default:F.number().optional()}),Qw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),enum:F.array(F.string()),default:F.string().optional()}),Xw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),oneOf:F.array(F.object({const:F.string(),title:F.string()})),default:F.string().optional()}),Ww=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),enum:F.array(F.string()),enumNames:F.array(F.string()).optional(),default:F.string().optional()}),Jw=F.union([Qw,Xw]),Gw=F.object({type:F.literal("array"),title:F.string().optional(),description:F.string().optional(),minItems:F.number().optional(),maxItems:F.number().optional(),items:F.object({type:F.literal("string"),enum:F.array(F.string())}),default:F.array(F.string()).optional()}),Kw=F.object({type:F.literal("array"),title:F.string().optional(),description:F.string().optional(),minItems:F.number().optional(),maxItems:F.number().optional(),items:F.object({anyOf:F.array(F.object({const:F.string(),title:F.string()}))}),default:F.array(F.string()).optional()}),Hw=F.union([Gw,Kw]),Bw=F.union([Ww,Jw,Hw]),Fw=F.union([Bw,$w,Zw,Yw]),Dw=k9.extend({mode:F.literal("form").optional(),message:F.string(),requestedSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),Fw),required:F.array(F.string()).optional()})}),Vw=k9.extend({mode:F.literal("url"),message:F.string(),elicitationId:F.string(),url:F.string().url()}),Lw=F.union([Dw,Vw]),cQ=y1.extend({method:F.literal("elicitation/create"),params:Lw}),Uw=U0.extend({elicitationId:F.string()}),jw=j0.extend({method:F.literal("notifications/elicitation/complete"),params:Uw}),d9=T1.extend({action:F.enum(["accept","decline","cancel"]),content:F.preprocess(($)=>$===null?void 0:$,F.record(F.string(),F.union([F.string(),F.number(),F.boolean(),F.array(F.string())])).optional())}),Aw=F.object({type:F.literal("ref/resource"),uri:F.string()});var zw=F.object({type:F.literal("ref/prompt"),name:F.string()}),Ow=J0.extend({ref:F.union([zw,Aw]),argument:F.object({name:F.string(),value:F.string()}),context:F.object({arguments:F.record(F.string(),F.string()).optional()}).optional()}),kK=y1.extend({method:F.literal("completion/complete"),params:Ow});var dQ=T1.extend({completion:F.looseObject({values:F.array(F.string()).max(100),total:F.optional(F.number().int()),hasMore:F.optional(F.boolean())})}),qw=F.object({uri:F.string().startsWith("file://"),name:F.string().optional(),_meta:F.record(F.string(),F.unknown()).optional()}),Nw=y1.extend({method:F.literal("roots/list"),params:J0.optional()}),xK=T1.extend({roots:F.array(qw)}),Mw=j0.extend({method:F.literal("notifications/roots/list_changed"),params:U0.optional()}),vi=F.union([q4,_K,kK,TK,yQ,bQ,wQ,RQ,IQ,IP,SP,I4,mQ,M4,w4,E4,_4]),yi=F.union([O4,N4,MQ,Mw,l9]),Ti=F.union([E6,c9,f4,d9,xK,P4,R4,R6]),ki=F.union([q4,iQ,cQ,Nw,M4,w4,E4,_4]),xi=F.union([O4,N4,dP,vP,SQ,lQ,hQ,l9,jw]),gi=F.union([E6,NQ,dQ,uQ,vQ,EQ,_Q,fQ,a6,i9,P4,R4,R6]);class l extends Error{constructor($,Z,Y){super(`MCP error ${$}: ${Z}`);this.code=$,this.data=Y,this.name="McpError"}static fromError($,Z,Y){if($===d.UrlElicitationRequired&&Y){let Q=Y;if(Q.elicitations)return new gK(Q.elicitations,Z)}return new l($,Z,Y)}}class gK extends l{constructor($,Z=`URL elicitation${$.length>1?"s":""} required`){super(d.UrlElicitationRequired,Z,{elicitations:$})}get elicitations(){return this.data?.elicitations??[]}}function _6($){return $==="completed"||$==="failed"||$==="cancelled"}import*as Iw from"zod/v4-mini";var Pw=Symbol("Let zodToJsonSchema decide on which parser to use");import{ZodFirstPartyTypeKind as gd}from"zod/v3";import{ZodFirstPartyTypeKind as oi}from"zod/v3";import{ZodFirstPartyTypeKind as Mc}from"zod/v3";var Oc=new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function nQ($){let Y=T8($)?.method;if(!Y)throw Error("Schema is missing a method literal");let Q=jQ(Y);if(typeof Q!=="string")throw Error("Schema method literal must be a string");return Q}function rQ($,Z){let Y=L0($,Z);if(!Y.success)throw Y.error;return Y.data}var fw=60000;class S4{constructor($){if(this._options=$,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(O4,(Z)=>{this._oncancel(Z)}),this.setNotificationHandler(N4,(Z)=>{this._onprogress(Z)}),this.setRequestHandler(q4,(Z)=>({})),this._taskStore=$?.taskStore,this._taskMessageQueue=$?.taskMessageQueue,this._taskStore)this.setRequestHandler(M4,async(Z,Y)=>{let Q=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!Q)throw new l(d.InvalidParams,"Failed to retrieve task: Task not found");return{...Q}}),this.setRequestHandler(w4,async(Z,Y)=>{let Q=async()=>{let W=Z.params.taskId;if(this._taskMessageQueue){let G;while(G=await this._taskMessageQueue.dequeue(W,Y.sessionId)){if(G.type==="response"||G.type==="error"){let K=G.message,B=K.id,D=this._requestResolvers.get(B);if(D)if(this._requestResolvers.delete(B),G.type==="response")D(K);else{let V=K,L=new l(V.error.code,V.error.message,V.error.data);D(L)}else{let V=G.type==="response"?"Response":"Error";this._onerror(Error(`${V} handler missing for request ${B}`))}continue}await this._transport?.send(G.message,{relatedRequestId:Y.requestId})}}let J=await this._taskStore.getTask(W,Y.sessionId);if(!J)throw new l(d.InvalidParams,`Task not found: ${W}`);if(!_6(J.status))return await this._waitForTaskUpdate(W,Y.signal),await Q();if(_6(J.status)){let G=await this._taskStore.getTaskResult(W,Y.sessionId);return this._clearTaskQueue(W),{...G,_meta:{...G._meta,[P6]:{taskId:W}}}}return await Q()};return await Q()}),this.setRequestHandler(E4,async(Z,Y)=>{try{let{tasks:Q,nextCursor:W}=await this._taskStore.listTasks(Z.params?.cursor,Y.sessionId);return{tasks:Q,nextCursor:W,_meta:{}}}catch(Q){throw new l(d.InvalidParams,`Failed to list tasks: ${Q instanceof Error?Q.message:String(Q)}`)}}),this.setRequestHandler(_4,async(Z,Y)=>{try{let Q=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!Q)throw new l(d.InvalidParams,`Task not found: ${Z.params.taskId}`);if(_6(Q.status))throw new l(d.InvalidParams,`Cannot cancel task in terminal status: ${Q.status}`);await this._taskStore.updateTaskStatus(Z.params.taskId,"cancelled","Client cancelled task execution.",Y.sessionId),this._clearTaskQueue(Z.params.taskId);let W=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!W)throw new l(d.InvalidParams,`Task not found after cancellation: ${Z.params.taskId}`);return{_meta:{},...W}}catch(Q){if(Q instanceof l)throw Q;throw new l(d.InvalidRequest,`Failed to cancel task: ${Q instanceof Error?Q.message:String(Q)}`)}})}async _oncancel($){if(!$.params.requestId)return;this._requestHandlerAbortControllers.get($.params.requestId)?.abort($.params.reason)}_setupTimeout($,Z,Y,Q,W=!1){this._timeoutInfo.set($,{timeoutId:setTimeout(Q,Z),startTime:Date.now(),timeout:Z,maxTotalTimeout:Y,resetTimeoutOnProgress:W,onTimeout:Q})}_resetTimeout($){let Z=this._timeoutInfo.get($);if(!Z)return!1;let Y=Date.now()-Z.startTime;if(Z.maxTotalTimeout&&Y>=Z.maxTotalTimeout)throw this._timeoutInfo.delete($),l.fromError(d.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:Z.maxTotalTimeout,totalElapsed:Y});return clearTimeout(Z.timeoutId),Z.timeoutId=setTimeout(Z.onTimeout,Z.timeout),!0}_cleanupTimeout($){let Z=this._timeoutInfo.get($);if(Z)clearTimeout(Z.timeoutId),this._timeoutInfo.delete($)}async connect($){if(this._transport)throw Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=$;let Z=this.transport?.onclose;this._transport.onclose=()=>{Z?.(),this._onclose()};let Y=this.transport?.onerror;this._transport.onerror=(W)=>{Y?.(W),this._onerror(W)};let Q=this._transport?.onmessage;this._transport.onmessage=(W,J)=>{if(Q?.(W,J),r6(W)||EK(W))this._onresponse(W);else if(x9(W))this._onrequest(W,J);else if(wK(W))this._onnotification(W);else this._onerror(Error(`Unknown message type: ${JSON.stringify(W)}`))},await this._transport.start()}_onclose(){let $=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let Y of this._timeoutInfo.values())clearTimeout(Y.timeoutId);this._timeoutInfo.clear();for(let Y of this._requestHandlerAbortControllers.values())Y.abort();this._requestHandlerAbortControllers.clear();let Z=l.fromError(d.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let Y of $.values())Y(Z)}_onerror($){this.onerror?.($)}_onnotification($){let Z=this._notificationHandlers.get($.method)??this.fallbackNotificationHandler;if(Z===void 0)return;Promise.resolve().then(()=>Z($)).catch((Y)=>this._onerror(Error(`Uncaught error in notification handler: ${Y}`)))}_onrequest($,Z){let Y=this._requestHandlers.get($.method)??this.fallbackRequestHandler,Q=this._transport,W=$.params?._meta?.[P6]?.taskId;if(Y===void 0){let D={jsonrpc:"2.0",id:$.id,error:{code:d.MethodNotFound,message:"Method not found"}};if(W&&this._taskMessageQueue)this._enqueueTaskMessage(W,{type:"error",message:D,timestamp:Date.now()},Q?.sessionId).catch((V)=>this._onerror(Error(`Failed to enqueue error response: ${V}`)));else Q?.send(D).catch((V)=>this._onerror(Error(`Failed to send an error response: ${V}`)));return}let J=new AbortController;this._requestHandlerAbortControllers.set($.id,J);let G=NK($.params)?$.params.task:void 0,K=this._taskStore?this.requestTaskStore($,Q?.sessionId):void 0,B={signal:J.signal,sessionId:Q?.sessionId,_meta:$.params?._meta,sendNotification:async(D)=>{if(J.signal.aborted)return;let V={relatedRequestId:$.id};if(W)V.relatedTask={taskId:W};await this.notification(D,V)},sendRequest:async(D,V,L)=>{if(J.signal.aborted)throw new l(d.ConnectionClosed,"Request was cancelled");let A={...L,relatedRequestId:$.id};if(W&&!A.relatedTask)A.relatedTask={taskId:W};let O=A.relatedTask?.taskId??W;if(O&&K)await K.updateTaskStatus(O,"input_required");return await this.request(D,V,A)},authInfo:Z?.authInfo,requestId:$.id,requestInfo:Z?.requestInfo,taskId:W,taskStore:K,taskRequestedTtl:G?.ttl,closeSSEStream:Z?.closeSSEStream,closeStandaloneSSEStream:Z?.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(G)this.assertTaskHandlerCapability($.method)}).then(()=>Y($,B)).then(async(D)=>{if(J.signal.aborted)return;let V={result:D,jsonrpc:"2.0",id:$.id};if(W&&this._taskMessageQueue)await this._enqueueTaskMessage(W,{type:"response",message:V,timestamp:Date.now()},Q?.sessionId);else await Q?.send(V)},async(D)=>{if(J.signal.aborted)return;let V={jsonrpc:"2.0",id:$.id,error:{code:Number.isSafeInteger(D.code)?D.code:d.InternalError,message:D.message??"Internal error",...D.data!==void 0&&{data:D.data}}};if(W&&this._taskMessageQueue)await this._enqueueTaskMessage(W,{type:"error",message:V,timestamp:Date.now()},Q?.sessionId);else await Q?.send(V)}).catch((D)=>this._onerror(Error(`Failed to send response: ${D}`))).finally(()=>{if(this._requestHandlerAbortControllers.get($.id)===J)this._requestHandlerAbortControllers.delete($.id)})}_onprogress($){let{progressToken:Z,...Y}=$.params,Q=Number(Z),W=this._progressHandlers.get(Q);if(!W){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify($)}`));return}let J=this._responseHandlers.get(Q),G=this._timeoutInfo.get(Q);if(G&&J&&G.resetTimeoutOnProgress)try{this._resetTimeout(Q)}catch(K){this._responseHandlers.delete(Q),this._progressHandlers.delete(Q),this._cleanupTimeout(Q),J(K);return}W(Y)}_onresponse($){let Z=Number($.id),Y=this._requestResolvers.get(Z);if(Y){if(this._requestResolvers.delete(Z),r6($))Y($);else{let J=new l($.error.code,$.error.message,$.error.data);Y(J)}return}let Q=this._responseHandlers.get(Z);if(Q===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify($)}`));return}this._responseHandlers.delete(Z),this._cleanupTimeout(Z);let W=!1;if(r6($)&&$.result&&typeof $.result==="object"){let J=$.result;if(J.task&&typeof J.task==="object"){let G=J.task;if(typeof G.taskId==="string")W=!0,this._taskProgressTokens.set(G.taskId,Z)}}if(!W)this._progressHandlers.delete(Z);if(r6($))Q($);else{let J=l.fromError($.error.code,$.error.message,$.error.data);Q(J)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream($,Z,Y){let{task:Q}=Y??{};if(!Q){try{yield{type:"result",result:await this.request($,Z,Y)}}catch(J){yield{type:"error",error:J instanceof l?J:new l(d.InternalError,String(J))}}return}let W;try{let J=await this.request($,R6,Y);if(J.task)W=J.task.taskId,yield{type:"taskCreated",task:J.task};else throw new l(d.InternalError,"Task creation did not return a task");while(!0){let G=await this.getTask({taskId:W},Y);if(yield{type:"taskStatus",task:G},_6(G.status)){if(G.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:W},Z,Y)};else if(G.status==="failed")yield{type:"error",error:new l(d.InternalError,`Task ${W} failed`)};else if(G.status==="cancelled")yield{type:"error",error:new l(d.InternalError,`Task ${W} was cancelled`)};return}if(G.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:W},Z,Y)};return}let K=G.pollInterval??this._options?.defaultTaskPollInterval??1000;await new Promise((B)=>setTimeout(B,K)),Y?.signal?.throwIfAborted()}}catch(J){yield{type:"error",error:J instanceof l?J:new l(d.InternalError,String(J))}}}request($,Z,Y){let{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J,task:G,relatedTask:K}=Y??{};return new Promise((B,D)=>{let V=(N)=>{D(N)};if(!this._transport){V(Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{if(this.assertCapabilityForMethod($.method),G)this.assertTaskCapability($.method)}catch(N){V(N);return}Y?.signal?.throwIfAborted();let L=this._requestMessageId++,A={...$,jsonrpc:"2.0",id:L};if(Y?.onprogress)this._progressHandlers.set(L,Y.onprogress),A.params={...$.params,_meta:{...$.params?._meta||{},progressToken:L}};if(G)A.params={...A.params,task:G};if(K)A.params={...A.params,_meta:{...A.params?._meta||{},[P6]:K}};let O=(N)=>{this._responseHandlers.delete(L),this._progressHandlers.delete(L),this._cleanupTimeout(L),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:L,reason:String(N)}},{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J}).catch((f)=>this._onerror(Error(`Failed to send cancellation: ${f}`)));let E=N instanceof l?N:new l(d.RequestTimeout,String(N));D(E)};this._responseHandlers.set(L,(N)=>{if(Y?.signal?.aborted)return;if(N instanceof Error)return D(N);try{let E=L0(Z,N.result);if(!E.success)D(E.error);else B(E.data)}catch(E){D(E)}}),Y?.signal?.addEventListener("abort",()=>{O(Y?.signal?.reason)});let q=Y?.timeout??fw,M=()=>O(l.fromError(d.RequestTimeout,"Request timed out",{timeout:q}));this._setupTimeout(L,q,Y?.maxTotalTimeout,M,Y?.resetTimeoutOnProgress??!1);let I=K?.taskId;if(I){let N=(E)=>{let f=this._responseHandlers.get(L);if(f)f(E);else this._onerror(Error(`Response handler missing for side-channeled request ${L}`))};this._requestResolvers.set(L,N),this._enqueueTaskMessage(I,{type:"request",message:A,timestamp:Date.now()}).catch((E)=>{this._cleanupTimeout(L),D(E)})}else this._transport.send(A,{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J}).catch((N)=>{this._cleanupTimeout(L),D(N)})})}async getTask($,Z){return this.request({method:"tasks/get",params:$},P4,Z)}async getTaskResult($,Z,Y){return this.request({method:"tasks/result",params:$},Z,Y)}async listTasks($,Z){return this.request({method:"tasks/list",params:$},R4,Z)}async cancelTask($,Z){return this.request({method:"tasks/cancel",params:$},IK,Z)}async notification($,Z){if(!this._transport)throw Error("Not connected");this.assertNotificationCapability($.method);let Y=Z?.relatedTask?.taskId;if(Y){let G={...$,jsonrpc:"2.0",params:{...$.params,_meta:{...$.params?._meta||{},[P6]:Z.relatedTask}}};await this._enqueueTaskMessage(Y,{type:"notification",message:G,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes($.method)&&!$.params&&!Z?.relatedRequestId&&!Z?.relatedTask){if(this._pendingDebouncedNotifications.has($.method))return;this._pendingDebouncedNotifications.add($.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete($.method),!this._transport)return;let G={...$,jsonrpc:"2.0"};if(Z?.relatedTask)G={...G,params:{...G.params,_meta:{...G.params?._meta||{},[P6]:Z.relatedTask}}};this._transport?.send(G,Z).catch((K)=>this._onerror(K))});return}let J={...$,jsonrpc:"2.0"};if(Z?.relatedTask)J={...J,params:{...J.params,_meta:{...J.params?._meta||{},[P6]:Z.relatedTask}}};await this._transport.send(J,Z)}setRequestHandler($,Z){let Y=nQ($);this.assertRequestHandlerCapability(Y),this._requestHandlers.set(Y,(Q,W)=>{let J=rQ($,Q);return Promise.resolve(Z(J,W))})}removeRequestHandler($){this._requestHandlers.delete($)}assertCanSetRequestHandler($){if(this._requestHandlers.has($))throw Error(`A request handler for ${$} already exists, which would be overridden`)}setNotificationHandler($,Z){let Y=nQ($);this._notificationHandlers.set(Y,(Q)=>{let W=rQ($,Q);return Promise.resolve(Z(W))})}removeNotificationHandler($){this._notificationHandlers.delete($)}_cleanupTaskProgressHandler($){let Z=this._taskProgressTokens.get($);if(Z!==void 0)this._progressHandlers.delete(Z),this._taskProgressTokens.delete($)}async _enqueueTaskMessage($,Z,Y){if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let Q=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue($,Z,Y,Q)}async _clearTaskQueue($,Z){if(this._taskMessageQueue){let Y=await this._taskMessageQueue.dequeueAll($,Z);for(let Q of Y)if(Q.type==="request"&&x9(Q.message)){let W=Q.message.id,J=this._requestResolvers.get(W);if(J)J(new l(d.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(W);else this._onerror(Error(`Resolver missing for request ${W} during task ${$} cleanup`))}}}async _waitForTaskUpdate($,Z){let Y=this._options?.defaultTaskPollInterval??1000;try{let Q=await this._taskStore?.getTask($);if(Q?.pollInterval)Y=Q.pollInterval}catch{}return new Promise((Q,W)=>{if(Z.aborted){W(new l(d.InvalidRequest,"Request cancelled"));return}let J=setTimeout(Q,Y);Z.addEventListener("abort",()=>{clearTimeout(J),W(new l(d.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore($,Z){let Y=this._taskStore;if(!Y)throw Error("No task store configured");return{createTask:async(Q)=>{if(!$)throw Error("No request provided");return await Y.createTask(Q,$.id,{method:$.method,params:$.params},Z)},getTask:async(Q)=>{let W=await Y.getTask(Q,Z);if(!W)throw new l(d.InvalidParams,"Failed to retrieve task: Task not found");return W},storeTaskResult:async(Q,W,J)=>{await Y.storeTaskResult(Q,W,J,Z);let G=await Y.getTask(Q,Z);if(G){let K=l9.parse({method:"notifications/tasks/status",params:G});if(await this.notification(K),_6(G.status))this._cleanupTaskProgressHandler(Q)}},getTaskResult:(Q)=>{return Y.getTaskResult(Q,Z)},updateTaskStatus:async(Q,W,J)=>{let G=await Y.getTask(Q,Z);if(!G)throw new l(d.InvalidParams,`Task "${Q}" not found - it may have been cleaned up`);if(_6(G.status))throw new l(d.InvalidParams,`Cannot update task "${Q}" from terminal status "${G.status}" to "${W}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await Y.updateTaskStatus(Q,W,J,Z);let K=await Y.getTask(Q,Z);if(K){let B=l9.parse({method:"notifications/tasks/status",params:K});if(await this.notification(B),_6(K.status))this._cleanupTaskProgressHandler(Q)}},listTasks:(Q)=>{return Y.listTasks(Q,Z)}}}}function uK($){return $!==null&&typeof $==="object"&&!Array.isArray($)}function aQ($,Z){let Y={...$};for(let Q in Z){let W=Q,J=Z[W];if(J===void 0)continue;let G=Y[W];if(uK(G)&&uK(J))Y[W]={...G,...J};else Y[W]=J}return Y}var UV=i6(L5(),1),jV=i6(tX(),1);function mb(){let $=new UV.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return jV.default($),$}class j5{constructor($){this._ajv=$??mb()}getValidator($){let Z="$id"in $&&typeof $.$id==="string"?this._ajv.getSchema($.$id)??this._ajv.compile($):this._ajv.compile($);return(Y)=>{if(Z(Y))return{valid:!0,data:Y,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(Z.errors)}}}}class eX{constructor($){this._client=$}async*callToolStream($,Z=a6,Y){let Q=this._client,W={...Y,task:Y?.task??(Q.isToolTask($.name)?{}:void 0)},J=Q.requestStream({method:"tools/call",params:$},Z,W),G=Q.getToolOutputValidator($.name);for await(let K of J){if(K.type==="result"&&G){let B=K.result;if(!B.structuredContent&&!B.isError){yield{type:"error",error:new l(d.InvalidRequest,`Tool ${$.name} has an output schema but did not return structured content`)};return}if(B.structuredContent)try{let D=G(B.structuredContent);if(!D.valid){yield{type:"error",error:new l(d.InvalidParams,`Structured content does not match the tool's output schema: ${D.errorMessage}`)};return}}catch(D){if(D instanceof l){yield{type:"error",error:D};return}yield{type:"error",error:new l(d.InvalidParams,`Failed to validate structured content: ${D instanceof Error?D.message:String(D)}`)};return}}yield K}}async getTask($,Z){return this._client.getTask({taskId:$},Z)}async getTaskResult($,Z,Y){return this._client.getTaskResult({taskId:$},Z,Y)}async listTasks($,Z){return this._client.listTasks($?{cursor:$}:void 0,Z)}async cancelTask($,Z){return this._client.cancelTask({taskId:$},Z)}requestStream($,Z,Y){return this._client.requestStream($,Z,Y)}}function $W($,Z,Y){if(!$)throw Error(`${Y} does not support task creation (required for ${Z})`);switch(Z){case"tools/call":if(!$.tools?.call)throw Error(`${Y} does not support task creation for tools/call (required for ${Z})`);break;default:break}}function ZW($,Z,Y){if(!$)throw Error(`${Y} does not support task creation (required for ${Z})`);switch(Z){case"sampling/createMessage":if(!$.sampling?.createMessage)throw Error(`${Y} does not support task creation for sampling/createMessage (required for ${Z})`);break;case"elicitation/create":if(!$.elicitation?.create)throw Error(`${Y} does not support task creation for elicitation/create (required for ${Z})`);break;default:break}}function A5($,Z){if(!$||Z===null||typeof Z!=="object")return;if($.type==="object"&&$.properties&&typeof $.properties==="object"){let Y=Z,Q=$.properties;for(let W of Object.keys(Q)){let J=Q[W];if(Y[W]===void 0&&Object.prototype.hasOwnProperty.call(J,"default"))Y[W]=J.default;if(Y[W]!==void 0)A5(J,Y[W])}}if(Array.isArray($.anyOf)){for(let Y of $.anyOf)if(typeof Y!=="boolean")A5(Y,Z)}if(Array.isArray($.oneOf)){for(let Y of $.oneOf)if(typeof Y!=="boolean")A5(Y,Z)}}function lb($){if(!$)return{supportsFormMode:!1,supportsUrlMode:!1};let Z=$.form!==void 0,Y=$.url!==void 0;return{supportsFormMode:Z||!Z&&!Y,supportsUrlMode:Y}}class z5 extends S4{constructor($,Z){super(Z);if(this._clientInfo=$,this._cachedToolOutputValidators=new Map,this._cachedKnownTaskTools=new Set,this._cachedRequiredTaskTools=new Set,this._listChangedDebounceTimers=new Map,this._capabilities=Z?.capabilities??{},this._jsonSchemaValidator=Z?.jsonSchemaValidator??new j5,Z?.listChanged)this._pendingListChangedConfig=Z.listChanged}_setupListChangedHandlers($){if($.tools&&this._serverCapabilities?.tools?.listChanged)this._setupListChangedHandler("tools",lQ,$.tools,async()=>{return(await this.listTools()).tools});if($.prompts&&this._serverCapabilities?.prompts?.listChanged)this._setupListChangedHandler("prompts",hQ,$.prompts,async()=>{return(await this.listPrompts()).prompts});if($.resources&&this._serverCapabilities?.resources?.listChanged)this._setupListChangedHandler("resources",SQ,$.resources,async()=>{return(await this.listResources()).resources})}get experimental(){if(!this._experimental)this._experimental={tasks:new eX(this)};return this._experimental}registerCapabilities($){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=aQ(this._capabilities,$)}setRequestHandler($,Z){let Q=T8($)?.method;if(!Q)throw Error("Schema is missing a method literal");let W;if(d6(Q)){let G=Q;W=G._zod?.def?.value??G.value}else{let G=Q;W=G._def?.value??G.value}if(typeof W!=="string")throw Error("Schema method literal must be a string");let J=W;if(J==="elicitation/create"){let G=async(K,B)=>{let D=L0(cQ,K);if(!D.success){let N=D.error instanceof Error?D.error.message:String(D.error);throw new l(d.InvalidParams,`Invalid elicitation request: ${N}`)}let{params:V}=D.data;V.mode=V.mode??"form";let{supportsFormMode:L,supportsUrlMode:A}=lb(this._capabilities.elicitation);if(V.mode==="form"&&!L)throw new l(d.InvalidParams,"Client does not support form-mode elicitation requests");if(V.mode==="url"&&!A)throw new l(d.InvalidParams,"Client does not support URL-mode elicitation requests");let O=await Promise.resolve(Z(K,B));if(V.task){let N=L0(R6,O);if(!N.success){let E=N.error instanceof Error?N.error.message:String(N.error);throw new l(d.InvalidParams,`Invalid task creation result: ${E}`)}return N.data}let q=L0(d9,O);if(!q.success){let N=q.error instanceof Error?q.error.message:String(q.error);throw new l(d.InvalidParams,`Invalid elicitation result: ${N}`)}let M=q.data,I=V.mode==="form"?V.requestedSchema:void 0;if(V.mode==="form"&&M.action==="accept"&&M.content&&I){if(this._capabilities.elicitation?.form?.applyDefaults)try{A5(I,M.content)}catch{}}return M};return super.setRequestHandler($,G)}if(J==="sampling/createMessage"){let G=async(K,B)=>{let D=L0(iQ,K);if(!D.success){let M=D.error instanceof Error?D.error.message:String(D.error);throw new l(d.InvalidParams,`Invalid sampling request: ${M}`)}let{params:V}=D.data,L=await Promise.resolve(Z(K,B));if(V.task){let M=L0(R6,L);if(!M.success){let I=M.error instanceof Error?M.error.message:String(M.error);throw new l(d.InvalidParams,`Invalid task creation result: ${I}`)}return M.data}let O=V.tools||V.toolChoice?f4:c9,q=L0(O,L);if(!q.success){let M=q.error instanceof Error?q.error.message:String(q.error);throw new l(d.InvalidParams,`Invalid sampling result: ${M}`)}return q.data};return super.setRequestHandler($,G)}return super.setRequestHandler($,Z)}assertCapability($,Z){if(!this._serverCapabilities?.[$])throw Error(`Server does not support ${$} (required for ${Z})`)}async connect($,Z){if(await super.connect($),$.sessionId!==void 0)return;try{let Y=await this.request({method:"initialize",params:{protocolVersion:n6,capabilities:this._capabilities,clientInfo:this._clientInfo}},NQ,Z);if(Y===void 0)throw Error(`Server sent invalid initialize result: ${Y}`);if(!AQ.includes(Y.protocolVersion))throw Error(`Server's protocol version is not supported: ${Y.protocolVersion}`);if(this._serverCapabilities=Y.capabilities,this._serverVersion=Y.serverInfo,$.setProtocolVersion)$.setProtocolVersion(Y.protocolVersion);if(this._instructions=Y.instructions,await this.notification({method:"notifications/initialized"}),this._pendingListChangedConfig)this._setupListChangedHandlers(this._pendingListChangedConfig),this._pendingListChangedConfig=void 0}catch(Y){throw this.close(),Y}}getServerCapabilities(){return this._serverCapabilities}getServerVersion(){return this._serverVersion}getInstructions(){return this._instructions}assertCapabilityForMethod($){switch($){case"logging/setLevel":if(!this._serverCapabilities?.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"prompts/get":case"prompts/list":if(!this._serverCapabilities?.prompts)throw Error(`Server does not support prompts (required for ${$})`);break;case"resources/list":case"resources/templates/list":case"resources/read":case"resources/subscribe":case"resources/unsubscribe":if(!this._serverCapabilities?.resources)throw Error(`Server does not support resources (required for ${$})`);if($==="resources/subscribe"&&!this._serverCapabilities.resources.subscribe)throw Error(`Server does not support resource subscriptions (required for ${$})`);break;case"tools/call":case"tools/list":if(!this._serverCapabilities?.tools)throw Error(`Server does not support tools (required for ${$})`);break;case"completion/complete":if(!this._serverCapabilities?.completions)throw Error(`Server does not support completions (required for ${$})`);break;case"initialize":break;case"ping":break}}assertNotificationCapability($){switch($){case"notifications/roots/list_changed":if(!this._capabilities.roots?.listChanged)throw Error(`Client does not support roots list changed notifications (required for ${$})`);break;case"notifications/initialized":break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability($){if(!this._capabilities)return;switch($){case"sampling/createMessage":if(!this._capabilities.sampling)throw Error(`Client does not support sampling capability (required for ${$})`);break;case"elicitation/create":if(!this._capabilities.elicitation)throw Error(`Client does not support elicitation capability (required for ${$})`);break;case"roots/list":if(!this._capabilities.roots)throw Error(`Client does not support roots capability (required for ${$})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw Error(`Client does not support tasks capability (required for ${$})`);break;case"ping":break}}assertTaskCapability($){$W(this._serverCapabilities?.tasks?.requests,$,"Server")}assertTaskHandlerCapability($){if(!this._capabilities)return;ZW(this._capabilities.tasks?.requests,$,"Client")}async ping($){return this.request({method:"ping"},E6,$)}async complete($,Z){return this.request({method:"completion/complete",params:$},dQ,Z)}async setLoggingLevel($,Z){return this.request({method:"logging/setLevel",params:{level:$}},E6,Z)}async getPrompt($,Z){return this.request({method:"prompts/get",params:$},uQ,Z)}async listPrompts($,Z){return this.request({method:"prompts/list",params:$},vQ,Z)}async listResources($,Z){return this.request({method:"resources/list",params:$},EQ,Z)}async listResourceTemplates($,Z){return this.request({method:"resources/templates/list",params:$},_Q,Z)}async readResource($,Z){return this.request({method:"resources/read",params:$},fQ,Z)}async subscribeResource($,Z){return this.request({method:"resources/subscribe",params:$},E6,Z)}async unsubscribeResource($,Z){return this.request({method:"resources/unsubscribe",params:$},E6,Z)}async callTool($,Z=a6,Y){if(this.isToolTaskRequired($.name))throw new l(d.InvalidRequest,`Tool "${$.name}" requires task-based execution. Use client.experimental.tasks.callToolStream() instead.`);let Q=await this.request({method:"tools/call",params:$},Z,Y),W=this.getToolOutputValidator($.name);if(W){if(!Q.structuredContent&&!Q.isError)throw new l(d.InvalidRequest,`Tool ${$.name} has an output schema but did not return structured content`);if(Q.structuredContent)try{let J=W(Q.structuredContent);if(!J.valid)throw new l(d.InvalidParams,`Structured content does not match the tool's output schema: ${J.errorMessage}`)}catch(J){if(J instanceof l)throw J;throw new l(d.InvalidParams,`Failed to validate structured content: ${J instanceof Error?J.message:String(J)}`)}}return Q}isToolTask($){if(!this._serverCapabilities?.tasks?.requests?.tools?.call)return!1;return this._cachedKnownTaskTools.has($)}isToolTaskRequired($){return this._cachedRequiredTaskTools.has($)}cacheToolMetadata($){this._cachedToolOutputValidators.clear(),this._cachedKnownTaskTools.clear(),this._cachedRequiredTaskTools.clear();for(let Z of $){if(Z.outputSchema){let Q=this._jsonSchemaValidator.getValidator(Z.outputSchema);this._cachedToolOutputValidators.set(Z.name,Q)}let Y=Z.execution?.taskSupport;if(Y==="required"||Y==="optional")this._cachedKnownTaskTools.add(Z.name);if(Y==="required")this._cachedRequiredTaskTools.add(Z.name)}}getToolOutputValidator($){return this._cachedToolOutputValidators.get($)}async listTools($,Z){let Y=await this.request({method:"tools/list",params:$},i9,Z);return this.cacheToolMetadata(Y.tools),Y}_setupListChangedHandler($,Z,Y,Q){let W=yK.safeParse(Y);if(!W.success)throw Error(`Invalid ${$} listChanged options: ${W.error.message}`);if(typeof Y.onChanged!=="function")throw Error(`Invalid ${$} listChanged options: onChanged must be a function`);let{autoRefresh:J,debounceMs:G}=W.data,{onChanged:K}=Y,B=async()=>{if(!J){K(null,null);return}try{let V=await Q();K(null,V)}catch(V){let L=V instanceof Error?V:Error(String(V));K(L,null)}},D=()=>{if(G){let V=this._listChangedDebounceTimers.get($);if(V)clearTimeout(V);let L=setTimeout(B,G);this._listChangedDebounceTimers.set($,L)}else B()};this.setNotificationHandler(Z,D)}async sendRootsListChanged(){return this.notification({method:"notifications/roots/list_changed"})}}function o8($){if(!$)return{};if($ instanceof Headers)return Object.fromEntries($.entries());if(Array.isArray($))return Object.fromEntries($);return{...$}}function O5($=fetch,Z){if(!Z)return $;return async(Y,Q)=>{let W={...Z,...Q,headers:Q?.headers?{...o8(Z.headers),...o8(Q.headers)}:Z.headers};return $(Y,W)}}var YW;YW=globalThis.crypto?.webcrypto??globalThis.crypto??import("crypto").then(($)=>$.webcrypto);async function pb($){return(await YW).getRandomValues(new Uint8Array($))}async function ib($){let Y=Math.pow(2,8)-Math.pow(2,8)%66,Q="";while(Q.length<$){let W=await pb($-Q.length);for(let J of W)if(J<Y)Q+="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~"[J%66]}return Q}async function cb($){return await ib($)}async function db($){let Z=await(await YW).subtle.digest("SHA-256",new TextEncoder().encode($));return btoa(String.fromCharCode(...new Uint8Array(Z))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}async function QW($){if(!$)$=43;if($<43||$>128)throw`Expected a length between 43 and 128. Received ${$}.`;let Z=await cb($),Y=await db(Z);return{code_verifier:Z,code_challenge:Y}}import*as P from"zod/v4";var g1=P.url().superRefine(($,Z)=>{if(!URL.canParse($))return Z.addIssue({code:P.ZodIssueCode.custom,message:"URL must be parseable",fatal:!0}),P.NEVER}).refine(($)=>{let Z=new URL($);return Z.protocol!=="javascript:"&&Z.protocol!=="data:"&&Z.protocol!=="vbscript:"},{message:"URL cannot use javascript:, data:, or vbscript: scheme"}),zV=P.looseObject({resource:P.string().url(),authorization_servers:P.array(g1).optional(),jwks_uri:P.string().url().optional(),scopes_supported:P.array(P.string()).optional(),bearer_methods_supported:P.array(P.string()).optional(),resource_signing_alg_values_supported:P.array(P.string()).optional(),resource_name:P.string().optional(),resource_documentation:P.string().optional(),resource_policy_uri:P.string().url().optional(),resource_tos_uri:P.string().url().optional(),tls_client_certificate_bound_access_tokens:P.boolean().optional(),authorization_details_types_supported:P.array(P.string()).optional(),dpop_signing_alg_values_supported:P.array(P.string()).optional(),dpop_bound_access_tokens_required:P.boolean().optional()}),XW=P.looseObject({issuer:P.string(),authorization_endpoint:g1,token_endpoint:g1,registration_endpoint:g1.optional(),scopes_supported:P.array(P.string()).optional(),response_types_supported:P.array(P.string()),response_modes_supported:P.array(P.string()).optional(),grant_types_supported:P.array(P.string()).optional(),token_endpoint_auth_methods_supported:P.array(P.string()).optional(),token_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),service_documentation:g1.optional(),revocation_endpoint:g1.optional(),revocation_endpoint_auth_methods_supported:P.array(P.string()).optional(),revocation_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),introspection_endpoint:P.string().optional(),introspection_endpoint_auth_methods_supported:P.array(P.string()).optional(),introspection_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),code_challenge_methods_supported:P.array(P.string()).optional(),client_id_metadata_document_supported:P.boolean().optional()}),nb=P.looseObject({issuer:P.string(),authorization_endpoint:g1,token_endpoint:g1,userinfo_endpoint:g1.optional(),jwks_uri:g1,registration_endpoint:g1.optional(),scopes_supported:P.array(P.string()).optional(),response_types_supported:P.array(P.string()),response_modes_supported:P.array(P.string()).optional(),grant_types_supported:P.array(P.string()).optional(),acr_values_supported:P.array(P.string()).optional(),subject_types_supported:P.array(P.string()),id_token_signing_alg_values_supported:P.array(P.string()),id_token_encryption_alg_values_supported:P.array(P.string()).optional(),id_token_encryption_enc_values_supported:P.array(P.string()).optional(),userinfo_signing_alg_values_supported:P.array(P.string()).optional(),userinfo_encryption_alg_values_supported:P.array(P.string()).optional(),userinfo_encryption_enc_values_supported:P.array(P.string()).optional(),request_object_signing_alg_values_supported:P.array(P.string()).optional(),request_object_encryption_alg_values_supported:P.array(P.string()).optional(),request_object_encryption_enc_values_supported:P.array(P.string()).optional(),token_endpoint_auth_methods_supported:P.array(P.string()).optional(),token_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),display_values_supported:P.array(P.string()).optional(),claim_types_supported:P.array(P.string()).optional(),claims_supported:P.array(P.string()).optional(),service_documentation:P.string().optional(),claims_locales_supported:P.array(P.string()).optional(),ui_locales_supported:P.array(P.string()).optional(),claims_parameter_supported:P.boolean().optional(),request_parameter_supported:P.boolean().optional(),request_uri_parameter_supported:P.boolean().optional(),require_request_uri_registration:P.boolean().optional(),op_policy_uri:g1.optional(),op_tos_uri:g1.optional(),client_id_metadata_document_supported:P.boolean().optional()}),OV=P.object({...nb.shape,...XW.pick({code_challenge_methods_supported:!0}).shape}),qV=P.object({access_token:P.string(),id_token:P.string().optional(),token_type:P.string(),expires_in:P.coerce.number().optional(),scope:P.string().optional(),refresh_token:P.string().optional()}).strip(),NV=P.object({error:P.string(),error_description:P.string().optional(),error_uri:P.string().optional()}),AV=g1.optional().or(P.literal("").transform(()=>{return})),rb=P.object({redirect_uris:P.array(g1),token_endpoint_auth_method:P.string().optional(),grant_types:P.array(P.string()).optional(),response_types:P.array(P.string()).optional(),client_name:P.string().optional(),client_uri:g1.optional(),logo_uri:AV,scope:P.string().optional(),contacts:P.array(P.string()).optional(),tos_uri:AV,policy_uri:P.string().optional(),jwks_uri:g1.optional(),jwks:P.any().optional(),software_id:P.string().optional(),software_version:P.string().optional(),software_statement:P.string().optional()}).strip(),ab=P.object({client_id:P.string(),client_secret:P.string().optional(),client_id_issued_at:P.number().optional(),client_secret_expires_at:P.number().optional()}).strip(),MV=rb.merge(ab),Mo=P.object({error:P.string(),error_description:P.string().optional()}).strip(),Po=P.object({token:P.string(),token_type_hint:P.string().optional()}).strip();function PV($){let Z=typeof $==="string"?new URL($):new URL($.href);return Z.hash="",Z}function wV({requestedResource:$,configuredResource:Z}){let Y=typeof $==="string"?new URL($):new URL($.href),Q=typeof Z==="string"?new URL(Z):new URL(Z.href);if(Y.origin!==Q.origin)return!1;if(Y.pathname.length<Q.pathname.length)return!1;let W=Y.pathname.endsWith("/")?Y.pathname:Y.pathname+"/",J=Q.pathname.endsWith("/")?Q.pathname:Q.pathname+"/";return W.startsWith(J)}class R1 extends Error{constructor($,Z){super($);this.errorUri=Z,this.name=this.constructor.name}toResponseObject(){let $={error:this.errorCode,error_description:this.message};if(this.errorUri)$.error_uri=this.errorUri;return $}get errorCode(){return this.constructor.errorCode}}class q5 extends R1{}q5.errorCode="invalid_request";class s8 extends R1{}s8.errorCode="invalid_client";class t8 extends R1{}t8.errorCode="invalid_grant";class e8 extends R1{}e8.errorCode="unauthorized_client";class N5 extends R1{}N5.errorCode="unsupported_grant_type";class M5 extends R1{}M5.errorCode="invalid_scope";class P5 extends R1{}P5.errorCode="access_denied";class T6 extends R1{}T6.errorCode="server_error";class w5 extends R1{}w5.errorCode="temporarily_unavailable";class E5 extends R1{}E5.errorCode="unsupported_response_type";class R5 extends R1{}R5.errorCode="unsupported_token_type";class _5 extends R1{}_5.errorCode="invalid_token";class C5 extends R1{}C5.errorCode="method_not_allowed";class I5 extends R1{}I5.errorCode="too_many_requests";class $9 extends R1{}$9.errorCode="invalid_client_metadata";class f5 extends R1{}f5.errorCode="insufficient_scope";class S5 extends R1{}S5.errorCode="invalid_target";var EV={[q5.errorCode]:q5,[s8.errorCode]:s8,[t8.errorCode]:t8,[e8.errorCode]:e8,[N5.errorCode]:N5,[M5.errorCode]:M5,[P5.errorCode]:P5,[T6.errorCode]:T6,[w5.errorCode]:w5,[E5.errorCode]:E5,[R5.errorCode]:R5,[_5.errorCode]:_5,[C5.errorCode]:C5,[I5.errorCode]:I5,[$9.errorCode]:$9,[f5.errorCode]:f5,[S5.errorCode]:S5};class e1 extends Error{constructor($){super($??"Unauthorized")}}function ob($){return["client_secret_basic","client_secret_post","none"].includes($)}var WW="code",JW="S256";function sb($,Z){let Y=$.client_secret!==void 0;if("token_endpoint_auth_method"in $&&$.token_endpoint_auth_method&&ob($.token_endpoint_auth_method)&&(Z.length===0||Z.includes($.token_endpoint_auth_method)))return $.token_endpoint_auth_method;if(Z.length===0)return Y?"client_secret_basic":"none";if(Y&&Z.includes("client_secret_basic"))return"client_secret_basic";if(Y&&Z.includes("client_secret_post"))return"client_secret_post";if(Z.includes("none"))return"none";return Y?"client_secret_post":"none"}function tb($,Z,Y,Q){let{client_id:W,client_secret:J}=Z;switch($){case"client_secret_basic":eb(W,J,Y);return;case"client_secret_post":$v(W,J,Q);return;case"none":Zv(W,Q);return;default:throw Error(`Unsupported client authentication method: ${$}`)}}function eb($,Z,Y){if(!Z)throw Error("client_secret_basic authentication requires a client_secret");let Q=btoa(`${$}:${Z}`);Y.set("Authorization",`Basic ${Q}`)}function $v($,Z,Y){if(Y.set("client_id",$),Z)Y.set("client_secret",Z)}function Zv($,Z){Z.set("client_id",$)}async function _V($){let Z=$ instanceof Response?$.status:void 0,Y=$ instanceof Response?await $.text():$;try{let Q=NV.parse(JSON.parse(Y)),{error:W,error_description:J,error_uri:G}=Q;return new(EV[W]||T6)(J||"",G)}catch(Q){let W=`${Z?`HTTP ${Z}: `:""}Invalid OAuth error response: ${Q}. Raw body: ${Y}`;return new T6(W)}}async function p0($,Z){try{return await GW($,Z)}catch(Y){if(Y instanceof s8||Y instanceof e8)return await $.invalidateCredentials?.("all"),await GW($,Z);else if(Y instanceof t8)return await $.invalidateCredentials?.("tokens"),await GW($,Z);throw Y}}async function GW($,{serverUrl:Z,authorizationCode:Y,scope:Q,resourceMetadataUrl:W,fetchFn:J}){let G=await $.discoveryState?.(),K,B,D,V=W;if(!V&&G?.resourceMetadataUrl)V=new URL(G.resourceMetadataUrl);if(G?.authorizationServerUrl){if(B=G.authorizationServerUrl,K=G.resourceMetadata,D=G.authorizationServerMetadata??await FW(B,{fetchFn:J}),!K)try{K=await HW(Z,{resourceMetadataUrl:V},J)}catch{}if(D!==G.authorizationServerMetadata||K!==G.resourceMetadata)await $.saveDiscoveryState?.({authorizationServerUrl:String(B),resourceMetadataUrl:V?.toString(),resourceMetadata:K,authorizationServerMetadata:D})}else{let f=await Kv(Z,{resourceMetadataUrl:V,fetchFn:J});B=f.authorizationServerUrl,D=f.authorizationServerMetadata,K=f.resourceMetadata,await $.saveDiscoveryState?.({authorizationServerUrl:String(B),resourceMetadataUrl:V?.toString(),resourceMetadata:K,authorizationServerMetadata:D})}let L=await Qv(Z,$,K),A=Q||K?.scopes_supported?.join(" ")||$.clientMetadata.scope,O=await Promise.resolve($.clientInformation());if(!O){if(Y!==void 0)throw Error("Existing OAuth client information is required when exchanging an authorization code");let f=D?.client_id_metadata_document_supported===!0,v=$.clientMetadataUrl;if(v&&!Yv(v))throw new $9(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${v}`);if(f&&v)O={client_id:v},await $.saveClientInformation?.(O);else{if(!$.saveClientInformation)throw Error("OAuth client information must be saveable for dynamic registration");let $1=await Vv(B,{metadata:D,clientMetadata:$.clientMetadata,scope:A,fetchFn:J});await $.saveClientInformation($1),O=$1}}let q=!$.redirectUrl;if(Y!==void 0||q){let f=await Dv($,B,{metadata:D,resource:L,authorizationCode:Y,fetchFn:J});return await $.saveTokens(f),"AUTHORIZED"}let M=await $.tokens();if(M?.refresh_token)try{let f=await Fv(B,{metadata:D,clientInformation:O,refreshToken:M.refresh_token,resource:L,addClientAuthentication:$.addClientAuthentication,fetchFn:J});return await $.saveTokens(f),"AUTHORIZED"}catch(f){if(!(f instanceof R1)||f instanceof T6);else throw f}let I=$.state?await $.state():void 0,{authorizationUrl:N,codeVerifier:E}=await Hv(B,{metadata:D,clientInformation:O,state:I,redirectUrl:$.redirectUrl,scope:A,resource:L});return await $.saveCodeVerifier(E),await $.redirectToAuthorization(N),"REDIRECT"}function Yv($){if(!$)return!1;try{let Z=new URL($);return Z.protocol==="https:"&&Z.pathname!=="/"}catch{return!1}}async function Qv($,Z,Y){let Q=PV($);if(Z.validateResourceURL)return await Z.validateResourceURL(Q,Y?.resource);if(!Y)return;if(!wV({requestedResource:Q,configuredResource:Y.resource}))throw Error(`Protected resource ${Y.resource} does not match expected ${Q} (or origin)`);return new URL(Y.resource)}function Z9($){let Z=$.headers.get("WWW-Authenticate");if(!Z)return{};let[Y,Q]=Z.split(" ");if(Y.toLowerCase()!=="bearer"||!Q)return{};let W=KW($,"resource_metadata")||void 0,J;if(W)try{J=new URL(W)}catch{}let G=KW($,"scope")||void 0,K=KW($,"error")||void 0;return{resourceMetadataUrl:J,scope:G,error:K}}function KW($,Z){let Y=$.headers.get("WWW-Authenticate");if(!Y)return null;let Q=new RegExp(`${Z}=(?:"([^"]+)"|([^\\s,]+))`),W=Y.match(Q);if(W)return W[1]||W[2];return null}async function HW($,Z,Y=fetch){let Q=await Jv($,"oauth-protected-resource",Y,{protocolVersion:Z?.protocolVersion,metadataUrl:Z?.resourceMetadataUrl});if(!Q||Q.status===404)throw await Q?.body?.cancel(),Error("Resource server does not implement OAuth 2.0 Protected Resource Metadata.");if(!Q.ok)throw await Q.body?.cancel(),Error(`HTTP ${Q.status} trying to load well-known OAuth protected resource metadata.`);return zV.parse(await Q.json())}async function BW($,Z,Y=fetch){try{return await Y($,{headers:Z})}catch(Q){if(Q instanceof TypeError)if(Z)return BW($,void 0,Y);else return;throw Q}}function Xv($,Z="",Y={}){if(Z.endsWith("/"))Z=Z.slice(0,-1);return Y.prependPathname?`${Z}/.well-known/${$}`:`/.well-known/${$}${Z}`}async function RV($,Z,Y=fetch){return await BW($,{"MCP-Protocol-Version":Z},Y)}function Wv($,Z){return!$||$.status>=400&&$.status<500&&Z!=="/"}async function Jv($,Z,Y,Q){let W=new URL($),J=Q?.protocolVersion??n6,G;if(Q?.metadataUrl)G=new URL(Q.metadataUrl);else{let B=Xv(Z,W.pathname);G=new URL(B,Q?.metadataServerUrl??W),G.search=W.search}let K=await RV(G,J,Y);if(!Q?.metadataUrl&&Wv(K,W.pathname)){let B=new URL(`/.well-known/${Z}`,W);K=await RV(B,J,Y)}return K}function Gv($){let Z=typeof $==="string"?new URL($):$,Y=Z.pathname!=="/",Q=[];if(!Y)return Q.push({url:new URL("/.well-known/oauth-authorization-server",Z.origin),type:"oauth"}),Q.push({url:new URL("/.well-known/openid-configuration",Z.origin),type:"oidc"}),Q;let W=Z.pathname;if(W.endsWith("/"))W=W.slice(0,-1);return Q.push({url:new URL(`/.well-known/oauth-authorization-server${W}`,Z.origin),type:"oauth"}),Q.push({url:new URL(`/.well-known/openid-configuration${W}`,Z.origin),type:"oidc"}),Q.push({url:new URL(`${W}/.well-known/openid-configuration`,Z.origin),type:"oidc"}),Q}async function FW($,{fetchFn:Z=fetch,protocolVersion:Y=n6}={}){let Q={"MCP-Protocol-Version":Y,Accept:"application/json"},W=Gv($);for(let{url:J,type:G}of W){let K=await BW(J,Q,Z);if(!K)continue;if(!K.ok){if(await K.body?.cancel(),K.status>=400&&K.status<500)continue;throw Error(`HTTP ${K.status} trying to load ${G==="oauth"?"OAuth":"OpenID provider"} metadata from ${J}`)}if(G==="oauth")return XW.parse(await K.json());else return OV.parse(await K.json())}return}async function Kv($,Z){let Y,Q;try{if(Y=await HW($,{resourceMetadataUrl:Z?.resourceMetadataUrl},Z?.fetchFn),Y.authorization_servers&&Y.authorization_servers.length>0)Q=Y.authorization_servers[0]}catch{}if(!Q)Q=String(new URL("/",$));let W=await FW(Q,{fetchFn:Z?.fetchFn});return{authorizationServerUrl:Q,authorizationServerMetadata:W,resourceMetadata:Y}}async function Hv($,{metadata:Z,clientInformation:Y,redirectUrl:Q,scope:W,state:J,resource:G}){let K;if(Z){if(K=new URL(Z.authorization_endpoint),!Z.response_types_supported.includes(WW))throw Error(`Incompatible auth server: does not support response type ${WW}`);if(Z.code_challenge_methods_supported&&!Z.code_challenge_methods_supported.includes(JW))throw Error(`Incompatible auth server: does not support code challenge method ${JW}`)}else K=new URL("/authorize",$);let B=await QW(),D=B.code_verifier,V=B.code_challenge;if(K.searchParams.set("response_type",WW),K.searchParams.set("client_id",Y.client_id),K.searchParams.set("code_challenge",V),K.searchParams.set("code_challenge_method",JW),K.searchParams.set("redirect_uri",String(Q)),J)K.searchParams.set("state",J);if(W)K.searchParams.set("scope",W);if(W?.includes("offline_access"))K.searchParams.append("prompt","consent");if(G)K.searchParams.set("resource",G.href);return{authorizationUrl:K,codeVerifier:D}}function Bv($,Z,Y){return new URLSearchParams({grant_type:"authorization_code",code:$,code_verifier:Z,redirect_uri:String(Y)})}async function CV($,{metadata:Z,tokenRequestParams:Y,clientInformation:Q,addClientAuthentication:W,resource:J,fetchFn:G}){let K=Z?.token_endpoint?new URL(Z.token_endpoint):new URL("/token",$),B=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(J)Y.set("resource",J.href);if(W)await W(B,Y,K,Z);else if(Q){let V=Z?.token_endpoint_auth_methods_supported??[],L=sb(Q,V);tb(L,Q,B,Y)}let D=await(G??fetch)(K,{method:"POST",headers:B,body:Y});if(!D.ok)throw await _V(D);return qV.parse(await D.json())}async function Fv($,{metadata:Z,clientInformation:Y,refreshToken:Q,resource:W,addClientAuthentication:J,fetchFn:G}){let K=new URLSearchParams({grant_type:"refresh_token",refresh_token:Q}),B=await CV($,{metadata:Z,tokenRequestParams:K,clientInformation:Y,addClientAuthentication:J,resource:W,fetchFn:G});return{refresh_token:Q,...B}}async function Dv($,Z,{metadata:Y,resource:Q,authorizationCode:W,fetchFn:J}={}){let G=$.clientMetadata.scope,K;if($.prepareTokenRequest)K=await $.prepareTokenRequest(G);if(!K){if(!W)throw Error("Either provider.prepareTokenRequest() or authorizationCode is required");if(!$.redirectUrl)throw Error("redirectUrl is required for authorization_code flow");let D=await $.codeVerifier();K=Bv(W,D,$.redirectUrl)}let B=await $.clientInformation();return CV(Z,{metadata:Y,tokenRequestParams:K,clientInformation:B??void 0,addClientAuthentication:$.addClientAuthentication,resource:Q,fetchFn:J})}async function Vv($,{metadata:Z,clientMetadata:Y,scope:Q,fetchFn:W}){let J;if(Z){if(!Z.registration_endpoint)throw Error("Incompatible auth server: does not support dynamic client registration");J=new URL(Z.registration_endpoint)}else J=new URL("/register",$);let G=await(W??fetch)(J,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...Y,...Q!==void 0?{scope:Q}:{}})});if(!G.ok)throw await _V(G);return MV.parse(await G.json())}class VW extends Error{constructor($,Z){super($),this.name="ParseError",this.type=Z.type,this.field=Z.field,this.value=Z.value,this.line=Z.line}}var IV=10,Lv=13,Y8=32;function DW($){}function b5($){if(typeof $=="function")throw TypeError("`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?");let{onEvent:Z=DW,onError:Y=DW,onRetry:Q=DW,onComment:W}=$,J=[],G=!0,K,B="",D=0,V;function L(N){if(G&&(G=!1,N.charCodeAt(0)===239&&N.charCodeAt(1)===187&&N.charCodeAt(2)===191&&(N=N.slice(3))),J.length===0){let v=A(N);v!==""&&J.push(v);return}if(N.indexOf(`
|
|
942
|
+
`;await NM(G,B,{mode:384}),await qM(G,K)}}import{ExportResultCode as Pl}from"@opentelemetry/core";import{AggregationTemporality as El,DataPointType as Rl}from"@opentelemetry/sdk-metrics";import{ExportResultCode as bl}from"@opentelemetry/core";var kl=Buffer.byteLength("... [TRUNCATED]","utf8");import{BatchLogRecordProcessor as Rp,LoggerProvider as _p}from"@opentelemetry/sdk-logs";import{detectResources as Ip,envDetector as fp,hostDetector as Sp,osDetector as bp,processDetector as vp,resourceFromAttributes as yp}from"@opentelemetry/resources";import{PeriodicExportingMetricReader as kp}from"@opentelemetry/sdk-metrics";import{NOOP_LOGGER as ul}from"@opentelemetry/api-logs";import{NodeSDK as up}from"@opentelemetry/sdk-node";import{BatchSpanProcessor as mp,SamplingDecision as v8}from"@opentelemetry/sdk-trace-base";import{SpanStatusCode as il}from"@opentelemetry/api";var IM="__d",fM=wM("Current request"),SM=1;var XK=($)=>{let Y=new URL($.url).searchParams.get(IM);if(Y==="")return crypto.randomUUID();if(!Y)Y=$.headers.get("x-trace-debug-id");return Y};class WK{inner;constructor($){this.inner=$}shouldSample($,Z,Y,Q,W,J){let G=$.getValue(fM);if(!G){if(this.inner)return this.inner.shouldSample($,Z,Y,Q,W,J);return{decision:v8.RECORD_AND_SAMPLED}}let K=XK(G);if(K)return{decision:v8.RECORD_AND_SAMPLED,attributes:{"trace.debug.id":K}};if(this.inner){let B=this.inner.shouldSample($,Z,Y,Q,W,J);if(B.decision===v8.RECORD_AND_SAMPLED){let D=crypto.randomUUID();B.attributes={...B.attributes??{},"trace.debug.id":D}}return B}return{decision:v8.NOT_RECORD}}toString(){return"DebugSampler"}}class JK{ratio;constructor($){this.ratio=$}shouldSample(){if(Math.random()<this.ratio)return{decision:v8.RECORD_AND_SAMPLED};return{decision:v8.NOT_RECORD}}toString(){return`RatioSampler(${this.ratio})`}}var pp=new CM({preventServerStart:!0}),ip=new WK(new JK(SM));var QK=RM.getTracer("studio","1.0.0"),V4=EM.getMeter("studio","1.0.0"),bM=_M.getLogger("studio","1.0.0"),HQ=($,Z,Y)=>{let Q={},W=Y,J=Y[Y.length-1];if(J!==null&&typeof J==="object"&&!Array.isArray(J)&&!(J instanceof Error)&&Object.getPrototypeOf(J)===Object.prototype)Q=J,W=Y.slice(0,-1);let G=W.map((K)=>{if(K instanceof Error)return`${K.name}: ${K.message}`;if(typeof K==="object")try{return JSON.stringify(K)}catch{return"[Object]"}return String(K)}).join(" ");bM.emit({severityNumber:$,severityText:Z,body:G,attributes:{"log.source":"console",...Q}})},BQ={error:console.error.bind(console),warn:console.warn.bind(console),debug:console.debug.bind(console)};console.error=(...$)=>{HQ(KQ.ERROR,"ERROR",$),BQ.error(...$)};console.warn=(...$)=>{HQ(KQ.WARN,"WARN",$),BQ.warn(...$)};console.debug=(...$)=>{HQ(KQ.DEBUG,"DEBUG",$),BQ.debug(...$)};var FQ,GK=0,DQ=500;function vM(){if(FQ)return;let $=performance.now()+DQ;FQ=setInterval(()=>{let Z=performance.now();GK=Math.max(0,Z-$),$=Z+DQ},DQ),FQ.unref?.()}function KK(){return vM(),GK}var TM=()=>V4.createHistogram("db.query.duration",{description:"Database query execution duration in milliseconds",unit:"ms"}),HK=()=>V4.createHistogram("db.pool.acquire.duration",{description:"Time spent waiting to acquire a connection from the pool",unit:"ms"}),BK=400,kM=100,xM=($)=>(Z)=>{let Y={"db.statement":Z.query.sql,"db.status":Z.level==="error"?"error":"success"};if(Z.queryDurationMillis>BK){let Q=KK(),W=Q>BK/2;console.error(W?"Slow query measurement \u2014 likely event-loop lag, not slow SQL:":"Slow query detected:",{durationMs:Z.queryDurationMillis,eventLoopLagMs:Math.round(Q),sql:Z.query.sql,pool:{total:$.totalCount,idle:$.idleCount,waiting:$.waitingCount,max:L4()}})}if(TM().record(Z.queryDurationMillis,Y),Z.level==="error")console.error("Query failed:",{durationMs:Z.queryDurationMillis,error:Z.error,sql:Z.query.sql})};function gM($){let Z=$.connect.bind($);return $.connect=(Y)=>{if(typeof Y==="function")return Z(Y);let Q=performance.now(),W=L4(),J=$.idleCount===0&&$.totalCount>=W,G=$.idleCount;return Z().then((K)=>{let B=performance.now()-Q;if(HK().record(B,{"db.pool.outcome":J?"contended":"available"}),B>kM)if(J)console.error("Slow db pool acquire \u2014 pool saturated:",{waitMs:B,total:$.totalCount,idle:$.idleCount,waiting:$.waitingCount,max:W});else console.warn("Slow db pool acquire \u2014 event-loop lag (not pool):",{waitMs:B,idleAtStart:G,total:$.totalCount,max:W});return K},(K)=>{throw HK().record(performance.now()-Q,{"db.pool.outcome":"error"}),K})},$}var VK={keepAlive:!0,keepAliveInitialDelayMillis:1e4,idleTimeoutMillis:300000,connectionTimeoutMillis:30000,allowExitOnIdle:!0};function LK(){try{return b8().databasePgSsl}catch{return!1}}function L4(){try{return b8().databasePoolMax}catch{return 10}}function uM($){let Z=gM(new DK({connectionString:$,max:L4(),ssl:LK(),...VK})),Y=new FK({pool:Z});return{type:"postgres",db:new yM({dialect:Y,log:xM(Z)}),pool:Z}}function T9(){return b8().databaseUrl}function UK($){let Z=$||T9();return new FK({pool:new DK({connectionString:Z,max:L4(),ssl:LK(),...VK})})}function hM($){let Z=$||T9();return uM(Z)}async function jK($){if(await $.db.destroy(),!$.pool.ended)await $.pool.end();if($===y9)y9=null}var y9=null;function VQ(){if(!y9)y9=hM(T9());return y9}async function AK($){let Y={database:UK($||T9()),plugins:[pM({dynamicAccessControl:{enabled:!0,enableCustomResources:!0}}),iM(),cM(),dM(),aM(),rM({loginPage:"/login"}),lM(),nM({sendMagicLink:async()=>{}}),oM({sendVerificationOTP:async()=>{}})]},{toBeAdded:Q,toBeCreated:W,runMigrations:J}=await mM(Y);if(!Q.length&&!W.length)return"up to date";return await J(),`${W.length+Q.length} table(s) migrated`}import{createContext as sM,useContext as Di}from"react";import{jsx as Ui}from"react/jsx-runtime";var Vi=sM(void 0);import $6 from"react";import Ni from"react-dom";function YP($){if(!$||typeof document>"u")return;let Z=document.head||document.getElementsByTagName("head")[0],Y=document.createElement("style");Y.type="text/css",Z.appendChild(Y),Y.styleSheet?Y.styleSheet.cssText=$:Y.appendChild(document.createTextNode($))}var Mi=Array(12).fill(0);var UQ=1;class zK{constructor(){this.subscribe=($)=>{return this.subscribers.push($),()=>{let Z=this.subscribers.indexOf($);this.subscribers.splice(Z,1)}},this.publish=($)=>{this.subscribers.forEach((Z)=>Z($))},this.addToast=($)=>{this.publish($),this.toasts=[...this.toasts,$]},this.create=($)=>{var Z;let{message:Y,...Q}=$,W=typeof($==null?void 0:$.id)==="number"||((Z=$.id)==null?void 0:Z.length)>0?$.id:UQ++,J=this.toasts.find((K)=>{return K.id===W}),G=$.dismissible===void 0?!0:$.dismissible;if(this.dismissedToasts.has(W))this.dismissedToasts.delete(W);if(J)this.toasts=this.toasts.map((K)=>{if(K.id===W)return this.publish({...K,...$,id:W,title:Y}),{...K,...$,id:W,dismissible:G,title:Y};return K});else this.addToast({title:Y,...Q,dismissible:G,id:W});return W},this.dismiss=($)=>{if($)this.dismissedToasts.add($),requestAnimationFrame(()=>this.subscribers.forEach((Z)=>Z({id:$,dismiss:!0})));else this.toasts.forEach((Z)=>{this.subscribers.forEach((Y)=>Y({id:Z.id,dismiss:!0}))});return $},this.message=($,Z)=>{return this.create({...Z,message:$})},this.error=($,Z)=>{return this.create({...Z,message:$,type:"error"})},this.success=($,Z)=>{return this.create({...Z,type:"success",message:$})},this.info=($,Z)=>{return this.create({...Z,type:"info",message:$})},this.warning=($,Z)=>{return this.create({...Z,type:"warning",message:$})},this.loading=($,Z)=>{return this.create({...Z,type:"loading",message:$})},this.promise=($,Z)=>{if(!Z)return;let Y=void 0;if(Z.loading!==void 0)Y=this.create({...Z,promise:$,type:"loading",message:Z.loading,description:typeof Z.description!=="function"?Z.description:void 0});let Q=Promise.resolve($ instanceof Function?$():$),W=Y!==void 0,J,G=Q.then(async(B)=>{if(J=["resolve",B],$6.isValidElement(B))W=!1,this.create({id:Y,type:"default",message:B});else if(XP(B)&&!B.ok){W=!1;let V=typeof Z.error==="function"?await Z.error(`HTTP error! status: ${B.status}`):Z.error,L=typeof Z.description==="function"?await Z.description(`HTTP error! status: ${B.status}`):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"error",description:L,...O})}else if(B instanceof Error){W=!1;let V=typeof Z.error==="function"?await Z.error(B):Z.error,L=typeof Z.description==="function"?await Z.description(B):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"error",description:L,...O})}else if(Z.success!==void 0){W=!1;let V=typeof Z.success==="function"?await Z.success(B):Z.success,L=typeof Z.description==="function"?await Z.description(B):Z.description,O=typeof V==="object"&&!$6.isValidElement(V)?V:{message:V};this.create({id:Y,type:"success",description:L,...O})}}).catch(async(B)=>{if(J=["reject",B],Z.error!==void 0){W=!1;let D=typeof Z.error==="function"?await Z.error(B):Z.error,V=typeof Z.description==="function"?await Z.description(B):Z.description,A=typeof D==="object"&&!$6.isValidElement(D)?D:{message:D};this.create({id:Y,type:"error",description:V,...A})}}).finally(()=>{if(W)this.dismiss(Y),Y=void 0;Z.finally==null||Z.finally.call(Z)}),K=()=>new Promise((B,D)=>G.then(()=>J[0]==="reject"?D(J[1]):B(J[1])).catch(D));if(typeof Y!=="string"&&typeof Y!=="number")return{unwrap:K};else return Object.assign(Y,{unwrap:K})},this.custom=($,Z)=>{let Y=(Z==null?void 0:Z.id)||UQ++;return this.create({jsx:$(Y),id:Y,...Z}),Y},this.getActiveToasts=()=>{return this.toasts.filter(($)=>!this.dismissedToasts.has($.id))},this.subscribers=[],this.toasts=[],this.dismissedToasts=new Set}}var V0=new zK,QP=($,Z)=>{let Y=(Z==null?void 0:Z.id)||UQ++;return V0.addToast({title:$,...Z,id:Y}),Y},XP=($)=>{return $&&typeof $==="object"&&"ok"in $&&typeof $.ok==="boolean"&&"status"in $&&typeof $.status==="number"},WP=QP,JP=()=>V0.toasts,GP=()=>V0.getActiveToasts(),KP=Object.assign(WP,{success:V0.success,info:V0.info,warning:V0.warning,error:V0.error,custom:V0.custom,message:V0.message,promise:V0.promise,dismiss:V0.dismiss,loading:V0.loading},{getHistory:JP,getToasts:GP});YP("[data-sonner-toaster][dir=ltr],html[dir=ltr]{--toast-icon-margin-start:-3px;--toast-icon-margin-end:4px;--toast-svg-margin-start:-1px;--toast-svg-margin-end:0px;--toast-button-margin-start:auto;--toast-button-margin-end:0;--toast-close-button-start:0;--toast-close-button-end:unset;--toast-close-button-transform:translate(-35%, -35%)}[data-sonner-toaster][dir=rtl],html[dir=rtl]{--toast-icon-margin-start:4px;--toast-icon-margin-end:-3px;--toast-svg-margin-start:0px;--toast-svg-margin-end:-1px;--toast-button-margin-start:0;--toast-button-margin-end:auto;--toast-close-button-start:unset;--toast-close-button-end:0;--toast-close-button-transform:translate(35%, -35%)}[data-sonner-toaster]{position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1:hsl(0, 0%, 99%);--gray2:hsl(0, 0%, 97.3%);--gray3:hsl(0, 0%, 95.1%);--gray4:hsl(0, 0%, 93%);--gray5:hsl(0, 0%, 90.9%);--gray6:hsl(0, 0%, 88.7%);--gray7:hsl(0, 0%, 85.8%);--gray8:hsl(0, 0%, 78%);--gray9:hsl(0, 0%, 56.1%);--gray10:hsl(0, 0%, 52.3%);--gray11:hsl(0, 0%, 43.5%);--gray12:hsl(0, 0%, 9%);--border-radius:8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:0;z-index:999999999;transition:transform .4s ease}@media (hover:none) and (pointer:coarse){[data-sonner-toaster][data-lifted=true]{transform:none}}[data-sonner-toaster][data-x-position=right]{right:var(--offset-right)}[data-sonner-toaster][data-x-position=left]{left:var(--offset-left)}[data-sonner-toaster][data-x-position=center]{left:50%;transform:translateX(-50%)}[data-sonner-toaster][data-y-position=top]{top:var(--offset-top)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--offset-bottom)}[data-sonner-toast]{--y:translateY(100%);--lift-amount:calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:0;overflow-wrap:anywhere}[data-sonner-toast][data-styled=true]{padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px rgba(0,0,0,.1);width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}[data-sonner-toast]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-y-position=top]{top:0;--y:translateY(-100%);--lift:1;--lift-amount:calc(1 * var(--gap))}[data-sonner-toast][data-y-position=bottom]{bottom:0;--y:translateY(100%);--lift:-1;--lift-amount:calc(var(--lift) * var(--gap))}[data-sonner-toast][data-styled=true] [data-description]{font-weight:400;line-height:1.4;color:#3f3f3f}[data-rich-colors=true][data-sonner-toast][data-styled=true] [data-description]{color:inherit}[data-sonner-toaster][data-sonner-theme=dark] [data-description]{color:#e8e8e8}[data-sonner-toast][data-styled=true] [data-title]{font-weight:500;line-height:1.5;color:inherit}[data-sonner-toast][data-styled=true] [data-icon]{display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}[data-sonner-toast][data-promise=true] [data-icon]>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}[data-sonner-toast][data-styled=true] [data-icon]>*{flex-shrink:0}[data-sonner-toast][data-styled=true] [data-icon] svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}[data-sonner-toast][data-styled=true] [data-content]{display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;font-weight:500;cursor:pointer;outline:0;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}[data-sonner-toast][data-styled=true] [data-button]:focus-visible{box-shadow:0 0 0 2px rgba(0,0,0,.4)}[data-sonner-toast][data-styled=true] [data-button]:first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}[data-sonner-toast][data-styled=true] [data-cancel]{color:var(--normal-text);background:rgba(0,0,0,.08)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-styled=true] [data-cancel]{background:rgba(255,255,255,.3)}[data-sonner-toast][data-styled=true] [data-close-button]{position:absolute;left:var(--toast-close-button-start);right:var(--toast-close-button-end);top:0;height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);background:var(--normal-bg);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast][data-styled=true] [data-close-button]:focus-visible{box-shadow:0 4px 12px rgba(0,0,0,.1),0 0 0 2px rgba(0,0,0,.2)}[data-sonner-toast][data-styled=true] [data-disabled=true]{cursor:not-allowed}[data-sonner-toast][data-styled=true]:hover [data-close-button]:hover{background:var(--gray2);border-color:var(--gray5)}[data-sonner-toast][data-swiping=true]::before{content:'';position:absolute;left:-100%;right:-100%;height:100%;z-index:-1}[data-sonner-toast][data-y-position=top][data-swiping=true]::before{bottom:50%;transform:scaleY(3) translateY(50%)}[data-sonner-toast][data-y-position=bottom][data-swiping=true]::before{top:50%;transform:scaleY(3) translateY(-50%)}[data-sonner-toast][data-swiping=false][data-removed=true]::before{content:'';position:absolute;inset:0;transform:scaleY(2)}[data-sonner-toast][data-expanded=true]::after{content:'';position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}[data-sonner-toast][data-mounted=true]{--y:translateY(0);opacity:1}[data-sonner-toast][data-expanded=false][data-front=false]{--scale:var(--toasts-before) * 0.05 + 1;--y:translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--scale)));height:var(--front-toast-height)}[data-sonner-toast]>*{transition:opacity .4s}[data-sonner-toast][data-x-position=right]{right:0}[data-sonner-toast][data-x-position=left]{left:0}[data-sonner-toast][data-expanded=false][data-front=false][data-styled=true]>*{opacity:0}[data-sonner-toast][data-visible=false]{opacity:0;pointer-events:none}[data-sonner-toast][data-mounted=true][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}[data-sonner-toast][data-removed=true][data-front=true][data-swipe-out=false]{--y:translateY(calc(var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=true]{--y:translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=false]{--y:translateY(40%);opacity:0;transition:transform .5s,opacity .2s}[data-sonner-toast][data-removed=true][data-front=false]::before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y,0)) translateX(var(--swipe-amount-x,0));transition:none}[data-sonner-toast][data-swiped=true]{user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{from{transform:var(--y) translateX(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translateX(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{from{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media (max-width:600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--mobile-offset-bottom)}[data-sonner-toaster][data-y-position=top]{top:var(--mobile-offset-top)}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-sonner-theme=light]{--normal-bg:#fff;--normal-border:var(--gray4);--normal-text:var(--gray12);--success-bg:hsl(143, 85%, 96%);--success-border:hsl(145, 92%, 87%);--success-text:hsl(140, 100%, 27%);--info-bg:hsl(208, 100%, 97%);--info-border:hsl(221, 91%, 93%);--info-text:hsl(210, 92%, 45%);--warning-bg:hsl(49, 100%, 97%);--warning-border:hsl(49, 91%, 84%);--warning-text:hsl(31, 92%, 45%);--error-bg:hsl(359, 100%, 97%);--error-border:hsl(359, 100%, 94%);--error-text:hsl(360, 100%, 45%)}[data-sonner-toaster][data-sonner-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg:#000;--normal-border:hsl(0, 0%, 20%);--normal-text:var(--gray1)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg:#fff;--normal-border:var(--gray3);--normal-text:var(--gray12)}[data-sonner-toaster][data-sonner-theme=dark]{--normal-bg:#000;--normal-bg-hover:hsl(0, 0%, 12%);--normal-border:hsl(0, 0%, 20%);--normal-border-hover:hsl(0, 0%, 25%);--normal-text:var(--gray1);--success-bg:hsl(150, 100%, 6%);--success-border:hsl(147, 100%, 12%);--success-text:hsl(150, 86%, 65%);--info-bg:hsl(215, 100%, 6%);--info-border:hsl(223, 43%, 17%);--info-text:hsl(216, 87%, 65%);--warning-bg:hsl(64, 100%, 6%);--warning-border:hsl(60, 100%, 9%);--warning-text:hsl(46, 87%, 65%);--error-bg:hsl(358, 76%, 10%);--error-border:hsl(357, 89%, 16%);--error-text:hsl(358, 100%, 81%)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size:16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:first-child{animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}100%{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}100%{opacity:.15}}@media (prefers-reduced-motion){.sonner-loading-bar,[data-sonner-toast],[data-sonner-toast]>*{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}");import*as HP from"zod/v3";import*as U4 from"zod/v4-mini";function d6($){return!!$._zod}function L0($,Z){if(d6($))return U4.safeParse($,Z);return $.safeParse(Z)}function T8($){if(!$)return;let Z;if(d6($))Z=$._zod?.def?.shape;else Z=$.shape;if(!Z)return;if(typeof Z==="function")try{return Z()}catch{return}return Z}function jQ($){if(d6($)){let J=$._zod?.def;if(J){if(J.value!==void 0)return J.value;if(Array.isArray(J.values)&&J.values.length>0)return J.values[0]}}let Y=$._def;if(Y){if(Y.value!==void 0)return Y.value;if(Array.isArray(Y.values)&&Y.values.length>0)return Y.values[0]}let Q=$.value;if(Q!==void 0)return Q;return}import*as F from"zod/v4";var n6="2025-11-25";var AQ=[n6,"2025-06-18","2025-03-26","2024-11-05","2024-10-07"],P6="io.modelcontextprotocol/related-task",A4="2.0",C1=F.custom(($)=>$!==null&&(typeof $==="object"||typeof $==="function")),OK=F.union([F.string(),F.number().int()]),qK=F.string(),Ii=F.looseObject({ttl:F.number().optional(),pollInterval:F.number().optional()}),BP=F.object({ttl:F.number().optional()}),FP=F.object({taskId:F.string()}),zQ=F.looseObject({progressToken:OK.optional(),[P6]:FP.optional()}),J0=F.object({_meta:zQ.optional()}),k9=J0.extend({task:BP.optional()}),NK=($)=>k9.safeParse($).success,y1=F.object({method:F.string(),params:J0.loose().optional()}),U0=F.object({_meta:zQ.optional()}),j0=F.object({method:F.string(),params:U0.loose().optional()}),T1=F.looseObject({_meta:zQ.optional()}),z4=F.union([F.string(),F.number().int()]),MK=F.object({jsonrpc:F.literal(A4),id:z4,...y1.shape}).strict(),x9=($)=>MK.safeParse($).success,PK=F.object({jsonrpc:F.literal(A4),...j0.shape}).strict(),wK=($)=>PK.safeParse($).success,OQ=F.object({jsonrpc:F.literal(A4),id:z4,result:T1}).strict(),r6=($)=>OQ.safeParse($).success;var d;(function($){$[$.ConnectionClosed=-32000]="ConnectionClosed",$[$.RequestTimeout=-32001]="RequestTimeout",$[$.ParseError=-32700]="ParseError",$[$.InvalidRequest=-32600]="InvalidRequest",$[$.MethodNotFound=-32601]="MethodNotFound",$[$.InvalidParams=-32602]="InvalidParams",$[$.InternalError=-32603]="InternalError",$[$.UrlElicitationRequired=-32042]="UrlElicitationRequired"})(d||(d={}));var qQ=F.object({jsonrpc:F.literal(A4),id:z4.optional(),error:F.object({code:F.number().int(),message:F.string(),data:F.unknown().optional()})}).strict();var EK=($)=>qQ.safeParse($).success;var w6=F.union([MK,PK,OQ,qQ]),fi=F.union([OQ,qQ]),E6=T1.strict(),DP=U0.extend({requestId:z4.optional(),reason:F.string().optional()}),O4=j0.extend({method:F.literal("notifications/cancelled"),params:DP}),VP=F.object({src:F.string(),mimeType:F.string().optional(),sizes:F.array(F.string()).optional(),theme:F.enum(["light","dark"]).optional()}),g9=F.object({icons:F.array(VP).optional()}),k8=F.object({name:F.string(),title:F.string().optional()}),RK=k8.extend({...k8.shape,...g9.shape,version:F.string(),websiteUrl:F.string().optional(),description:F.string().optional()}),LP=F.intersection(F.object({applyDefaults:F.boolean().optional()}),F.record(F.string(),F.unknown())),UP=F.preprocess(($)=>{if($&&typeof $==="object"&&!Array.isArray($)){if(Object.keys($).length===0)return{form:{}}}return $},F.intersection(F.object({form:LP.optional(),url:C1.optional()}),F.record(F.string(),F.unknown()).optional())),jP=F.looseObject({list:C1.optional(),cancel:C1.optional(),requests:F.looseObject({sampling:F.looseObject({createMessage:C1.optional()}).optional(),elicitation:F.looseObject({create:C1.optional()}).optional()}).optional()}),AP=F.looseObject({list:C1.optional(),cancel:C1.optional(),requests:F.looseObject({tools:F.looseObject({call:C1.optional()}).optional()}).optional()}),zP=F.object({experimental:F.record(F.string(),C1).optional(),sampling:F.object({context:C1.optional(),tools:C1.optional()}).optional(),elicitation:UP.optional(),roots:F.object({listChanged:F.boolean().optional()}).optional(),tasks:jP.optional(),extensions:F.record(F.string(),C1).optional()}),OP=J0.extend({protocolVersion:F.string(),capabilities:zP,clientInfo:RK}),_K=y1.extend({method:F.literal("initialize"),params:OP});var qP=F.object({experimental:F.record(F.string(),C1).optional(),logging:C1.optional(),completions:C1.optional(),prompts:F.object({listChanged:F.boolean().optional()}).optional(),resources:F.object({subscribe:F.boolean().optional(),listChanged:F.boolean().optional()}).optional(),tools:F.object({listChanged:F.boolean().optional()}).optional(),tasks:AP.optional(),extensions:F.record(F.string(),C1).optional()}),NQ=T1.extend({protocolVersion:F.string(),capabilities:qP,serverInfo:RK,instructions:F.string().optional()}),MQ=j0.extend({method:F.literal("notifications/initialized"),params:U0.optional()}),CK=($)=>MQ.safeParse($).success,q4=y1.extend({method:F.literal("ping"),params:J0.optional()}),NP=F.object({progress:F.number(),total:F.optional(F.number()),message:F.optional(F.string())}),MP=F.object({...U0.shape,...NP.shape,progressToken:OK}),N4=j0.extend({method:F.literal("notifications/progress"),params:MP}),PP=J0.extend({cursor:qK.optional()}),u9=y1.extend({params:PP.optional()}),h9=T1.extend({nextCursor:qK.optional()}),wP=F.enum(["working","input_required","completed","failed","cancelled"]),m9=F.object({taskId:F.string(),status:wP,ttl:F.union([F.number(),F.null()]),createdAt:F.string(),lastUpdatedAt:F.string(),pollInterval:F.optional(F.number()),statusMessage:F.optional(F.string())}),R6=T1.extend({task:m9}),EP=U0.merge(m9),l9=j0.extend({method:F.literal("notifications/tasks/status"),params:EP}),M4=y1.extend({method:F.literal("tasks/get"),params:J0.extend({taskId:F.string()})}),P4=T1.merge(m9),w4=y1.extend({method:F.literal("tasks/result"),params:J0.extend({taskId:F.string()})}),Si=T1.loose(),E4=u9.extend({method:F.literal("tasks/list")}),R4=h9.extend({tasks:F.array(m9)}),_4=y1.extend({method:F.literal("tasks/cancel"),params:J0.extend({taskId:F.string()})}),IK=T1.merge(m9),fK=F.object({uri:F.string(),mimeType:F.optional(F.string()),_meta:F.record(F.string(),F.unknown()).optional()}),SK=fK.extend({text:F.string()}),PQ=F.string().refine(($)=>{try{return atob($),!0}catch{return!1}},{message:"Invalid Base64 string"}),bK=fK.extend({blob:PQ}),p9=F.enum(["user","assistant"]),x8=F.object({audience:F.array(p9).optional(),priority:F.number().min(0).max(1).optional(),lastModified:F.iso.datetime({offset:!0}).optional()}),vK=F.object({...k8.shape,...g9.shape,uri:F.string(),description:F.optional(F.string()),mimeType:F.optional(F.string()),size:F.optional(F.number()),annotations:x8.optional(),_meta:F.optional(F.looseObject({}))}),RP=F.object({...k8.shape,...g9.shape,uriTemplate:F.string(),description:F.optional(F.string()),mimeType:F.optional(F.string()),annotations:x8.optional(),_meta:F.optional(F.looseObject({}))}),wQ=u9.extend({method:F.literal("resources/list")}),EQ=h9.extend({resources:F.array(vK)}),RQ=u9.extend({method:F.literal("resources/templates/list")}),_Q=h9.extend({resourceTemplates:F.array(RP)}),CQ=J0.extend({uri:F.string()}),_P=CQ,IQ=y1.extend({method:F.literal("resources/read"),params:_P}),fQ=T1.extend({contents:F.array(F.union([SK,bK]))}),SQ=j0.extend({method:F.literal("notifications/resources/list_changed"),params:U0.optional()}),CP=CQ,IP=y1.extend({method:F.literal("resources/subscribe"),params:CP}),fP=CQ,SP=y1.extend({method:F.literal("resources/unsubscribe"),params:fP}),bP=U0.extend({uri:F.string()}),vP=j0.extend({method:F.literal("notifications/resources/updated"),params:bP}),yP=F.object({name:F.string(),description:F.optional(F.string()),required:F.optional(F.boolean())}),TP=F.object({...k8.shape,...g9.shape,description:F.optional(F.string()),arguments:F.optional(F.array(yP)),_meta:F.optional(F.looseObject({}))}),bQ=u9.extend({method:F.literal("prompts/list")}),vQ=h9.extend({prompts:F.array(TP)}),kP=J0.extend({name:F.string(),arguments:F.record(F.string(),F.string()).optional()}),yQ=y1.extend({method:F.literal("prompts/get"),params:kP}),TQ=F.object({type:F.literal("text"),text:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),kQ=F.object({type:F.literal("image"),data:PQ,mimeType:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),xQ=F.object({type:F.literal("audio"),data:PQ,mimeType:F.string(),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),xP=F.object({type:F.literal("tool_use"),name:F.string(),id:F.string(),input:F.record(F.string(),F.unknown()),_meta:F.record(F.string(),F.unknown()).optional()}),gP=F.object({type:F.literal("resource"),resource:F.union([SK,bK]),annotations:x8.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),uP=vK.extend({type:F.literal("resource_link")}),gQ=F.union([TQ,kQ,xQ,uP,gP]),hP=F.object({role:p9,content:gQ}),uQ=T1.extend({description:F.string().optional(),messages:F.array(hP)}),hQ=j0.extend({method:F.literal("notifications/prompts/list_changed"),params:U0.optional()}),mP=F.object({title:F.string().optional(),readOnlyHint:F.boolean().optional(),destructiveHint:F.boolean().optional(),idempotentHint:F.boolean().optional(),openWorldHint:F.boolean().optional()}),lP=F.object({taskSupport:F.enum(["required","optional","forbidden"]).optional()}),C4=F.object({...k8.shape,...g9.shape,description:F.string().optional(),inputSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),C1).optional(),required:F.array(F.string()).optional()}).catchall(F.unknown()),outputSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),C1).optional(),required:F.array(F.string()).optional()}).catchall(F.unknown()).optional(),annotations:mP.optional(),execution:lP.optional(),_meta:F.record(F.string(),F.unknown()).optional()}),mQ=u9.extend({method:F.literal("tools/list")}),i9=h9.extend({tools:F.array(C4)}),a6=T1.extend({content:F.array(gQ).default([]),structuredContent:F.record(F.string(),F.unknown()).optional(),isError:F.boolean().optional()}),bi=a6.or(T1.extend({toolResult:F.unknown()})),pP=k9.extend({name:F.string(),arguments:F.record(F.string(),F.unknown()).optional()}),I4=y1.extend({method:F.literal("tools/call"),params:pP}),lQ=j0.extend({method:F.literal("notifications/tools/list_changed"),params:U0.optional()}),yK=F.object({autoRefresh:F.boolean().default(!0),debounceMs:F.number().int().nonnegative().default(300)}),pQ=F.enum(["debug","info","notice","warning","error","critical","alert","emergency"]),iP=J0.extend({level:pQ}),TK=y1.extend({method:F.literal("logging/setLevel"),params:iP}),cP=U0.extend({level:pQ,logger:F.string().optional(),data:F.unknown()}),dP=j0.extend({method:F.literal("notifications/message"),params:cP}),nP=F.object({name:F.string().optional()}),rP=F.object({hints:F.array(nP).optional(),costPriority:F.number().min(0).max(1).optional(),speedPriority:F.number().min(0).max(1).optional(),intelligencePriority:F.number().min(0).max(1).optional()}),aP=F.object({mode:F.enum(["auto","required","none"]).optional()}),oP=F.object({type:F.literal("tool_result"),toolUseId:F.string().describe("The unique identifier for the corresponding tool call."),content:F.array(gQ).default([]),structuredContent:F.object({}).loose().optional(),isError:F.boolean().optional(),_meta:F.record(F.string(),F.unknown()).optional()}),sP=F.discriminatedUnion("type",[TQ,kQ,xQ]),j4=F.discriminatedUnion("type",[TQ,kQ,xQ,xP,oP]),tP=F.object({role:p9,content:F.union([j4,F.array(j4)]),_meta:F.record(F.string(),F.unknown()).optional()}),eP=k9.extend({messages:F.array(tP),modelPreferences:rP.optional(),systemPrompt:F.string().optional(),includeContext:F.enum(["none","thisServer","allServers"]).optional(),temperature:F.number().optional(),maxTokens:F.number().int(),stopSequences:F.array(F.string()).optional(),metadata:C1.optional(),tools:F.array(C4).optional(),toolChoice:aP.optional()}),iQ=y1.extend({method:F.literal("sampling/createMessage"),params:eP}),c9=T1.extend({model:F.string(),stopReason:F.optional(F.enum(["endTurn","stopSequence","maxTokens"]).or(F.string())),role:p9,content:sP}),f4=T1.extend({model:F.string(),stopReason:F.optional(F.enum(["endTurn","stopSequence","maxTokens","toolUse"]).or(F.string())),role:p9,content:F.union([j4,F.array(j4)])}),$w=F.object({type:F.literal("boolean"),title:F.string().optional(),description:F.string().optional(),default:F.boolean().optional()}),Zw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),minLength:F.number().optional(),maxLength:F.number().optional(),format:F.enum(["email","uri","date","date-time"]).optional(),default:F.string().optional()}),Yw=F.object({type:F.enum(["number","integer"]),title:F.string().optional(),description:F.string().optional(),minimum:F.number().optional(),maximum:F.number().optional(),default:F.number().optional()}),Qw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),enum:F.array(F.string()),default:F.string().optional()}),Xw=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),oneOf:F.array(F.object({const:F.string(),title:F.string()})),default:F.string().optional()}),Ww=F.object({type:F.literal("string"),title:F.string().optional(),description:F.string().optional(),enum:F.array(F.string()),enumNames:F.array(F.string()).optional(),default:F.string().optional()}),Jw=F.union([Qw,Xw]),Gw=F.object({type:F.literal("array"),title:F.string().optional(),description:F.string().optional(),minItems:F.number().optional(),maxItems:F.number().optional(),items:F.object({type:F.literal("string"),enum:F.array(F.string())}),default:F.array(F.string()).optional()}),Kw=F.object({type:F.literal("array"),title:F.string().optional(),description:F.string().optional(),minItems:F.number().optional(),maxItems:F.number().optional(),items:F.object({anyOf:F.array(F.object({const:F.string(),title:F.string()}))}),default:F.array(F.string()).optional()}),Hw=F.union([Gw,Kw]),Bw=F.union([Ww,Jw,Hw]),Fw=F.union([Bw,$w,Zw,Yw]),Dw=k9.extend({mode:F.literal("form").optional(),message:F.string(),requestedSchema:F.object({type:F.literal("object"),properties:F.record(F.string(),Fw),required:F.array(F.string()).optional()})}),Vw=k9.extend({mode:F.literal("url"),message:F.string(),elicitationId:F.string(),url:F.string().url()}),Lw=F.union([Dw,Vw]),cQ=y1.extend({method:F.literal("elicitation/create"),params:Lw}),Uw=U0.extend({elicitationId:F.string()}),jw=j0.extend({method:F.literal("notifications/elicitation/complete"),params:Uw}),d9=T1.extend({action:F.enum(["accept","decline","cancel"]),content:F.preprocess(($)=>$===null?void 0:$,F.record(F.string(),F.union([F.string(),F.number(),F.boolean(),F.array(F.string())])).optional())}),Aw=F.object({type:F.literal("ref/resource"),uri:F.string()});var zw=F.object({type:F.literal("ref/prompt"),name:F.string()}),Ow=J0.extend({ref:F.union([zw,Aw]),argument:F.object({name:F.string(),value:F.string()}),context:F.object({arguments:F.record(F.string(),F.string()).optional()}).optional()}),kK=y1.extend({method:F.literal("completion/complete"),params:Ow});var dQ=T1.extend({completion:F.looseObject({values:F.array(F.string()).max(100),total:F.optional(F.number().int()),hasMore:F.optional(F.boolean())})}),qw=F.object({uri:F.string().startsWith("file://"),name:F.string().optional(),_meta:F.record(F.string(),F.unknown()).optional()}),Nw=y1.extend({method:F.literal("roots/list"),params:J0.optional()}),xK=T1.extend({roots:F.array(qw)}),Mw=j0.extend({method:F.literal("notifications/roots/list_changed"),params:U0.optional()}),vi=F.union([q4,_K,kK,TK,yQ,bQ,wQ,RQ,IQ,IP,SP,I4,mQ,M4,w4,E4,_4]),yi=F.union([O4,N4,MQ,Mw,l9]),Ti=F.union([E6,c9,f4,d9,xK,P4,R4,R6]),ki=F.union([q4,iQ,cQ,Nw,M4,w4,E4,_4]),xi=F.union([O4,N4,dP,vP,SQ,lQ,hQ,l9,jw]),gi=F.union([E6,NQ,dQ,uQ,vQ,EQ,_Q,fQ,a6,i9,P4,R4,R6]);class l extends Error{constructor($,Z,Y){super(`MCP error ${$}: ${Z}`);this.code=$,this.data=Y,this.name="McpError"}static fromError($,Z,Y){if($===d.UrlElicitationRequired&&Y){let Q=Y;if(Q.elicitations)return new gK(Q.elicitations,Z)}return new l($,Z,Y)}}class gK extends l{constructor($,Z=`URL elicitation${$.length>1?"s":""} required`){super(d.UrlElicitationRequired,Z,{elicitations:$})}get elicitations(){return this.data?.elicitations??[]}}function _6($){return $==="completed"||$==="failed"||$==="cancelled"}import*as Iw from"zod/v4-mini";var Pw=Symbol("Let zodToJsonSchema decide on which parser to use");import{ZodFirstPartyTypeKind as gd}from"zod/v3";import{ZodFirstPartyTypeKind as oi}from"zod/v3";import{ZodFirstPartyTypeKind as Mc}from"zod/v3";var Oc=new Set("ABCDEFGHIJKLMNOPQRSTUVXYZabcdefghijklmnopqrstuvxyz0123456789");function nQ($){let Y=T8($)?.method;if(!Y)throw Error("Schema is missing a method literal");let Q=jQ(Y);if(typeof Q!=="string")throw Error("Schema method literal must be a string");return Q}function rQ($,Z){let Y=L0($,Z);if(!Y.success)throw Y.error;return Y.data}var fw=60000;class S4{constructor($){if(this._options=$,this._requestMessageId=0,this._requestHandlers=new Map,this._requestHandlerAbortControllers=new Map,this._notificationHandlers=new Map,this._responseHandlers=new Map,this._progressHandlers=new Map,this._timeoutInfo=new Map,this._pendingDebouncedNotifications=new Set,this._taskProgressTokens=new Map,this._requestResolvers=new Map,this.setNotificationHandler(O4,(Z)=>{this._oncancel(Z)}),this.setNotificationHandler(N4,(Z)=>{this._onprogress(Z)}),this.setRequestHandler(q4,(Z)=>({})),this._taskStore=$?.taskStore,this._taskMessageQueue=$?.taskMessageQueue,this._taskStore)this.setRequestHandler(M4,async(Z,Y)=>{let Q=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!Q)throw new l(d.InvalidParams,"Failed to retrieve task: Task not found");return{...Q}}),this.setRequestHandler(w4,async(Z,Y)=>{let Q=async()=>{let W=Z.params.taskId;if(this._taskMessageQueue){let G;while(G=await this._taskMessageQueue.dequeue(W,Y.sessionId)){if(G.type==="response"||G.type==="error"){let K=G.message,B=K.id,D=this._requestResolvers.get(B);if(D)if(this._requestResolvers.delete(B),G.type==="response")D(K);else{let V=K,L=new l(V.error.code,V.error.message,V.error.data);D(L)}else{let V=G.type==="response"?"Response":"Error";this._onerror(Error(`${V} handler missing for request ${B}`))}continue}await this._transport?.send(G.message,{relatedRequestId:Y.requestId})}}let J=await this._taskStore.getTask(W,Y.sessionId);if(!J)throw new l(d.InvalidParams,`Task not found: ${W}`);if(!_6(J.status))return await this._waitForTaskUpdate(W,Y.signal),await Q();if(_6(J.status)){let G=await this._taskStore.getTaskResult(W,Y.sessionId);return this._clearTaskQueue(W),{...G,_meta:{...G._meta,[P6]:{taskId:W}}}}return await Q()};return await Q()}),this.setRequestHandler(E4,async(Z,Y)=>{try{let{tasks:Q,nextCursor:W}=await this._taskStore.listTasks(Z.params?.cursor,Y.sessionId);return{tasks:Q,nextCursor:W,_meta:{}}}catch(Q){throw new l(d.InvalidParams,`Failed to list tasks: ${Q instanceof Error?Q.message:String(Q)}`)}}),this.setRequestHandler(_4,async(Z,Y)=>{try{let Q=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!Q)throw new l(d.InvalidParams,`Task not found: ${Z.params.taskId}`);if(_6(Q.status))throw new l(d.InvalidParams,`Cannot cancel task in terminal status: ${Q.status}`);await this._taskStore.updateTaskStatus(Z.params.taskId,"cancelled","Client cancelled task execution.",Y.sessionId),this._clearTaskQueue(Z.params.taskId);let W=await this._taskStore.getTask(Z.params.taskId,Y.sessionId);if(!W)throw new l(d.InvalidParams,`Task not found after cancellation: ${Z.params.taskId}`);return{_meta:{},...W}}catch(Q){if(Q instanceof l)throw Q;throw new l(d.InvalidRequest,`Failed to cancel task: ${Q instanceof Error?Q.message:String(Q)}`)}})}async _oncancel($){if(!$.params.requestId)return;this._requestHandlerAbortControllers.get($.params.requestId)?.abort($.params.reason)}_setupTimeout($,Z,Y,Q,W=!1){this._timeoutInfo.set($,{timeoutId:setTimeout(Q,Z),startTime:Date.now(),timeout:Z,maxTotalTimeout:Y,resetTimeoutOnProgress:W,onTimeout:Q})}_resetTimeout($){let Z=this._timeoutInfo.get($);if(!Z)return!1;let Y=Date.now()-Z.startTime;if(Z.maxTotalTimeout&&Y>=Z.maxTotalTimeout)throw this._timeoutInfo.delete($),l.fromError(d.RequestTimeout,"Maximum total timeout exceeded",{maxTotalTimeout:Z.maxTotalTimeout,totalElapsed:Y});return clearTimeout(Z.timeoutId),Z.timeoutId=setTimeout(Z.onTimeout,Z.timeout),!0}_cleanupTimeout($){let Z=this._timeoutInfo.get($);if(Z)clearTimeout(Z.timeoutId),this._timeoutInfo.delete($)}async connect($){if(this._transport)throw Error("Already connected to a transport. Call close() before connecting to a new transport, or use a separate Protocol instance per connection.");this._transport=$;let Z=this.transport?.onclose;this._transport.onclose=()=>{Z?.(),this._onclose()};let Y=this.transport?.onerror;this._transport.onerror=(W)=>{Y?.(W),this._onerror(W)};let Q=this._transport?.onmessage;this._transport.onmessage=(W,J)=>{if(Q?.(W,J),r6(W)||EK(W))this._onresponse(W);else if(x9(W))this._onrequest(W,J);else if(wK(W))this._onnotification(W);else this._onerror(Error(`Unknown message type: ${JSON.stringify(W)}`))},await this._transport.start()}_onclose(){let $=this._responseHandlers;this._responseHandlers=new Map,this._progressHandlers.clear(),this._taskProgressTokens.clear(),this._pendingDebouncedNotifications.clear();for(let Y of this._timeoutInfo.values())clearTimeout(Y.timeoutId);this._timeoutInfo.clear();for(let Y of this._requestHandlerAbortControllers.values())Y.abort();this._requestHandlerAbortControllers.clear();let Z=l.fromError(d.ConnectionClosed,"Connection closed");this._transport=void 0,this.onclose?.();for(let Y of $.values())Y(Z)}_onerror($){this.onerror?.($)}_onnotification($){let Z=this._notificationHandlers.get($.method)??this.fallbackNotificationHandler;if(Z===void 0)return;Promise.resolve().then(()=>Z($)).catch((Y)=>this._onerror(Error(`Uncaught error in notification handler: ${Y}`)))}_onrequest($,Z){let Y=this._requestHandlers.get($.method)??this.fallbackRequestHandler,Q=this._transport,W=$.params?._meta?.[P6]?.taskId;if(Y===void 0){let D={jsonrpc:"2.0",id:$.id,error:{code:d.MethodNotFound,message:"Method not found"}};if(W&&this._taskMessageQueue)this._enqueueTaskMessage(W,{type:"error",message:D,timestamp:Date.now()},Q?.sessionId).catch((V)=>this._onerror(Error(`Failed to enqueue error response: ${V}`)));else Q?.send(D).catch((V)=>this._onerror(Error(`Failed to send an error response: ${V}`)));return}let J=new AbortController;this._requestHandlerAbortControllers.set($.id,J);let G=NK($.params)?$.params.task:void 0,K=this._taskStore?this.requestTaskStore($,Q?.sessionId):void 0,B={signal:J.signal,sessionId:Q?.sessionId,_meta:$.params?._meta,sendNotification:async(D)=>{if(J.signal.aborted)return;let V={relatedRequestId:$.id};if(W)V.relatedTask={taskId:W};await this.notification(D,V)},sendRequest:async(D,V,L)=>{if(J.signal.aborted)throw new l(d.ConnectionClosed,"Request was cancelled");let A={...L,relatedRequestId:$.id};if(W&&!A.relatedTask)A.relatedTask={taskId:W};let O=A.relatedTask?.taskId??W;if(O&&K)await K.updateTaskStatus(O,"input_required");return await this.request(D,V,A)},authInfo:Z?.authInfo,requestId:$.id,requestInfo:Z?.requestInfo,taskId:W,taskStore:K,taskRequestedTtl:G?.ttl,closeSSEStream:Z?.closeSSEStream,closeStandaloneSSEStream:Z?.closeStandaloneSSEStream};Promise.resolve().then(()=>{if(G)this.assertTaskHandlerCapability($.method)}).then(()=>Y($,B)).then(async(D)=>{if(J.signal.aborted)return;let V={result:D,jsonrpc:"2.0",id:$.id};if(W&&this._taskMessageQueue)await this._enqueueTaskMessage(W,{type:"response",message:V,timestamp:Date.now()},Q?.sessionId);else await Q?.send(V)},async(D)=>{if(J.signal.aborted)return;let V={jsonrpc:"2.0",id:$.id,error:{code:Number.isSafeInteger(D.code)?D.code:d.InternalError,message:D.message??"Internal error",...D.data!==void 0&&{data:D.data}}};if(W&&this._taskMessageQueue)await this._enqueueTaskMessage(W,{type:"error",message:V,timestamp:Date.now()},Q?.sessionId);else await Q?.send(V)}).catch((D)=>this._onerror(Error(`Failed to send response: ${D}`))).finally(()=>{if(this._requestHandlerAbortControllers.get($.id)===J)this._requestHandlerAbortControllers.delete($.id)})}_onprogress($){let{progressToken:Z,...Y}=$.params,Q=Number(Z),W=this._progressHandlers.get(Q);if(!W){this._onerror(Error(`Received a progress notification for an unknown token: ${JSON.stringify($)}`));return}let J=this._responseHandlers.get(Q),G=this._timeoutInfo.get(Q);if(G&&J&&G.resetTimeoutOnProgress)try{this._resetTimeout(Q)}catch(K){this._responseHandlers.delete(Q),this._progressHandlers.delete(Q),this._cleanupTimeout(Q),J(K);return}W(Y)}_onresponse($){let Z=Number($.id),Y=this._requestResolvers.get(Z);if(Y){if(this._requestResolvers.delete(Z),r6($))Y($);else{let J=new l($.error.code,$.error.message,$.error.data);Y(J)}return}let Q=this._responseHandlers.get(Z);if(Q===void 0){this._onerror(Error(`Received a response for an unknown message ID: ${JSON.stringify($)}`));return}this._responseHandlers.delete(Z),this._cleanupTimeout(Z);let W=!1;if(r6($)&&$.result&&typeof $.result==="object"){let J=$.result;if(J.task&&typeof J.task==="object"){let G=J.task;if(typeof G.taskId==="string")W=!0,this._taskProgressTokens.set(G.taskId,Z)}}if(!W)this._progressHandlers.delete(Z);if(r6($))Q($);else{let J=l.fromError($.error.code,$.error.message,$.error.data);Q(J)}}get transport(){return this._transport}async close(){await this._transport?.close()}async*requestStream($,Z,Y){let{task:Q}=Y??{};if(!Q){try{yield{type:"result",result:await this.request($,Z,Y)}}catch(J){yield{type:"error",error:J instanceof l?J:new l(d.InternalError,String(J))}}return}let W;try{let J=await this.request($,R6,Y);if(J.task)W=J.task.taskId,yield{type:"taskCreated",task:J.task};else throw new l(d.InternalError,"Task creation did not return a task");while(!0){let G=await this.getTask({taskId:W},Y);if(yield{type:"taskStatus",task:G},_6(G.status)){if(G.status==="completed")yield{type:"result",result:await this.getTaskResult({taskId:W},Z,Y)};else if(G.status==="failed")yield{type:"error",error:new l(d.InternalError,`Task ${W} failed`)};else if(G.status==="cancelled")yield{type:"error",error:new l(d.InternalError,`Task ${W} was cancelled`)};return}if(G.status==="input_required"){yield{type:"result",result:await this.getTaskResult({taskId:W},Z,Y)};return}let K=G.pollInterval??this._options?.defaultTaskPollInterval??1000;await new Promise((B)=>setTimeout(B,K)),Y?.signal?.throwIfAborted()}}catch(J){yield{type:"error",error:J instanceof l?J:new l(d.InternalError,String(J))}}}request($,Z,Y){let{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J,task:G,relatedTask:K}=Y??{};return new Promise((B,D)=>{let V=(N)=>{D(N)};if(!this._transport){V(Error("Not connected"));return}if(this._options?.enforceStrictCapabilities===!0)try{if(this.assertCapabilityForMethod($.method),G)this.assertTaskCapability($.method)}catch(N){V(N);return}Y?.signal?.throwIfAborted();let L=this._requestMessageId++,A={...$,jsonrpc:"2.0",id:L};if(Y?.onprogress)this._progressHandlers.set(L,Y.onprogress),A.params={...$.params,_meta:{...$.params?._meta||{},progressToken:L}};if(G)A.params={...A.params,task:G};if(K)A.params={...A.params,_meta:{...A.params?._meta||{},[P6]:K}};let O=(N)=>{this._responseHandlers.delete(L),this._progressHandlers.delete(L),this._cleanupTimeout(L),this._transport?.send({jsonrpc:"2.0",method:"notifications/cancelled",params:{requestId:L,reason:String(N)}},{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J}).catch((f)=>this._onerror(Error(`Failed to send cancellation: ${f}`)));let E=N instanceof l?N:new l(d.RequestTimeout,String(N));D(E)};this._responseHandlers.set(L,(N)=>{if(Y?.signal?.aborted)return;if(N instanceof Error)return D(N);try{let E=L0(Z,N.result);if(!E.success)D(E.error);else B(E.data)}catch(E){D(E)}}),Y?.signal?.addEventListener("abort",()=>{O(Y?.signal?.reason)});let q=Y?.timeout??fw,M=()=>O(l.fromError(d.RequestTimeout,"Request timed out",{timeout:q}));this._setupTimeout(L,q,Y?.maxTotalTimeout,M,Y?.resetTimeoutOnProgress??!1);let I=K?.taskId;if(I){let N=(E)=>{let f=this._responseHandlers.get(L);if(f)f(E);else this._onerror(Error(`Response handler missing for side-channeled request ${L}`))};this._requestResolvers.set(L,N),this._enqueueTaskMessage(I,{type:"request",message:A,timestamp:Date.now()}).catch((E)=>{this._cleanupTimeout(L),D(E)})}else this._transport.send(A,{relatedRequestId:Q,resumptionToken:W,onresumptiontoken:J}).catch((N)=>{this._cleanupTimeout(L),D(N)})})}async getTask($,Z){return this.request({method:"tasks/get",params:$},P4,Z)}async getTaskResult($,Z,Y){return this.request({method:"tasks/result",params:$},Z,Y)}async listTasks($,Z){return this.request({method:"tasks/list",params:$},R4,Z)}async cancelTask($,Z){return this.request({method:"tasks/cancel",params:$},IK,Z)}async notification($,Z){if(!this._transport)throw Error("Not connected");this.assertNotificationCapability($.method);let Y=Z?.relatedTask?.taskId;if(Y){let G={...$,jsonrpc:"2.0",params:{...$.params,_meta:{...$.params?._meta||{},[P6]:Z.relatedTask}}};await this._enqueueTaskMessage(Y,{type:"notification",message:G,timestamp:Date.now()});return}if((this._options?.debouncedNotificationMethods??[]).includes($.method)&&!$.params&&!Z?.relatedRequestId&&!Z?.relatedTask){if(this._pendingDebouncedNotifications.has($.method))return;this._pendingDebouncedNotifications.add($.method),Promise.resolve().then(()=>{if(this._pendingDebouncedNotifications.delete($.method),!this._transport)return;let G={...$,jsonrpc:"2.0"};if(Z?.relatedTask)G={...G,params:{...G.params,_meta:{...G.params?._meta||{},[P6]:Z.relatedTask}}};this._transport?.send(G,Z).catch((K)=>this._onerror(K))});return}let J={...$,jsonrpc:"2.0"};if(Z?.relatedTask)J={...J,params:{...J.params,_meta:{...J.params?._meta||{},[P6]:Z.relatedTask}}};await this._transport.send(J,Z)}setRequestHandler($,Z){let Y=nQ($);this.assertRequestHandlerCapability(Y),this._requestHandlers.set(Y,(Q,W)=>{let J=rQ($,Q);return Promise.resolve(Z(J,W))})}removeRequestHandler($){this._requestHandlers.delete($)}assertCanSetRequestHandler($){if(this._requestHandlers.has($))throw Error(`A request handler for ${$} already exists, which would be overridden`)}setNotificationHandler($,Z){let Y=nQ($);this._notificationHandlers.set(Y,(Q)=>{let W=rQ($,Q);return Promise.resolve(Z(W))})}removeNotificationHandler($){this._notificationHandlers.delete($)}_cleanupTaskProgressHandler($){let Z=this._taskProgressTokens.get($);if(Z!==void 0)this._progressHandlers.delete(Z),this._taskProgressTokens.delete($)}async _enqueueTaskMessage($,Z,Y){if(!this._taskStore||!this._taskMessageQueue)throw Error("Cannot enqueue task message: taskStore and taskMessageQueue are not configured");let Q=this._options?.maxTaskQueueSize;await this._taskMessageQueue.enqueue($,Z,Y,Q)}async _clearTaskQueue($,Z){if(this._taskMessageQueue){let Y=await this._taskMessageQueue.dequeueAll($,Z);for(let Q of Y)if(Q.type==="request"&&x9(Q.message)){let W=Q.message.id,J=this._requestResolvers.get(W);if(J)J(new l(d.InternalError,"Task cancelled or completed")),this._requestResolvers.delete(W);else this._onerror(Error(`Resolver missing for request ${W} during task ${$} cleanup`))}}}async _waitForTaskUpdate($,Z){let Y=this._options?.defaultTaskPollInterval??1000;try{let Q=await this._taskStore?.getTask($);if(Q?.pollInterval)Y=Q.pollInterval}catch{}return new Promise((Q,W)=>{if(Z.aborted){W(new l(d.InvalidRequest,"Request cancelled"));return}let J=setTimeout(Q,Y);Z.addEventListener("abort",()=>{clearTimeout(J),W(new l(d.InvalidRequest,"Request cancelled"))},{once:!0})})}requestTaskStore($,Z){let Y=this._taskStore;if(!Y)throw Error("No task store configured");return{createTask:async(Q)=>{if(!$)throw Error("No request provided");return await Y.createTask(Q,$.id,{method:$.method,params:$.params},Z)},getTask:async(Q)=>{let W=await Y.getTask(Q,Z);if(!W)throw new l(d.InvalidParams,"Failed to retrieve task: Task not found");return W},storeTaskResult:async(Q,W,J)=>{await Y.storeTaskResult(Q,W,J,Z);let G=await Y.getTask(Q,Z);if(G){let K=l9.parse({method:"notifications/tasks/status",params:G});if(await this.notification(K),_6(G.status))this._cleanupTaskProgressHandler(Q)}},getTaskResult:(Q)=>{return Y.getTaskResult(Q,Z)},updateTaskStatus:async(Q,W,J)=>{let G=await Y.getTask(Q,Z);if(!G)throw new l(d.InvalidParams,`Task "${Q}" not found - it may have been cleaned up`);if(_6(G.status))throw new l(d.InvalidParams,`Cannot update task "${Q}" from terminal status "${G.status}" to "${W}". Terminal states (completed, failed, cancelled) cannot transition to other states.`);await Y.updateTaskStatus(Q,W,J,Z);let K=await Y.getTask(Q,Z);if(K){let B=l9.parse({method:"notifications/tasks/status",params:K});if(await this.notification(B),_6(K.status))this._cleanupTaskProgressHandler(Q)}},listTasks:(Q)=>{return Y.listTasks(Q,Z)}}}}function uK($){return $!==null&&typeof $==="object"&&!Array.isArray($)}function aQ($,Z){let Y={...$};for(let Q in Z){let W=Q,J=Z[W];if(J===void 0)continue;let G=Y[W];if(uK(G)&&uK(J))Y[W]={...G,...J};else Y[W]=J}return Y}var UV=i6(L5(),1),jV=i6(tX(),1);function mb(){let $=new UV.default({strict:!1,validateFormats:!0,validateSchema:!1,allErrors:!0});return jV.default($),$}class j5{constructor($){this._ajv=$??mb()}getValidator($){let Z="$id"in $&&typeof $.$id==="string"?this._ajv.getSchema($.$id)??this._ajv.compile($):this._ajv.compile($);return(Y)=>{if(Z(Y))return{valid:!0,data:Y,errorMessage:void 0};else return{valid:!1,data:void 0,errorMessage:this._ajv.errorsText(Z.errors)}}}}class eX{constructor($){this._client=$}async*callToolStream($,Z=a6,Y){let Q=this._client,W={...Y,task:Y?.task??(Q.isToolTask($.name)?{}:void 0)},J=Q.requestStream({method:"tools/call",params:$},Z,W),G=Q.getToolOutputValidator($.name);for await(let K of J){if(K.type==="result"&&G){let B=K.result;if(!B.structuredContent&&!B.isError){yield{type:"error",error:new l(d.InvalidRequest,`Tool ${$.name} has an output schema but did not return structured content`)};return}if(B.structuredContent)try{let D=G(B.structuredContent);if(!D.valid){yield{type:"error",error:new l(d.InvalidParams,`Structured content does not match the tool's output schema: ${D.errorMessage}`)};return}}catch(D){if(D instanceof l){yield{type:"error",error:D};return}yield{type:"error",error:new l(d.InvalidParams,`Failed to validate structured content: ${D instanceof Error?D.message:String(D)}`)};return}}yield K}}async getTask($,Z){return this._client.getTask({taskId:$},Z)}async getTaskResult($,Z,Y){return this._client.getTaskResult({taskId:$},Z,Y)}async listTasks($,Z){return this._client.listTasks($?{cursor:$}:void 0,Z)}async cancelTask($,Z){return this._client.cancelTask({taskId:$},Z)}requestStream($,Z,Y){return this._client.requestStream($,Z,Y)}}function $W($,Z,Y){if(!$)throw Error(`${Y} does not support task creation (required for ${Z})`);switch(Z){case"tools/call":if(!$.tools?.call)throw Error(`${Y} does not support task creation for tools/call (required for ${Z})`);break;default:break}}function ZW($,Z,Y){if(!$)throw Error(`${Y} does not support task creation (required for ${Z})`);switch(Z){case"sampling/createMessage":if(!$.sampling?.createMessage)throw Error(`${Y} does not support task creation for sampling/createMessage (required for ${Z})`);break;case"elicitation/create":if(!$.elicitation?.create)throw Error(`${Y} does not support task creation for elicitation/create (required for ${Z})`);break;default:break}}function A5($,Z){if(!$||Z===null||typeof Z!=="object")return;if($.type==="object"&&$.properties&&typeof $.properties==="object"){let Y=Z,Q=$.properties;for(let W of Object.keys(Q)){let J=Q[W];if(Y[W]===void 0&&Object.prototype.hasOwnProperty.call(J,"default"))Y[W]=J.default;if(Y[W]!==void 0)A5(J,Y[W])}}if(Array.isArray($.anyOf)){for(let Y of $.anyOf)if(typeof Y!=="boolean")A5(Y,Z)}if(Array.isArray($.oneOf)){for(let Y of $.oneOf)if(typeof Y!=="boolean")A5(Y,Z)}}function lb($){if(!$)return{supportsFormMode:!1,supportsUrlMode:!1};let Z=$.form!==void 0,Y=$.url!==void 0;return{supportsFormMode:Z||!Z&&!Y,supportsUrlMode:Y}}class z5 extends S4{constructor($,Z){super(Z);if(this._clientInfo=$,this._cachedToolOutputValidators=new Map,this._cachedKnownTaskTools=new Set,this._cachedRequiredTaskTools=new Set,this._listChangedDebounceTimers=new Map,this._capabilities=Z?.capabilities??{},this._jsonSchemaValidator=Z?.jsonSchemaValidator??new j5,Z?.listChanged)this._pendingListChangedConfig=Z.listChanged}_setupListChangedHandlers($){if($.tools&&this._serverCapabilities?.tools?.listChanged)this._setupListChangedHandler("tools",lQ,$.tools,async()=>{return(await this.listTools()).tools});if($.prompts&&this._serverCapabilities?.prompts?.listChanged)this._setupListChangedHandler("prompts",hQ,$.prompts,async()=>{return(await this.listPrompts()).prompts});if($.resources&&this._serverCapabilities?.resources?.listChanged)this._setupListChangedHandler("resources",SQ,$.resources,async()=>{return(await this.listResources()).resources})}get experimental(){if(!this._experimental)this._experimental={tasks:new eX(this)};return this._experimental}registerCapabilities($){if(this.transport)throw Error("Cannot register capabilities after connecting to transport");this._capabilities=aQ(this._capabilities,$)}setRequestHandler($,Z){let Q=T8($)?.method;if(!Q)throw Error("Schema is missing a method literal");let W;if(d6(Q)){let G=Q;W=G._zod?.def?.value??G.value}else{let G=Q;W=G._def?.value??G.value}if(typeof W!=="string")throw Error("Schema method literal must be a string");let J=W;if(J==="elicitation/create"){let G=async(K,B)=>{let D=L0(cQ,K);if(!D.success){let N=D.error instanceof Error?D.error.message:String(D.error);throw new l(d.InvalidParams,`Invalid elicitation request: ${N}`)}let{params:V}=D.data;V.mode=V.mode??"form";let{supportsFormMode:L,supportsUrlMode:A}=lb(this._capabilities.elicitation);if(V.mode==="form"&&!L)throw new l(d.InvalidParams,"Client does not support form-mode elicitation requests");if(V.mode==="url"&&!A)throw new l(d.InvalidParams,"Client does not support URL-mode elicitation requests");let O=await Promise.resolve(Z(K,B));if(V.task){let N=L0(R6,O);if(!N.success){let E=N.error instanceof Error?N.error.message:String(N.error);throw new l(d.InvalidParams,`Invalid task creation result: ${E}`)}return N.data}let q=L0(d9,O);if(!q.success){let N=q.error instanceof Error?q.error.message:String(q.error);throw new l(d.InvalidParams,`Invalid elicitation result: ${N}`)}let M=q.data,I=V.mode==="form"?V.requestedSchema:void 0;if(V.mode==="form"&&M.action==="accept"&&M.content&&I){if(this._capabilities.elicitation?.form?.applyDefaults)try{A5(I,M.content)}catch{}}return M};return super.setRequestHandler($,G)}if(J==="sampling/createMessage"){let G=async(K,B)=>{let D=L0(iQ,K);if(!D.success){let M=D.error instanceof Error?D.error.message:String(D.error);throw new l(d.InvalidParams,`Invalid sampling request: ${M}`)}let{params:V}=D.data,L=await Promise.resolve(Z(K,B));if(V.task){let M=L0(R6,L);if(!M.success){let I=M.error instanceof Error?M.error.message:String(M.error);throw new l(d.InvalidParams,`Invalid task creation result: ${I}`)}return M.data}let O=V.tools||V.toolChoice?f4:c9,q=L0(O,L);if(!q.success){let M=q.error instanceof Error?q.error.message:String(q.error);throw new l(d.InvalidParams,`Invalid sampling result: ${M}`)}return q.data};return super.setRequestHandler($,G)}return super.setRequestHandler($,Z)}assertCapability($,Z){if(!this._serverCapabilities?.[$])throw Error(`Server does not support ${$} (required for ${Z})`)}async connect($,Z){if(await super.connect($),$.sessionId!==void 0)return;try{let Y=await this.request({method:"initialize",params:{protocolVersion:n6,capabilities:this._capabilities,clientInfo:this._clientInfo}},NQ,Z);if(Y===void 0)throw Error(`Server sent invalid initialize result: ${Y}`);if(!AQ.includes(Y.protocolVersion))throw Error(`Server's protocol version is not supported: ${Y.protocolVersion}`);if(this._serverCapabilities=Y.capabilities,this._serverVersion=Y.serverInfo,$.setProtocolVersion)$.setProtocolVersion(Y.protocolVersion);if(this._instructions=Y.instructions,await this.notification({method:"notifications/initialized"}),this._pendingListChangedConfig)this._setupListChangedHandlers(this._pendingListChangedConfig),this._pendingListChangedConfig=void 0}catch(Y){throw this.close(),Y}}getServerCapabilities(){return this._serverCapabilities}getServerVersion(){return this._serverVersion}getInstructions(){return this._instructions}assertCapabilityForMethod($){switch($){case"logging/setLevel":if(!this._serverCapabilities?.logging)throw Error(`Server does not support logging (required for ${$})`);break;case"prompts/get":case"prompts/list":if(!this._serverCapabilities?.prompts)throw Error(`Server does not support prompts (required for ${$})`);break;case"resources/list":case"resources/templates/list":case"resources/read":case"resources/subscribe":case"resources/unsubscribe":if(!this._serverCapabilities?.resources)throw Error(`Server does not support resources (required for ${$})`);if($==="resources/subscribe"&&!this._serverCapabilities.resources.subscribe)throw Error(`Server does not support resource subscriptions (required for ${$})`);break;case"tools/call":case"tools/list":if(!this._serverCapabilities?.tools)throw Error(`Server does not support tools (required for ${$})`);break;case"completion/complete":if(!this._serverCapabilities?.completions)throw Error(`Server does not support completions (required for ${$})`);break;case"initialize":break;case"ping":break}}assertNotificationCapability($){switch($){case"notifications/roots/list_changed":if(!this._capabilities.roots?.listChanged)throw Error(`Client does not support roots list changed notifications (required for ${$})`);break;case"notifications/initialized":break;case"notifications/cancelled":break;case"notifications/progress":break}}assertRequestHandlerCapability($){if(!this._capabilities)return;switch($){case"sampling/createMessage":if(!this._capabilities.sampling)throw Error(`Client does not support sampling capability (required for ${$})`);break;case"elicitation/create":if(!this._capabilities.elicitation)throw Error(`Client does not support elicitation capability (required for ${$})`);break;case"roots/list":if(!this._capabilities.roots)throw Error(`Client does not support roots capability (required for ${$})`);break;case"tasks/get":case"tasks/list":case"tasks/result":case"tasks/cancel":if(!this._capabilities.tasks)throw Error(`Client does not support tasks capability (required for ${$})`);break;case"ping":break}}assertTaskCapability($){$W(this._serverCapabilities?.tasks?.requests,$,"Server")}assertTaskHandlerCapability($){if(!this._capabilities)return;ZW(this._capabilities.tasks?.requests,$,"Client")}async ping($){return this.request({method:"ping"},E6,$)}async complete($,Z){return this.request({method:"completion/complete",params:$},dQ,Z)}async setLoggingLevel($,Z){return this.request({method:"logging/setLevel",params:{level:$}},E6,Z)}async getPrompt($,Z){return this.request({method:"prompts/get",params:$},uQ,Z)}async listPrompts($,Z){return this.request({method:"prompts/list",params:$},vQ,Z)}async listResources($,Z){return this.request({method:"resources/list",params:$},EQ,Z)}async listResourceTemplates($,Z){return this.request({method:"resources/templates/list",params:$},_Q,Z)}async readResource($,Z){return this.request({method:"resources/read",params:$},fQ,Z)}async subscribeResource($,Z){return this.request({method:"resources/subscribe",params:$},E6,Z)}async unsubscribeResource($,Z){return this.request({method:"resources/unsubscribe",params:$},E6,Z)}async callTool($,Z=a6,Y){if(this.isToolTaskRequired($.name))throw new l(d.InvalidRequest,`Tool "${$.name}" requires task-based execution. Use client.experimental.tasks.callToolStream() instead.`);let Q=await this.request({method:"tools/call",params:$},Z,Y),W=this.getToolOutputValidator($.name);if(W){if(!Q.structuredContent&&!Q.isError)throw new l(d.InvalidRequest,`Tool ${$.name} has an output schema but did not return structured content`);if(Q.structuredContent)try{let J=W(Q.structuredContent);if(!J.valid)throw new l(d.InvalidParams,`Structured content does not match the tool's output schema: ${J.errorMessage}`)}catch(J){if(J instanceof l)throw J;throw new l(d.InvalidParams,`Failed to validate structured content: ${J instanceof Error?J.message:String(J)}`)}}return Q}isToolTask($){if(!this._serverCapabilities?.tasks?.requests?.tools?.call)return!1;return this._cachedKnownTaskTools.has($)}isToolTaskRequired($){return this._cachedRequiredTaskTools.has($)}cacheToolMetadata($){this._cachedToolOutputValidators.clear(),this._cachedKnownTaskTools.clear(),this._cachedRequiredTaskTools.clear();for(let Z of $){if(Z.outputSchema){let Q=this._jsonSchemaValidator.getValidator(Z.outputSchema);this._cachedToolOutputValidators.set(Z.name,Q)}let Y=Z.execution?.taskSupport;if(Y==="required"||Y==="optional")this._cachedKnownTaskTools.add(Z.name);if(Y==="required")this._cachedRequiredTaskTools.add(Z.name)}}getToolOutputValidator($){return this._cachedToolOutputValidators.get($)}async listTools($,Z){let Y=await this.request({method:"tools/list",params:$},i9,Z);return this.cacheToolMetadata(Y.tools),Y}_setupListChangedHandler($,Z,Y,Q){let W=yK.safeParse(Y);if(!W.success)throw Error(`Invalid ${$} listChanged options: ${W.error.message}`);if(typeof Y.onChanged!=="function")throw Error(`Invalid ${$} listChanged options: onChanged must be a function`);let{autoRefresh:J,debounceMs:G}=W.data,{onChanged:K}=Y,B=async()=>{if(!J){K(null,null);return}try{let V=await Q();K(null,V)}catch(V){let L=V instanceof Error?V:Error(String(V));K(L,null)}},D=()=>{if(G){let V=this._listChangedDebounceTimers.get($);if(V)clearTimeout(V);let L=setTimeout(B,G);this._listChangedDebounceTimers.set($,L)}else B()};this.setNotificationHandler(Z,D)}async sendRootsListChanged(){return this.notification({method:"notifications/roots/list_changed"})}}function o8($){if(!$)return{};if($ instanceof Headers)return Object.fromEntries($.entries());if(Array.isArray($))return Object.fromEntries($);return{...$}}function O5($=fetch,Z){if(!Z)return $;return async(Y,Q)=>{let W={...Z,...Q,headers:Q?.headers?{...o8(Z.headers),...o8(Q.headers)}:Z.headers};return $(Y,W)}}var YW;YW=globalThis.crypto?.webcrypto??globalThis.crypto??import("crypto").then(($)=>$.webcrypto);async function pb($){return(await YW).getRandomValues(new Uint8Array($))}async function ib($){let Y=Math.pow(2,8)-Math.pow(2,8)%66,Q="";while(Q.length<$){let W=await pb($-Q.length);for(let J of W)if(J<Y)Q+="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789-._~"[J%66]}return Q}async function cb($){return await ib($)}async function db($){let Z=await(await YW).subtle.digest("SHA-256",new TextEncoder().encode($));return btoa(String.fromCharCode(...new Uint8Array(Z))).replace(/\//g,"_").replace(/\+/g,"-").replace(/=/g,"")}async function QW($){if(!$)$=43;if($<43||$>128)throw`Expected a length between 43 and 128. Received ${$}.`;let Z=await cb($),Y=await db(Z);return{code_verifier:Z,code_challenge:Y}}import*as P from"zod/v4";var g1=P.url().superRefine(($,Z)=>{if(!URL.canParse($))return Z.addIssue({code:P.ZodIssueCode.custom,message:"URL must be parseable",fatal:!0}),P.NEVER}).refine(($)=>{let Z=new URL($);return Z.protocol!=="javascript:"&&Z.protocol!=="data:"&&Z.protocol!=="vbscript:"},{message:"URL cannot use javascript:, data:, or vbscript: scheme"}),zV=P.looseObject({resource:P.string().url(),authorization_servers:P.array(g1).optional(),jwks_uri:P.string().url().optional(),scopes_supported:P.array(P.string()).optional(),bearer_methods_supported:P.array(P.string()).optional(),resource_signing_alg_values_supported:P.array(P.string()).optional(),resource_name:P.string().optional(),resource_documentation:P.string().optional(),resource_policy_uri:P.string().url().optional(),resource_tos_uri:P.string().url().optional(),tls_client_certificate_bound_access_tokens:P.boolean().optional(),authorization_details_types_supported:P.array(P.string()).optional(),dpop_signing_alg_values_supported:P.array(P.string()).optional(),dpop_bound_access_tokens_required:P.boolean().optional()}),XW=P.looseObject({issuer:P.string(),authorization_endpoint:g1,token_endpoint:g1,registration_endpoint:g1.optional(),scopes_supported:P.array(P.string()).optional(),response_types_supported:P.array(P.string()),response_modes_supported:P.array(P.string()).optional(),grant_types_supported:P.array(P.string()).optional(),token_endpoint_auth_methods_supported:P.array(P.string()).optional(),token_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),service_documentation:g1.optional(),revocation_endpoint:g1.optional(),revocation_endpoint_auth_methods_supported:P.array(P.string()).optional(),revocation_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),introspection_endpoint:P.string().optional(),introspection_endpoint_auth_methods_supported:P.array(P.string()).optional(),introspection_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),code_challenge_methods_supported:P.array(P.string()).optional(),client_id_metadata_document_supported:P.boolean().optional()}),nb=P.looseObject({issuer:P.string(),authorization_endpoint:g1,token_endpoint:g1,userinfo_endpoint:g1.optional(),jwks_uri:g1,registration_endpoint:g1.optional(),scopes_supported:P.array(P.string()).optional(),response_types_supported:P.array(P.string()),response_modes_supported:P.array(P.string()).optional(),grant_types_supported:P.array(P.string()).optional(),acr_values_supported:P.array(P.string()).optional(),subject_types_supported:P.array(P.string()),id_token_signing_alg_values_supported:P.array(P.string()),id_token_encryption_alg_values_supported:P.array(P.string()).optional(),id_token_encryption_enc_values_supported:P.array(P.string()).optional(),userinfo_signing_alg_values_supported:P.array(P.string()).optional(),userinfo_encryption_alg_values_supported:P.array(P.string()).optional(),userinfo_encryption_enc_values_supported:P.array(P.string()).optional(),request_object_signing_alg_values_supported:P.array(P.string()).optional(),request_object_encryption_alg_values_supported:P.array(P.string()).optional(),request_object_encryption_enc_values_supported:P.array(P.string()).optional(),token_endpoint_auth_methods_supported:P.array(P.string()).optional(),token_endpoint_auth_signing_alg_values_supported:P.array(P.string()).optional(),display_values_supported:P.array(P.string()).optional(),claim_types_supported:P.array(P.string()).optional(),claims_supported:P.array(P.string()).optional(),service_documentation:P.string().optional(),claims_locales_supported:P.array(P.string()).optional(),ui_locales_supported:P.array(P.string()).optional(),claims_parameter_supported:P.boolean().optional(),request_parameter_supported:P.boolean().optional(),request_uri_parameter_supported:P.boolean().optional(),require_request_uri_registration:P.boolean().optional(),op_policy_uri:g1.optional(),op_tos_uri:g1.optional(),client_id_metadata_document_supported:P.boolean().optional()}),OV=P.object({...nb.shape,...XW.pick({code_challenge_methods_supported:!0}).shape}),qV=P.object({access_token:P.string(),id_token:P.string().optional(),token_type:P.string(),expires_in:P.coerce.number().optional(),scope:P.string().optional(),refresh_token:P.string().optional()}).strip(),NV=P.object({error:P.string(),error_description:P.string().optional(),error_uri:P.string().optional()}),AV=g1.optional().or(P.literal("").transform(()=>{return})),rb=P.object({redirect_uris:P.array(g1),token_endpoint_auth_method:P.string().optional(),grant_types:P.array(P.string()).optional(),response_types:P.array(P.string()).optional(),client_name:P.string().optional(),client_uri:g1.optional(),logo_uri:AV,scope:P.string().optional(),contacts:P.array(P.string()).optional(),tos_uri:AV,policy_uri:P.string().optional(),jwks_uri:g1.optional(),jwks:P.any().optional(),software_id:P.string().optional(),software_version:P.string().optional(),software_statement:P.string().optional()}).strip(),ab=P.object({client_id:P.string(),client_secret:P.string().optional(),client_id_issued_at:P.number().optional(),client_secret_expires_at:P.number().optional()}).strip(),MV=rb.merge(ab),Mo=P.object({error:P.string(),error_description:P.string().optional()}).strip(),Po=P.object({token:P.string(),token_type_hint:P.string().optional()}).strip();function PV($){let Z=typeof $==="string"?new URL($):new URL($.href);return Z.hash="",Z}function wV({requestedResource:$,configuredResource:Z}){let Y=typeof $==="string"?new URL($):new URL($.href),Q=typeof Z==="string"?new URL(Z):new URL(Z.href);if(Y.origin!==Q.origin)return!1;if(Y.pathname.length<Q.pathname.length)return!1;let W=Y.pathname.endsWith("/")?Y.pathname:Y.pathname+"/",J=Q.pathname.endsWith("/")?Q.pathname:Q.pathname+"/";return W.startsWith(J)}class R1 extends Error{constructor($,Z){super($);this.errorUri=Z,this.name=this.constructor.name}toResponseObject(){let $={error:this.errorCode,error_description:this.message};if(this.errorUri)$.error_uri=this.errorUri;return $}get errorCode(){return this.constructor.errorCode}}class q5 extends R1{}q5.errorCode="invalid_request";class s8 extends R1{}s8.errorCode="invalid_client";class t8 extends R1{}t8.errorCode="invalid_grant";class e8 extends R1{}e8.errorCode="unauthorized_client";class N5 extends R1{}N5.errorCode="unsupported_grant_type";class M5 extends R1{}M5.errorCode="invalid_scope";class P5 extends R1{}P5.errorCode="access_denied";class T6 extends R1{}T6.errorCode="server_error";class w5 extends R1{}w5.errorCode="temporarily_unavailable";class E5 extends R1{}E5.errorCode="unsupported_response_type";class R5 extends R1{}R5.errorCode="unsupported_token_type";class _5 extends R1{}_5.errorCode="invalid_token";class C5 extends R1{}C5.errorCode="method_not_allowed";class I5 extends R1{}I5.errorCode="too_many_requests";class $9 extends R1{}$9.errorCode="invalid_client_metadata";class f5 extends R1{}f5.errorCode="insufficient_scope";class S5 extends R1{}S5.errorCode="invalid_target";var EV={[q5.errorCode]:q5,[s8.errorCode]:s8,[t8.errorCode]:t8,[e8.errorCode]:e8,[N5.errorCode]:N5,[M5.errorCode]:M5,[P5.errorCode]:P5,[T6.errorCode]:T6,[w5.errorCode]:w5,[E5.errorCode]:E5,[R5.errorCode]:R5,[_5.errorCode]:_5,[C5.errorCode]:C5,[I5.errorCode]:I5,[$9.errorCode]:$9,[f5.errorCode]:f5,[S5.errorCode]:S5};class e1 extends Error{constructor($){super($??"Unauthorized")}}function ob($){return["client_secret_basic","client_secret_post","none"].includes($)}var WW="code",JW="S256";function sb($,Z){let Y=$.client_secret!==void 0;if("token_endpoint_auth_method"in $&&$.token_endpoint_auth_method&&ob($.token_endpoint_auth_method)&&(Z.length===0||Z.includes($.token_endpoint_auth_method)))return $.token_endpoint_auth_method;if(Z.length===0)return Y?"client_secret_basic":"none";if(Y&&Z.includes("client_secret_basic"))return"client_secret_basic";if(Y&&Z.includes("client_secret_post"))return"client_secret_post";if(Z.includes("none"))return"none";return Y?"client_secret_post":"none"}function tb($,Z,Y,Q){let{client_id:W,client_secret:J}=Z;switch($){case"client_secret_basic":eb(W,J,Y);return;case"client_secret_post":$v(W,J,Q);return;case"none":Zv(W,Q);return;default:throw Error(`Unsupported client authentication method: ${$}`)}}function eb($,Z,Y){if(!Z)throw Error("client_secret_basic authentication requires a client_secret");let Q=btoa(`${$}:${Z}`);Y.set("Authorization",`Basic ${Q}`)}function $v($,Z,Y){if(Y.set("client_id",$),Z)Y.set("client_secret",Z)}function Zv($,Z){Z.set("client_id",$)}async function _V($){let Z=$ instanceof Response?$.status:void 0,Y=$ instanceof Response?await $.text():$;try{let Q=NV.parse(JSON.parse(Y)),{error:W,error_description:J,error_uri:G}=Q;return new(EV[W]||T6)(J||"",G)}catch(Q){let W=`${Z?`HTTP ${Z}: `:""}Invalid OAuth error response: ${Q}. Raw body: ${Y}`;return new T6(W)}}async function p0($,Z){try{return await GW($,Z)}catch(Y){if(Y instanceof s8||Y instanceof e8)return await $.invalidateCredentials?.("all"),await GW($,Z);else if(Y instanceof t8)return await $.invalidateCredentials?.("tokens"),await GW($,Z);throw Y}}async function GW($,{serverUrl:Z,authorizationCode:Y,scope:Q,resourceMetadataUrl:W,fetchFn:J}){let G=await $.discoveryState?.(),K,B,D,V=W;if(!V&&G?.resourceMetadataUrl)V=new URL(G.resourceMetadataUrl);if(G?.authorizationServerUrl){if(B=G.authorizationServerUrl,K=G.resourceMetadata,D=G.authorizationServerMetadata??await FW(B,{fetchFn:J}),!K)try{K=await HW(Z,{resourceMetadataUrl:V},J)}catch{}if(D!==G.authorizationServerMetadata||K!==G.resourceMetadata)await $.saveDiscoveryState?.({authorizationServerUrl:String(B),resourceMetadataUrl:V?.toString(),resourceMetadata:K,authorizationServerMetadata:D})}else{let f=await Kv(Z,{resourceMetadataUrl:V,fetchFn:J});B=f.authorizationServerUrl,D=f.authorizationServerMetadata,K=f.resourceMetadata,await $.saveDiscoveryState?.({authorizationServerUrl:String(B),resourceMetadataUrl:V?.toString(),resourceMetadata:K,authorizationServerMetadata:D})}let L=await Qv(Z,$,K),A=Q||K?.scopes_supported?.join(" ")||$.clientMetadata.scope,O=await Promise.resolve($.clientInformation());if(!O){if(Y!==void 0)throw Error("Existing OAuth client information is required when exchanging an authorization code");let f=D?.client_id_metadata_document_supported===!0,v=$.clientMetadataUrl;if(v&&!Yv(v))throw new $9(`clientMetadataUrl must be a valid HTTPS URL with a non-root pathname, got: ${v}`);if(f&&v)O={client_id:v},await $.saveClientInformation?.(O);else{if(!$.saveClientInformation)throw Error("OAuth client information must be saveable for dynamic registration");let $1=await Vv(B,{metadata:D,clientMetadata:$.clientMetadata,scope:A,fetchFn:J});await $.saveClientInformation($1),O=$1}}let q=!$.redirectUrl;if(Y!==void 0||q){let f=await Dv($,B,{metadata:D,resource:L,authorizationCode:Y,fetchFn:J});return await $.saveTokens(f),"AUTHORIZED"}let M=await $.tokens();if(M?.refresh_token)try{let f=await Fv(B,{metadata:D,clientInformation:O,refreshToken:M.refresh_token,resource:L,addClientAuthentication:$.addClientAuthentication,fetchFn:J});return await $.saveTokens(f),"AUTHORIZED"}catch(f){if(!(f instanceof R1)||f instanceof T6);else throw f}let I=$.state?await $.state():void 0,{authorizationUrl:N,codeVerifier:E}=await Hv(B,{metadata:D,clientInformation:O,state:I,redirectUrl:$.redirectUrl,scope:A,resource:L});return await $.saveCodeVerifier(E),await $.redirectToAuthorization(N),"REDIRECT"}function Yv($){if(!$)return!1;try{let Z=new URL($);return Z.protocol==="https:"&&Z.pathname!=="/"}catch{return!1}}async function Qv($,Z,Y){let Q=PV($);if(Z.validateResourceURL)return await Z.validateResourceURL(Q,Y?.resource);if(!Y)return;if(!wV({requestedResource:Q,configuredResource:Y.resource}))throw Error(`Protected resource ${Y.resource} does not match expected ${Q} (or origin)`);return new URL(Y.resource)}function Z9($){let Z=$.headers.get("WWW-Authenticate");if(!Z)return{};let[Y,Q]=Z.split(" ");if(Y.toLowerCase()!=="bearer"||!Q)return{};let W=KW($,"resource_metadata")||void 0,J;if(W)try{J=new URL(W)}catch{}let G=KW($,"scope")||void 0,K=KW($,"error")||void 0;return{resourceMetadataUrl:J,scope:G,error:K}}function KW($,Z){let Y=$.headers.get("WWW-Authenticate");if(!Y)return null;let Q=new RegExp(`${Z}=(?:"([^"]+)"|([^\\s,]+))`),W=Y.match(Q);if(W)return W[1]||W[2];return null}async function HW($,Z,Y=fetch){let Q=await Jv($,"oauth-protected-resource",Y,{protocolVersion:Z?.protocolVersion,metadataUrl:Z?.resourceMetadataUrl});if(!Q||Q.status===404)throw await Q?.body?.cancel(),Error("Resource server does not implement OAuth 2.0 Protected Resource Metadata.");if(!Q.ok)throw await Q.body?.cancel(),Error(`HTTP ${Q.status} trying to load well-known OAuth protected resource metadata.`);return zV.parse(await Q.json())}async function BW($,Z,Y=fetch){try{return await Y($,{headers:Z})}catch(Q){if(Q instanceof TypeError)if(Z)return BW($,void 0,Y);else return;throw Q}}function Xv($,Z="",Y={}){if(Z.endsWith("/"))Z=Z.slice(0,-1);return Y.prependPathname?`${Z}/.well-known/${$}`:`/.well-known/${$}${Z}`}async function RV($,Z,Y=fetch){return await BW($,{"MCP-Protocol-Version":Z},Y)}function Wv($,Z){return!$||$.status>=400&&$.status<500&&Z!=="/"}async function Jv($,Z,Y,Q){let W=new URL($),J=Q?.protocolVersion??n6,G;if(Q?.metadataUrl)G=new URL(Q.metadataUrl);else{let B=Xv(Z,W.pathname);G=new URL(B,Q?.metadataServerUrl??W),G.search=W.search}let K=await RV(G,J,Y);if(!Q?.metadataUrl&&Wv(K,W.pathname)){let B=new URL(`/.well-known/${Z}`,W);K=await RV(B,J,Y)}return K}function Gv($){let Z=typeof $==="string"?new URL($):$,Y=Z.pathname!=="/",Q=[];if(!Y)return Q.push({url:new URL("/.well-known/oauth-authorization-server",Z.origin),type:"oauth"}),Q.push({url:new URL("/.well-known/openid-configuration",Z.origin),type:"oidc"}),Q;let W=Z.pathname;if(W.endsWith("/"))W=W.slice(0,-1);return Q.push({url:new URL(`/.well-known/oauth-authorization-server${W}`,Z.origin),type:"oauth"}),Q.push({url:new URL(`/.well-known/openid-configuration${W}`,Z.origin),type:"oidc"}),Q.push({url:new URL(`${W}/.well-known/openid-configuration`,Z.origin),type:"oidc"}),Q}async function FW($,{fetchFn:Z=fetch,protocolVersion:Y=n6}={}){let Q={"MCP-Protocol-Version":Y,Accept:"application/json"},W=Gv($);for(let{url:J,type:G}of W){let K=await BW(J,Q,Z);if(!K)continue;if(!K.ok){if(await K.body?.cancel(),K.status>=400&&K.status<500)continue;throw Error(`HTTP ${K.status} trying to load ${G==="oauth"?"OAuth":"OpenID provider"} metadata from ${J}`)}if(G==="oauth")return XW.parse(await K.json());else return OV.parse(await K.json())}return}async function Kv($,Z){let Y,Q;try{if(Y=await HW($,{resourceMetadataUrl:Z?.resourceMetadataUrl},Z?.fetchFn),Y.authorization_servers&&Y.authorization_servers.length>0)Q=Y.authorization_servers[0]}catch{}if(!Q)Q=String(new URL("/",$));let W=await FW(Q,{fetchFn:Z?.fetchFn});return{authorizationServerUrl:Q,authorizationServerMetadata:W,resourceMetadata:Y}}async function Hv($,{metadata:Z,clientInformation:Y,redirectUrl:Q,scope:W,state:J,resource:G}){let K;if(Z){if(K=new URL(Z.authorization_endpoint),!Z.response_types_supported.includes(WW))throw Error(`Incompatible auth server: does not support response type ${WW}`);if(Z.code_challenge_methods_supported&&!Z.code_challenge_methods_supported.includes(JW))throw Error(`Incompatible auth server: does not support code challenge method ${JW}`)}else K=new URL("/authorize",$);let B=await QW(),D=B.code_verifier,V=B.code_challenge;if(K.searchParams.set("response_type",WW),K.searchParams.set("client_id",Y.client_id),K.searchParams.set("code_challenge",V),K.searchParams.set("code_challenge_method",JW),K.searchParams.set("redirect_uri",String(Q)),J)K.searchParams.set("state",J);if(W)K.searchParams.set("scope",W);if(W?.includes("offline_access"))K.searchParams.append("prompt","consent");if(G)K.searchParams.set("resource",G.href);return{authorizationUrl:K,codeVerifier:D}}function Bv($,Z,Y){return new URLSearchParams({grant_type:"authorization_code",code:$,code_verifier:Z,redirect_uri:String(Y)})}async function CV($,{metadata:Z,tokenRequestParams:Y,clientInformation:Q,addClientAuthentication:W,resource:J,fetchFn:G}){let K=Z?.token_endpoint?new URL(Z.token_endpoint):new URL("/token",$),B=new Headers({"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"});if(J)Y.set("resource",J.href);if(W)await W(B,Y,K,Z);else if(Q){let V=Z?.token_endpoint_auth_methods_supported??[],L=sb(Q,V);tb(L,Q,B,Y)}let D=await(G??fetch)(K,{method:"POST",headers:B,body:Y});if(!D.ok)throw await _V(D);return qV.parse(await D.json())}async function Fv($,{metadata:Z,clientInformation:Y,refreshToken:Q,resource:W,addClientAuthentication:J,fetchFn:G}){let K=new URLSearchParams({grant_type:"refresh_token",refresh_token:Q}),B=await CV($,{metadata:Z,tokenRequestParams:K,clientInformation:Y,addClientAuthentication:J,resource:W,fetchFn:G});return{refresh_token:Q,...B}}async function Dv($,Z,{metadata:Y,resource:Q,authorizationCode:W,fetchFn:J}={}){let G=$.clientMetadata.scope,K;if($.prepareTokenRequest)K=await $.prepareTokenRequest(G);if(!K){if(!W)throw Error("Either provider.prepareTokenRequest() or authorizationCode is required");if(!$.redirectUrl)throw Error("redirectUrl is required for authorization_code flow");let D=await $.codeVerifier();K=Bv(W,D,$.redirectUrl)}let B=await $.clientInformation();return CV(Z,{metadata:Y,tokenRequestParams:K,clientInformation:B??void 0,addClientAuthentication:$.addClientAuthentication,resource:Q,fetchFn:J})}async function Vv($,{metadata:Z,clientMetadata:Y,scope:Q,fetchFn:W}){let J;if(Z){if(!Z.registration_endpoint)throw Error("Incompatible auth server: does not support dynamic client registration");J=new URL(Z.registration_endpoint)}else J=new URL("/register",$);let G=await(W??fetch)(J,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...Y,...Q!==void 0?{scope:Q}:{}})});if(!G.ok)throw await _V(G);return MV.parse(await G.json())}class VW extends Error{constructor($,Z){super($),this.name="ParseError",this.type=Z.type,this.field=Z.field,this.value=Z.value,this.line=Z.line}}var IV=10,Lv=13,Y8=32;function DW($){}function b5($){if(typeof $=="function")throw TypeError("`callbacks` must be an object, got a function instead. Did you mean `{onEvent: fn}`?");let{onEvent:Z=DW,onError:Y=DW,onRetry:Q=DW,onComment:W}=$,J=[],G=!0,K,B="",D=0,V;function L(N){if(G&&(G=!1,N.charCodeAt(0)===239&&N.charCodeAt(1)===187&&N.charCodeAt(2)===191&&(N=N.slice(3))),J.length===0){let v=A(N);v!==""&&J.push(v);return}if(N.indexOf(`
|
|
943
943
|
`)===-1&&N.indexOf("\r")===-1){J.push(N);return}J.push(N);let E=J.join("");J.length=0;let f=A(E);f!==""&&J.push(f)}function A(N){let E=0;if(N.indexOf("\r")===-1){let f=N.indexOf(`
|
|
944
944
|
`,E);for(;f!==-1;){if(E===f){D>0&&Z({id:K,event:V,data:B}),K=void 0,B="",D=0,V=void 0,E=f+1,f=N.indexOf(`
|
|
945
945
|
`,E);continue}let v=N.charCodeAt(E);if(fV(N,E,v)){let y=N.charCodeAt(E+5)===Y8?E+6:E+5,$1=N.slice(y,f);if(D===0&&N.charCodeAt(f+1)===IV){Z({id:K,event:V,data:$1}),K=void 0,B="",V=void 0,E=f+2,f=N.indexOf(`
|