decocms 2.311.8 → 2.311.10
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-9Ey0HjEK.js → AlertCircle-CBFejk6X.js} +1 -1
- package/dist/client/assets/{Archive-DPagM8Sv.js → Archive-iAwIFcLN.js} +1 -1
- package/dist/client/assets/{ArrowNarrowLeft-CX80utcZ.js → ArrowNarrowLeft-C0NWe8i5.js} +1 -1
- package/dist/client/assets/{ArrowUpRight-Dnm-Dm1H.js → ArrowUpRight-wDGVfxe4.js} +1 -1
- package/dist/client/assets/{Check-C0YCNcAk.js → Check-BzVO1AiZ.js} +1 -1
- package/dist/client/assets/{CheckCircle-DC6iqfFI.js → CheckCircle-B7pbvHXn.js} +1 -1
- package/dist/client/assets/{ChevronDown-Cwqb-1uD.js → ChevronDown-Deq9bkeU.js} +1 -1
- package/dist/client/assets/{ChevronRight-CrWz1sFy.js → ChevronRight-De9CjTSZ.js} +1 -1
- package/dist/client/assets/{ChevronUp-BMBmNR0B.js → ChevronUp-B22gTkPS.js} +1 -1
- package/dist/client/assets/{Container-Bk9UG2qc.js → Container-10kbY0mV.js} +1 -1
- package/dist/client/assets/{DotsVertical-B7yU948Y.js → DotsVertical-B0gKWs5D.js} +1 -1
- package/dist/client/assets/{LinkExternal01-DxfMOMNm.js → LinkExternal01-DkQ5Dk0s.js} +1 -1
- package/dist/client/assets/{Lock01-Cds15CcD.js → Lock01-CHNFEFTO.js} +1 -1
- package/dist/client/assets/{Palette-BhAbwiYB.js → Palette-B7UA48pi.js} +1 -1
- package/dist/client/assets/{Play-DT05vsyX.js → Play-BunaO9my.js} +1 -1
- package/dist/client/assets/{Plus-LaAbD5qL.js → Plus-DlXyaJQM.js} +1 -1
- package/dist/client/assets/{RefreshCcw01-BS-aU6o_.js → RefreshCcw01-BsycvfGb.js} +1 -1
- package/dist/client/assets/{SearchMd-DLpvei6Y.js → SearchMd-15kzRVQe.js} +1 -1
- package/dist/client/assets/{Settings02-DIJ_hqNi.js → Settings02-DVi1PM0X.js} +1 -1
- package/dist/client/assets/{Shield01-B0gusvIt.js → Shield01-B70wMBqd.js} +1 -1
- package/dist/client/assets/{Star01-Dr3hv_f2.js → Star01-CJoi6RDa.js} +1 -1
- package/dist/client/assets/{Sun-Cjk_RdSq.js → Sun-CGoBYMaF.js} +1 -1
- package/dist/client/assets/{Tool01-CKIVHH97.js → Tool01-D48iIlf1.js} +1 -1
- package/dist/client/assets/{Trash01-CGR2s5lX.js → Trash01-r5gnirq_.js} +1 -1
- package/dist/client/assets/{User01-TUOjLrvV.js → User01-DJ7t0J9b.js} +1 -1
- package/dist/client/assets/{Users03-CrFC9gy5.js → Users03-DYLtKI27.js} +1 -1
- package/dist/client/assets/{X-EkEnxljM.js → X-BkKDRlJI.js} +1 -1
- package/dist/client/assets/{XCircle-DX3ew0Vv.js → XCircle-sedM5Yzu.js} +1 -1
- package/dist/client/assets/{XClose-Bgl_mrN0.js → XClose-Bx_xQQD_.js} +1 -1
- package/dist/client/assets/{Zap-nGrPPn6s.js → Zap-Cf_cpNNU.js} +1 -1
- package/dist/client/assets/{ZapSquare-3WrsQC0a.js → ZapSquare-DlRSLgAv.js} +1 -1
- package/dist/client/assets/{accordion-CVBGYkjx.js → accordion-DT47aOa3.js} +1 -1
- package/dist/client/assets/{agent-icon-C5r21-mU.js → agent-icon-DUbGEO2S.js} +1 -1
- package/dist/client/assets/{agents-list-DYSwFq4O.js → agents-list-rwKMRHld.js} +1 -1
- package/dist/client/assets/ai-providers-CRf0IUiu.js +1 -0
- package/dist/client/assets/{alert-dialog-CUlBW44D.js → alert-dialog-2Jj762BJ.js} +1 -1
- package/dist/client/assets/{auth-catchall-b0gnrvFE.js → auth-catchall-DTur9gCU.js} +1 -1
- package/dist/client/assets/{automation-list-row-B0Yyrl0C.js → automation-list-row-Cuemsvmv.js} +1 -1
- package/dist/client/assets/{automations-BoyHWA09.js → automations-DN3LYNZV.js} +1 -1
- package/dist/client/assets/{avatar-CCEBXDhS.js → avatar-BoueLWcb.js} +1 -1
- package/dist/client/assets/{badge-Br91qQU7.js → badge-kdIe7Szq.js} +1 -1
- package/dist/client/assets/{brand-context-BssJ3FOZ.js → brand-context-C39FhTOD.js} +1 -1
- package/dist/client/assets/{card-DQgc505G.js → card-1EoqQ-Q7.js} +1 -1
- package/dist/client/assets/{chat-context-D0lbPtlR.js → chat-context-CqLR71Tu.js} +1 -1
- package/dist/client/assets/{checkbox-BCxF1VyO.js → checkbox-CL4jg0mR.js} +1 -1
- package/dist/client/assets/{collection-detail-BPMkE5rf.js → collection-detail-Be93090Z.js} +1 -1
- package/dist/client/assets/{collection-display-button-DTW3X--x.js → collection-display-button-BWk8xHdj.js} +1 -1
- package/dist/client/assets/{collection-search-DzJ2_6S7.js → collection-search-B-8Jnp5p.js} +1 -1
- package/dist/client/assets/{collection-search-Cm33ynx1.js → collection-search-BOMyE6Ld.js} +1 -1
- package/dist/client/assets/{collection-table-wrapper-D6-pSdID.js → collection-table-wrapper-Cb-FxojL.js} +1 -1
- package/dist/client/assets/{collection-tabs-DNkzHSYG.js → collection-tabs-Li95C-8Z.js} +1 -1
- package/dist/client/assets/{collections-C9L2aOYp.js → collections-BpcdhWS9.js} +1 -1
- package/dist/client/assets/{command-C-2IxKk5.js → command-D-VqtTkt.js} +1 -1
- package/dist/client/assets/{connection-card-BoxVMaxE.js → connection-card-D4MG7ceA.js} +1 -1
- package/dist/client/assets/{connection-detail-_uhhok2G.js → connection-detail-C9HOgjUN.js} +1 -1
- package/dist/client/assets/{connection-form-helpers-o8Xx8W0s.js → connection-form-helpers-C96WddUN.js} +1 -1
- package/dist/client/assets/{connections-BiBKwha4.js → connections-Dudt-pG4.js} +1 -1
- package/dist/client/assets/{constants--Dugzbiv.js → constants--Z68frQS.js} +1 -1
- package/dist/client/assets/{constants-CK0eEQbn.js → constants-BY3slQ5k.js} +1 -1
- package/dist/client/assets/{dialog-BxXbq3AD.js → dialog-2qod6XLb.js} +1 -1
- package/dist/client/assets/{domain-settings-C-3L2-eL.js → domain-settings-BXrvw6Lv.js} +1 -1
- package/dist/client/assets/{drawer-UeGl-sjm.js → drawer-DSH3rjuX.js} +1 -1
- package/dist/client/assets/{dropdown-menu-DQ7iI93C.js → dropdown-menu-CYyf-ZrC.js} +1 -1
- package/dist/client/assets/{dynamic-plugin-layout-Dn0vyVNY.js → dynamic-plugin-layout-RlhEpflE.js} +1 -1
- package/dist/client/assets/{empty-state-CKzOWRtK.js → empty-state-BdiBdNme.js} +1 -1
- package/dist/client/assets/{empty-state-D_f63UFh.js → empty-state-DebOy9XU.js} +1 -1
- package/dist/client/assets/{extract-connection-data-DMpmuOOJ.js → extract-connection-data-BTMDGqDD.js} +1 -1
- package/dist/client/assets/{features-DyUlYERL.js → features-Cxt-JPsD.js} +1 -1
- package/dist/client/assets/{form-BwE1BJrb.js → form-BxsxXSuZ.js} +1 -1
- package/dist/client/assets/{general-DUugdid2.js → general-u1Y39J62.js} +1 -1
- package/dist/client/assets/{index-C4DcQ8LW.js → index-0enbmaSe.js} +2 -2
- package/dist/client/assets/{index-CxyXuh3-.js → index-BNtQbO2i.js} +1 -1
- package/dist/client/assets/{index-DUyJmZSw.js → index-BVirFM6V.js} +1 -1
- package/dist/client/assets/{index-C1CY6-RI.js → index-Bna4Mzv7.js} +1 -1
- package/dist/client/assets/{index-D2MseDzL.js → index-CJ3mMCam.js} +1 -1
- package/dist/client/assets/{index-Cnh6l9lE.js → index-CbJD4O9M.js} +3 -3
- package/dist/client/assets/{index-cE983NnZ.js → index-Co04TeZ5.js} +1 -1
- package/dist/client/assets/{index-DLI7RfTF.js → index-CucV4lBd.js} +1 -1
- package/dist/client/assets/{index-C7x_kc-H.js → index-D1Os768e.js} +1 -1
- package/dist/client/assets/{index-CeMlJGK7.js → index-D9p0G3vk.js} +1 -1
- package/dist/client/assets/{index-DX5CKVPt.js → index-DKffdYnU.js} +1 -1
- package/dist/client/assets/{index-CpyFP_Y6.js → index-Dk7VTW9z.js} +1 -1
- package/dist/client/assets/index-DmW2ChV3.js +1 -0
- package/dist/client/assets/{index-B0gV229o.js → index-DyLEkJ9h.js} +1 -1
- package/dist/client/assets/{index-CwEMRsg9.js → index-fQuO2Dc3.js} +1 -1
- package/dist/client/assets/{index-cFrtNDeh.js → index-sxBFqhbB.js} +1 -1
- package/dist/client/assets/{infiniteQueryObserver-M5HXhTa-.js → infiniteQueryObserver-sxIykUWp.js} +1 -1
- package/dist/client/assets/{input-Zc7XqLBz.js → input-CZy7VBF-.js} +1 -1
- package/dist/client/assets/{integration-icon-dIK4SySX.js → integration-icon-Cgu3nEbl.js} +1 -1
- package/dist/client/assets/{label-DQVfYyGa.js → label-BhPoqbH1.js} +1 -1
- package/dist/client/assets/{layout-DoXFaFc9.js → layout-jAXEQlv4.js} +1 -1
- package/dist/client/assets/{lean-canvas-recruit-modal-B6jYbHdS.js → lean-canvas-recruit-modal-Mo-uvZiE.js} +1 -1
- package/dist/client/assets/{login-C53Yny6q.js → login-BgB-8JX_.js} +1 -1
- package/dist/client/assets/{members-CXQHdw2n.js → members-D5i4jyvH.js} +1 -1
- package/dist/client/assets/{monaco-editor-BluEEKw9.js → monaco-editor-D-E1NsT_.js} +1 -1
- package/dist/client/assets/{monitoring-stats-row-C7uh_AJ1.js → monitoring-stats-row-CaU12GnW.js} +1 -1
- package/dist/client/assets/{oauth-callback-B18mSbUX.js → oauth-callback-BrTY445n.js} +1 -1
- package/dist/client/assets/{oauth-callback-ai-provider-B5LWXlVw.js → oauth-callback-ai-provider-BA8nRDph.js} +1 -1
- package/dist/client/assets/{onboarding-B9N5e87t.js → onboarding-CAft2_BY.js} +1 -1
- package/dist/client/assets/{org-layout-HZO2enZQ.js → org-layout-C0XY3j3w.js} +1 -1
- package/dist/client/assets/{org-plugin-layout-X1oNY1R9.js → org-plugin-layout-CiPGTy9y.js} +1 -1
- package/dist/client/assets/{pair-Cl7nEWLx.js → pair-DyP8v5ZE.js} +1 -1
- package/dist/client/assets/{plugin-empty-state-mFDhSKtm.js → plugin-empty-state-CPC4iNPZ.js} +1 -1
- package/dist/client/assets/{plugin-header-BzIWRAUv.js → plugin-header-BaIUgM8O.js} +1 -1
- package/dist/client/assets/{plugin-layout-Ckgza9x1.js → plugin-layout-CP7WeU3S.js} +1 -1
- package/dist/client/assets/{popover-fFiZRgP_.js → popover-g5bCjakL.js} +1 -1
- package/dist/client/assets/{profile-CDEKCuy5.js → profile-DE9V4UAe.js} +1 -1
- package/dist/client/assets/{project-app-view-DYhcROSR.js → project-app-view-CsUA3eWI.js} +1 -1
- package/dist/client/assets/registry-Cth6leQk.js +2 -0
- package/dist/client/assets/{registry-layout-DhmXFNYV.js → registry-layout-IV9o5tdh.js} +1 -1
- package/dist/client/assets/{required-auth-layout-DdqUlG6N.js → required-auth-layout-CbwdpaRZ.js} +1 -1
- package/dist/client/assets/{reset-password-CG-HQXTs.js → reset-password-HK92arRg.js} +1 -1
- package/dist/client/assets/{roles-BToZK3zI.js → roles-BWPZWJaM.js} +1 -1
- package/dist/client/assets/{scroll-area-DDk0Exbn.js → scroll-area-DPp3zriG.js} +1 -1
- package/dist/client/assets/{search-input-BHdl2Sic.js → search-input-DFpePjxv.js} +1 -1
- package/dist/client/assets/{select-CdC5gLdi.js → select-DNBVly7-.js} +1 -1
- package/dist/client/assets/{select-model-BkJ0KPp-.js → select-model-DeUWMCqm.js} +1 -1
- package/dist/client/assets/settings-layout-D82thllZ.js +1 -0
- package/dist/client/assets/{settings-section-Dab3WzAF.js → settings-section-DLmrAiBm.js} +1 -1
- package/dist/client/assets/{shell-layout-lDvOUVZf.js → shell-layout-R4iIIify.js} +1 -1
- package/dist/client/assets/{skeleton-jCfWKtEG.js → skeleton-D3XIs5gC.js} +1 -1
- package/dist/client/assets/{sso-y81n9RBZ.js → sso-DM0bDf34.js} +1 -1
- package/dist/client/assets/{store-CvYwjdEK.js → store-DBYsfjv2.js} +1 -1
- package/dist/client/assets/store-registry-Be_BNgv2.js +2 -0
- package/dist/client/assets/{switch-fkgGJ6Y_.js → switch-ChHlr-0p.js} +1 -1
- package/dist/client/assets/{table-B_6GznCu.js → table-D-EfNZTA.js} +1 -1
- package/dist/client/assets/{tabs-qDZiCngi.js → tabs-C3Y9bmk3.js} +1 -1
- package/dist/client/assets/{task-status-BaBW3UXJ.js → task-status-Byb391SI.js} +1 -1
- package/dist/client/assets/{textarea-C2BrY9Le.js → textarea-TEFGem1K.js} +1 -1
- package/dist/client/assets/{toggle-group-B-jspLpZ.js → toggle-group-DYAaGRJB.js} +1 -1
- package/dist/client/assets/{tools-list-6JBD-Zot.js → tools-list-DHP55xBU.js} +1 -1
- package/dist/client/assets/{tooltip-CC8e8bYw.js → tooltip-DZ4hI4gi.js} +1 -1
- package/dist/client/assets/{types-BrKOUOZu.js → types-D599MtjY.js} +1 -1
- package/dist/client/assets/{use-ai-providers-B2sC2ALY.js → use-ai-providers-DSutNjVp.js} +1 -1
- package/dist/client/assets/{use-collections-CeVghh3K.js → use-collections-BbQAdI3o.js} +1 -1
- package/dist/client/assets/{use-connection-Cyq0iJ5j.js → use-connection-CrEyI3P_.js} +1 -1
- package/dist/client/assets/{use-copy-DR2hWJaD.js → use-copy-Df3K3sfk.js} +1 -1
- package/dist/client/assets/{use-create-virtual-mcp-DGMHB2cc.js → use-create-virtual-mcp-t8SMbFkV.js} +1 -1
- package/dist/client/assets/{use-debounced-autosave-DwUIvZBw.js → use-debounced-autosave-IAh8TU4o.js} +1 -1
- package/dist/client/assets/{use-decopilot-events-YJpIJj4i.js → use-decopilot-events-CxAD33F2.js} +1 -1
- package/dist/client/assets/{use-delete-connection-BkbDfapg.js → use-delete-connection-zP-NAmKT.js} +1 -1
- package/dist/client/assets/{use-infinite-scroll-Hb3Vf_3I.js → use-infinite-scroll-hrqUZmbE.js} +1 -1
- package/dist/client/assets/{use-list-state-wzK4SDnM.js → use-list-state-DsStSeaC.js} +1 -1
- package/dist/client/assets/{use-mcp-tools-CPgnB2kL.js → use-mcp-tools-kqffQmIa.js} +1 -1
- package/dist/client/assets/{use-members-BXnMgIf9.js → use-members-BqQiitMx.js} +1 -1
- package/dist/client/assets/{use-navigate-to-agent-BJNAm35_.js → use-navigate-to-agent-DkjTuG5H.js} +1 -1
- package/dist/client/assets/{use-org-auth-client-B2VsJjxT.js → use-org-auth-client-DM9zvqH-.js} +1 -1
- package/dist/client/assets/{use-org-sso-D98ffRJ_.js → use-org-sso-DFTMWioi.js} +1 -1
- package/dist/client/assets/{use-organization-roles-CsvLhbKb.js → use-organization-roles-CzgnOad2.js} +1 -1
- package/dist/client/assets/{use-organization-settings-SrrzYdc9.js → use-organization-settings-CZnRZbph.js} +1 -1
- package/dist/client/assets/{use-registry-connections-B0GzmRQn.js → use-registry-connections-CT-N1sCh.js} +1 -1
- package/dist/client/assets/{use-status-sounds-CtnKWsOu.js → use-status-sounds-Bewyc919.js} +1 -1
- package/dist/client/assets/{use-tasks-DToWWiz1.js → use-tasks-9cquzKq3.js} +1 -1
- package/dist/client/assets/{use-view-mode-BqpScb5m.js → use-view-mode-B2bqG4ko.js} +1 -1
- package/dist/client/assets/{use-virtual-mcp-DA2HdrC3.js → use-virtual-mcp-Bl5HfgtI.js} +1 -1
- package/dist/client/assets/useInfiniteQuery-P_vpKUlW.js +1 -0
- package/dist/client/assets/useSuspenseInfiniteQuery-CdjREh1b.js +1 -0
- package/dist/client/assets/{user-CrGRA0V7.js → user-BmqT7ATa.js} +1 -1
- package/dist/client/assets/{view-mode-toggle-DlPw4C1T.js → view-mode-toggle-DdV_2G2i.js} +1 -1
- package/dist/client/assets/{workflow-YCSeFh2m.js → workflow-Oj5odTn3.js} +1 -1
- package/dist/client/assets/workflow-detail-BT6eq7UZ.js +1 -0
- package/dist/client/index.html +1 -1
- package/dist/server/cli.js +86 -91
- package/dist/server/node_modules/ansi-styles/index.d.ts +236 -0
- package/dist/server/node_modules/ansi-styles/index.js +223 -0
- package/dist/server/node_modules/{ansi-regex → ansi-styles}/package.json +13 -20
- package/dist/server/node_modules/ansi-styles/readme.md +173 -0
- package/dist/server/node_modules/onetime/index.d.ts +64 -0
- package/dist/server/node_modules/onetime/index.js +44 -0
- package/dist/server/node_modules/onetime/package.json +43 -0
- package/dist/server/node_modules/onetime/readme.md +94 -0
- package/dist/server/node_modules/pg/LICENSE +21 -0
- package/dist/server/node_modules/pg/README.md +95 -0
- package/dist/server/node_modules/pg/esm/index.mjs +20 -0
- package/dist/server/node_modules/pg/lib/client.js +743 -0
- package/dist/server/node_modules/pg/lib/connection-parameters.js +171 -0
- package/dist/server/node_modules/pg/lib/connection.js +221 -0
- package/dist/server/node_modules/pg/lib/crypto/cert-signatures.js +122 -0
- package/dist/server/node_modules/pg/lib/crypto/sasl.js +212 -0
- package/dist/server/node_modules/pg/lib/crypto/utils-legacy.js +43 -0
- package/dist/server/node_modules/pg/lib/crypto/utils-webcrypto.js +89 -0
- package/dist/server/node_modules/pg/lib/crypto/utils.js +9 -0
- package/dist/server/node_modules/pg/lib/defaults.js +91 -0
- package/dist/server/node_modules/pg/lib/index.js +73 -0
- package/dist/server/node_modules/pg/lib/native/client.js +323 -0
- package/dist/server/node_modules/pg/lib/native/index.js +2 -0
- package/dist/server/node_modules/pg/lib/native/query.js +165 -0
- package/dist/server/node_modules/pg/lib/query.js +252 -0
- package/dist/server/node_modules/pg/lib/result.js +109 -0
- package/dist/server/node_modules/pg/lib/stream.js +83 -0
- package/dist/server/node_modules/pg/lib/type-overrides.js +35 -0
- package/dist/server/node_modules/pg/lib/utils.js +217 -0
- package/dist/server/node_modules/pg/package.json +76 -0
- package/dist/server/server.js +85 -90
- package/package.json +1 -1
- package/dist/client/assets/ai-providers-C23uGGTh.js +0 -1
- package/dist/client/assets/index-BtV0adYp.js +0 -1
- package/dist/client/assets/registry-SRrrOWaz.js +0 -2
- package/dist/client/assets/settings-layout-C75rVJeh.js +0 -1
- package/dist/client/assets/store-registry-DNpjvrs_.js +0 -2
- package/dist/client/assets/useInfiniteQuery-DZyvg0dy.js +0 -1
- package/dist/client/assets/useSuspenseInfiniteQuery-DItg4qEF.js +0 -1
- package/dist/client/assets/workflow-detail-C-1jRApT.js +0 -1
- package/dist/server/node_modules/ansi-regex/index.d.ts +0 -33
- package/dist/server/node_modules/ansi-regex/index.js +0 -14
- package/dist/server/node_modules/ansi-regex/readme.md +0 -66
- package/dist/server/node_modules/emoji-regex/LICENSE-MIT.txt +0 -20
- package/dist/server/node_modules/emoji-regex/README.md +0 -107
- package/dist/server/node_modules/emoji-regex/index.d.ts +0 -3
- package/dist/server/node_modules/emoji-regex/index.js +0 -4
- package/dist/server/node_modules/emoji-regex/index.mjs +0 -4
- package/dist/server/node_modules/emoji-regex/package.json +0 -45
- package/dist/server/node_modules/is-fullwidth-code-point/index.d.ts +0 -17
- package/dist/server/node_modules/is-fullwidth-code-point/index.js +0 -12
- package/dist/server/node_modules/is-fullwidth-code-point/package.json +0 -53
- package/dist/server/node_modules/is-fullwidth-code-point/readme.md +0 -31
- /package/dist/server/node_modules/{ansi-regex → ansi-styles}/license +0 -0
- /package/dist/server/node_modules/{is-fullwidth-code-point → onetime}/license +0 -0
package/dist/server/cli.js
CHANGED
|
@@ -1643,7 +1643,7 @@ AS SELECT
|
|
|
1643
1643
|
FROM monitoring_metrics
|
|
1644
1644
|
GROUP BY organization_id, name, bucket, connection_id, tool_name, status
|
|
1645
1645
|
`}),console.log("[clickhouse-schema] monitoring_metrics_rollup_1m_mv view ready")}finally{await G.close()}}catch(Y){console.error("[clickhouse-schema] Failed to create rollup DDL (queries will fall back to raw table):",Y)}}async function iA1(X){let Y={...process.env},G=e$1(X,Y),Q=G.settings.encryptionKey;console.log(`[settings] ENCRYPTION_KEY = ${JSON.stringify(Q)} (${Q.length} chars)`);let{ensureServices:J}=await Promise.resolve().then(() => (l$1(),u$1)),{outputs:W,services:Z}=await J({home:G.settings.dataDir,externalDatabaseUrl:G.externalDatabaseUrl,externalNatsUrl:G.externalNatsUrl});if(!G.skipMigrations){let{migrateBetterAuth:K}=await Promise.resolve().then(() => (YW0(),Jg4));await K(W.databaseUrl);let{createDatabase:H}=await Promise.resolve().then(() => (ZU(),Qg4)),{migrateToLatest:U}=await Promise.resolve().then(() => (Us4(),Fs4)),B=H(W.databaseUrl);await U({keepOpen:!0,database:B,skipBetterAuth:!0})}if(G.settings.clickhouseUrl){let{ensureClickHouseRollup:K}=await Promise.resolve().then(() => B16);await K(G.settings.clickhouseUrl)}let $={...G.settings,databaseUrl:W.databaseUrl,natsUrls:W.natsUrls};return xt1($),{settings:$,services:Z.map((K)=>({name:K.name==="PostgreSQL"?"Postgres":K.name,port:K.port})),managedServiceNames:Z.filter((K)=>K.owner==="managed").map((K)=>K.name)}}var kN0=w(()=>{yt1();l9()});var tA1={};T0(tA1,{updateService:()=>Ya,toggleViewMode:()=>vN0,toggleVibeState:()=>fN0,toggleLogFlow:()=>_N0,subscribeCliState:()=>CX1,setVibe:()=>Ya5,setTuiConsoleIntercepted:()=>pA1,setServerUrl:()=>_X1,setMigrationsDone:()=>vX1,setEnv:()=>fX1,setDevMode:()=>et5,setDataDir:()=>Xa5,isTuiConsoleIntercepted:()=>nA1,getCliState:()=>kX1,addLogEntry:()=>Wz});function TU(){for(let X of CN0)X()}function kX1(){return e9}function CX1(X){return CN0.add(X),()=>CN0.delete(X)}function Ya(X){e9={...e9,services:e9.services.map((Y)=>Y.name===X.name?X:Y)},TU()}function vX1(){e9={...e9,migrationsStatus:"done"},TU()}function _X1(X){e9={...e9,serverUrl:X},TU()}function fX1(X){e9={...e9,env:X},TU()}function Wz(X){let Y=[...e9.logs,X];e9={...e9,logs:Y.length>500?Y.slice(-500):Y},TU()}function et5(){e9={...e9,services:[...e9.services,{name:"Vite",status:"pending",port:0}]},TU()}function vN0(){e9={...e9,viewMode:e9.viewMode==="requests"?"config":"requests"},TU()}function _N0(){e9={...e9,logFlow:!e9.logFlow},TU()}function Xa5(X){e9={...e9,dataDir:X},TU()}function Ya5(X){e9={...e9,vibe:X},TU()}function fN0(){e9={...e9,vibe:!e9.vibe},TU()}function pA1(X){N16=X}function nA1(){return N16}var e9,CN0,N16=!1;var $z=w(()=>{e9={services:[{name:"Postgres",status:"pending",port:0},{name:"NATS",status:"pending",port:0}],migrationsStatus:"pending",serverUrl:null,env:null,logs:[],viewMode:"requests",logFlow:!1,vibe:!1,dataDir:null},CN0=new Set});import{createServer as z16}from"net";function Ga5(X){return new Promise((Y)=>{let G=z16();G.once("error",()=>Y(!1)),G.listen(X,"0.0.0.0",()=>{G.close(()=>Y(!0))})})}async function aA1(X){if(await Ga5(X))return X;let Y=await new Promise((G,Q)=>{let J=z16();J.once("error",Q),J.listen(0,"0.0.0.0",()=>{let W=J.address(),Z=typeof W==="object"&&W?W.port:0;J.close(()=>G(Z))})});return console.warn(`Port ${X} is in use, using port ${Y} instead.`),Y}var bN0=()=>{};var yN0={};T0(yN0,{startDevServer:()=>Ja5});import{join as Qa5}from"path";function O16(X){return X.replace(/\x1b\[[0-9;]*m/g,"")}function D16(X){let Y=X.getReader(),G=new TextDecoder,Q="";function J(){let W=Q.split(`
|
|
1646
|
-
`);Q=W.pop()??"";for(let Z of W){let $=O16(Z).replace(/^\[\d+\]\s*/,"").trim();if(!$)continue;Wz({method:"",path:"",status:0,duration:0,timestamp:new Date,rawLine:$})}}(async()=>{for(;;){let{done:W,value:Z}=await Y.read();if(W)break;Q+=G.decode(Z,{stream:!0}),J()}if(Q.trim()){let W=O16(Q).replace(/^\[\d+\]\s*/,"").trim();if(W)Wz({method:"",path:"",status:0,duration:0,timestamp:new Date,rawLine:W})}})()}async function Ja5(X){let{vitePort:Y,baseUrl:G,noTui:Q}=X,J=await aA1(Number(X.port)),{settings:W,services:Z,managedServiceNames:$}=await iA1({port:String(J),home:X.home,baseUrl:X.baseUrl,localMode:X.localMode,skipMigrations:X.skipMigrations,noTui:X.noTui,vitePort:X.vitePort});for(let z of Z)Ya({name:z.name,status:"ready",port:z.port});fX1(W),vX1();let K=Qa5(import.meta.dir,"..","..","..","..",".."),H=Q===!0,U=Bun.spawn(["bun","run","--cwd=apps/mesh","dev:servers"],{cwd:K,env:{...process.env,PORT:String(W.port),VITE_PORT:String(Y),DATABASE_URL:W.databaseUrl,NATS_URL:W.natsUrls.join(","),NODE_ENV:W.nodeEnv,DECOCMS_LOCAL_MODE:String(W.localMode),DECOCMS_HOME:W.dataDir,DATA_DIR:W.dataDir,DECO_CLI:"1",...W.baseUrl?{BASE_URL:W.baseUrl}:{}},stdio:["inherit",H?"inherit":"pipe",H?"inherit":"pipe"]});if(!H)D16(U.stdout),D16(U.stderr);let B=G||`http://localhost:${W.port}`;_X1(B),Ya({name:"Vite",status:"ready",port:Number(Y)});let N=async(z)=>{if(U.kill(z),$.length>0){let{stopServices:O}=await Promise.resolve().then(() => (l$1(),u$1));await O(W.dataDir)}};return process.on("SIGINT",()=>N("SIGINT")),process.on("SIGTERM",()=>N("SIGTERM")),{port:Number(W.port),process:U}}var xN0=w(()=>{kN0();$z();bN0()});import{Box as hN0,Text as gN0}from"ink";import{jsx as L16,jsxs as rA1}from"react/jsx-runtime";function w16(X){if(!X)return"not set";try{let Y=new URL(X);if(Y.password)Y.password="***";if(Y.username&&Y.username.length>3)Y.username=Y.username.slice(0,3)+"***";return Y.pathname="/",Y.search="",Y.hash="",Y.toString()}catch{if(X.length<=10)return X;return X.slice(0,6)+"***"+X.slice(-4)}}function $a5(X,Y){if(Za5.has(X))return Y?{text:"\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF",dimColor:!0}:{text:"not set",dimColor:!0};if(Wa5.has(X)){if(Array.isArray(Y)){if(Y.length===0)return{text:"not set",dimColor:!0};return{text:Y.map((W)=>w16(W)).join(", "),color:"cyan"}}let Q=w16(Y);return Q==="not set"?{text:Q,dimColor:!0}:{text:Q,color:"cyan"}}if(Y===void 0||Y===null||Y==="")return{text:"not set",dimColor:!0};let G=String(Y);if(G==="true")return{text:G,color:"green"};if(G==="false")return{text:G,color:"yellow"};try{return new URL(G),{text:G,color:"cyan"}}catch{return{text:G}}}function Ka5(X){return[{title:"Core",entries:[{key:"NODE_ENV",value:X.nodeEnv},{key:"PORT",value:X.port},{key:"BASE_URL",value:X.baseUrl??`http://localhost:${X.port}`},{key:"DATA_DIR",value:X.dataDir}]},{title:"Database",entries:[{key:"DATABASE_URL",value:X.databaseUrl},{key:"DATABASE_PG_SSL",value:X.databasePgSsl}]},{title:"Auth & Secrets",entries:[{key:"BETTER_AUTH_SECRET",value:X.betterAuthSecret},{key:"ENCRYPTION_KEY",value:X.encryptionKey},{key:"MESH_JWT_SECRET",value:X.meshJwtSecret},{key:"STUDIO_PROVISION_SECRET_KEY",value:X.studioProvisionSecretKey},{key:"DISABLE_RATE_LIMIT",value:X.disableRateLimit}]},{title:"Auth Providers",entries:[{key:"AUTH_EMAIL_PASSWORD_ENABLED",value:process.env.AUTH_EMAIL_PASSWORD_ENABLED??"true"},{key:"AUTH_GOOGLE_CLIENT_ID",value:!!process.env.AUTH_GOOGLE_CLIENT_ID},{key:"AUTH_GITHUB_CLIENT_ID",value:!!process.env.AUTH_GITHUB_CLIENT_ID},{key:"AUTH_RESEND_API_KEY",value:!!process.env.AUTH_RESEND_API_KEY},{key:"AUTH_SENDGRID_API_KEY",value:!!process.env.AUTH_SENDGRID_API_KEY},{key:"AUTH_SSO_MS_CLIENT_ID",value:!!process.env.AUTH_SSO_MS_CLIENT_ID},{key:"AUTH_SSO_GOOGLE_CLIENT_ID",value:!!process.env.AUTH_SSO_GOOGLE_CLIENT_ID},{key:"AUTH_MAGIC_LINK_ENABLED",value:process.env.AUTH_MAGIC_LINK_ENABLED==="true"},{key:"AUTH_EMAIL_OTP_ENABLED",value:process.env.AUTH_EMAIL_OTP_ENABLED==="true"}]},{title:"Observability",entries:[{key:"CLICKHOUSE_URL",value:X.clickhouseUrl},{key:"OTEL_SERVICE_NAME",value:X.otelServiceName}]},{title:"Event Bus & Networking",entries:[{key:"NATS_URL",value:X.natsUrls}]},{title:"Config Files",entries:[{key:"CONFIG_PATH",value:X.configPath}]},{title:"AI Gateway",entries:[{key:"DECO_AI_GATEWAY_ENABLED",value:X.aiGatewayEnabled},{key:"DECO_AI_GATEWAY_URL",value:X.aiGatewayUrl}]}]}function E16({env:X}){let Y=Ka5(X);return L16(hN0,{flexDirection:"column",children:Y.map((G)=>rA1(hN0,{flexDirection:"column",marginTop:1,children:[rA1(gN0,{dimColor:!0,children:[" ","\u2500\u2500 ",G.title," ","\u2500".repeat(Math.max(0,38-G.title.length))]}),G.entries.map(({key:Q,value:J})=>{let W=$a5(Q,J);return rA1(hN0,{children:[rA1(gN0,{dimColor:!0,children:[" ",Q.padEnd(36)]}),L16(gN0,{color:W.color,dimColor:W.dimColor,children:W.text})]},Q)})]},G.title))})}var Za5,Wa5;var P16=w(()=>{Za5=new Set(["BETTER_AUTH_SECRET","ENCRYPTION_KEY","MESH_JWT_SECRET","STUDIO_PROVISION_SECRET_KEY"]),Wa5=new Set(["DATABASE_URL","CLICKHOUSE_URL","NATS_URL"])});var uN0;var q16=w(()=>{uN0={name:"decocms",version:"2.311.8",description:"Deco CMS \u2014 Self-hostable MCP Gateway for managing AI connections and tools",author:"Deco team",repository:{type:"git",url:"git+https://github.com/decocms/studio.git",directory:"apps/mesh"},bugs:{url:"https://github.com/decocms/studio/issues"},type:"module",bin:{deco:"./dist/server/cli.js"},files:["dist/**/*"],scripts:{dev:'bun run migrate && concurrently "bun run dev:client" "bun run dev:server"',"dev:servers":'concurrently "bun run dev:client" "bun run dev:server"',"dev:client":"bun --bun vite dev","dev:server":"bun run --cwd=../../packages/sandbox build && NODE_ENV=development bun --env-file=.env --hot run src/index.ts","build:client":"bun --bun vite build","build:server":"bun run scripts/bundle-server-script.ts --dist ./dist/server","db:migrate":"bun run ./dist/server/migrate.js",check:"tsc --noEmit",start:"bun run ./dist/server/server.js",migrate:"bun run src/database/migrate.ts",test:"bun test","test:e2e":"playwright test","test:e2e:ui":"playwright test --ui","better-auth:migrate":"bunx --bun @better-auth/cli migrate -y --config src/auth/index.ts",prepublishOnly:"bun run build:client && bun run build:server"},optionalDependencies:{"@duckdb/node-api":"^1.5.0-r.1","@freestyle-sh/with-bun":"^0.2.12","@freestyle-sh/with-deno":"^0.0.4","@freestyle-sh/with-nodejs":"^0.2.9","freestyle-sandboxes":"^0.1.46"},dependencies:{"@ai-sdk/anthropic":"^3.0.58","@ai-sdk/google":"^3.0.60","@ai-sdk/openai":"^3.0.50","@anthropic-ai/sdk":"^0.79.0","@aws-sdk/client-s3":"^3.1013.0","@aws-sdk/s3-request-presigner":"^3.1013.0","@clickhouse/client":"^1.8.1","@deco-cx/warp-node":"^0.3.20","@dnd-kit/core":"^6.3.1","@dnd-kit/sortable":"^10.0.0","@dnd-kit/utilities":"^3.2.2","@inkjs/ui":"^2.0.0","@modelcontextprotocol/ext-apps":"^1.2.2","@openrouter/ai-sdk-provider":"^2.2.5","@opentelemetry/core":"^2.6.0","@tanstack/react-virtual":"^3.13.21","@xterm/addon-fit":"^0.11.0","@xterm/xterm":"^6.0.0","ai-sdk-provider-claude-code":"^3.4.4","ai-sdk-provider-codex-cli":"^1.1.0","embedded-postgres":"^18.3.0-beta.16",ink:"^6.8.0",kysely:"^0.28.12",nats:"^2.29.3","node-pty":"^1.0.0","posthog-js":"^1.371.1","posthog-node":"^5.0.0",react:"^19.2.0","react-dom":"^19.2.0"},devDependencies:{"@ai-sdk/provider":"^3.0.8","@ai-sdk/react":"^3.0.118","@anthropic-ai/claude-agent-sdk":"^0.2.80","@better-auth/sso":"1.4.1","@daveyplate/better-auth-ui":"^3.2.7","@deco/ui":"workspace:*","@decocms/better-auth":"1.5.17","@decocms/bindings":"workspace:*","@decocms/mcp-utils":"workspace:*","@decocms/mesh-sdk":"workspace:*","@decocms/runtime":"workspace:*","@decocms/vite-plugin":"workspace:*","@electric-sql/pglite":"^0.3.15","@floating-ui/react":"^0.27.16","@hookform/resolvers":"^5.2.2","@jitl/quickjs-wasmfile-release-sync":"0.31.0","@modelcontextprotocol/sdk":"1.27.1","@monaco-editor/react":"^4.7.0","@opentelemetry/api":"^1.9.0","@opentelemetry/api-logs":"^0.211.0","@opentelemetry/exporter-logs-otlp-proto":"^0.211.0","@opentelemetry/exporter-prometheus":"^0.208.0","@opentelemetry/exporter-trace-otlp-proto":"^0.207.0","@opentelemetry/instrumentation-runtime-node":"^0.24.0","@opentelemetry/sdk-logs":"^0.211.0","@opentelemetry/sdk-metrics":"^2.2.0","@opentelemetry/sdk-node":"^0.207.0","@opentelemetry/sdk-trace-base":"^2.5.0","@playwright/test":"^1.58.2","@radix-ui/react-avatar":"^1.1.10","@radix-ui/react-checkbox":"^1.3.3","@radix-ui/react-dialog":"^1.1.15","@radix-ui/react-dropdown-menu":"^2.1.16","@radix-ui/react-label":"^2.1.7","@radix-ui/react-select":"^2.2.6","@radix-ui/react-separator":"^1.1.7","@radix-ui/react-slot":"^1.2.3","@radix-ui/react-tabs":"^1.1.13","@rjsf/core":"^6.1.2","@rjsf/shadcn":"^6.1.2","@rjsf/utils":"^6.1.2","@rjsf/validator-ajv8":"^6.1.2","@tailwindcss/vite":"^4.1.17","@tanstack/react-query":"5.90.11","@tanstack/react-router":"^1.139.7","@tiptap/core":"3.20.2","@tiptap/extension-mention":"3.20.2","@tiptap/extension-placeholder":"3.20.2","@tiptap/pm":"3.20.2","@tiptap/react":"3.20.2","@tiptap/starter-kit":"3.20.2","@tiptap/suggestion":"3.20.2","@types/bun":"^1.3.1","@types/pg":"^8.15.6","@types/react-syntax-highlighter":"^15.5.13","@untitledui/icons":"^0.0.19","@vercel/nft":"^1.1.1","@vitejs/plugin-react":"^5.1.0",ai:"^6.0.116","babel-plugin-react-compiler":"^1.0.0","better-auth":"1.4.5","class-variance-authority":"^0.7.1",clsx:"^2.1.1",concurrently:"^9.2.1",croner:"^9.1.0","date-fns":"^4.1.0",degit:"^2.8.4",hono:"^4.10.7","input-otp":"^1.4.2",jose:"^6.0.11","kysely-pglite":"^0.6.1","lucide-react":"^0.468.0",marked:"^15.0.6","@decocms/sandbox":"workspace:*","mesh-plugin-workflows":"workspace:*",nanoid:"^5.1.6",pg:"^8.16.3",prettier:"^3.4.2","react-hook-form":"^7.66.0","react-markdown":"^10.1.0","react-resizable-panels":"^2.1.7","react-syntax-highlighter":"^15.6.1",recharts:"^3.6.0","rehype-raw":"^7.0.0","remark-gfm":"^4.0.0","sass-embedded":"^1.97.2",sonner:"^2.0.7","tailwind-merge":"^3.3.1",tailwindcss:"^4.1.17",typescript:"^5.9.3",vite:"^7.2.1","vite-tsconfig-paths":"^5.1.4",zod:"^4.0.0",zustand:"^5.0.9"},homepage:"https://github.com/decocms/studio",keywords:["mcp","model-context-protocol","ai","gateway","self-hosted","mesh","tools"],license:"MIT",publishConfig:{access:"public"}}});import{Box as IU,Text as RX}from"ink";import{Spinner as Fa5}from"@inkjs/ui";import{useSyncExternalStore as A16}from"react";import{jsx as TY,jsxs as sQ}from"react/jsx-runtime";function Oa5(X,Y){if(!X||!za5.has(X))return X;let G=lN0[Y]??lN0[lN0.length-1];return X==="#875f00"?G[0]:G[1]}function T16({status:X}){if(X==="pending")return TY(Fa5,{label:""});return TY(RX,{color:"green",children:"\u2713"})}function I16({services:X,migrationsStatus:Y,home:G,serverUrl:Q,vibe:J}){let W=A16(mm0,lm0),Z=A16(tm0,nm0);return sQ(IU,{flexDirection:"column",paddingBottom:1,children:[J?sQ(IU,{flexDirection:"column",children:[W.map(($,K)=>{let H=Z[K],U=$.reduce((N,z)=>N+z.text.length,0),B=Math.max(0,Na5-U);return sQ(IU,{flexDirection:"row",children:[$.map((N,z)=>{let O=Oa5(N.color,K);return O?TY(RX,{color:O,children:N.text},z):TY(RX,{children:N.text},z)}),TY(RX,{children:" ".repeat(B+2)}),H?.map((N,z)=>N.color?TY(RX,{color:N.color,children:N.char},z):TY(RX,{children:N.char},z))]},K)}),sQ(RX,{dimColor:!0,children:[" v",uN0.version]})]}):sQ(IU,{flexDirection:"column",marginTop:1,children:[Ua5.map(($,K)=>TY(RX,{color:Ba5[K],children:$},K)),sQ(RX,{dimColor:!0,children:[" v",uN0.version]})]}),TY(IU,{marginBottom:1,children:TY(RX,{dimColor:!0,children:"\u2500".repeat(80)})}),TY(IU,{children:sQ(RX,{dimColor:!0,children:["Home: ",G]})}),sQ(IU,{gap:2,children:[X.map(($)=>sQ(IU,{gap:1,children:[sQ(RX,{children:[$.name," :",$.port||"...."]}),TY(T16,{status:$.status})]},$.name)),sQ(IU,{gap:1,children:[TY(RX,{children:"Migrations"}),TY(T16,{status:Y})]})]}),TY(IU,{children:Q?sQ(RX,{children:["Open in browser: ",TY(RX,{color:"cyan",children:Q})]}):TY(RX,{dimColor:!0,children:"Starting..."})}),sQ(IU,{gap:2,children:[sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"K"})," ","toggle config"]}),sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"L"})," ","toggle log flow"]}),sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"V"})," ","toggle vibe ",J?"\u266A Nihilore \xB7 CC BY 4.0":""]}),J&&sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"N"})," ","skip song"]})]})]})}var Ua5,Ba5,lN0,Na5=30,za5;var V16=w(()=>{q16();Vt1();Ct1();Ua5=[" \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588 ","\u2591\u2591\u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588 \u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588\u2588\u2588 "," \u2591\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2588 \u2591 \u2588\u2588\u2588 \u2591\u2591\u2591 \u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588\u2591\u2591\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591 \u2588\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588 "," \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2591\u2591\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2591 ","\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591 "],Ba5=["#00ff64","#00ee5e","#00dc56","#00c84e","#00b444","#00a03c","#008832","#006e28"],lN0=[["#00ff64","#00cc50"],["#00f060","#00c04c"],["#00e05c","#00b448"],["#00d058","#00a844"],["#00c054","#009c40"],["#00b050","#00903c"],["#00a04c","#008438"],["#009048","#007834"],["#008044","#006c30"],["#007040","#00602c"],["#00603c","#005428"]],za5=new Set(["#875f00","#5f3800"])});import{useSyncExternalStore as Da5}from"react";function wa5(){let X=process.stdout.rows||24,Y=process.stdout.columns||80;if(X!==oA1.rows||Y!==oA1.columns)oA1={rows:X,columns:Y};return oA1}function La5(X){return process.stdout.on("resize",X),()=>{process.stdout.off("resize",X)}}function j16(){return Da5(La5,wa5)}var oA1;var M16=w(()=>{oA1={rows:process.stdout.rows||24,columns:process.stdout.columns||80}});import{Box as Ea5,Text as bX1}from"ink";import{useSyncExternalStore as Pa5}from"react";import{jsx as mN0,jsxs as dN0}from"react/jsx-runtime";function qa5(X){if(X>=500)return"red";if(X>=400)return"yellow";if(X>=300)return"cyan";return"green"}function R16({logs:X,headerHeight:Y}){let{rows:G}=j16(),{logFlow:Q}=Pa5(CX1,kX1),J=Math.max(1,G-Y-1),W=Q?X:X.slice(-J);return mN0(Ea5,{flexDirection:"column",children:W.map((Z,$)=>{if(Z.rawLine)return mN0(bX1,{dimColor:!0,children:Z.rawLine},$);let K=Z.duration<1000?`${Z.duration}ms`:`${(Z.duration/1000).toFixed(1)}s`;return dN0(bX1,{children:[dN0(bX1,{dimColor:!0,children:[Z.method.padEnd(6)," ",Z.path.padEnd(30)," "]}),mN0(bX1,{color:qa5(Z.status),children:Z.status}),dN0(bX1,{dimColor:!0,children:[" ",K.padStart(8)]})]},$)})})}var S16=w(()=>{$z();M16()});var cN0={};T0(cN0,{App:()=>Ra5});import{Box as Aa5,Text as Ta5,useInput as Ia5}from"ink";import{useSyncExternalStore as Va5}from"react";import{jsx as sA1,jsxs as Sa5}from"react/jsx-runtime";function Ra5({home:X}){let Y=Va5(CX1,kX1);return Ia5((G)=>{if(G==="k"||G==="K")vN0();if(G==="l"||G==="L")_N0();if((G==="v"||G==="V")&&Y.dataDir)bt1(Y.dataDir),fN0();if((G==="n"||G==="N")&&Y.vibe)ft1()}),Sa5(Aa5,{flexDirection:"column",children:[sA1(I16,{services:Y.services,migrationsStatus:Y.migrationsStatus,home:X,serverUrl:Y.serverUrl,vibe:Y.vibe}),Y.viewMode==="config"?Y.env?sA1(E16,{env:Y.env}):sA1(Ta5,{dimColor:!0,children:"Loading configuration..."}):sA1(R16,{logs:Y.logs,headerHeight:Y.vibe?Ma5:ja5})]})}var ja5=15,Ma5=19;var iN0=w(()=>{P16();V16();S16();$z();fd()});function k16(X,Y={}){return{PORT:String(X.port),NODE_ENV:X.nodeEnv,BASE_URL:X.baseUrl,DATA_DIR:X.dataDir,DECOCMS_HOME:X.dataDir,DATABASE_URL:X.databaseUrl,DATABASE_PG_SSL:String(X.databasePgSsl),DATABASE_POOL_MAX:String(X.databasePoolMax),NATS_URL:X.natsUrls.join(","),BETTER_AUTH_SECRET:X.betterAuthSecret,ENCRYPTION_KEY:X.encryptionKey,MESH_JWT_SECRET:X.meshJwtSecret,DECOCMS_LOCAL_MODE:String(X.localMode),DISABLE_RATE_LIMIT:String(X.disableRateLimit),STUDIO_PROVISION_SECRET_KEY:X.studioProvisionSecretKey,CONFIG_PATH:X.configPath,...Object.fromEntries(Object.entries(process.env).filter(([G])=>G.startsWith("AUTH_"))),DECO_AI_GATEWAY_ENABLED:String(X.aiGatewayEnabled),DECO_AI_GATEWAY_URL:X.aiGatewayUrl,ENABLE_DECO_IMPORT:String(X.enableDecoImport),S3_ENDPOINT:X.s3Endpoint,S3_BUCKET:X.s3Bucket,S3_REGION:X.s3Region,S3_ACCESS_KEY_ID:X.s3AccessKeyId,S3_SECRET_ACCESS_KEY:X.s3SecretAccessKey,S3_FORCE_PATH_STYLE:String(X.s3ForcePathStyle),OTEL_SERVICE_NAME:X.otelServiceName,CLICKHOUSE_URL:X.clickhouseUrl,OTEL_EXPORTER_OTLP_ENDPOINT:process.env.OTEL_EXPORTER_OTLP_ENDPOINT,OTEL_EXPORTER_OTLP_PROTOCOL:process.env.OTEL_EXPORTER_OTLP_PROTOCOL,OTEL_RESOURCE_ATTRIBUTES:process.env.OTEL_RESOURCE_ATTRIBUTES,DECO_SUPABASE_URL:X.decoSupabaseUrl,DECO_SUPABASE_SERVICE_KEY:X.decoSupabaseServiceKey,FIRECRAWL_API_KEY:X.firecrawlApiKey,STUDIO_SANDBOX_RUNNER:process.env.STUDIO_SANDBOX_RUNNER,STUDIO_SANDBOX_TEMPLATE_NAME:process.env.STUDIO_SANDBOX_TEMPLATE_NAME,STUDIO_ENV:process.env.STUDIO_ENV,STUDIO_SANDBOX_PREVIEW_URL_PATTERN:process.env.STUDIO_SANDBOX_PREVIEW_URL_PATTERN,STUDIO_SANDBOX_PREVIEW_GATEWAY_NAME:process.env.STUDIO_SANDBOX_PREVIEW_GATEWAY_NAME,STUDIO_SANDBOX_PREVIEW_GATEWAY_NAMESPACE:process.env.STUDIO_SANDBOX_PREVIEW_GATEWAY_NAMESPACE,STUDIO_SANDBOX_SENTINEL_TOKEN:process.env.STUDIO_SANDBOX_SENTINEL_TOKEN,KUBERNETES_SERVICE_HOST:process.env.KUBERNETES_SERVICE_HOST,KUBERNETES_SERVICE_PORT:process.env.KUBERNETES_SERVICE_PORT,FREESTYLE_API_KEY:process.env.FREESTYLE_API_KEY,BROWSERLESS_TOKEN:process.env.BROWSERLESS_TOKEN,NODE_EXTRA_CA_CERTS:process.env.NODE_EXTRA_CA_CERTS,DECO_CLI:"1",DECO_NO_TUI:"true",...Y}}var yj=k((ba5)=>{ba5.HttpAuthLocation=void 0;(function(X){X.HEADER="header",X.QUERY="query"})(ba5.HttpAuthLocation||(ba5.HttpAuthLocation={}));ba5.HttpApiKeyAuthLocation=void 0;(function(X){X.HEADER="header",X.QUERY="query"})(ba5.HttpApiKeyAuthLocation||(ba5.HttpApiKeyAuthLocation={}));ba5.EndpointURLScheme=void 0;(function(X){X.HTTP="http",X.HTTPS="https"})(ba5.EndpointURLScheme||(ba5.EndpointURLScheme={}));ba5.AlgorithmId=void 0;(function(X){X.MD5="md5",X.CRC32="crc32",X.CRC32C="crc32c",X.SHA1="sha1",X.SHA256="sha256"})(ba5.AlgorithmId||(ba5.AlgorithmId={}));var ka5=(X)=>{let Y=[];if(X.sha256!==void 0)Y.push({algorithmId:()=>ba5.AlgorithmId.SHA256,checksumConstructor:()=>X.sha256});if(X.md5!=null)Y.push({algorithmId:()=>ba5.AlgorithmId.MD5,checksumConstructor:()=>X.md5});return{addChecksumAlgorithm(G){Y.push(G)},checksumAlgorithms(){return Y}}},Ca5=(X)=>{let Y={};return X.checksumAlgorithms().forEach((G)=>{Y[G.algorithmId()]=G.checksumConstructor()}),Y},va5=(X)=>{return ka5(X)},_a5=(X)=>{return Ca5(X)};ba5.FieldPosition=void 0;(function(X){X[X.HEADER=0]="HEADER",X[X.TRAILER=1]="TRAILER"})(ba5.FieldPosition||(ba5.FieldPosition={}));var fa5="__smithy_context";ba5.IniSectionType=void 0;(function(X){X.PROFILE="profile",X.SSO_SESSION="sso-session",X.SERVICES="services"})(ba5.IniSectionType||(ba5.IniSectionType={}));ba5.RequestHandlerProtocol=void 0;(function(X){X.HTTP_0_9="http/0.9",X.HTTP_1_0="http/1.0",X.TDS_8_0="tds/8.0"})(ba5.RequestHandlerProtocol||(ba5.RequestHandlerProtocol={}));ba5.SMITHY_CONTEXT_KEY=fa5;ba5.getDefaultClientConfiguration=va5;ba5.resolveDefaultRuntimeConfig=_a5});var u7=k((ca5)=>{var ga5=yj(),ua5=(X)=>{return{setHttpHandler(Y){X.httpHandler=Y},httpHandler(){return X.httpHandler},updateHttpClientConfig(Y,G){X.httpHandler?.updateHttpClientConfig(Y,G)},httpHandlerConfigs(){return X.httpHandler.httpHandlerConfigs()}}},la5=(X)=>{return{httpHandler:X.httpHandler()}};class C16{name;kind;values;constructor({name:X,kind:Y=ga5.FieldPosition.HEADER,values:G=[]}){this.name=X,this.kind=Y,this.values=G}add(X){this.values.push(X)}set(X){this.values=X}remove(X){this.values=this.values.filter((Y)=>Y!==X)}toString(){return this.values.map((X)=>X.includes(",")||X.includes(" ")?`"${X}"`:X).join(", ")}get(){return this.values}}class v16{entries={};encoding;constructor({fields:X=[],encoding:Y="utf-8"}){X.forEach(this.setField.bind(this)),this.encoding=Y}setField(X){this.entries[X.name.toLowerCase()]=X}getField(X){return this.entries[X.toLowerCase()]}removeField(X){delete this.entries[X.toLowerCase()]}getByType(X){return Object.values(this.entries).filter((Y)=>Y.kind===X)}}class eA1{method;protocol;hostname;port;path;query;headers;username;password;fragment;body;constructor(X){this.method=X.method||"GET",this.hostname=X.hostname||"localhost",this.port=X.port,this.query=X.query||{},this.headers=X.headers||{},this.body=X.body,this.protocol=X.protocol?X.protocol.slice(-1)!==":"?`${X.protocol}:`:X.protocol:"https:",this.path=X.path?X.path.charAt(0)!=="/"?`/${X.path}`:X.path:"/",this.username=X.username,this.password=X.password,this.fragment=X.fragment}static clone(X){let Y=new eA1({...X,headers:{...X.headers}});if(Y.query)Y.query=ma5(Y.query);return Y}static isInstance(X){if(!X)return!1;let Y=X;return"method"in Y&&"protocol"in Y&&"hostname"in Y&&"path"in Y&&typeof Y.query==="object"&&typeof Y.headers==="object"}clone(){return eA1.clone(this)}}function ma5(X){return Object.keys(X).reduce((Y,G)=>{let Q=X[G];return{...Y,[G]:Array.isArray(Q)?[...Q]:Q}},{})}class _16{statusCode;reason;headers;body;constructor(X){this.statusCode=X.statusCode,this.reason=X.reason,this.headers=X.headers||{},this.body=X.body}static isInstance(X){if(!X)return!1;let Y=X;return typeof Y.statusCode==="number"&&typeof Y.headers==="object"}}function da5(X){return/^[a-z0-9][a-z0-9\.\-]*[a-z0-9]$/.test(X)}ca5.Field=C16;ca5.Fields=v16;ca5.HttpRequest=eA1;ca5.HttpResponse=_16;ca5.getHttpHandlerExtensionConfiguration=ua5;ca5.isValidHostname=da5;ca5.resolveHttpHandlerRuntimeConfig=la5});function sa5(X){return(Y)=>async(G)=>{let{request:Q}=G;if(X.expectContinueHeader!==!1&&f16.HttpRequest.isInstance(Q)&&Q.body&&X.runtime==="node"&&X.requestHandler?.constructor?.name!=="FetchHttpHandler"){let J=!0;if(typeof X.expectContinueHeader==="number")try{J=(Number(Q.headers?.["content-length"])??X.bodyLengthChecker?.(Q.body)??1/0)>=X.expectContinueHeader}catch(W){}else J=!!X.expectContinueHeader;if(J)Q.headers.Expect="100-continue"}return Y({...G,request:Q})}}var f16,ea5,b16=(X)=>({applyToStack:(Y)=>{Y.add(sa5(X),ea5)}});var y16=w(()=>{f16=X1(u7(),1);ea5={step:"build",tags:["SET_EXPECT_HEADER","EXPECT_HEADER"],name:"addExpectContinueMiddleware",override:!0}});var wH,XT1,xj,YT1,E9,x16,xX1;var LH=w(()=>{wH={WHEN_SUPPORTED:"WHEN_SUPPORTED",WHEN_REQUIRED:"WHEN_REQUIRED"},XT1=wH.WHEN_SUPPORTED,xj={WHEN_SUPPORTED:"WHEN_SUPPORTED",WHEN_REQUIRED:"WHEN_REQUIRED"},YT1=wH.WHEN_SUPPORTED;(function(X){X.MD5="MD5",X.CRC32="CRC32",X.CRC32C="CRC32C",X.CRC64NVME="CRC64NVME",X.SHA1="SHA1",X.SHA256="SHA256"})(E9||(E9={}));(function(X){X.HEADER="header",X.TRAILER="trailer"})(x16||(x16={}));xX1=E9.CRC32});var kq,Ga=(X,Y,G,Q)=>{if(!(Y in X))return;let J=X[Y].toUpperCase();if(!Object.values(G).includes(J))throw TypeError(`Cannot load ${Q} '${Y}'. Expected one of ${Object.values(G)}, got '${X[Y]}'.`);return J};var sN0=w(()=>{(function(X){X.ENV="env",X.CONFIG="shared config entry"})(kq||(kq={}))});var Xr5="AWS_REQUEST_CHECKSUM_CALCULATION",Yr5="request_checksum_calculation",h16;var g16=w(()=>{LH();sN0();h16={environmentVariableSelector:(X)=>Ga(X,Xr5,wH,kq.ENV),configFileSelector:(X)=>Ga(X,Yr5,wH,kq.CONFIG),default:XT1}});var Gr5="AWS_RESPONSE_CHECKSUM_VALIDATION",Qr5="response_checksum_validation",u16;var l16=w(()=>{LH();sN0();u16={environmentVariableSelector:(X)=>Ga(X,Gr5,xj,kq.ENV),configFileSelector:(X)=>Ga(X,Qr5,xj,kq.CONFIG),default:YT1}});var Xz0=k((Nr5)=>{var Jr5=["AuthFailure","InvalidSignatureException","RequestExpired","RequestInTheFuture","RequestTimeTooSkewed","SignatureDoesNotMatch"],Zr5=["BandwidthLimitExceeded","EC2ThrottledException","LimitExceededException","PriorRequestNotComplete","ProvisionedThroughputExceededException","RequestLimitExceeded","RequestThrottled","RequestThrottledException","SlowDown","ThrottledException","Throttling","ThrottlingException","TooManyRequestsException","TransactionInProgressException"],Wr5=["TimeoutError","RequestTimeout","RequestTimeoutException"],$r5=[500,502,503,504],Kr5=["ECONNRESET","ECONNREFUSED","EPIPE","ETIMEDOUT"],Hr5=["EHOSTUNREACH","ENETUNREACH","ENOTFOUND"],m16=(X)=>X?.$retryable!==void 0,Fr5=(X)=>Jr5.includes(X.name),d16=(X)=>X.$metadata?.clockSkewCorrected,c16=(X)=>{let Y=new Set(["Failed to fetch","NetworkError when attempting to fetch resource","The Internet connection appears to be offline","Load failed","Network request failed"]);if(!(X&&X instanceof TypeError))return!1;return Y.has(X.message)},Ur5=(X)=>X.$metadata?.httpStatusCode===429||Zr5.includes(X.name)||X.$retryable?.throttling==!0,eN0=(X,Y=0)=>m16(X)||d16(X)||X.name==="InvalidSignatureException"&&X.message?.includes("Signature expired")||Wr5.includes(X.name)||Kr5.includes(X?.code||"")||Hr5.includes(X?.code||"")||$r5.includes(X.$metadata?.httpStatusCode||0)||c16(X)||i16(X)||X.cause!==void 0&&Y<=10&&eN0(X.cause,Y+1),Br5=(X)=>{if(X.$metadata?.httpStatusCode!==void 0){let Y=X.$metadata.httpStatusCode;if(500<=Y&&Y<=599&&!eN0(X))return!0;return!1}return!1};function i16(X){return X.code==="ERR_HTTP2_STREAM_ERROR"&&X.message.includes("NGHTTP2_REFUSED_STREAM")}Nr5.isBrowserNetworkError=c16;Nr5.isClockSkewCorrectedError=d16;Nr5.isClockSkewError=Fr5;Nr5.isNodeJsHttp2TransientError=i16;Nr5.isRetryableByTrait=m16;Nr5.isServerError=Br5;Nr5.isThrottlingError=Ur5;Nr5.isTransientError=eN0});var Dw=k((kr5)=>{var Ar5=Xz0();kr5.RETRY_MODES=void 0;(function(X){X.STANDARD="standard",X.ADAPTIVE="adaptive"})(kr5.RETRY_MODES||(kr5.RETRY_MODES={}));var QT1=3,Tr5=kr5.RETRY_MODES.STANDARD;class JT1{static setTimeoutFn=setTimeout;beta;minCapacity;minFillRate;scaleConstant;smooth;enabled=!1;availableTokens=0;lastMaxRate=0;measuredTxRate=0;requestCount=0;fillRate;lastThrottleTime;lastTimestamp=0;lastTxRateBucket;maxCapacity;timeWindow=0;constructor(X){this.beta=X?.beta??0.7,this.minCapacity=X?.minCapacity??1,this.minFillRate=X?.minFillRate??0.5,this.scaleConstant=X?.scaleConstant??0.4,this.smooth=X?.smooth??0.8,this.lastThrottleTime=this.getCurrentTimeInSeconds(),this.lastTxRateBucket=Math.floor(this.getCurrentTimeInSeconds()),this.fillRate=this.minFillRate,this.maxCapacity=this.minCapacity}async getSendToken(){return this.acquireTokenBucket(1)}updateClientSendingRate(X){let Y;this.updateMeasuredRate();let G=X;if(G?.errorType==="THROTTLING"||Ar5.isThrottlingError(G?.error??X)){let W=!this.enabled?this.measuredTxRate:Math.min(this.measuredTxRate,this.fillRate);this.lastMaxRate=W,this.calculateTimeWindow(),this.lastThrottleTime=this.getCurrentTimeInSeconds(),Y=this.cubicThrottle(W),this.enableTokenBucket()}else this.calculateTimeWindow(),Y=this.cubicSuccess(this.getCurrentTimeInSeconds());let J=Math.min(Y,2*this.measuredTxRate);this.updateTokenBucketRate(J)}getCurrentTimeInSeconds(){return Date.now()/1000}async acquireTokenBucket(X){if(!this.enabled)return;if(this.refillTokenBucket(),X>this.availableTokens){let Y=(X-this.availableTokens)/this.fillRate*1000;await new Promise((G)=>JT1.setTimeoutFn(G,Y))}this.availableTokens=this.availableTokens-X}refillTokenBucket(){let X=this.getCurrentTimeInSeconds();if(!this.lastTimestamp){this.lastTimestamp=X;return}let Y=(X-this.lastTimestamp)*this.fillRate;this.availableTokens=Math.min(this.maxCapacity,this.availableTokens+Y),this.lastTimestamp=X}calculateTimeWindow(){this.timeWindow=this.getPrecise(Math.pow(this.lastMaxRate*(1-this.beta)/this.scaleConstant,0.3333333333333333))}cubicThrottle(X){return this.getPrecise(X*this.beta)}cubicSuccess(X){return this.getPrecise(this.scaleConstant*Math.pow(X-this.lastThrottleTime-this.timeWindow,3)+this.lastMaxRate)}enableTokenBucket(){this.enabled=!0}updateTokenBucketRate(X){this.refillTokenBucket(),this.fillRate=Math.max(X,this.minFillRate),this.maxCapacity=Math.max(X,this.minCapacity),this.availableTokens=Math.min(this.availableTokens,this.maxCapacity)}updateMeasuredRate(){let X=this.getCurrentTimeInSeconds(),Y=Math.floor(X*2)/2;if(this.requestCount++,Y>this.lastTxRateBucket){let G=this.requestCount/(Y-this.lastTxRateBucket);this.measuredTxRate=this.getPrecise(G*this.smooth+this.measuredTxRate*(1-this.smooth)),this.requestCount=0,this.lastTxRateBucket=Y}}getPrecise(X){return parseFloat(X.toFixed(8))}}var Ir5=100,Qz0=20000,Vr5=500,Yz0=500,jr5=5,Mr5=10,p16=1,Rr5="amz-sdk-invocation-id",Sr5="amz-sdk-request";class eQ{static v2026=typeof process<"u"&&process.env?.SMITHY_NEW_RETRIES_2026==="true";static delay(){return eQ.v2026?50:100}static throttlingDelay(){return eQ.v2026?1000:500}static cost(){return eQ.v2026?14:5}static throttlingCost(){return eQ.v2026?5:10}static modifiedCostType(){return eQ.v2026?"THROTTLING":"TRANSIENT"}}class n16{x=eQ.delay();computeNextBackoffDelay(X){let Y=Math.random(),G=2,Q=Y*Math.min(this.x*2**X,Qz0);return Math.floor(Q)}setDelayBase(X){this.x=X}}class Gz0{delay;count;cost;longPoll;constructor(X,Y,G,Q){this.delay=X,this.count=Y,this.cost=G,this.longPoll=Q}getRetryCount(){return this.count}getRetryDelay(){return Math.min(Qz0,this.delay)}getRetryCost(){return this.cost}isLongPoll(){return this.longPoll}}var GT1={incompatible:1,attempts:2,capacity:3};class hX1{mode=kr5.RETRY_MODES.STANDARD;capacity=Yz0;retryBackoffStrategy;maxAttemptsProvider;baseDelay;constructor(X){if(typeof X==="number")this.maxAttemptsProvider=async()=>X;else if(typeof X==="function")this.maxAttemptsProvider=X;else if(X&&typeof X==="object")this.maxAttemptsProvider=async()=>X.maxAttempts,this.baseDelay=X.baseDelay,this.retryBackoffStrategy=X.backoff;this.maxAttemptsProvider??=async()=>QT1,this.baseDelay??=eQ.delay(),this.retryBackoffStrategy??=new n16}async acquireInitialRetryToken(X){return new Gz0(eQ.delay(),0,void 0,eQ.v2026&&X.includes(":longpoll"))}async refreshRetryTokenForRetry(X,Y){let G=await this.getMaxAttempts(),Q=this.retryCode(X,Y,G),J=Q===0,W=X.isLongPoll?.();if(J||W){let Z=Y.errorType;this.retryBackoffStrategy.setDelayBase(Z==="THROTTLING"?eQ.throttlingDelay():this.baseDelay);let $=this.retryBackoffStrategy.computeNextBackoffDelay(X.getRetryCount()),K=$;if(Y.retryAfterHint instanceof Date)K=Math.max($,Math.min(Y.retryAfterHint.getTime()-Date.now(),$+5000));if(!J)throw Object.assign(Error("No retry token available"),{$backoff:eQ.v2026&&Q===GT1.capacity&&W?K:0});else{let H=this.getCapacityCost(Z);return this.capacity-=H,new Gz0(K,X.getRetryCount()+1,H,X.isLongPoll?.()??!1)}}throw Error("No retry token available")}recordSuccess(X){this.capacity=Math.min(Yz0,this.capacity+(X.getRetryCost()??p16))}getCapacity(){return this.capacity}async maxAttempts(){return this.maxAttemptsProvider()}async getMaxAttempts(){try{return await this.maxAttemptsProvider()}catch(X){return console.warn(`Max attempts provider could not resolve. Using default of ${QT1}`),QT1}}retryCode(X,Y,G){let Q=X.getRetryCount()+1,J=this.isRetryableError(Y.errorType)?0:GT1.incompatible,W=Q<G?0:GT1.attempts,Z=this.capacity>=this.getCapacityCost(Y.errorType)?0:GT1.capacity;return J||W||Z}getCapacityCost(X){return X===eQ.modifiedCostType()?eQ.throttlingCost():eQ.cost()}isRetryableError(X){return X==="THROTTLING"||X==="TRANSIENT"}}class t16{mode=kr5.RETRY_MODES.ADAPTIVE;rateLimiter;standardRetryStrategy;constructor(X,Y){let{rateLimiter:G}=Y??{};this.rateLimiter=G??new JT1,this.standardRetryStrategy=Y?new hX1({maxAttempts:typeof X==="number"?X:3,...Y}):new hX1(X)}async acquireInitialRetryToken(X){return await this.rateLimiter.getSendToken(),this.standardRetryStrategy.acquireInitialRetryToken(X)}async refreshRetryTokenForRetry(X,Y){return this.rateLimiter.updateClientSendingRate(Y),this.standardRetryStrategy.refreshRetryTokenForRetry(X,Y)}recordSuccess(X){this.rateLimiter.updateClientSendingRate({}),this.standardRetryStrategy.recordSuccess(X)}async maxAttemptsProvider(){return this.standardRetryStrategy.maxAttempts()}}class a16 extends hX1{computeNextBackoffDelay;constructor(X,Y=eQ.delay()){super(typeof X==="function"?X:async()=>X);if(typeof Y==="number")this.computeNextBackoffDelay=()=>Y;else this.computeNextBackoffDelay=Y}async refreshRetryTokenForRetry(X,Y){let G=await super.refreshRetryTokenForRetry(X,Y);return G.getRetryDelay=()=>this.computeNextBackoffDelay(G.getRetryCount()),G}}kr5.AdaptiveRetryStrategy=t16;kr5.ConfiguredRetryStrategy=a16;kr5.DEFAULT_MAX_ATTEMPTS=QT1;kr5.DEFAULT_RETRY_DELAY_BASE=Ir5;kr5.DEFAULT_RETRY_MODE=Tr5;kr5.DefaultRateLimiter=JT1;kr5.INITIAL_RETRY_TOKENS=Yz0;kr5.INVOCATION_ID_HEADER=Rr5;kr5.MAXIMUM_RETRY_DELAY=Qz0;kr5.NO_RETRY_INCREMENT=p16;kr5.REQUEST_HEADER=Sr5;kr5.RETRY_COST=jr5;kr5.Retry=eQ;kr5.StandardRetryStrategy=hX1;kr5.THROTTLING_RETRY_DELAY_BASE=Vr5;kr5.TIMEOUT_RETRY_COST=Mr5});var WX=k((Yo5)=>{var nr5=Dw(),Jz0={warningEmitted:!1},tr5=(X)=>{if(X&&!Jz0.warningEmitted&&parseInt(X.substring(1,X.indexOf(".")))<20)Jz0.warningEmitted=!0,process.emitWarning(`NodeDeprecationWarning: The AWS SDK for JavaScript (v3) will
|
|
1646
|
+
`);Q=W.pop()??"";for(let Z of W){let $=O16(Z).replace(/^\[\d+\]\s*/,"").trim();if(!$)continue;Wz({method:"",path:"",status:0,duration:0,timestamp:new Date,rawLine:$})}}(async()=>{for(;;){let{done:W,value:Z}=await Y.read();if(W)break;Q+=G.decode(Z,{stream:!0}),J()}if(Q.trim()){let W=O16(Q).replace(/^\[\d+\]\s*/,"").trim();if(W)Wz({method:"",path:"",status:0,duration:0,timestamp:new Date,rawLine:W})}})()}async function Ja5(X){let{vitePort:Y,baseUrl:G,noTui:Q}=X,J=await aA1(Number(X.port)),{settings:W,services:Z,managedServiceNames:$}=await iA1({port:String(J),home:X.home,baseUrl:X.baseUrl,localMode:X.localMode,skipMigrations:X.skipMigrations,noTui:X.noTui,vitePort:X.vitePort});for(let z of Z)Ya({name:z.name,status:"ready",port:z.port});fX1(W),vX1();let K=Qa5(import.meta.dir,"..","..","..","..",".."),H=Q===!0,U=Bun.spawn(["bun","run","--cwd=apps/mesh","dev:servers"],{cwd:K,env:{...process.env,PORT:String(W.port),VITE_PORT:String(Y),DATABASE_URL:W.databaseUrl,NATS_URL:W.natsUrls.join(","),NODE_ENV:W.nodeEnv,DECOCMS_LOCAL_MODE:String(W.localMode),DECOCMS_HOME:W.dataDir,DATA_DIR:W.dataDir,DECO_CLI:"1",...W.baseUrl?{BASE_URL:W.baseUrl}:{}},stdio:["inherit",H?"inherit":"pipe",H?"inherit":"pipe"]});if(!H)D16(U.stdout),D16(U.stderr);let B=G||`http://localhost:${W.port}`;_X1(B),Ya({name:"Vite",status:"ready",port:Number(Y)});let N=async(z)=>{if(U.kill(z),$.length>0){let{stopServices:O}=await Promise.resolve().then(() => (l$1(),u$1));await O(W.dataDir)}};return process.on("SIGINT",()=>N("SIGINT")),process.on("SIGTERM",()=>N("SIGTERM")),{port:Number(W.port),process:U}}var xN0=w(()=>{kN0();$z();bN0()});import{Box as hN0,Text as gN0}from"ink";import{jsx as L16,jsxs as rA1}from"react/jsx-runtime";function w16(X){if(!X)return"not set";try{let Y=new URL(X);if(Y.password)Y.password="***";if(Y.username&&Y.username.length>3)Y.username=Y.username.slice(0,3)+"***";return Y.pathname="/",Y.search="",Y.hash="",Y.toString()}catch{if(X.length<=10)return X;return X.slice(0,6)+"***"+X.slice(-4)}}function $a5(X,Y){if(Za5.has(X))return Y?{text:"\u25CF\u25CF\u25CF\u25CF\u25CF\u25CF",dimColor:!0}:{text:"not set",dimColor:!0};if(Wa5.has(X)){if(Array.isArray(Y)){if(Y.length===0)return{text:"not set",dimColor:!0};return{text:Y.map((W)=>w16(W)).join(", "),color:"cyan"}}let Q=w16(Y);return Q==="not set"?{text:Q,dimColor:!0}:{text:Q,color:"cyan"}}if(Y===void 0||Y===null||Y==="")return{text:"not set",dimColor:!0};let G=String(Y);if(G==="true")return{text:G,color:"green"};if(G==="false")return{text:G,color:"yellow"};try{return new URL(G),{text:G,color:"cyan"}}catch{return{text:G}}}function Ka5(X){return[{title:"Core",entries:[{key:"NODE_ENV",value:X.nodeEnv},{key:"PORT",value:X.port},{key:"BASE_URL",value:X.baseUrl??`http://localhost:${X.port}`},{key:"DATA_DIR",value:X.dataDir}]},{title:"Database",entries:[{key:"DATABASE_URL",value:X.databaseUrl},{key:"DATABASE_PG_SSL",value:X.databasePgSsl}]},{title:"Auth & Secrets",entries:[{key:"BETTER_AUTH_SECRET",value:X.betterAuthSecret},{key:"ENCRYPTION_KEY",value:X.encryptionKey},{key:"MESH_JWT_SECRET",value:X.meshJwtSecret},{key:"STUDIO_PROVISION_SECRET_KEY",value:X.studioProvisionSecretKey},{key:"DISABLE_RATE_LIMIT",value:X.disableRateLimit}]},{title:"Auth Providers",entries:[{key:"AUTH_EMAIL_PASSWORD_ENABLED",value:process.env.AUTH_EMAIL_PASSWORD_ENABLED??"true"},{key:"AUTH_GOOGLE_CLIENT_ID",value:!!process.env.AUTH_GOOGLE_CLIENT_ID},{key:"AUTH_GITHUB_CLIENT_ID",value:!!process.env.AUTH_GITHUB_CLIENT_ID},{key:"AUTH_RESEND_API_KEY",value:!!process.env.AUTH_RESEND_API_KEY},{key:"AUTH_SENDGRID_API_KEY",value:!!process.env.AUTH_SENDGRID_API_KEY},{key:"AUTH_SSO_MS_CLIENT_ID",value:!!process.env.AUTH_SSO_MS_CLIENT_ID},{key:"AUTH_SSO_GOOGLE_CLIENT_ID",value:!!process.env.AUTH_SSO_GOOGLE_CLIENT_ID},{key:"AUTH_MAGIC_LINK_ENABLED",value:process.env.AUTH_MAGIC_LINK_ENABLED==="true"},{key:"AUTH_EMAIL_OTP_ENABLED",value:process.env.AUTH_EMAIL_OTP_ENABLED==="true"}]},{title:"Observability",entries:[{key:"CLICKHOUSE_URL",value:X.clickhouseUrl},{key:"OTEL_SERVICE_NAME",value:X.otelServiceName}]},{title:"Event Bus & Networking",entries:[{key:"NATS_URL",value:X.natsUrls}]},{title:"Config Files",entries:[{key:"CONFIG_PATH",value:X.configPath}]},{title:"AI Gateway",entries:[{key:"DECO_AI_GATEWAY_ENABLED",value:X.aiGatewayEnabled},{key:"DECO_AI_GATEWAY_URL",value:X.aiGatewayUrl}]}]}function E16({env:X}){let Y=Ka5(X);return L16(hN0,{flexDirection:"column",children:Y.map((G)=>rA1(hN0,{flexDirection:"column",marginTop:1,children:[rA1(gN0,{dimColor:!0,children:[" ","\u2500\u2500 ",G.title," ","\u2500".repeat(Math.max(0,38-G.title.length))]}),G.entries.map(({key:Q,value:J})=>{let W=$a5(Q,J);return rA1(hN0,{children:[rA1(gN0,{dimColor:!0,children:[" ",Q.padEnd(36)]}),L16(gN0,{color:W.color,dimColor:W.dimColor,children:W.text})]},Q)})]},G.title))})}var Za5,Wa5;var P16=w(()=>{Za5=new Set(["BETTER_AUTH_SECRET","ENCRYPTION_KEY","MESH_JWT_SECRET","STUDIO_PROVISION_SECRET_KEY"]),Wa5=new Set(["DATABASE_URL","CLICKHOUSE_URL","NATS_URL"])});var uN0;var q16=w(()=>{uN0={name:"decocms",version:"2.311.10",description:"Deco CMS \u2014 Self-hostable MCP Gateway for managing AI connections and tools",author:"Deco team",repository:{type:"git",url:"git+https://github.com/decocms/studio.git",directory:"apps/mesh"},bugs:{url:"https://github.com/decocms/studio/issues"},type:"module",bin:{deco:"./dist/server/cli.js"},files:["dist/**/*"],scripts:{dev:'bun run migrate && concurrently "bun run dev:client" "bun run dev:server"',"dev:servers":'concurrently "bun run dev:client" "bun run dev:server"',"dev:client":"bun --bun vite dev","dev:server":"bun run --cwd=../../packages/sandbox build && NODE_ENV=development bun --env-file=.env --hot run src/index.ts","build:client":"bun --bun vite build","build:server":"bun run scripts/bundle-server-script.ts --dist ./dist/server","db:migrate":"bun run ./dist/server/migrate.js",check:"tsc --noEmit",start:"bun run ./dist/server/server.js",migrate:"bun run src/database/migrate.ts",test:"bun test","test:e2e":"playwright test","test:e2e:ui":"playwright test --ui","better-auth:migrate":"bunx --bun @better-auth/cli migrate -y --config src/auth/index.ts",prepublishOnly:"bun run build:client && bun run build:server"},optionalDependencies:{"@duckdb/node-api":"^1.5.0-r.1","@freestyle-sh/with-bun":"^0.2.12","@freestyle-sh/with-deno":"^0.0.4","@freestyle-sh/with-nodejs":"^0.2.9","freestyle-sandboxes":"^0.1.46"},dependencies:{"@ai-sdk/anthropic":"^3.0.58","@ai-sdk/google":"^3.0.60","@ai-sdk/openai":"^3.0.50","@anthropic-ai/sdk":"^0.79.0","@aws-sdk/client-s3":"^3.1013.0","@aws-sdk/s3-request-presigner":"^3.1013.0","@clickhouse/client":"^1.8.1","@deco-cx/warp-node":"^0.3.20","@dnd-kit/core":"^6.3.1","@dnd-kit/sortable":"^10.0.0","@dnd-kit/utilities":"^3.2.2","@inkjs/ui":"^2.0.0","@modelcontextprotocol/ext-apps":"^1.2.2","@openrouter/ai-sdk-provider":"^2.2.5","@opentelemetry/core":"^2.6.0","@tanstack/react-virtual":"^3.13.21","@xterm/addon-fit":"^0.11.0","@xterm/xterm":"^6.0.0","ai-sdk-provider-claude-code":"^3.4.4","ai-sdk-provider-codex-cli":"^1.1.0","embedded-postgres":"^18.3.0-beta.16",ink:"^6.8.0",kysely:"^0.28.12",nats:"^2.29.3","node-pty":"^1.0.0","posthog-js":"^1.371.1","posthog-node":"^5.0.0",react:"^19.2.0","react-dom":"^19.2.0"},devDependencies:{"@ai-sdk/provider":"^3.0.8","@ai-sdk/react":"^3.0.118","@anthropic-ai/claude-agent-sdk":"^0.2.80","@better-auth/sso":"1.4.1","@daveyplate/better-auth-ui":"^3.2.7","@deco/ui":"workspace:*","@decocms/better-auth":"1.5.17","@decocms/bindings":"workspace:*","@decocms/mcp-utils":"workspace:*","@decocms/mesh-sdk":"workspace:*","@decocms/runtime":"workspace:*","@decocms/vite-plugin":"workspace:*","@electric-sql/pglite":"^0.3.15","@floating-ui/react":"^0.27.16","@hookform/resolvers":"^5.2.2","@jitl/quickjs-wasmfile-release-sync":"0.31.0","@modelcontextprotocol/sdk":"1.27.1","@monaco-editor/react":"^4.7.0","@opentelemetry/api":"^1.9.0","@opentelemetry/api-logs":"^0.211.0","@opentelemetry/exporter-logs-otlp-proto":"^0.211.0","@opentelemetry/exporter-prometheus":"^0.208.0","@opentelemetry/exporter-trace-otlp-proto":"^0.207.0","@opentelemetry/instrumentation-runtime-node":"^0.24.0","@opentelemetry/sdk-logs":"^0.211.0","@opentelemetry/sdk-metrics":"^2.2.0","@opentelemetry/sdk-node":"^0.207.0","@opentelemetry/sdk-trace-base":"^2.5.0","@playwright/test":"^1.58.2","@radix-ui/react-avatar":"^1.1.10","@radix-ui/react-checkbox":"^1.3.3","@radix-ui/react-dialog":"^1.1.15","@radix-ui/react-dropdown-menu":"^2.1.16","@radix-ui/react-label":"^2.1.7","@radix-ui/react-select":"^2.2.6","@radix-ui/react-separator":"^1.1.7","@radix-ui/react-slot":"^1.2.3","@radix-ui/react-tabs":"^1.1.13","@rjsf/core":"^6.1.2","@rjsf/shadcn":"^6.1.2","@rjsf/utils":"^6.1.2","@rjsf/validator-ajv8":"^6.1.2","@tailwindcss/vite":"^4.1.17","@tanstack/react-query":"5.90.11","@tanstack/react-router":"^1.139.7","@tiptap/core":"3.20.2","@tiptap/extension-mention":"3.20.2","@tiptap/extension-placeholder":"3.20.2","@tiptap/pm":"3.20.2","@tiptap/react":"3.20.2","@tiptap/starter-kit":"3.20.2","@tiptap/suggestion":"3.20.2","@types/bun":"^1.3.1","@types/pg":"^8.15.6","@types/react-syntax-highlighter":"^15.5.13","@untitledui/icons":"^0.0.19","@vercel/nft":"^1.1.1","@vitejs/plugin-react":"^5.1.0",ai:"^6.0.116","babel-plugin-react-compiler":"^1.0.0","better-auth":"1.4.5","class-variance-authority":"^0.7.1",clsx:"^2.1.1",concurrently:"^9.2.1",croner:"^9.1.0","date-fns":"^4.1.0",degit:"^2.8.4",hono:"^4.10.7","input-otp":"^1.4.2",jose:"^6.0.11","kysely-pglite":"^0.6.1","lucide-react":"^0.468.0",marked:"^15.0.6","@decocms/sandbox":"workspace:*","mesh-plugin-workflows":"workspace:*",nanoid:"^5.1.6",pg:"^8.16.3",prettier:"^3.4.2","react-hook-form":"^7.66.0","react-markdown":"^10.1.0","react-resizable-panels":"^2.1.7","react-syntax-highlighter":"^15.6.1",recharts:"^3.6.0","rehype-raw":"^7.0.0","remark-gfm":"^4.0.0","sass-embedded":"^1.97.2",sonner:"^2.0.7","tailwind-merge":"^3.3.1",tailwindcss:"^4.1.17",typescript:"^5.9.3",vite:"^7.2.1","vite-tsconfig-paths":"^5.1.4",zod:"^4.0.0",zustand:"^5.0.9"},homepage:"https://github.com/decocms/studio",keywords:["mcp","model-context-protocol","ai","gateway","self-hosted","mesh","tools"],license:"MIT",publishConfig:{access:"public"}}});import{Box as IU,Text as RX}from"ink";import{Spinner as Fa5}from"@inkjs/ui";import{useSyncExternalStore as A16}from"react";import{jsx as TY,jsxs as sQ}from"react/jsx-runtime";function Oa5(X,Y){if(!X||!za5.has(X))return X;let G=lN0[Y]??lN0[lN0.length-1];return X==="#875f00"?G[0]:G[1]}function T16({status:X}){if(X==="pending")return TY(Fa5,{label:""});return TY(RX,{color:"green",children:"\u2713"})}function I16({services:X,migrationsStatus:Y,home:G,serverUrl:Q,vibe:J}){let W=A16(mm0,lm0),Z=A16(tm0,nm0);return sQ(IU,{flexDirection:"column",paddingBottom:1,children:[J?sQ(IU,{flexDirection:"column",children:[W.map(($,K)=>{let H=Z[K],U=$.reduce((N,z)=>N+z.text.length,0),B=Math.max(0,Na5-U);return sQ(IU,{flexDirection:"row",children:[$.map((N,z)=>{let O=Oa5(N.color,K);return O?TY(RX,{color:O,children:N.text},z):TY(RX,{children:N.text},z)}),TY(RX,{children:" ".repeat(B+2)}),H?.map((N,z)=>N.color?TY(RX,{color:N.color,children:N.char},z):TY(RX,{children:N.char},z))]},K)}),sQ(RX,{dimColor:!0,children:[" v",uN0.version]})]}):sQ(IU,{flexDirection:"column",marginTop:1,children:[Ua5.map(($,K)=>TY(RX,{color:Ba5[K],children:$},K)),sQ(RX,{dimColor:!0,children:[" v",uN0.version]})]}),TY(IU,{marginBottom:1,children:TY(RX,{dimColor:!0,children:"\u2500".repeat(80)})}),TY(IU,{children:sQ(RX,{dimColor:!0,children:["Home: ",G]})}),sQ(IU,{gap:2,children:[X.map(($)=>sQ(IU,{gap:1,children:[sQ(RX,{children:[$.name," :",$.port||"...."]}),TY(T16,{status:$.status})]},$.name)),sQ(IU,{gap:1,children:[TY(RX,{children:"Migrations"}),TY(T16,{status:Y})]})]}),TY(IU,{children:Q?sQ(RX,{children:["Open in browser: ",TY(RX,{color:"cyan",children:Q})]}):TY(RX,{dimColor:!0,children:"Starting..."})}),sQ(IU,{gap:2,children:[sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"K"})," ","toggle config"]}),sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"L"})," ","toggle log flow"]}),sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"V"})," ","toggle vibe ",J?"\u266A Nihilore \xB7 CC BY 4.0":""]}),J&&sQ(RX,{dimColor:!0,children:[TY(RX,{bold:!0,dimColor:!0,children:"N"})," ","skip song"]})]})]})}var Ua5,Ba5,lN0,Na5=30,za5;var V16=w(()=>{q16();Vt1();Ct1();Ua5=[" \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588 ","\u2591\u2591\u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588 \u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588\u2591\u2591\u2591\u2591\u2591\u2588\u2588\u2588 "," \u2591\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2588 \u2591 \u2588\u2588\u2588 \u2591\u2591\u2591 \u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588\u2591\u2591\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591\u2588\u2588\u2588"," \u2591\u2588\u2588\u2588 \u2588\u2588\u2588 \u2591\u2588\u2588\u2588 \u2591 \u2588\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588\u2591\u2591\u2588\u2588\u2588 \u2588\u2588\u2588 "," \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2591\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2588 \u2591\u2591\u2591\u2588\u2588\u2588\u2588\u2588\u2588\u2588\u2591 ","\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591\u2591 \u2591\u2591\u2591\u2591\u2591\u2591\u2591 "],Ba5=["#00ff64","#00ee5e","#00dc56","#00c84e","#00b444","#00a03c","#008832","#006e28"],lN0=[["#00ff64","#00cc50"],["#00f060","#00c04c"],["#00e05c","#00b448"],["#00d058","#00a844"],["#00c054","#009c40"],["#00b050","#00903c"],["#00a04c","#008438"],["#009048","#007834"],["#008044","#006c30"],["#007040","#00602c"],["#00603c","#005428"]],za5=new Set(["#875f00","#5f3800"])});import{useSyncExternalStore as Da5}from"react";function wa5(){let X=process.stdout.rows||24,Y=process.stdout.columns||80;if(X!==oA1.rows||Y!==oA1.columns)oA1={rows:X,columns:Y};return oA1}function La5(X){return process.stdout.on("resize",X),()=>{process.stdout.off("resize",X)}}function j16(){return Da5(La5,wa5)}var oA1;var M16=w(()=>{oA1={rows:process.stdout.rows||24,columns:process.stdout.columns||80}});import{Box as Ea5,Text as bX1}from"ink";import{useSyncExternalStore as Pa5}from"react";import{jsx as mN0,jsxs as dN0}from"react/jsx-runtime";function qa5(X){if(X>=500)return"red";if(X>=400)return"yellow";if(X>=300)return"cyan";return"green"}function R16({logs:X,headerHeight:Y}){let{rows:G}=j16(),{logFlow:Q}=Pa5(CX1,kX1),J=Math.max(1,G-Y-1),W=Q?X:X.slice(-J);return mN0(Ea5,{flexDirection:"column",children:W.map((Z,$)=>{if(Z.rawLine)return mN0(bX1,{dimColor:!0,children:Z.rawLine},$);let K=Z.duration<1000?`${Z.duration}ms`:`${(Z.duration/1000).toFixed(1)}s`;return dN0(bX1,{children:[dN0(bX1,{dimColor:!0,children:[Z.method.padEnd(6)," ",Z.path.padEnd(30)," "]}),mN0(bX1,{color:qa5(Z.status),children:Z.status}),dN0(bX1,{dimColor:!0,children:[" ",K.padStart(8)]})]},$)})})}var S16=w(()=>{$z();M16()});var cN0={};T0(cN0,{App:()=>Ra5});import{Box as Aa5,Text as Ta5,useInput as Ia5}from"ink";import{useSyncExternalStore as Va5}from"react";import{jsx as sA1,jsxs as Sa5}from"react/jsx-runtime";function Ra5({home:X}){let Y=Va5(CX1,kX1);return Ia5((G)=>{if(G==="k"||G==="K")vN0();if(G==="l"||G==="L")_N0();if((G==="v"||G==="V")&&Y.dataDir)bt1(Y.dataDir),fN0();if((G==="n"||G==="N")&&Y.vibe)ft1()}),Sa5(Aa5,{flexDirection:"column",children:[sA1(I16,{services:Y.services,migrationsStatus:Y.migrationsStatus,home:X,serverUrl:Y.serverUrl,vibe:Y.vibe}),Y.viewMode==="config"?Y.env?sA1(E16,{env:Y.env}):sA1(Ta5,{dimColor:!0,children:"Loading configuration..."}):sA1(R16,{logs:Y.logs,headerHeight:Y.vibe?Ma5:ja5})]})}var ja5=15,Ma5=19;var iN0=w(()=>{P16();V16();S16();$z();fd()});function k16(X,Y={}){return{PORT:String(X.port),NODE_ENV:X.nodeEnv,BASE_URL:X.baseUrl,DATA_DIR:X.dataDir,DECOCMS_HOME:X.dataDir,DATABASE_URL:X.databaseUrl,DATABASE_PG_SSL:String(X.databasePgSsl),DATABASE_POOL_MAX:String(X.databasePoolMax),NATS_URL:X.natsUrls.join(","),BETTER_AUTH_SECRET:X.betterAuthSecret,ENCRYPTION_KEY:X.encryptionKey,MESH_JWT_SECRET:X.meshJwtSecret,DECOCMS_LOCAL_MODE:String(X.localMode),DISABLE_RATE_LIMIT:String(X.disableRateLimit),STUDIO_PROVISION_SECRET_KEY:X.studioProvisionSecretKey,CONFIG_PATH:X.configPath,...Object.fromEntries(Object.entries(process.env).filter(([G])=>G.startsWith("AUTH_"))),DECO_AI_GATEWAY_ENABLED:String(X.aiGatewayEnabled),DECO_AI_GATEWAY_URL:X.aiGatewayUrl,ENABLE_DECO_IMPORT:String(X.enableDecoImport),S3_ENDPOINT:X.s3Endpoint,S3_BUCKET:X.s3Bucket,S3_REGION:X.s3Region,S3_ACCESS_KEY_ID:X.s3AccessKeyId,S3_SECRET_ACCESS_KEY:X.s3SecretAccessKey,S3_FORCE_PATH_STYLE:String(X.s3ForcePathStyle),OTEL_SERVICE_NAME:X.otelServiceName,CLICKHOUSE_URL:X.clickhouseUrl,OTEL_EXPORTER_OTLP_ENDPOINT:process.env.OTEL_EXPORTER_OTLP_ENDPOINT,OTEL_EXPORTER_OTLP_PROTOCOL:process.env.OTEL_EXPORTER_OTLP_PROTOCOL,OTEL_RESOURCE_ATTRIBUTES:process.env.OTEL_RESOURCE_ATTRIBUTES,DECO_SUPABASE_URL:X.decoSupabaseUrl,DECO_SUPABASE_SERVICE_KEY:X.decoSupabaseServiceKey,FIRECRAWL_API_KEY:X.firecrawlApiKey,STUDIO_SANDBOX_RUNNER:process.env.STUDIO_SANDBOX_RUNNER,STUDIO_SANDBOX_TEMPLATE_NAME:process.env.STUDIO_SANDBOX_TEMPLATE_NAME,STUDIO_ENV:process.env.STUDIO_ENV,STUDIO_SANDBOX_PREVIEW_URL_PATTERN:process.env.STUDIO_SANDBOX_PREVIEW_URL_PATTERN,STUDIO_SANDBOX_PREVIEW_GATEWAY_NAME:process.env.STUDIO_SANDBOX_PREVIEW_GATEWAY_NAME,STUDIO_SANDBOX_PREVIEW_GATEWAY_NAMESPACE:process.env.STUDIO_SANDBOX_PREVIEW_GATEWAY_NAMESPACE,STUDIO_SANDBOX_SENTINEL_TOKEN:process.env.STUDIO_SANDBOX_SENTINEL_TOKEN,KUBERNETES_SERVICE_HOST:process.env.KUBERNETES_SERVICE_HOST,KUBERNETES_SERVICE_PORT:process.env.KUBERNETES_SERVICE_PORT,FREESTYLE_API_KEY:process.env.FREESTYLE_API_KEY,BROWSERLESS_TOKEN:process.env.BROWSERLESS_TOKEN,NODE_EXTRA_CA_CERTS:process.env.NODE_EXTRA_CA_CERTS,DECO_CLI:"1",DECO_NO_TUI:"true",...Y}}var yj=k((ba5)=>{ba5.HttpAuthLocation=void 0;(function(X){X.HEADER="header",X.QUERY="query"})(ba5.HttpAuthLocation||(ba5.HttpAuthLocation={}));ba5.HttpApiKeyAuthLocation=void 0;(function(X){X.HEADER="header",X.QUERY="query"})(ba5.HttpApiKeyAuthLocation||(ba5.HttpApiKeyAuthLocation={}));ba5.EndpointURLScheme=void 0;(function(X){X.HTTP="http",X.HTTPS="https"})(ba5.EndpointURLScheme||(ba5.EndpointURLScheme={}));ba5.AlgorithmId=void 0;(function(X){X.MD5="md5",X.CRC32="crc32",X.CRC32C="crc32c",X.SHA1="sha1",X.SHA256="sha256"})(ba5.AlgorithmId||(ba5.AlgorithmId={}));var ka5=(X)=>{let Y=[];if(X.sha256!==void 0)Y.push({algorithmId:()=>ba5.AlgorithmId.SHA256,checksumConstructor:()=>X.sha256});if(X.md5!=null)Y.push({algorithmId:()=>ba5.AlgorithmId.MD5,checksumConstructor:()=>X.md5});return{addChecksumAlgorithm(G){Y.push(G)},checksumAlgorithms(){return Y}}},Ca5=(X)=>{let Y={};return X.checksumAlgorithms().forEach((G)=>{Y[G.algorithmId()]=G.checksumConstructor()}),Y},va5=(X)=>{return ka5(X)},_a5=(X)=>{return Ca5(X)};ba5.FieldPosition=void 0;(function(X){X[X.HEADER=0]="HEADER",X[X.TRAILER=1]="TRAILER"})(ba5.FieldPosition||(ba5.FieldPosition={}));var fa5="__smithy_context";ba5.IniSectionType=void 0;(function(X){X.PROFILE="profile",X.SSO_SESSION="sso-session",X.SERVICES="services"})(ba5.IniSectionType||(ba5.IniSectionType={}));ba5.RequestHandlerProtocol=void 0;(function(X){X.HTTP_0_9="http/0.9",X.HTTP_1_0="http/1.0",X.TDS_8_0="tds/8.0"})(ba5.RequestHandlerProtocol||(ba5.RequestHandlerProtocol={}));ba5.SMITHY_CONTEXT_KEY=fa5;ba5.getDefaultClientConfiguration=va5;ba5.resolveDefaultRuntimeConfig=_a5});var u7=k((ca5)=>{var ga5=yj(),ua5=(X)=>{return{setHttpHandler(Y){X.httpHandler=Y},httpHandler(){return X.httpHandler},updateHttpClientConfig(Y,G){X.httpHandler?.updateHttpClientConfig(Y,G)},httpHandlerConfigs(){return X.httpHandler.httpHandlerConfigs()}}},la5=(X)=>{return{httpHandler:X.httpHandler()}};class C16{name;kind;values;constructor({name:X,kind:Y=ga5.FieldPosition.HEADER,values:G=[]}){this.name=X,this.kind=Y,this.values=G}add(X){this.values.push(X)}set(X){this.values=X}remove(X){this.values=this.values.filter((Y)=>Y!==X)}toString(){return this.values.map((X)=>X.includes(",")||X.includes(" ")?`"${X}"`:X).join(", ")}get(){return this.values}}class v16{entries={};encoding;constructor({fields:X=[],encoding:Y="utf-8"}){X.forEach(this.setField.bind(this)),this.encoding=Y}setField(X){this.entries[X.name.toLowerCase()]=X}getField(X){return this.entries[X.toLowerCase()]}removeField(X){delete this.entries[X.toLowerCase()]}getByType(X){return Object.values(this.entries).filter((Y)=>Y.kind===X)}}class eA1{method;protocol;hostname;port;path;query;headers;username;password;fragment;body;constructor(X){this.method=X.method||"GET",this.hostname=X.hostname||"localhost",this.port=X.port,this.query=X.query||{},this.headers=X.headers||{},this.body=X.body,this.protocol=X.protocol?X.protocol.slice(-1)!==":"?`${X.protocol}:`:X.protocol:"https:",this.path=X.path?X.path.charAt(0)!=="/"?`/${X.path}`:X.path:"/",this.username=X.username,this.password=X.password,this.fragment=X.fragment}static clone(X){let Y=new eA1({...X,headers:{...X.headers}});if(Y.query)Y.query=ma5(Y.query);return Y}static isInstance(X){if(!X)return!1;let Y=X;return"method"in Y&&"protocol"in Y&&"hostname"in Y&&"path"in Y&&typeof Y.query==="object"&&typeof Y.headers==="object"}clone(){return eA1.clone(this)}}function ma5(X){return Object.keys(X).reduce((Y,G)=>{let Q=X[G];return{...Y,[G]:Array.isArray(Q)?[...Q]:Q}},{})}class _16{statusCode;reason;headers;body;constructor(X){this.statusCode=X.statusCode,this.reason=X.reason,this.headers=X.headers||{},this.body=X.body}static isInstance(X){if(!X)return!1;let Y=X;return typeof Y.statusCode==="number"&&typeof Y.headers==="object"}}function da5(X){return/^[a-z0-9][a-z0-9\.\-]*[a-z0-9]$/.test(X)}ca5.Field=C16;ca5.Fields=v16;ca5.HttpRequest=eA1;ca5.HttpResponse=_16;ca5.getHttpHandlerExtensionConfiguration=ua5;ca5.isValidHostname=da5;ca5.resolveHttpHandlerRuntimeConfig=la5});function sa5(X){return(Y)=>async(G)=>{let{request:Q}=G;if(X.expectContinueHeader!==!1&&f16.HttpRequest.isInstance(Q)&&Q.body&&X.runtime==="node"&&X.requestHandler?.constructor?.name!=="FetchHttpHandler"){let J=!0;if(typeof X.expectContinueHeader==="number")try{J=(Number(Q.headers?.["content-length"])??X.bodyLengthChecker?.(Q.body)??1/0)>=X.expectContinueHeader}catch(W){}else J=!!X.expectContinueHeader;if(J)Q.headers.Expect="100-continue"}return Y({...G,request:Q})}}var f16,ea5,b16=(X)=>({applyToStack:(Y)=>{Y.add(sa5(X),ea5)}});var y16=w(()=>{f16=X1(u7(),1);ea5={step:"build",tags:["SET_EXPECT_HEADER","EXPECT_HEADER"],name:"addExpectContinueMiddleware",override:!0}});var wH,XT1,xj,YT1,E9,x16,xX1;var LH=w(()=>{wH={WHEN_SUPPORTED:"WHEN_SUPPORTED",WHEN_REQUIRED:"WHEN_REQUIRED"},XT1=wH.WHEN_SUPPORTED,xj={WHEN_SUPPORTED:"WHEN_SUPPORTED",WHEN_REQUIRED:"WHEN_REQUIRED"},YT1=wH.WHEN_SUPPORTED;(function(X){X.MD5="MD5",X.CRC32="CRC32",X.CRC32C="CRC32C",X.CRC64NVME="CRC64NVME",X.SHA1="SHA1",X.SHA256="SHA256"})(E9||(E9={}));(function(X){X.HEADER="header",X.TRAILER="trailer"})(x16||(x16={}));xX1=E9.CRC32});var kq,Ga=(X,Y,G,Q)=>{if(!(Y in X))return;let J=X[Y].toUpperCase();if(!Object.values(G).includes(J))throw TypeError(`Cannot load ${Q} '${Y}'. Expected one of ${Object.values(G)}, got '${X[Y]}'.`);return J};var sN0=w(()=>{(function(X){X.ENV="env",X.CONFIG="shared config entry"})(kq||(kq={}))});var Xr5="AWS_REQUEST_CHECKSUM_CALCULATION",Yr5="request_checksum_calculation",h16;var g16=w(()=>{LH();sN0();h16={environmentVariableSelector:(X)=>Ga(X,Xr5,wH,kq.ENV),configFileSelector:(X)=>Ga(X,Yr5,wH,kq.CONFIG),default:XT1}});var Gr5="AWS_RESPONSE_CHECKSUM_VALIDATION",Qr5="response_checksum_validation",u16;var l16=w(()=>{LH();sN0();u16={environmentVariableSelector:(X)=>Ga(X,Gr5,xj,kq.ENV),configFileSelector:(X)=>Ga(X,Qr5,xj,kq.CONFIG),default:YT1}});var Xz0=k((Nr5)=>{var Jr5=["AuthFailure","InvalidSignatureException","RequestExpired","RequestInTheFuture","RequestTimeTooSkewed","SignatureDoesNotMatch"],Zr5=["BandwidthLimitExceeded","EC2ThrottledException","LimitExceededException","PriorRequestNotComplete","ProvisionedThroughputExceededException","RequestLimitExceeded","RequestThrottled","RequestThrottledException","SlowDown","ThrottledException","Throttling","ThrottlingException","TooManyRequestsException","TransactionInProgressException"],Wr5=["TimeoutError","RequestTimeout","RequestTimeoutException"],$r5=[500,502,503,504],Kr5=["ECONNRESET","ECONNREFUSED","EPIPE","ETIMEDOUT"],Hr5=["EHOSTUNREACH","ENETUNREACH","ENOTFOUND"],m16=(X)=>X?.$retryable!==void 0,Fr5=(X)=>Jr5.includes(X.name),d16=(X)=>X.$metadata?.clockSkewCorrected,c16=(X)=>{let Y=new Set(["Failed to fetch","NetworkError when attempting to fetch resource","The Internet connection appears to be offline","Load failed","Network request failed"]);if(!(X&&X instanceof TypeError))return!1;return Y.has(X.message)},Ur5=(X)=>X.$metadata?.httpStatusCode===429||Zr5.includes(X.name)||X.$retryable?.throttling==!0,eN0=(X,Y=0)=>m16(X)||d16(X)||X.name==="InvalidSignatureException"&&X.message?.includes("Signature expired")||Wr5.includes(X.name)||Kr5.includes(X?.code||"")||Hr5.includes(X?.code||"")||$r5.includes(X.$metadata?.httpStatusCode||0)||c16(X)||i16(X)||X.cause!==void 0&&Y<=10&&eN0(X.cause,Y+1),Br5=(X)=>{if(X.$metadata?.httpStatusCode!==void 0){let Y=X.$metadata.httpStatusCode;if(500<=Y&&Y<=599&&!eN0(X))return!0;return!1}return!1};function i16(X){return X.code==="ERR_HTTP2_STREAM_ERROR"&&X.message.includes("NGHTTP2_REFUSED_STREAM")}Nr5.isBrowserNetworkError=c16;Nr5.isClockSkewCorrectedError=d16;Nr5.isClockSkewError=Fr5;Nr5.isNodeJsHttp2TransientError=i16;Nr5.isRetryableByTrait=m16;Nr5.isServerError=Br5;Nr5.isThrottlingError=Ur5;Nr5.isTransientError=eN0});var Dw=k((kr5)=>{var Ar5=Xz0();kr5.RETRY_MODES=void 0;(function(X){X.STANDARD="standard",X.ADAPTIVE="adaptive"})(kr5.RETRY_MODES||(kr5.RETRY_MODES={}));var QT1=3,Tr5=kr5.RETRY_MODES.STANDARD;class JT1{static setTimeoutFn=setTimeout;beta;minCapacity;minFillRate;scaleConstant;smooth;enabled=!1;availableTokens=0;lastMaxRate=0;measuredTxRate=0;requestCount=0;fillRate;lastThrottleTime;lastTimestamp=0;lastTxRateBucket;maxCapacity;timeWindow=0;constructor(X){this.beta=X?.beta??0.7,this.minCapacity=X?.minCapacity??1,this.minFillRate=X?.minFillRate??0.5,this.scaleConstant=X?.scaleConstant??0.4,this.smooth=X?.smooth??0.8,this.lastThrottleTime=this.getCurrentTimeInSeconds(),this.lastTxRateBucket=Math.floor(this.getCurrentTimeInSeconds()),this.fillRate=this.minFillRate,this.maxCapacity=this.minCapacity}async getSendToken(){return this.acquireTokenBucket(1)}updateClientSendingRate(X){let Y;this.updateMeasuredRate();let G=X;if(G?.errorType==="THROTTLING"||Ar5.isThrottlingError(G?.error??X)){let W=!this.enabled?this.measuredTxRate:Math.min(this.measuredTxRate,this.fillRate);this.lastMaxRate=W,this.calculateTimeWindow(),this.lastThrottleTime=this.getCurrentTimeInSeconds(),Y=this.cubicThrottle(W),this.enableTokenBucket()}else this.calculateTimeWindow(),Y=this.cubicSuccess(this.getCurrentTimeInSeconds());let J=Math.min(Y,2*this.measuredTxRate);this.updateTokenBucketRate(J)}getCurrentTimeInSeconds(){return Date.now()/1000}async acquireTokenBucket(X){if(!this.enabled)return;if(this.refillTokenBucket(),X>this.availableTokens){let Y=(X-this.availableTokens)/this.fillRate*1000;await new Promise((G)=>JT1.setTimeoutFn(G,Y))}this.availableTokens=this.availableTokens-X}refillTokenBucket(){let X=this.getCurrentTimeInSeconds();if(!this.lastTimestamp){this.lastTimestamp=X;return}let Y=(X-this.lastTimestamp)*this.fillRate;this.availableTokens=Math.min(this.maxCapacity,this.availableTokens+Y),this.lastTimestamp=X}calculateTimeWindow(){this.timeWindow=this.getPrecise(Math.pow(this.lastMaxRate*(1-this.beta)/this.scaleConstant,0.3333333333333333))}cubicThrottle(X){return this.getPrecise(X*this.beta)}cubicSuccess(X){return this.getPrecise(this.scaleConstant*Math.pow(X-this.lastThrottleTime-this.timeWindow,3)+this.lastMaxRate)}enableTokenBucket(){this.enabled=!0}updateTokenBucketRate(X){this.refillTokenBucket(),this.fillRate=Math.max(X,this.minFillRate),this.maxCapacity=Math.max(X,this.minCapacity),this.availableTokens=Math.min(this.availableTokens,this.maxCapacity)}updateMeasuredRate(){let X=this.getCurrentTimeInSeconds(),Y=Math.floor(X*2)/2;if(this.requestCount++,Y>this.lastTxRateBucket){let G=this.requestCount/(Y-this.lastTxRateBucket);this.measuredTxRate=this.getPrecise(G*this.smooth+this.measuredTxRate*(1-this.smooth)),this.requestCount=0,this.lastTxRateBucket=Y}}getPrecise(X){return parseFloat(X.toFixed(8))}}var Ir5=100,Qz0=20000,Vr5=500,Yz0=500,jr5=5,Mr5=10,p16=1,Rr5="amz-sdk-invocation-id",Sr5="amz-sdk-request";class eQ{static v2026=typeof process<"u"&&process.env?.SMITHY_NEW_RETRIES_2026==="true";static delay(){return eQ.v2026?50:100}static throttlingDelay(){return eQ.v2026?1000:500}static cost(){return eQ.v2026?14:5}static throttlingCost(){return eQ.v2026?5:10}static modifiedCostType(){return eQ.v2026?"THROTTLING":"TRANSIENT"}}class n16{x=eQ.delay();computeNextBackoffDelay(X){let Y=Math.random(),G=2,Q=Y*Math.min(this.x*2**X,Qz0);return Math.floor(Q)}setDelayBase(X){this.x=X}}class Gz0{delay;count;cost;longPoll;constructor(X,Y,G,Q){this.delay=X,this.count=Y,this.cost=G,this.longPoll=Q}getRetryCount(){return this.count}getRetryDelay(){return Math.min(Qz0,this.delay)}getRetryCost(){return this.cost}isLongPoll(){return this.longPoll}}var GT1={incompatible:1,attempts:2,capacity:3};class hX1{mode=kr5.RETRY_MODES.STANDARD;capacity=Yz0;retryBackoffStrategy;maxAttemptsProvider;baseDelay;constructor(X){if(typeof X==="number")this.maxAttemptsProvider=async()=>X;else if(typeof X==="function")this.maxAttemptsProvider=X;else if(X&&typeof X==="object")this.maxAttemptsProvider=async()=>X.maxAttempts,this.baseDelay=X.baseDelay,this.retryBackoffStrategy=X.backoff;this.maxAttemptsProvider??=async()=>QT1,this.baseDelay??=eQ.delay(),this.retryBackoffStrategy??=new n16}async acquireInitialRetryToken(X){return new Gz0(eQ.delay(),0,void 0,eQ.v2026&&X.includes(":longpoll"))}async refreshRetryTokenForRetry(X,Y){let G=await this.getMaxAttempts(),Q=this.retryCode(X,Y,G),J=Q===0,W=X.isLongPoll?.();if(J||W){let Z=Y.errorType;this.retryBackoffStrategy.setDelayBase(Z==="THROTTLING"?eQ.throttlingDelay():this.baseDelay);let $=this.retryBackoffStrategy.computeNextBackoffDelay(X.getRetryCount()),K=$;if(Y.retryAfterHint instanceof Date)K=Math.max($,Math.min(Y.retryAfterHint.getTime()-Date.now(),$+5000));if(!J)throw Object.assign(Error("No retry token available"),{$backoff:eQ.v2026&&Q===GT1.capacity&&W?K:0});else{let H=this.getCapacityCost(Z);return this.capacity-=H,new Gz0(K,X.getRetryCount()+1,H,X.isLongPoll?.()??!1)}}throw Error("No retry token available")}recordSuccess(X){this.capacity=Math.min(Yz0,this.capacity+(X.getRetryCost()??p16))}getCapacity(){return this.capacity}async maxAttempts(){return this.maxAttemptsProvider()}async getMaxAttempts(){try{return await this.maxAttemptsProvider()}catch(X){return console.warn(`Max attempts provider could not resolve. Using default of ${QT1}`),QT1}}retryCode(X,Y,G){let Q=X.getRetryCount()+1,J=this.isRetryableError(Y.errorType)?0:GT1.incompatible,W=Q<G?0:GT1.attempts,Z=this.capacity>=this.getCapacityCost(Y.errorType)?0:GT1.capacity;return J||W||Z}getCapacityCost(X){return X===eQ.modifiedCostType()?eQ.throttlingCost():eQ.cost()}isRetryableError(X){return X==="THROTTLING"||X==="TRANSIENT"}}class t16{mode=kr5.RETRY_MODES.ADAPTIVE;rateLimiter;standardRetryStrategy;constructor(X,Y){let{rateLimiter:G}=Y??{};this.rateLimiter=G??new JT1,this.standardRetryStrategy=Y?new hX1({maxAttempts:typeof X==="number"?X:3,...Y}):new hX1(X)}async acquireInitialRetryToken(X){return await this.rateLimiter.getSendToken(),this.standardRetryStrategy.acquireInitialRetryToken(X)}async refreshRetryTokenForRetry(X,Y){return this.rateLimiter.updateClientSendingRate(Y),this.standardRetryStrategy.refreshRetryTokenForRetry(X,Y)}recordSuccess(X){this.rateLimiter.updateClientSendingRate({}),this.standardRetryStrategy.recordSuccess(X)}async maxAttemptsProvider(){return this.standardRetryStrategy.maxAttempts()}}class a16 extends hX1{computeNextBackoffDelay;constructor(X,Y=eQ.delay()){super(typeof X==="function"?X:async()=>X);if(typeof Y==="number")this.computeNextBackoffDelay=()=>Y;else this.computeNextBackoffDelay=Y}async refreshRetryTokenForRetry(X,Y){let G=await super.refreshRetryTokenForRetry(X,Y);return G.getRetryDelay=()=>this.computeNextBackoffDelay(G.getRetryCount()),G}}kr5.AdaptiveRetryStrategy=t16;kr5.ConfiguredRetryStrategy=a16;kr5.DEFAULT_MAX_ATTEMPTS=QT1;kr5.DEFAULT_RETRY_DELAY_BASE=Ir5;kr5.DEFAULT_RETRY_MODE=Tr5;kr5.DefaultRateLimiter=JT1;kr5.INITIAL_RETRY_TOKENS=Yz0;kr5.INVOCATION_ID_HEADER=Rr5;kr5.MAXIMUM_RETRY_DELAY=Qz0;kr5.NO_RETRY_INCREMENT=p16;kr5.REQUEST_HEADER=Sr5;kr5.RETRY_COST=jr5;kr5.Retry=eQ;kr5.StandardRetryStrategy=hX1;kr5.THROTTLING_RETRY_DELAY_BASE=Vr5;kr5.TIMEOUT_RETRY_COST=Mr5});var WX=k((Yo5)=>{var nr5=Dw(),Jz0={warningEmitted:!1},tr5=(X)=>{if(X&&!Jz0.warningEmitted&&parseInt(X.substring(1,X.indexOf(".")))<20)Jz0.warningEmitted=!0,process.emitWarning(`NodeDeprecationWarning: The AWS SDK for JavaScript (v3) will
|
|
1647
1647
|
no longer support Node.js ${X} in January 2026.
|
|
1648
1648
|
|
|
1649
1649
|
To continue receiving updates to AWS services, bug fixes, and security
|
|
@@ -6930,111 +6930,106 @@ if (!store.read()) {
|
|
|
6930
6930
|
console.log(\`[daemon] boot_id=\${process.env.DAEMON_BOOT_ID} ready, unclaimed \\u2014 waiting for workload config\`);
|
|
6931
6931
|
}
|
|
6932
6932
|
var firstWorkLogged = false;
|
|
6933
|
+
async function configH(req) {
|
|
6934
|
+
const { method } = req;
|
|
6935
|
+
if (method === "GET")
|
|
6936
|
+
return configReadH();
|
|
6937
|
+
if (method === "PUT" || method === "POST") {
|
|
6938
|
+
const res = await configUpdateH(req);
|
|
6939
|
+
if (res.status === 200)
|
|
6940
|
+
markClaimed();
|
|
6941
|
+
return res;
|
|
6942
|
+
}
|
|
6943
|
+
return jsonResponse({ error: "Not found: /_decopilot_vm/config" }, 404);
|
|
6944
|
+
}
|
|
6945
|
+
function tasksRouteH(req, method, vmPath) {
|
|
6946
|
+
if (method === "GET" && vmPath === "/tasks")
|
|
6947
|
+
return tasksListH(req);
|
|
6948
|
+
if (method === "POST" && vmPath === "/tasks/kill-all")
|
|
6949
|
+
return tasksKillAllH();
|
|
6950
|
+
if (method === "GET" && /^\\/tasks\\/[^/]+\\/stream$/.test(vmPath))
|
|
6951
|
+
return tasksStreamH(req);
|
|
6952
|
+
if (method === "POST" && /^\\/tasks\\/[^/]+\\/kill$/.test(vmPath))
|
|
6953
|
+
return tasksKillH(req);
|
|
6954
|
+
if (method === "DELETE" && /^\\/tasks\\/[^/]+$/.test(vmPath))
|
|
6955
|
+
return tasksDeleteH(req);
|
|
6956
|
+
if (method === "GET" && /^\\/tasks\\/[^/]+$/.test(vmPath))
|
|
6957
|
+
return tasksGetH(req);
|
|
6958
|
+
return jsonResponse({ error: \`Not found: /_decopilot_vm\${vmPath}\` }, 404);
|
|
6959
|
+
}
|
|
6960
|
+
function execRouteH(req, vmPath) {
|
|
6961
|
+
if (vmPath.endsWith("/kill")) {
|
|
6962
|
+
const rawName = vmPath.slice("/exec/".length, -"/kill".length);
|
|
6963
|
+
try {
|
|
6964
|
+
const name = decodeURIComponent(rawName);
|
|
6965
|
+
return jsonResponse({
|
|
6966
|
+
killed: taskManager.killByLogName(name, { intentional: true })
|
|
6967
|
+
});
|
|
6968
|
+
} catch {
|
|
6969
|
+
return jsonResponse({ error: "invalid script name" }, 400);
|
|
6970
|
+
}
|
|
6971
|
+
}
|
|
6972
|
+
return execH(req);
|
|
6973
|
+
}
|
|
6974
|
+
var fsH = {
|
|
6975
|
+
"/read": readH,
|
|
6976
|
+
"/write": writeH,
|
|
6977
|
+
"/edit": editH,
|
|
6978
|
+
"/grep": grepH,
|
|
6979
|
+
"/glob": globH,
|
|
6980
|
+
"/write_from_url": writeFromUrlH,
|
|
6981
|
+
"/upload_to_url": uploadToUrlH,
|
|
6982
|
+
"/bash": bashH
|
|
6983
|
+
};
|
|
6984
|
+
var CORS_HEADERS = {
|
|
6985
|
+
"Access-Control-Allow-Origin": "*",
|
|
6986
|
+
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE",
|
|
6987
|
+
"Access-Control-Allow-Headers": "Content-Type, Accept, Cache-Control, Authorization"
|
|
6988
|
+
};
|
|
6989
|
+
function vmRouteH(req, method, vmPath) {
|
|
6990
|
+
if (method === "GET" && vmPath === "/idle")
|
|
6991
|
+
return idleH();
|
|
6992
|
+
if (method === "GET" && vmPath === "/events")
|
|
6993
|
+
return eventsH();
|
|
6994
|
+
if (method === "GET" && vmPath === "/scripts")
|
|
6995
|
+
return scriptsHandler();
|
|
6996
|
+
if (method === "OPTIONS")
|
|
6997
|
+
return new Response(null, { status: 204, headers: CORS_HEADERS });
|
|
6998
|
+
const denied = requireToken(req, bootConfig.daemonToken);
|
|
6999
|
+
if (denied)
|
|
7000
|
+
return denied;
|
|
7001
|
+
if (vmPath === "/config")
|
|
7002
|
+
return configH(req);
|
|
7003
|
+
if (vmPath.startsWith("/tasks"))
|
|
7004
|
+
return tasksRouteH(req, method, vmPath);
|
|
7005
|
+
if (method === "POST" && vmPath in fsH)
|
|
7006
|
+
return fsH[vmPath](req);
|
|
7007
|
+
if (method === "POST" && vmPath.startsWith("/exec/"))
|
|
7008
|
+
return execRouteH(req, vmPath);
|
|
7009
|
+
return jsonResponse({ error: \`Not found: /_decopilot_vm\${vmPath}\` }, 404);
|
|
7010
|
+
}
|
|
6933
7011
|
Bun.serve({
|
|
6934
7012
|
port: bootConfig.proxyPort,
|
|
6935
7013
|
hostname: "0.0.0.0",
|
|
6936
7014
|
idleTimeout: 0,
|
|
6937
7015
|
async fetch(req, server) {
|
|
6938
|
-
const
|
|
6939
|
-
const
|
|
7016
|
+
const { pathname: p } = new URL(req.url);
|
|
7017
|
+
const { method } = req;
|
|
6940
7018
|
if (p !== "/health" && p !== "/_decopilot_vm/idle") {
|
|
6941
7019
|
bumpActivity();
|
|
6942
7020
|
if (!firstWorkLogged) {
|
|
6943
7021
|
firstWorkLogged = true;
|
|
6944
|
-
console.log(\`[daemon] boot_id=\${process.env.DAEMON_BOOT_ID} first request: METHOD=\${
|
|
7022
|
+
console.log(\`[daemon] boot_id=\${process.env.DAEMON_BOOT_ID} first request: METHOD=\${method} PATH=\${p}\`);
|
|
6945
7023
|
}
|
|
6946
7024
|
}
|
|
6947
7025
|
if (req.headers.get("upgrade")?.toLowerCase() === "websocket" && !p.startsWith("/_decopilot_vm/")) {
|
|
6948
7026
|
const ok = server.upgrade(req, { data: wsProxy.upgradeData(req) });
|
|
6949
|
-
|
|
6950
|
-
return;
|
|
6951
|
-
return new Response("Upgrade failed", { status: 400 });
|
|
7027
|
+
return ok ? undefined : new Response("Upgrade failed", { status: 400 });
|
|
6952
7028
|
}
|
|
6953
|
-
if (
|
|
7029
|
+
if (method === "GET" && p === "/health")
|
|
6954
7030
|
return healthH();
|
|
6955
|
-
if (
|
|
6956
|
-
return
|
|
6957
|
-
if (req.method === "GET" && p === "/_decopilot_vm/events")
|
|
6958
|
-
return eventsH();
|
|
6959
|
-
if (req.method === "GET" && p === "/_decopilot_vm/scripts")
|
|
6960
|
-
return scriptsHandler();
|
|
6961
|
-
if (p === "/_decopilot_vm/config") {
|
|
6962
|
-
const denied = requireToken(req, bootConfig.daemonToken);
|
|
6963
|
-
if (denied)
|
|
6964
|
-
return denied;
|
|
6965
|
-
if (req.method === "GET")
|
|
6966
|
-
return configReadH();
|
|
6967
|
-
if (req.method === "PUT" || req.method === "POST") {
|
|
6968
|
-
const res = await configUpdateH(req);
|
|
6969
|
-
if (res.status === 200)
|
|
6970
|
-
markClaimed();
|
|
6971
|
-
return res;
|
|
6972
|
-
}
|
|
6973
|
-
}
|
|
6974
|
-
if (p.startsWith("/_decopilot_vm/tasks")) {
|
|
6975
|
-
const denied = requireToken(req, bootConfig.daemonToken);
|
|
6976
|
-
if (denied)
|
|
6977
|
-
return denied;
|
|
6978
|
-
if (req.method === "GET" && p === "/_decopilot_vm/tasks")
|
|
6979
|
-
return tasksListH(req);
|
|
6980
|
-
if (req.method === "POST" && p === "/_decopilot_vm/tasks/kill-all")
|
|
6981
|
-
return tasksKillAllH();
|
|
6982
|
-
if (req.method === "GET" && /^\\/_decopilot_vm\\/tasks\\/[^/]+\\/stream$/.test(p))
|
|
6983
|
-
return tasksStreamH(req);
|
|
6984
|
-
if (req.method === "POST" && /^\\/_decopilot_vm\\/tasks\\/[^/]+\\/kill$/.test(p))
|
|
6985
|
-
return tasksKillH(req);
|
|
6986
|
-
if (req.method === "DELETE" && /^\\/_decopilot_vm\\/tasks\\/[^/]+$/.test(p))
|
|
6987
|
-
return tasksDeleteH(req);
|
|
6988
|
-
if (req.method === "GET" && /^\\/_decopilot_vm\\/tasks\\/[^/]+$/.test(p))
|
|
6989
|
-
return tasksGetH(req);
|
|
6990
|
-
}
|
|
6991
|
-
if (req.method === "POST" && p.startsWith("/_decopilot_vm/")) {
|
|
6992
|
-
const denied = requireToken(req, bootConfig.daemonToken);
|
|
6993
|
-
if (denied)
|
|
6994
|
-
return denied;
|
|
6995
|
-
if (p === "/_decopilot_vm/read")
|
|
6996
|
-
return readH(req);
|
|
6997
|
-
if (p === "/_decopilot_vm/write")
|
|
6998
|
-
return writeH(req);
|
|
6999
|
-
if (p === "/_decopilot_vm/edit")
|
|
7000
|
-
return editH(req);
|
|
7001
|
-
if (p === "/_decopilot_vm/grep")
|
|
7002
|
-
return grepH(req);
|
|
7003
|
-
if (p === "/_decopilot_vm/glob")
|
|
7004
|
-
return globH(req);
|
|
7005
|
-
if (p === "/_decopilot_vm/write_from_url")
|
|
7006
|
-
return writeFromUrlH(req);
|
|
7007
|
-
if (p === "/_decopilot_vm/upload_to_url")
|
|
7008
|
-
return uploadToUrlH(req);
|
|
7009
|
-
if (p === "/_decopilot_vm/bash")
|
|
7010
|
-
return bashH(req);
|
|
7011
|
-
if (p.endsWith("/kill") && p.startsWith("/_decopilot_vm/exec/")) {
|
|
7012
|
-
const rawName = p.slice("/_decopilot_vm/exec/".length, -"/kill".length);
|
|
7013
|
-
let name;
|
|
7014
|
-
try {
|
|
7015
|
-
name = decodeURIComponent(rawName);
|
|
7016
|
-
} catch {
|
|
7017
|
-
return jsonResponse({ error: "invalid script name" }, 400);
|
|
7018
|
-
}
|
|
7019
|
-
const killed = taskManager.killByLogName(name, { intentional: true });
|
|
7020
|
-
return jsonResponse({ killed });
|
|
7021
|
-
}
|
|
7022
|
-
if (p.startsWith("/_decopilot_vm/exec/"))
|
|
7023
|
-
return execH(req);
|
|
7024
|
-
}
|
|
7025
|
-
if (req.method === "OPTIONS" && p.startsWith("/_decopilot_vm/")) {
|
|
7026
|
-
return new Response(null, {
|
|
7027
|
-
status: 204,
|
|
7028
|
-
headers: {
|
|
7029
|
-
"Access-Control-Allow-Origin": "*",
|
|
7030
|
-
"Access-Control-Allow-Methods": "GET, POST, PUT, DELETE",
|
|
7031
|
-
"Access-Control-Allow-Headers": "Content-Type, Accept, Cache-Control, Authorization"
|
|
7032
|
-
}
|
|
7033
|
-
});
|
|
7034
|
-
}
|
|
7035
|
-
if (p.startsWith("/_decopilot_vm/")) {
|
|
7036
|
-
return jsonResponse({ error: \`Not found: \${p}\` }, 404);
|
|
7037
|
-
}
|
|
7031
|
+
if (p.startsWith("/_decopilot_vm/"))
|
|
7032
|
+
return vmRouteH(req, method, p.slice("/_decopilot_vm".length));
|
|
7038
7033
|
return proxyH(req);
|
|
7039
7034
|
},
|
|
7040
7035
|
websocket: {
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
export type CSPair = { // eslint-disable-line @typescript-eslint/naming-convention
|
|
2
|
+
/**
|
|
3
|
+
The ANSI terminal control sequence for starting this style.
|
|
4
|
+
*/
|
|
5
|
+
readonly open: string;
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
The ANSI terminal control sequence for ending this style.
|
|
9
|
+
*/
|
|
10
|
+
readonly close: string;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export type ColorBase = {
|
|
14
|
+
/**
|
|
15
|
+
The ANSI terminal control sequence for ending this color.
|
|
16
|
+
*/
|
|
17
|
+
readonly close: string;
|
|
18
|
+
|
|
19
|
+
ansi(code: number): string;
|
|
20
|
+
|
|
21
|
+
ansi256(code: number): string;
|
|
22
|
+
|
|
23
|
+
ansi16m(red: number, green: number, blue: number): string;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export type Modifier = {
|
|
27
|
+
/**
|
|
28
|
+
Resets the current color chain.
|
|
29
|
+
*/
|
|
30
|
+
readonly reset: CSPair;
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
Make text bold.
|
|
34
|
+
*/
|
|
35
|
+
readonly bold: CSPair;
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
Emitting only a small amount of light.
|
|
39
|
+
*/
|
|
40
|
+
readonly dim: CSPair;
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
Make text italic. (Not widely supported)
|
|
44
|
+
*/
|
|
45
|
+
readonly italic: CSPair;
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
Make text underline. (Not widely supported)
|
|
49
|
+
*/
|
|
50
|
+
readonly underline: CSPair;
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
Make text overline.
|
|
54
|
+
|
|
55
|
+
Supported on VTE-based terminals, the GNOME terminal, mintty, and Git Bash.
|
|
56
|
+
*/
|
|
57
|
+
readonly overline: CSPair;
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
Inverse background and foreground colors.
|
|
61
|
+
*/
|
|
62
|
+
readonly inverse: CSPair;
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
Prints the text, but makes it invisible.
|
|
66
|
+
*/
|
|
67
|
+
readonly hidden: CSPair;
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
Puts a horizontal line through the center of the text. (Not widely supported)
|
|
71
|
+
*/
|
|
72
|
+
readonly strikethrough: CSPair;
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export type ForegroundColor = {
|
|
76
|
+
readonly black: CSPair;
|
|
77
|
+
readonly red: CSPair;
|
|
78
|
+
readonly green: CSPair;
|
|
79
|
+
readonly yellow: CSPair;
|
|
80
|
+
readonly blue: CSPair;
|
|
81
|
+
readonly cyan: CSPair;
|
|
82
|
+
readonly magenta: CSPair;
|
|
83
|
+
readonly white: CSPair;
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
Alias for `blackBright`.
|
|
87
|
+
*/
|
|
88
|
+
readonly gray: CSPair;
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
Alias for `blackBright`.
|
|
92
|
+
*/
|
|
93
|
+
readonly grey: CSPair;
|
|
94
|
+
|
|
95
|
+
readonly blackBright: CSPair;
|
|
96
|
+
readonly redBright: CSPair;
|
|
97
|
+
readonly greenBright: CSPair;
|
|
98
|
+
readonly yellowBright: CSPair;
|
|
99
|
+
readonly blueBright: CSPair;
|
|
100
|
+
readonly cyanBright: CSPair;
|
|
101
|
+
readonly magentaBright: CSPair;
|
|
102
|
+
readonly whiteBright: CSPair;
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
export type BackgroundColor = {
|
|
106
|
+
readonly bgBlack: CSPair;
|
|
107
|
+
readonly bgRed: CSPair;
|
|
108
|
+
readonly bgGreen: CSPair;
|
|
109
|
+
readonly bgYellow: CSPair;
|
|
110
|
+
readonly bgBlue: CSPair;
|
|
111
|
+
readonly bgCyan: CSPair;
|
|
112
|
+
readonly bgMagenta: CSPair;
|
|
113
|
+
readonly bgWhite: CSPair;
|
|
114
|
+
|
|
115
|
+
/**
|
|
116
|
+
Alias for `bgBlackBright`.
|
|
117
|
+
*/
|
|
118
|
+
readonly bgGray: CSPair;
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
Alias for `bgBlackBright`.
|
|
122
|
+
*/
|
|
123
|
+
readonly bgGrey: CSPair;
|
|
124
|
+
|
|
125
|
+
readonly bgBlackBright: CSPair;
|
|
126
|
+
readonly bgRedBright: CSPair;
|
|
127
|
+
readonly bgGreenBright: CSPair;
|
|
128
|
+
readonly bgYellowBright: CSPair;
|
|
129
|
+
readonly bgBlueBright: CSPair;
|
|
130
|
+
readonly bgCyanBright: CSPair;
|
|
131
|
+
readonly bgMagentaBright: CSPair;
|
|
132
|
+
readonly bgWhiteBright: CSPair;
|
|
133
|
+
};
|
|
134
|
+
|
|
135
|
+
export type ConvertColor = {
|
|
136
|
+
/**
|
|
137
|
+
Convert from the RGB color space to the ANSI 256 color space.
|
|
138
|
+
|
|
139
|
+
@param red - (`0...255`)
|
|
140
|
+
@param green - (`0...255`)
|
|
141
|
+
@param blue - (`0...255`)
|
|
142
|
+
*/
|
|
143
|
+
rgbToAnsi256(red: number, green: number, blue: number): number;
|
|
144
|
+
|
|
145
|
+
/**
|
|
146
|
+
Convert from the RGB HEX color space to the RGB color space.
|
|
147
|
+
|
|
148
|
+
@param hex - A hexadecimal string containing RGB data.
|
|
149
|
+
*/
|
|
150
|
+
hexToRgb(hex: string): [red: number, green: number, blue: number];
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
Convert from the RGB HEX color space to the ANSI 256 color space.
|
|
154
|
+
|
|
155
|
+
@param hex - A hexadecimal string containing RGB data.
|
|
156
|
+
*/
|
|
157
|
+
hexToAnsi256(hex: string): number;
|
|
158
|
+
|
|
159
|
+
/**
|
|
160
|
+
Convert from the ANSI 256 color space to the ANSI 16 color space.
|
|
161
|
+
|
|
162
|
+
@param code - A number representing the ANSI 256 color.
|
|
163
|
+
*/
|
|
164
|
+
ansi256ToAnsi(code: number): number;
|
|
165
|
+
|
|
166
|
+
/**
|
|
167
|
+
Convert from the RGB color space to the ANSI 16 color space.
|
|
168
|
+
|
|
169
|
+
@param red - (`0...255`)
|
|
170
|
+
@param green - (`0...255`)
|
|
171
|
+
@param blue - (`0...255`)
|
|
172
|
+
*/
|
|
173
|
+
rgbToAnsi(red: number, green: number, blue: number): number;
|
|
174
|
+
|
|
175
|
+
/**
|
|
176
|
+
Convert from the RGB HEX color space to the ANSI 16 color space.
|
|
177
|
+
|
|
178
|
+
@param hex - A hexadecimal string containing RGB data.
|
|
179
|
+
*/
|
|
180
|
+
hexToAnsi(hex: string): number;
|
|
181
|
+
};
|
|
182
|
+
|
|
183
|
+
/**
|
|
184
|
+
Basic modifier names.
|
|
185
|
+
*/
|
|
186
|
+
export type ModifierName = keyof Modifier;
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
Basic foreground color names.
|
|
190
|
+
|
|
191
|
+
[More colors here.](https://github.com/chalk/chalk/blob/main/readme.md#256-and-truecolor-color-support)
|
|
192
|
+
*/
|
|
193
|
+
export type ForegroundColorName = keyof ForegroundColor;
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
Basic background color names.
|
|
197
|
+
|
|
198
|
+
[More colors here.](https://github.com/chalk/chalk/blob/main/readme.md#256-and-truecolor-color-support)
|
|
199
|
+
*/
|
|
200
|
+
export type BackgroundColorName = keyof BackgroundColor;
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
Basic color names. The combination of foreground and background color names.
|
|
204
|
+
|
|
205
|
+
[More colors here.](https://github.com/chalk/chalk/blob/main/readme.md#256-and-truecolor-color-support)
|
|
206
|
+
*/
|
|
207
|
+
export type ColorName = ForegroundColorName | BackgroundColorName;
|
|
208
|
+
|
|
209
|
+
/**
|
|
210
|
+
Basic modifier names.
|
|
211
|
+
*/
|
|
212
|
+
export const modifierNames: readonly ModifierName[];
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
Basic foreground color names.
|
|
216
|
+
*/
|
|
217
|
+
export const foregroundColorNames: readonly ForegroundColorName[];
|
|
218
|
+
|
|
219
|
+
/**
|
|
220
|
+
Basic background color names.
|
|
221
|
+
*/
|
|
222
|
+
export const backgroundColorNames: readonly BackgroundColorName[];
|
|
223
|
+
|
|
224
|
+
/*
|
|
225
|
+
Basic color names. The combination of foreground and background color names.
|
|
226
|
+
*/
|
|
227
|
+
export const colorNames: readonly ColorName[];
|
|
228
|
+
|
|
229
|
+
declare const ansiStyles: {
|
|
230
|
+
readonly modifier: Modifier;
|
|
231
|
+
readonly color: ColorBase & ForegroundColor;
|
|
232
|
+
readonly bgColor: ColorBase & BackgroundColor;
|
|
233
|
+
readonly codes: ReadonlyMap<number, number>;
|
|
234
|
+
} & ForegroundColor & BackgroundColor & Modifier & ConvertColor;
|
|
235
|
+
|
|
236
|
+
export default ansiStyles;
|