@makaio/framework 1.0.0-dev-1781117225170 → 1.0.0-dev-1781354548379
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -0
- package/dist/.makaio-build.json +2 -2
- package/dist/adapter-UpcpZDOv.mjs +1 -0
- package/dist/adapters/config/index.d.mts +1 -1
- package/dist/adapters/config/index.mjs +1 -1
- package/dist/adapters/index.d.mts +13 -5
- package/dist/adapters/index.mjs +2 -2
- package/dist/adapters/node.d.mts +1 -1
- package/dist/adapters/node.mjs +1 -1
- package/dist/bus/index.mjs +1 -1
- package/dist/client-BJVDImPV.d.mts +175 -0
- package/dist/clients/index.d.mts +101 -1
- package/dist/clients/index.mjs +2 -2
- package/dist/contracts/adapter/index.d.mts +2 -2
- package/dist/contracts/adapter/index.mjs +1 -1
- package/dist/contracts/adapter/schemas/session-lineage.d.mts +1 -1
- package/dist/contracts/artifact/index.d.mts +1 -1
- package/dist/contracts/client/index.d.mts +2 -2
- package/dist/contracts/common/index.d.mts +1 -1
- package/dist/contracts/config/index.d.mts +1 -1
- package/dist/contracts/extension/index.d.mts +4 -4
- package/dist/contracts/extension/index.mjs +1 -1
- package/dist/contracts/facet/index.d.mts +1 -1
- package/dist/contracts/harness/index.d.mts +1 -1
- package/dist/contracts/host/index.d.mts +1 -1
- package/dist/contracts/index.d.mts +786 -108
- package/dist/contracts/index.mjs +1 -1
- package/dist/contracts/materialization/index.d.mts +3 -3
- package/dist/contracts/model-registry/index.d.mts +1 -1
- package/dist/contracts/native-session-supervisor/index.d.mts +1 -1
- package/dist/contracts/platform/index.d.mts +1 -1
- package/dist/contracts/provider/index.d.mts +2 -2
- package/dist/contracts/session/index.d.mts +3 -3
- package/dist/contracts/session/index.mjs +1 -1
- package/dist/contracts/shared/index.d.mts +1 -1
- package/dist/contracts/skill/index.d.mts +1 -1
- package/dist/contracts/telemetry/index.d.mts +1 -1
- package/dist/contracts/timeout/index.d.mts +1 -1
- package/dist/contracts/variant/index.d.mts +1 -1
- package/dist/{definition-Cp-5xJp_.d.mts → definition-DqJOg6Lv.d.mts} +1 -1
- package/dist/{detached-extension-handle-oXbjv1tA.mjs → detached-extension-handle-Diiwgm13.mjs} +1 -1
- package/dist/drizzle/0001_messages_content_tsv.na.md +18 -0
- package/dist/drizzle/0012_legal_kate_bishop.sql +3 -0
- package/dist/drizzle/0013_eager_rhodey.sql +56 -0
- package/dist/drizzle/0014_fancy_ultimo.sql +1 -0
- package/dist/drizzle/0015_m_mqbh8q5b.sql +1 -0
- package/dist/drizzle/0016_m_mqbmq8h7.sql +1 -0
- package/dist/drizzle/0017_m_mqbnf924.sql +1 -0
- package/dist/drizzle/meta/0012_snapshot.json +2934 -0
- package/dist/drizzle/meta/0013_snapshot.json +2954 -0
- package/dist/drizzle/meta/0014_snapshot.json +2959 -0
- package/dist/drizzle/meta/0015_snapshot.json +2966 -0
- package/dist/drizzle/meta/0016_snapshot.json +2973 -0
- package/dist/drizzle/meta/0017_snapshot.json +2980 -0
- package/dist/drizzle/meta/_journal.json +42 -0
- package/dist/drizzle-wjquQK2m.mjs +1 -0
- package/dist/extension-DfNcE0zm.mjs +1 -0
- package/dist/extension-ZBN4BGre.mjs +1 -0
- package/dist/{filesystem-service-CBJT7A5w.mjs → filesystem-service-BjfrUmGS.mjs} +1 -1
- package/dist/{globby-C0lgTOUl.mjs → globby-BIH65cbN.mjs} +1 -1
- package/dist/handler-DqpiV9eA.mjs +1 -0
- package/dist/handlers-BAB4fQNH.mjs +41 -0
- package/dist/{index-uQl_1wQO.d.mts → index-BAhJKQLX.d.mts} +8 -8
- package/dist/{index-i7o6FtS0.d.mts → index-BDRKAxIV.d.mts} +129 -2
- package/dist/{index-CXfWW8cP.d.mts → index-BHAOu6Hs.d.mts} +20 -20
- package/dist/{index-t9Vt4Jbb.d.mts → index-BHzgDuRE.d.mts} +20 -3
- package/dist/{index-SFkbbDxs.d.mts → index-BYkOUd0x.d.mts} +1 -1
- package/dist/{index-CmGvjpUG.d.mts → index-BheaEhyI.d.mts} +6 -6
- package/dist/{index-Dsu1tPHm.d.mts → index-Bibt5jAX.d.mts} +8 -8
- package/dist/{index-Bw8SkcWG.d.mts → index-Bw_zL7Rs.d.mts} +1 -1
- package/dist/{index-ClgVA8Rz.d.mts → index-C3zfJg6s.d.mts} +6 -6
- package/dist/{index-v2kRZnfw2.d.mts → index-CH5U3zSA2.d.mts} +20 -10
- package/dist/{index-hWzUQtDn.d.mts → index-CTn_Xi-p.d.mts} +92 -19
- package/dist/{index-BY-fz0Jy.d.mts → index-DPIdX6kb.d.mts} +358 -110
- package/dist/{index-kLBWooVu.d.mts → index-Da4ABgRq.d.mts} +12 -12
- package/dist/{index-C1uZLARQ.d.mts → index-DrGLAuZc.d.mts} +1409 -72
- package/dist/{index-CT-zFurA.d.mts → index-Drz_a7kW.d.mts} +1 -1
- package/dist/{index-BELri1Hy.d.mts → index-IekAD8Gp.d.mts} +8 -8
- package/dist/{index-C_jIVT40.d.mts → index-fVgKVvta.d.mts} +1 -1
- package/dist/{index-BFaeVdsn2.d.mts → index-zgm2j9V92.d.mts} +44 -2
- package/dist/kernel/cli/index.d.mts +2 -2
- package/dist/kernel/cli/register.d.mts +1 -1
- package/dist/kernel/extension/index.d.mts +1 -1
- package/dist/kernel/extension/index.mjs +1 -1
- package/dist/kernel/index.d.mts +5 -5
- package/dist/kernel/index.mjs +1 -1
- package/dist/kernel/namespace/index.d.mts +1 -1
- package/dist/kernel/observability/index.d.mts +1 -1
- package/dist/kernel/providers/index.d.mts +1 -1
- package/dist/kernel/window/index.d.mts +1 -1
- package/dist/{lib-zuQKc8ym.mjs → lib-Cq5R6Tx9.mjs} +1 -1
- package/dist/{lib-IkUYa2Qs.mjs → lib-nlcl5kRW.mjs} +1 -1
- package/dist/{load-extensions-DE8qDIqi.d.mts → load-extensions-D9nbDIiW.d.mts} +1 -1
- package/dist/{load-extensions-CwxilDj1.mjs → load-extensions-wELQ4BBN.mjs} +1 -1
- package/dist/mcp-http-server/index.d.mts +132 -19
- package/dist/mcp-http-server/index.mjs +2 -2
- package/dist/{namespace-Dik_dNeE.d.mts → namespace--s0d86h-.d.mts} +144 -0
- package/dist/{namespace-ffepZB8Y.d.mts → namespace-B73Sxj5L.d.mts} +6 -6
- package/dist/{namespace-CZPu_jvy.d.mts → namespace-Boe6l5n9.d.mts} +82 -46
- package/dist/{namespace-Da_dHfdm.d.mts → namespace-BxxBhcV_.d.mts} +2 -2
- package/dist/namespace-Dfq6MDN9.mjs +1 -0
- package/dist/{namespace-DvHoeMUV.d.mts → namespace-aJJfBJU5.d.mts} +173 -3
- package/dist/node/bus-server/index.d.mts +1 -1
- package/dist/node/bus-server/index.mjs +1 -1
- package/dist/node/bus-server/server-lifecycle.d.mts +1 -1
- package/dist/node/bus-server/server-lifecycle.mjs +1 -1
- package/dist/{orchestrator-shared-FnWrPS09.mjs → orchestrator-shared-BKFXaKPL.mjs} +1 -1
- package/dist/{package-B2HkKyRz.d.mts → package--RZnpN2J.d.mts} +2 -3
- package/dist/package-BzJvtM5O.mjs +1 -0
- package/dist/package-DzN_jdqd.mjs +1 -0
- package/dist/package.json +1 -1
- package/dist/primitive-runtime-CNC_bSac.mjs +1 -0
- package/dist/registry-RG-bkw3c.mjs +146 -0
- package/dist/rules/index.d.mts +1 -1
- package/dist/rules/index.mjs +1 -1
- package/dist/rules/schemas.d.mts +1 -1
- package/dist/runtime-bun/index.mjs +1 -1
- package/dist/runtime-node/bus/runtime/namespace.d.mts +8 -8
- package/dist/runtime-node/bus/runtime/schemas.d.mts +11 -4
- package/dist/runtime-node/bus/runtime/schemas.mjs +1 -1
- package/dist/runtime-node/extension-discovery.d.mts +1 -1
- package/dist/runtime-node/extension-validation.d.mts +1 -1
- package/dist/runtime-node/extension-validation.mjs +1 -1
- package/dist/runtime-node/index.d.mts +77 -38
- package/dist/runtime-node/index.mjs +26 -53
- package/dist/runtime-node/makaio-config.d.mts +1 -1
- package/dist/runtime-node/makaio-config.mjs +1 -1
- package/dist/runtime-node/workflow-worker/index.d.mts +1 -1
- package/dist/runtime-node/workflow-worker/index.mjs +1 -1
- package/dist/runtime-node/workflow-worker/worker-entry.mjs +1 -1
- package/dist/schema-C3TgjrsV.mjs +1 -0
- package/dist/schema-CzhOc7TV.mjs +1 -0
- package/dist/{schema-CfuF2cXW.d.mts → schema-DGMLvVoQ.d.mts} +237 -11
- package/dist/schemas-CuKayWhA.mjs +1 -0
- package/dist/{schemas-SPI-Y87l2.d.mts → schemas-kVcJMjjn2.d.mts} +6 -6
- package/dist/{schemas-BiMxSTUx.d.mts → schemas-t1VR6_b_.d.mts} +3 -3
- package/dist/services/adapter-runtime/index.d.mts +3 -3
- package/dist/services/adapter-runtime/namespace.d.mts +1 -1
- package/dist/services/adapter-runtime/schemas.d.mts +1 -1
- package/dist/services/adapter-subsystem/index.d.mts +2 -2
- package/dist/services/adapter-subsystem/namespace.d.mts +1 -1
- package/dist/services/agent-runtime/index.d.mts +2 -2
- package/dist/services/agent-runtime/namespace.d.mts +1 -1
- package/dist/services/agent-runtime/schemas.d.mts +1 -1
- package/dist/services/capability/index.d.mts +1 -1
- package/dist/services/codebase/index.d.mts +2 -2
- package/dist/services/codebase/namespace.d.mts +1 -1
- package/dist/services/codebase/schemas.d.mts +1 -1
- package/dist/services/compression/index.d.mts +2 -2
- package/dist/services/compression/namespace.d.mts +1 -1
- package/dist/services/compression/schemas.d.mts +1 -1
- package/dist/services/context-rules/index.d.mts +4 -4
- package/dist/services/execution-target/index.d.mts +3 -3
- package/dist/services/execution-target/namespace.d.mts +1 -1
- package/dist/services/execution-target/schemas.d.mts +1 -1
- package/dist/services/filesystem/index.d.mts +1 -1
- package/dist/services/filesystem/index.mjs +1 -1
- package/dist/services/filesystem/namespace.d.mts +6 -6
- package/dist/services/filesystem/schemas.d.mts +3 -3
- package/dist/services/harness/index.d.mts +31 -20
- package/dist/services/harness/index.mjs +1 -1
- package/dist/services/harness/storage/schema.d.mts +60 -16
- package/dist/services/harness/storage/schema.mjs +1 -1
- package/dist/services/index.d.mts +166 -69
- package/dist/services/index.mjs +1 -1
- package/dist/services/log-import/browser.d.mts +2 -2
- package/dist/services/log-import/index.d.mts +9 -15
- package/dist/services/log-import/index.mjs +2 -2
- package/dist/services/log-import/log-import.d.mts +1 -1
- package/dist/services/model-registry/index.d.mts +1 -1
- package/dist/services/preferences/index.d.mts +2 -2
- package/dist/services/preferences/schemas.d.mts +1 -1
- package/dist/services/preferences/storage-namespace.d.mts +2 -2
- package/dist/services/provider-context/index.d.mts +1 -1
- package/dist/services/provider-context/index.mjs +1 -1
- package/dist/services/session/handlers/index.d.mts +1 -1
- package/dist/services/session/handlers/index.mjs +1 -1
- package/dist/services/session/index.d.mts +10 -10
- package/dist/services/session/index.mjs +1 -1
- package/dist/services/session/messages/namespace.d.mts +1 -1
- package/dist/services/session/messages/namespace.mjs +1 -1
- package/dist/services/session/orchestrator-testing/index.d.mts +1 -1
- package/dist/services/session/orchestrator-testing/index.mjs +1 -1
- package/dist/services/session/session-events/namespace.d.mts +1 -1
- package/dist/services/session/session-events/namespace.mjs +1 -1
- package/dist/services/session/storage/namespace.d.mts +1 -1
- package/dist/services/session/storage/schema.d.mts +2 -2
- package/dist/services/session/storage/schema.mjs +1 -1
- package/dist/services/session/testing/index.d.mts +18 -2
- package/dist/services/session/testing/index.mjs +54 -3
- package/dist/services/session/testing/orchestrator-shared.d.mts +1 -1
- package/dist/services/session/testing/orchestrator-shared.mjs +1 -1
- package/dist/services/session/turns/namespace.d.mts +1 -1
- package/dist/services/session/turns/namespace.mjs +1 -1
- package/dist/services/session-editor/index.d.mts +1 -1
- package/dist/services/settings/index.d.mts +3 -3
- package/dist/services/settings/index.mjs +1 -1
- package/dist/services/settings/namespace.d.mts +6 -6
- package/dist/services/settings/storage/clients-namespace.d.mts +1 -1
- package/dist/services/settings/storage/clients-namespace.mjs +1 -1
- package/dist/services/settings/storage/index.d.mts +3 -3
- package/dist/services/settings/storage/index.mjs +1 -1
- package/dist/services/settings/storage/providers-namespace.d.mts +1 -1
- package/dist/services/settings/storage/providers-namespace.mjs +1 -1
- package/dist/services/subagent/index.d.mts +1 -1
- package/dist/services/subagent/index.mjs +1 -1
- package/dist/services/subagent-template/index.d.mts +2 -2
- package/dist/services/subagent-template/namespace.d.mts +1 -1
- package/dist/services/subagent-template/schemas.d.mts +1 -1
- package/dist/services/tool-approval/index.d.mts +1 -1
- package/dist/services/tool-approval/index.mjs +1 -1
- package/dist/services/tools/index.d.mts +1 -1
- package/dist/services/tools/index.mjs +1 -1
- package/dist/services/tray-menu/index.d.mts +3 -3
- package/dist/services/tray-menu/namespace.d.mts +1 -1
- package/dist/services/tray-menu/schemas.d.mts +1 -1
- package/dist/services/turn/index.d.mts +1 -1
- package/dist/services/turn/namespace.d.mts +1 -1
- package/dist/services/turn/schemas.d.mts +72 -0
- package/dist/services/turn/schemas.mjs +1 -1
- package/dist/{session-C1Cami7U.mjs → session-BwX5_k47.mjs} +1 -1
- package/dist/session-P4nX60Xx.mjs +39 -0
- package/dist/{src-DI5TcYUW.mjs → src-CBG3IHUl.mjs} +1 -1
- package/dist/storage/drizzle/client.d.mts +2 -78
- package/dist/storage/drizzle/client.mjs +1 -1
- package/dist/storage/drizzle/columns/postgres.d.mts +88 -0
- package/dist/storage/drizzle/columns/postgres.mjs +1 -0
- package/dist/storage/drizzle/columns/sqlite.d.mts +81 -0
- package/dist/storage/drizzle/columns/sqlite.mjs +1 -0
- package/dist/storage/drizzle/index.d.mts +976 -23
- package/dist/storage/drizzle/index.mjs +1 -1
- package/dist/storage/handlers/drizzle/index.d.mts +1 -1
- package/dist/storage/handlers/drizzle/index.mjs +1 -1
- package/dist/storage/handlers/index.d.mts +1 -1
- package/dist/storage/handlers/index.mjs +1 -1
- package/dist/testing/drizzle-harness.d.mts +52 -6
- package/dist/testing/drizzle-harness.mjs +1 -1
- package/dist/testing/index.d.mts +34 -2
- package/dist/testing/index.mjs +1 -1
- package/dist/{tool-approval-service-BgNcJvKx.mjs → tool-approval-service-DNHV5x0M.mjs} +1 -1
- package/dist/tools-CQImrHAp.mjs +1 -0
- package/dist/{types-CZHV05Lu.d.mts → types-BpuLMR2m.d.mts} +616 -433
- package/dist/{types-C5Uy3WEy.d.mts → types-D0fPFh-D.d.mts} +1 -1
- package/dist/{types-0u6hpELc.d.mts → types-D6jnDjP2.d.mts} +18 -5
- package/dist/ui-components/index.d.mts +36 -37
- package/dist/ui-kernel/index.d.mts +1 -1
- package/dist/ui-kernel/pages/schemas.d.mts +1 -1
- package/dist/ui-views/index.d.mts +2 -2
- package/dist/workflow-engine/index.d.mts +539 -110
- package/dist/workflow-engine/index.mjs +1 -1
- package/dist/workflow-engine/package.d.mts +1 -1
- package/dist/workflow-engine/package.mjs +1 -1
- package/dist/workflow-engine/workflow-orchestrator.mjs +1 -1
- package/dist/{workflow-worker-hDaQzTBl.mjs → workflow-worker-CK9Sqj7D.mjs} +1 -1
- package/package.json +49 -1
- package/dist/adapter-Dt2FDMs4.mjs +0 -1
- package/dist/drizzle-DpjZFY_j.mjs +0 -1
- package/dist/extension--5Q190u_.mjs +0 -1
- package/dist/extension-DFIZ3FCJ.mjs +0 -1
- package/dist/handlers-Bev7-xjL.mjs +0 -41
- package/dist/namespace-CDiM5Bcr.mjs +0 -1
- package/dist/namespace-h0HIuqx0.mjs +0 -1
- package/dist/package-C9wOiMK9.mjs +0 -1
- package/dist/package-OE9dMQsq.mjs +0 -1
- package/dist/primitive-runtime-1Z3JbRUj.mjs +0 -1
- package/dist/schema-DCJyzRHe.mjs +0 -1
- package/dist/schema-DOnJmAPw.mjs +0 -1
- package/dist/schemas-CSUwpaNm.mjs +0 -1
- package/dist/session-BnfsJoZi.mjs +0 -134
- package/dist/tools-B8d8Iqqx.mjs +0 -1
- package/dist/types-yTKQTAok.d.mts +0 -31
- /package/dist/{ajv-0JG5NFEd.mjs → ajv-BA2z5ztb.mjs} +0 -0
- /package/dist/{await-trigger-CHuOd5co.mjs → await-trigger-DREnXCEJ.mjs} +0 -0
- /package/dist/{base-orchestrator-D-S9v5VY.d.mts → base-orchestrator-M5mAB5-w.d.mts} +0 -0
- /package/dist/{cleanEnvForAdapter-BlpmyXYk.mjs → cleanEnvForAdapter-vZfPGi0X.mjs} +0 -0
- /package/dist/{clients-namespace-E97p_GKF.d.mts → clients-namespace-SFk7OTop.d.mts} +0 -0
- /package/dist/{config-namespace-R_34Wfps.d.mts → config-namespace-BzAvE2nY.d.mts} +0 -0
- /package/dist/{create-static-mount-B9Szo_7y.mjs → create-static-mount-BB1MIQ9J.mjs} +0 -0
- /package/dist/{cross-spawn-CTptpCy4.mjs → cross-spawn-BL6EvJBv.mjs} +0 -0
- /package/dist/{cursor-storage-YikwAZR5.mjs → cursor-storage-CmKjSvKY.mjs} +0 -0
- /package/dist/{definition-CYzWS2eR.d.mts → definition-BSghHJpQ.d.mts} +0 -0
- /package/dist/{definition-CvOuzWNT.d.mts → definition-q6iLw11H.d.mts} +0 -0
- /package/dist/{descriptor-to-package-9nrAH_D5.mjs → descriptor-to-package-CY8oc2gl.mjs} +0 -0
- /package/dist/{esm-CglYG5aA.mjs → esm-CQVFKEW5.mjs} +0 -0
- /package/dist/{extension-discovery-BD1-oNU_.d.mts → extension-discovery-CkV_VRdJ.d.mts} +0 -0
- /package/dist/{filesystem-service-BcwRp4k1.d.mts → filesystem-service-Ddngll0j.d.mts} +0 -0
- /package/dist/{index-DJQew2k-.d.mts → index-9IDJUJ4X.d.mts} +0 -0
- /package/dist/{index-CNYPKkyH.d.mts → index-BBvcP-P0.d.mts} +0 -0
- /package/dist/{index-DfUBcVtG.d.mts → index-BCKRUuI2.d.mts} +0 -0
- /package/dist/{index-Dn9Uum3F.d.mts → index-BMpRB6iE.d.mts} +0 -0
- /package/dist/{index-CdNDnxXR.d.mts → index-BbCjtc3h.d.mts} +0 -0
- /package/dist/{index-B6RGNugn.d.mts → index-BnQSPC6c.d.mts} +0 -0
- /package/dist/{index-DUPZKsd3.d.mts → index-BpXX9WZJ.d.mts} +0 -0
- /package/dist/{index-DUhXk_q6.d.mts → index-BpniJgxu.d.mts} +0 -0
- /package/dist/{index-ChG8ZUNP.d.mts → index-Bsp0O_sI.d.mts} +0 -0
- /package/dist/{index-CF7dnqQj.d.mts → index-Buo9H8RK.d.mts} +0 -0
- /package/dist/{index-9KnLzPYu.d.mts → index-BxFA1XcP.d.mts} +0 -0
- /package/dist/{index-AZ4iLe7O2.d.mts → index-C33Tq1ei2.d.mts} +0 -0
- /package/dist/{index--0CnhN0g.d.mts → index-C6BhKRnH.d.mts} +0 -0
- /package/dist/{index-BV8rSmDZ.d.mts → index-CDU_s69P.d.mts} +0 -0
- /package/dist/{index-BDlpFEsp2.d.mts → index-CGJjA-hR2.d.mts} +0 -0
- /package/dist/{index-DNGUXQGC.d.mts → index-Cz9JMjZK.d.mts} +0 -0
- /package/dist/{index-C-YBGCCG.d.mts → index-D0SUjZmU.d.mts} +0 -0
- /package/dist/{index-yNb7G73-.d.mts → index-D6Iyvz9T.d.mts} +0 -0
- /package/dist/{index-ziQTLYUO.d.mts → index-DOfq0qqv.d.mts} +0 -0
- /package/dist/{index-BYxgW2i0.d.mts → index-DSV1aFgK.d.mts} +0 -0
- /package/dist/{index-Dbwm5Y-Q.d.mts → index-Dsq2zKvu.d.mts} +0 -0
- /package/dist/{jsonl-transport-DBHQgcIm.mjs → jsonl-transport-C21tpVfe.mjs} +0 -0
- /package/dist/{lib-CaOdTS9F.mjs → lib-CNOQJtgs.mjs} +0 -0
- /package/dist/{namespace-DnZ4rS6T2.d.mts → namespace-B60mn8J-2.d.mts} +0 -0
- /package/dist/{namespace-DfYutvMT.d.mts → namespace-BBVtD1gu.d.mts} +0 -0
- /package/dist/{namespace-BaJJxBsI.d.mts → namespace-CHMszppN.d.mts} +0 -0
- /package/dist/{namespace-uGw5nK6d.d.mts → namespace-CqUGzG53.d.mts} +0 -0
- /package/dist/{namespace-13uMtVGj.d.mts → namespace-DRFJN-_z.d.mts} +0 -0
- /package/dist/{namespace-TfZGCy7N.d.mts → namespace-DzVf1hVH.d.mts} +0 -0
- /package/dist/{namespace-QTFnJWHC.d.mts → namespace-XTGCaSXj.d.mts} +0 -0
- /package/dist/{namespace-CTrNKkxY.d.mts → namespace-nlsvvMtD.d.mts} +0 -0
- /package/dist/{namespace-DkDvQJhB.d.mts → namespace-uuR0Fg5r.d.mts} +0 -0
- /package/dist/{orchestrator-shared-BZVeoRfr.d.mts → orchestrator-shared-D91Wk7z-.d.mts} +0 -0
- /package/dist/{out-CiFds_ap.mjs → out-C1JFb2Bp.mjs} +0 -0
- /package/dist/{provider-context-lfG0BpqX.mjs → provider-context-wp4VSJFI.mjs} +0 -0
- /package/dist/{providers-namespace-Cc9FQ-Zt.d.mts → providers-namespace-BqWYkydw.d.mts} +0 -0
- /package/dist/{schemas-BD-1NGmS.d.mts → schemas-B5ToLwIs.d.mts} +0 -0
- /package/dist/{schemas-Hy-lsBpg.d.mts → schemas-B77Gi8Xr.d.mts} +0 -0
- /package/dist/{schemas-BzK1I1eX.d.mts → schemas-C792eVAZ.d.mts} +0 -0
- /package/dist/{schemas-CYS6bkht.d.mts → schemas-Chyj6HuZ.d.mts} +0 -0
- /package/dist/{schemas-DL_bGYyZ.d.mts → schemas-DZUaRcYl.d.mts} +0 -0
- /package/dist/{schemas-DdZwjeF0.d.mts → schemas-Dv5FxHDT.d.mts} +0 -0
- /package/dist/{schemas-CsjB6gel.d.mts → schemas-Dyk7JuVl.d.mts} +0 -0
- /package/dist/{schemas-DFWGb4uj.d.mts → schemas-Kq33MTPY.d.mts} +0 -0
- /package/dist/{schemas-BFeP62V4.d.mts → schemas-lqvZ6UpK.d.mts} +0 -0
- /package/dist/{server-lifecycle-DVAbXQzg.d.mts → server-lifecycle-47mygK3E.d.mts} +0 -0
- /package/dist/{server-lifecycle-JTFuSJhg.mjs → server-lifecycle-Cg47L59Q.mjs} +0 -0
- /package/dist/{session-lineage-CxHc3_bm.d.mts → session-lineage-CKg6mErA.d.mts} +0 -0
- /package/dist/{shared-schemas-CKe2uN4-.mjs → shared-schemas-DYL7a-No.mjs} +0 -0
- /package/dist/{src-4_2jBceX.mjs → src-DedDL9iv.mjs} +0 -0
- /package/dist/{storage-namespace-I30TaZP7.d.mts → storage-namespace-BXmMUd7a.d.mts} +0 -0
- /package/dist/{storage-namespace-definition-ZNBL3v2h.d.mts → storage-namespace-definition-C3XbpiP8.d.mts} +0 -0
- /package/dist/{types-11QnNmpW.d.mts → types-5Gw3iVpK.d.mts} +0 -0
- /package/dist/{types-BKNpS4Xw.d.mts → types-B0BtvVAq.d.mts} +0 -0
- /package/dist/{types-BtMNh2FS.d.mts → types-D-bP8RRE.d.mts} +0 -0
- /package/dist/{window-registry-QD1rTk_f.d.mts → window-registry-CfEi_Ji4.d.mts} +0 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import{TurnStorageSubjects as e}from"./services/turn/namespace.mjs";import{agents as t,agentsDual as n,sessions as r,sessionsDual as i}from"./services/session/storage/schema.mjs";import"./schema-C3TgjrsV.mjs";import{a,i as o,n as s,o as c,r as l}from"./namespace-Dfq6MDN9.mjs";import{SessionStorageSubjects as u}from"./services/session/storage/namespace.mjs";import{D as d,F as f,T as p,_ as m,d as h,f as g,g as _,h as v,k as y,m as b,p as x,u as ee,v as te,y as S}from"./handlers-BAB4fQNH.mjs";import{r as ne,t as re}from"./provider-context-wp4VSJFI.mjs";import{AdapterRuntimeSubjects as ie}from"./services/adapter-runtime/namespace.mjs";import{MessageStorageSubjects as C}from"./services/session/messages/namespace.mjs";import{n as w}from"./namespace-D6X67cUk.mjs";import{z as T}from"zod";import{createHash as ae}from"node:crypto";import{MakaioBus as oe,NoHandlerError as se,TimeoutError as ce}from"@makaio/framework/bus";import{AdapterSubjects as E,AgentSubjects as D,CanonicalModelSubjects as le,CompressionModeSchema as ue,ForkTransformsSchema as de,MessageRoutingSchema as fe,SessionContextSchema as pe,SessionDiscoveredSchema as me,SessionStorageSetRequestSchema as he,SessionStorageUpdateSchema as ge,SessionSubjects as O,compareMessageCursorAsc as _e,compareMessageCursorDesc as ve,isCanonicalModelParseError as ye,messageToCursor as k,parseCanonicalModel as be}from"@makaio/framework/contracts";import{BaseService as xe}from"@makaio/framework/service-base";import{createStorageNamespaceDefinition as Se}from"@makaio/framework/storage";import{blob as Ce,index as we,integer as Te,primaryKey as Ee,sqliteTable as De,text as A,uniqueIndex as Oe}from"drizzle-orm/sqlite-core";import{index as ke,primaryKey as Ae}from"drizzle-orm/pg-core";import{defineDialectSchema as j,defineDualTable as je,didAffectRows as M,getRawSqlExecutor as Me,getStorageEngine as Ne,resolveSchema as N,resolveStorageEngine as P}from"@makaio/framework/storage/drizzle";import{and as F,asc as I,count as L,desc as R,eq as z,gt as Pe,gte as Fe,inArray as B,isNull as V,lt as Ie,lte as Le,or as Re,sql as H}from"drizzle-orm";import{ClientIdentityObservationSchema as ze}from"@makaio/framework/contracts/client";import{ImportCursorStorageSubjects as Be}from"@makaio/framework/adapters";function Ve(e){return e.on(O.agent.added,async t=>{let n=await e.requestOptional(u.get,{sessionId:t.payload.sessionId}),r=n.handled?n.data.session:void 0;r&&(r.adapterSessionId||(r.adapterSessionId=t.payload.adapterSessionId,r.adapterName=t.payload.adapterName,r.adapterId=t.payload.adapterId),(t.payload.role??(r.leadAgentId?`member`:`lead`))===`lead`&&(r.leadAgentId=t.payload.agentId),r.lastActivityAt=Date.now(),await e.request(u.set,{sessionId:t.payload.sessionId,session:r}))})}function He(e){return e.on(O.agent.removed,async t=>{let n=await e.requestOptional(u.get,{sessionId:t.payload.sessionId}),r=n.handled?n.data.session:void 0;r&&(await e.requestOptional(f.updateStatus,{agentId:t.payload.agentId,status:`disposed`}),r.leadAgentId===t.payload.agentId&&(r.leadAgentId=void 0),r.lastActivityAt=Date.now(),await e.request(u.set,{sessionId:t.payload.sessionId,session:r}))})}function Ue(e){return[Ke(e),qe(e),Je(e),We(e),Ye(e),Xe(e),Ze(e),Qe(e),$e(e),nt(e),Ve(e.bus),He(e.bus)]}function We(e){let{bus:t}=e;return t.on(O.turn.await,async e=>{let{sessionId:n,turnId:r,timeoutMs:i}=e.payload,a=new AbortController,o=t.once(O.turn.completed,{timeoutMs:i,filter:{sessionId:n,turnId:r},signal:a.signal});o.catch(()=>void 0);let s=await Ge(t,n,r);if(s!==void 0){a.abort(),e.setResult({completion:s});return}try{let t=await o;e.setResult({completion:t.payload})}catch(e){throw e instanceof Error&&e.name===`OnceTimeoutError`?new ce(`session.turn.await`,i):e}})}async function Ge(t,n,r){let i=await t.requestOptional(e.get,{turnId:r}),a=i.handled?i.data.turn:null;if(!(a?.sessionId!==n||a.status!==`completed`&&a.status!==`error`))return{sessionId:n,turnId:r,turnNumber:a.turnNumber,success:a.status===`completed`,...a.error!==void 0&&{error:a.error},...a.initiator!==void 0&&{initiator:a.initiator}}}function Ke(e){let{bus:t}=e;return t.on(O.create,async e=>{let{sessionId:n,parentSessionId:r,contextInheritance:i,forkPointMessageId:a,branchKind:o,forkTransforms:s,title:c,targetWorkingDirectory:l,executionTargetId:d,spawningToolCallId:f,originWindowId:p}=e.payload,m=n??crypto.randomUUID(),h=Date.now(),g={sessionId:m,createdAt:h,lastActivityAt:h,agents:[],status:`active`,title:c,parentSessionId:r,contextInheritance:i,forkPointMessageId:a,branchKind:o,forkTransforms:s,targetWorkingDirectory:l,executionTargetId:d,spawningToolCallId:f},_=await t.requestOptional(u.set,{sessionId:m,session:g,ifAbsent:!0});if(_.handled&&!_.data.success){e.setResult({sessionId:m});return}await t.emit(O.created,{sessionId:m,createdAt:g.createdAt,parentSessionId:r??null,branchKind:o??null,originWindowId:p??`server`}),e.setResult({sessionId:m})})}function qe(e){let{bus:t}=e;return t.on(O.get,async e=>{let n=await t.requestOptional(u.get,{sessionId:e.payload.sessionId}),r=n.handled?n.data.session:null;e.setResult({session:r})})}function Je(e){let{bus:t}=e;return t.on(O.list,async e=>{let{status:n,limit:r,offset:i,includePreview:a,executionTargetId:o}=e.payload,s=await t.requestOptional(u.list,{status:n??`all`,limit:r,offset:i,includePreview:a,executionTargetId:o}),c=s.handled?s.data.sessions:[],l=s.handled?s.data.total:0;e.setResult({sessions:c,total:l})})}function Ye(e){let{bus:t}=e;return t.on(O.close,async e=>{let{sessionId:n}=e.payload,r=await t.requestOptional(u.get,{sessionId:n}),i=r.handled?r.data.session:null;if(!i){e.setResult({success:!1});return}if(i.status===`closed`){e.setResult({success:!0});return}if(i.status!==`active`){e.setResult({success:!1});return}i.status=`closed`,i.lastActivityAt=Date.now(),await t.requestOptional(u.set,{sessionId:n,session:i}),await t.emit(O.closed,{sessionId:n}),e.setResult({success:!0})})}function Xe(e){let{bus:t}=e;return t.on(O.restartAgents,async e=>{let{sessionId:n}=e.payload,r=await t.requestOptional(f.listBySession,{sessionId:n}),i=r.handled?r.data.agents:[],a=[];for(let e of i)try{let n=await p(t,e,{cwd:e.cwd,model:e.model});await t.requestOptional(f.updateRuntime,{agentId:n.agentId,adapterId:n.adapterId}),a.push({agentId:n.agentId,adapterId:n.adapterId,success:!0})}catch(t){let n=t instanceof Error?t.cause:void 0,r=n instanceof Error?n.message:t instanceof Error?t.message:String(t);a.push({agentId:e.agentId,adapterId:e.adapterId,success:!1,error:r})}e.setResult({sessionId:n,results:a})})}function Ze(e){let{bus:t}=e;return t.on(O.update,async e=>{let{sessionId:n,executionTargetId:r,approvalPolicyOverride:i,title:a}=e.payload,o=await t.requestOptional(u.update,{sessionId:n,executionTargetId:r,approvalPolicyOverride:i,title:a}),s=o.handled?o.data.success:!1;if(s){let e=[];r!==void 0&&e.push(`executionTargetId`),i!==void 0&&e.push(`approvalPolicyOverride`),a!==void 0&&e.push(`title`),e.length>0&&await t.emit(O.updated,{sessionId:n,changedProperties:e})}e.setResult({success:s})})}function Qe(e){let{bus:t}=e;return t.on(O.archive,async e=>{let{sessionId:n}=e.payload,r=await t.requestOptional(u.get,{sessionId:n}),i=r.handled?r.data.session:null;if(!i){e.setResult({success:!1});return}if(i.status===`archived`){e.setResult({success:!0});return}if(i.status!==`closed`){e.setResult({success:!1});return}i.status=`archived`,i.lastActivityAt=Date.now(),await t.requestOptional(u.set,{sessionId:n,session:i}),await t.emit(O.archived,{sessionId:n}),e.setResult({success:!0})})}function $e(e){let{bus:t}=e;return t.on(O.purge,async e=>{let{sessionId:n}=e.payload,r=await t.requestOptional(u.get,{sessionId:n}),i=r.handled?r.data.session:null;if(!i){e.setResult({success:!1,error:`Session not found`});return}if(i.status!==`archived`){e.setResult({success:!1,error:`Cannot purge session unless archived. Call close then archive first.`});return}let a=await t.requestOptional(u.list,{status:`all`}),o=a.handled?a.data.sessions:[];for(let e of o)e.parentSessionId===n&&await t.requestOptional(u.set,{sessionId:e.sessionId,session:{...e,parentSessionId:void 0}});let c=await t.requestOptional(s.getEvents,{sessionId:n,options:{limit:1}}),l=c.handled?c.data.totalCount:0;await t.requestOptional(s.deleteBySession,{sessionId:n}),await t.requestOptional(u.delete,{sessionId:n}),await t.emit(O.purged,{sessionId:n}),e.setResult({success:!0,eventsDeleted:l})})}function et(e,t){let n=ae(`sha256`).update(`${e}\u0000${t}`).digest(`hex`);return`${n.slice(0,8)}-${n.slice(8,12)}-8${n.slice(13,16)}-9${n.slice(17,20)}-${n.slice(20,32)}`}async function tt(e,t,n,r){let i=await e.requestOptional(u.getByAdapterSessionId,{adapterSessionId:r,adapterName:n});if(i.handled&&i.data.session!==null){let e=i.data.session;if(e.adapterName===n)return{sessionId:e.sessionId,created:!1}}let a=await e.requestOptional(u.get,{sessionId:t}),o=a.handled?a.data.session:null;if(o!==null&&o.adapterName===n&&o.adapterSessionId===r)return{sessionId:o.sessionId,created:!1};throw Error(`session.registerExternal: session ID "${t}" already exists but does not carry adapter identity (${n}, ${r}); refusing to mis-attribute it`)}function nt(e){let{bus:t}=e;return t.on(O.registerExternal,async e=>{let{adapterName:n,adapterSessionId:r,lastClientIdentityObservation:i,sessionId:a,parentSessionId:o,contextInheritance:s,forkPointMessageId:c,branchKind:l,forkTransforms:d,title:f,targetWorkingDirectory:p,executionTargetId:m,spawningToolCallId:h,originWindowId:g}=e.payload,_=await t.requestOptional(u.getByAdapterSessionId,{adapterSessionId:r,adapterName:n});if(_.handled&&_.data.session!==null){let t=_.data.session;if(t.adapterName===n){e.setResult({sessionId:t.sessionId,created:!1});return}}let v=a??et(n,r),y=Date.now(),b={sessionId:v,createdAt:y,lastActivityAt:y,agents:[],status:`active`,adapterName:n,adapterSessionId:r,lastClientIdentityObservation:i,title:f,parentSessionId:o,contextInheritance:s,forkPointMessageId:c,branchKind:l,forkTransforms:d,targetWorkingDirectory:p,executionTargetId:m,spawningToolCallId:h},x=await t.requestOptional(u.set,{sessionId:v,session:b,ifAbsent:!0});if(x.handled&&!x.data.success){let i=await tt(t,v,n,r);e.setResult(i);return}await t.emit(O.created,{sessionId:v,createdAt:b.createdAt,parentSessionId:o??null,branchKind:l??null,originWindowId:g??`server`}),e.setResult({sessionId:v,created:!0})})}var rt=class extends xe{constructor(e=oe){super(e)}async onInit(){for(let e of Ue({bus:this.bus}))this.addCleanup(e);await this.reconcileOrphanedTurns()}async reconcileOrphanedTurns(){let t=await this.bus.requestOptional(e.listActive,{});if(!t.handled)return;let{turns:n}=t.data;for(let t of n)try{let{transitioned:n}=await this.bus.request(e.complete,{turnId:t.turnId,status:`error`,expectedStatus:`active`,error:`process-restart`});n&&await this.bus.emit(O.turn.completed,{sessionId:t.sessionId,turnId:t.turnId,turnNumber:t.turnNumber,success:!1,error:`process-restart`})}catch(e){console.error(`[MakaioSessionService] Failed to reconcile orphaned turn ${t.turnId}:`,e)}}};function it(e){return Error(`No adapter found for adapterName="${e}". Ensure adapter-runtime identity handlers are registered; adapter startup verifies live availability.`)}var at=class{bus;registry=new Map;cleanup;constructor(e){this.bus=e,this.cleanup=this.bus.on(E.initialized,e=>{this.registry.set(e.payload.adapterName,e.payload.adapterId)})}resolve(e){let t=this.registry.get(e);if(!t)throw it(e);return t}async resolveAvailable(e){try{let{adapterId:t}=await this.bus.request(ie.resolveId,{adapterName:e});return this.registry.set(e,t),t}catch{let t=this.registry.get(e);if(t)return t;throw it(e)}}destroy(){this.cleanup?.(),this.cleanup=void 0,this.registry.clear()}};function ot(e,t,n,r){return e.on(s.append,e=>{let{event:i}=e.payload,a=t.get(i.sessionId)??[];if(n.has(i.eventId)){e.setResult({success:!0});return}a.push(i),t.set(i.sessionId,a),n.set(i.eventId,r()),e.setResult({success:!0})})}function st(e,t,n){return e.on(s.getEvents,e=>{let{sessionId:r,options:i}=e.payload,a=t.get(r)??[],o=i?.order??`asc`,s=o===`desc`?[...a].reverse():a,c=0;if(i?.after&&/^\d+$/.test(i.after)){let t=Number(i.after),r=s.findIndex(e=>{let r=n.get(e.eventId)??-1;return o===`desc`?r<t:r>t});if(r===-1){e.setResult({events:[],nextCursor:null,totalCount:a.length});return}c=r}let l=s.slice(c);if(i?.types&&i.types.length>0){let e=new Set(i.types);l=l.filter(t=>e.has(t.type))}let u=i?.limit??100,d=l.length>u,f=l.slice(0,u),p=null;if(d&&f.length>0){let e=f[f.length-1],t=n.get(e.eventId);t!==void 0&&(p=t.toString())}e.setResult({events:f,nextCursor:p,totalCount:a.length})})}function ct(e,t){return e.on(s.getByIds,e=>{let{sessionId:n,eventIds:r}=e.payload,i=t.get(n)??[],a=new Set(r),o=i.filter(e=>a.has(e.eventId));e.setResult({events:o})})}function lt(e,t,n){return e.on(s.deleteBySession,e=>{let{sessionId:r}=e.payload,i=t.get(r);if(i)for(let e of i)n.delete(e.eventId);let a=i?.length??0;t.delete(r),e.setResult({success:!0,deletedCount:a})})}function ut(e,t){return e.on(s.getEventsBySessions,e=>{let{sessionIds:n,types:r,limitPerSession:i=50}=e.payload;if(n.length===0||r.length===0){e.setResult({eventsBySession:{}});return}let a=new Set(r),o={};for(let e of n){let n=(t.get(e)??[]).filter(e=>a.has(e.type)).reverse().slice(0,i);n.length>0&&(o[e]=n)}e.setResult({eventsBySession:o})})}function dt(e){let t=new Map,n=new Map,r=1,i=[ot(e,t,n,()=>r++),st(e,t,n),ct(e,t),lt(e,t,n),ut(e,t)];return()=>i.forEach(e=>e())}const ft=o.postgres,pt=j({sessionEvents:l},{sessionEvents:ft}),mt=[`sessionId`,`agentId`,`adapterId`,`messageId`,`turnId`];function ht(e){let t=e.payload,n={};for(let[e,r]of Object.entries(t))mt.includes(e)||(n[e]=r);return n}function gt(e){let t=JSON.parse(e.payload),n=e.type===`message`?e.messageId:e.originatingMessageId,r={...t,sessionId:e.sessionId,...e.agentId&&{agentId:e.agentId},...e.adapterId&&{adapterId:e.adapterId},...n&&{messageId:n},...e.type===`message`?{turnId:e.turnId??null}:e.turnId&&{turnId:e.turnId}};return{sessionId:e.sessionId,eventId:e.eventId,timestamp:e.timestamp,type:e.type,payload:r}}function _t(e){switch(e.type){case`user_message.sent`:{let t=e.payload.content;return typeof t==`string`?t:(Array.isArray(t.blocks)?t.blocks:[t.blocks]).filter(e=>e.type===`text`).map(e=>e.content).join(`
|
|
2
|
+
`)}case`agent.added`:case`user_message.acknowledged`:case`user_message.completed`:case`turn.started`:case`turn.completed`:case`message`:case`branch.created`:case`branch.merged`:case`squash`:return null;default:return vt(e.payload)}}function vt(e){let t=e.contentText;if(typeof t==`string`&&t.length>0)return t;let n=e.summary;return typeof n==`string`&&n.length>0?n:null}function yt({bus:e,db:t,sessionEvents:n}){return e.on(s.append,async e=>{let{event:r}=e.payload,i=`payload`in r&&`agentId`in r.payload?r.payload.agentId:null,a=`payload`in r&&`adapterId`in r.payload?r.payload.adapterId:null,o=`payload`in r&&`turnId`in r.payload?r.payload.turnId:null,s=`payload`in r&&`messageId`in r.payload?r.payload.messageId:null,c=r.type===`message`?s:null,l=r.type===`message`?null:s,u={sessionId:r.sessionId,eventId:r.eventId,timestamp:r.timestamp,type:r.type,agentId:i,adapterId:a,messageId:c,originatingMessageId:l,turnId:o,contentText:_t(r),payload:JSON.stringify(ht(r))};await t.insert(n).values(u).onConflictDoNothing(),e.setResult({success:!0})})}function bt({bus:e,db:t,sessionEvents:n}){return e.on(s.getEvents,async e=>{let{sessionId:r,options:i}=e.payload,a=[z(n.sessionId,r)],o=i?.order??`asc`;if(i?.after){let e=parseInt(i.after,10);!isNaN(e)&&e>0&&(o===`desc`?a.push(Ie(n.id,e)):a.push(Pe(n.id,e)))}i?.types&&i.types.length>0&&a.push(B(n.type,i.types));let s=i?.limit??100,c=o===`desc`?R:I,l=await t.select().from(n).where(F(...a)).orderBy(c(n.id)).limit(s+1),u=l.length>s,d=u?l.slice(0,s):l,f=d.map(gt),p=u&&d.length>0?d[d.length-1].id.toString():null;e.setResult({events:f,nextCursor:p})})}function xt({bus:e,db:t,sessionEvents:n}){return e.on(s.getByIds,async e=>{let{sessionId:r,eventIds:i}=e.payload,a=(await t.select().from(n).where(F(z(n.sessionId,r),B(n.eventId,i))).orderBy(I(n.timestamp))).map(gt);e.setResult({events:a})})}function St({bus:e,db:t,sessionEvents:n}){return e.on(s.deleteBySession,async e=>{let{sessionId:r}=e.payload,i=(await t.select().from(n).where(z(n.sessionId,r))).length;await t.delete(n).where(z(n.sessionId,r)),e.setResult({success:!0,deletedCount:i})})}function Ct({bus:e,db:t,sessionEvents:n}){return e.on(s.getEventsBySessions,async e=>{let{sessionIds:r,types:i,limitPerSession:a=50}=e.payload;if(r.length===0||i.length===0){e.setResult({eventsBySession:{}});return}let o={};for(let e of r){let r=await t.select().from(n).where(F(z(n.sessionId,e),B(n.type,i))).orderBy(R(n.timestamp)).limit(a);r.length>0&&(o[e]=r.map(gt))}e.setResult({eventsBySession:o})})}function wt(e,t){let{sessionEvents:n}=N(t,pt),r={bus:e,db:t,sessionEvents:n},i=[yt(r),bt(r),xt(r),St(r),Ct(r)];return()=>i.forEach(e=>e())}async function Tt(e,t){e.emit(C.stored,{message:structuredClone(t)});try{await e.request(s.append,{event:{sessionId:t.sessionId,eventId:crypto.randomUUID(),timestamp:t.timestamp,type:`message`,payload:{messageId:t.messageId,turnId:t.turnId,role:t.role}}})}catch(e){console.error(`[MessageStorage] Failed to emit session event for message:`,e)}}function U(e){return{messageId:e.messageId,turnId:e.turnId,sessionId:e.sessionId,role:e.role,contentText:e.contentText,blocks:JSON.parse(e.blocks),agentId:e.agentId??void 0,adapterSessionId:e.adapterSessionId??void 0,adapterMessageId:e.adapterMessageId??void 0,timestamp:e.timestamp,editOf:e.editOf??void 0,origin:e.origin??void 0}}function Et(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.append,async e=>{let{message:i,emitEvent:a}=e.payload,o=i.messageId??crypto.randomUUID(),s={...i,messageId:o,blocks:i.blocks??[]};await n.insert(r).values({messageId:o,turnId:s.turnId,sessionId:s.sessionId,role:s.role,contentText:s.contentText,blocks:JSON.stringify(s.blocks),agentId:s.agentId??null,adapterSessionId:s.adapterSessionId??null,adapterMessageId:s.adapterMessageId??null,timestamp:s.timestamp,editOf:s.editOf??null,origin:s.origin??null}),e.setResult({message:s}),(a??!0)&&await Tt(t,s)})}function Dt(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.getBySession,async e=>{let{sessionId:t,limit:i,after:a,includeAfter:o=!1,order:s=`asc`}=e.payload,c=s===`desc`?R:I,l=n.select().from(r).where(z(r.sessionId,t)).orderBy(c(r.timestamp),c(r.messageId));if(a){let e=s===`desc`?Re(Ie(r.timestamp,a.timestamp),F(z(r.timestamp,a.timestamp),o?Le(r.messageId,a.messageId):Ie(r.messageId,a.messageId))):Re(Pe(r.timestamp,a.timestamp),F(z(r.timestamp,a.timestamp),o?Fe(r.messageId,a.messageId):Pe(r.messageId,a.messageId)));l=n.select().from(r).where(F(z(r.sessionId,t),e)).orderBy(c(r.timestamp),c(r.messageId))}let u=i??100,d=await l.limit(u+1),f=d.length>u,p=f?d.slice(0,u):d,m=f&&p.length>0?k(p[p.length-1]):null;e.setResult({messages:p.map(U),nextCursor:m})})}function Ot(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.getByTurn,async e=>{let{turnId:t}=e.payload,i=await n.select().from(r).where(z(r.turnId,t)).orderBy(I(r.timestamp));e.setResult({messages:i.map(U)})})}function kt(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.get,async e=>{let{messageId:t}=e.payload,[i]=await n.select().from(r).where(z(r.messageId,t)).limit(1);e.setResult({message:i?U(i):null})})}function At(e){let{bus:t,db:n}=e,{messages:r}=N(n,c),i=P(n).fts;return t.on(C.search,async e=>{let{query:t,sessionId:a,limit:o}=e.payload,s=o??50;if(!t.trim()){e.setResult({messages:[],total:0});return}let{rows:c,total:l}=await i.searchMessages(n,r,{query:t,sessionId:a,limit:s});e.setResult({messages:c.map(U),total:l})})}function jt(e){let{bus:t,db:n}=e,{messages:r}=N(n,c),i=P(n).fts;return t.on(C.ftsSearch,async e=>{let{query:t,sessionId:a,limit:o=20}=e.payload;if(!t.trim()){e.setResult({results:[],total:0});return}let{results:s,total:c}=await i.searchMessageExcerpts(n,r,{query:t,sessionId:a,limit:o});e.setResult({results:s,total:c})})}function Mt(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.getByAdapterMessageId,async e=>{let{adapterMessageId:t}=e.payload,[i]=await n.select().from(r).where(z(r.adapterMessageId,t)).limit(1);e.setResult({message:i?U(i):null})})}function Nt(e){let{bus:t,db:n}=e,{messages:r}=N(n,c);return t.on(C.upsertByAdapterMessageId,async e=>{let{adapterMessageId:i,sessionId:a,turnId:o,role:s,contentText:c,blocks:l,agentId:u,adapterSessionId:d,timestamp:f,origin:p}=e.payload,[m]=await n.select({messageId:r.messageId}).from(r).where(z(r.adapterMessageId,i)).limit(1);if(m){e.setResult({messageId:m.messageId,created:!1});return}let h=crypto.randomUUID();await n.insert(r).values({messageId:h,turnId:o,sessionId:a,role:s,contentText:c,blocks:JSON.stringify(l),agentId:u??null,adapterSessionId:d??null,adapterMessageId:i,timestamp:f,editOf:null,origin:p??null}),e.setResult({messageId:h,created:!0}),await Tt(t,{messageId:h,sessionId:a,turnId:o,role:s,contentText:c,blocks:l,agentId:u??void 0,adapterSessionId:d??void 0,adapterMessageId:i,timestamp:f,editOf:void 0,origin:p??void 0})})}function Pt(e,t){let n={bus:e,db:t},r=[Et(n),Dt(n),Ot(n),kt(n),At(n),jt(n),Nt(n),Mt(n)];return()=>r.forEach(e=>e())}function Ft(e,t){return _e(k(e),k(t))}function It(e,t){return ve(k(e),k(t))}function Lt(e){let t=new Map,n=new Map,r=new Map,i=new Map,a=Rt(t,n,r,i),o=[zt(e,t,a),Bt(e,t,n),Vt(e,t,r),Ht(e,t),Ut(e,t),Wt(e,i,a),Gt(e,t,n,r,i)];return()=>o.forEach(e=>e())}function Rt(e,t,n,r){return i=>{e.set(i.messageId,i);let a=t.get(i.sessionId)??[];if(a.push(i.messageId),t.set(i.sessionId,a),i.turnId){let e=n.get(i.turnId)??[];e.push(i.messageId),n.set(i.turnId,e)}i.adapterMessageId&&r.set(i.adapterMessageId,i.messageId)}}function zt(e,t,n){return e.on(C.append,async t=>{let{message:r,emitEvent:i}=t.payload,a=r.messageId??crypto.randomUUID(),o={...r,messageId:a,blocks:r.blocks??[]};n(o),t.setResult({message:o}),(i??!0)&&await Tt(e,o)})}function Bt(e,t,n){return e.on(C.getBySession,async e=>{let{sessionId:r,limit:i,after:a,includeAfter:o=!1,order:s=`asc`}=e.payload,c=n.get(r)??[],l=s===`desc`?It:Ft,u=c.map(e=>t.get(e)).filter(e=>!!e).sort(l);a&&(u=u.filter(e=>{let t=s===`desc`?ve(k(e),a):_e(k(e),a);return o?t>=0:t>0}));let d=i??100,f=u.length>d,p=f?u.slice(0,d):u,m=f&&p.length>0?k(p[p.length-1]):null;e.setResult({messages:p,nextCursor:m})})}function Vt(e,t,n){return e.on(C.getByTurn,async e=>{let{turnId:r}=e.payload,i=(n.get(r)??[]).map(e=>t.get(e)).filter(e=>!!e).sort(Ft);e.setResult({messages:i})})}function Ht(e,t){return e.on(C.get,async e=>{e.setResult({message:t.get(e.payload.messageId)??null})})}function Ut(e,t){return e.on(C.search,async e=>{let{query:n,sessionId:r,limit:i}=e.payload,a=i??50,o=n.trim().toLowerCase(),s=[...t.values()].filter(e=>r?e.sessionId===r:!0),c=o.length===0?[]:s.filter(e=>e.contentText.toLowerCase().includes(o));c.sort(Ft),e.setResult({messages:c.slice(0,a),total:c.length})})}function Wt(e,t,n){return e.on(C.upsertByAdapterMessageId,async r=>{let{adapterMessageId:i,sessionId:a,turnId:o,role:s,contentText:c,blocks:l,agentId:u,adapterSessionId:d,timestamp:f,origin:p}=r.payload,m=t.get(i);if(m){r.setResult({messageId:m,created:!1});return}let h=crypto.randomUUID(),g={messageId:h,sessionId:a,turnId:o,role:s,contentText:c,blocks:l,agentId:u??void 0,adapterSessionId:d??void 0,adapterMessageId:i,timestamp:f,editOf:void 0,origin:p??void 0};n(g),r.setResult({messageId:h,created:!0}),await Tt(e,g)})}function Gt(e,t,n,r,i){return e.on(u.delete,e=>{let{sessionId:a}=e.payload,o=n.get(a)??[];for(let e of o){let n=t.get(e);if(n){if(t.delete(e),n.turnId){let t=(r.get(n.turnId)??[]).filter(t=>t!==e);t.length===0?r.delete(n.turnId):r.set(n.turnId,t)}n.adapterMessageId&&i.delete(n.adapterMessageId)}}n.delete(a)})}const Kt=je(`message_routing`,e=>({messageId:e.text(`message_id`).notNull().references(a,{onDelete:`cascade`}),agentId:e.text(`agent_id`).notNull(),status:e.textEnum(`status`,{enum:[`sent`,`acknowledged`,`completed`]}).notNull(),timestamp:e.epochMs(`timestamp`).notNull(),error:e.text(`error`)}),{sqlite:e=>[Ee({columns:[e.messageId,e.agentId,e.status]}),we(`idx_routing_agent`).on(e.agentId,e.timestamp)],postgres:e=>[Ae({columns:[e.messageId,e.agentId,e.status]}),ke(`idx_routing_agent`).on(e.agentId,e.timestamp)]}),qt=Kt.sqlite,Jt=Se(`messageRouting`,{schemas:{record:{request:fe,response:T.object({success:T.boolean()})},getByMessage:{request:T.object({messageId:T.string()}),response:T.object({routing:T.array(fe)})},getCompleted:{request:T.object({messageId:T.string()}),response:T.object({agentIds:T.array(T.string())})},isComplete:{request:T.object({messageId:T.string(),targetAgentIds:T.array(T.string())}),response:T.object({complete:T.boolean(),pending:T.array(T.string())})}},extensions:{drizzle:{messageRouting:qt}}}),W=Jt.subjects,Yt=Kt.postgres,Xt=j({messageRouting:qt},{messageRouting:Yt});function Zt(e){return{messageId:e.messageId,agentId:e.agentId,status:e.status,timestamp:e.timestamp,error:e.error??void 0}}function Qt(e,t){let{messageRouting:n}=N(t,Xt),r=[];return r.push(e.on(W.record,async e=>{let{messageId:r,agentId:i,status:a,timestamp:o,error:s}=e.payload;await t.insert(n).values({messageId:r,agentId:i,status:a,timestamp:o,error:s??null}).onConflictDoUpdate({target:[n.messageId,n.agentId,n.status],set:{timestamp:o,error:s??null}}),e.setResult({success:!0})})),r.push(e.on(W.getByMessage,async e=>{let{messageId:r}=e.payload,i=await t.select().from(n).where(z(n.messageId,r));e.setResult({routing:i.map(Zt)})})),r.push(e.on(W.getCompleted,async e=>{let{messageId:r}=e.payload,i=await t.select().from(n).where(F(z(n.messageId,r),z(n.status,`completed`)));e.setResult({agentIds:i.map(e=>e.agentId)})})),r.push(e.on(W.isComplete,async e=>{let{messageId:r,targetAgentIds:i}=e.payload,a=await t.select().from(n).where(F(z(n.messageId,r),z(n.status,`completed`))),o=new Set(a.map(e=>e.agentId)),s=i.filter(e=>!o.has(e));e.setResult({complete:s.length===0,pending:s})})),()=>r.forEach(e=>e())}var $t=class{byAgent=new Map;add(e){let t=this.byAgent.get(e.agentId);t?(t.inputTokens+=e.inputTokens,t.outputTokens+=e.outputTokens):this.byAgent.set(e.agentId,{inputTokens:e.inputTokens,outputTokens:e.outputTokens})}snapshot(){if(this.byAgent.size===0)return;let e=0,t=0,n={};for(let[r,i]of this.byAgent)e+=i.inputTokens,t+=i.outputTokens,n[r]={...i};return{total:{inputTokens:e,outputTokens:t},byAgent:n}}flush(){let e=this.snapshot();return this.byAgent.clear(),e}clear(){this.byAgent.clear()}},en=class{bus;activeTurns=new Map;usageAccumulators=new Map;completingSessions=new Set;bufferedUsageDuringCompletion=new Map;syntheticTurnCounters=new Map;cleanups=[];constructor(e){this.bus=e}async createTurn(t,n,r,i){let a=await this.bus.requestOptional(e.create,{sessionId:t,...i!==void 0&&{turnId:i},...r!==void 0&&{initiator:r}}),o,s;if(a.handled)o=a.data.turn.turnId,s=a.data.turn.turnNumber;else{o=i??crypto.randomUUID();let e=(this.syntheticTurnCounters.get(t)??0)+1;this.syntheticTurnCounters.set(t,e),s=e}let c=new S({sessionId:t,agentIds:n,turnId:o,turnNumber:s,initiator:r});return this.activeTurns.set(t,c),this.usageAccumulators.set(t,new $t),c}registerCompletionHandlers(e){this.cleanups.push(this.bus.on(D.usage,e=>{let{agentId:t,turnId:n,inputTokens:r,outputTokens:i}=e.payload;if(!n){console.warn(`[SessionTurnManager] Dropping usage event without turnId (agentId=${t}).`);return}let a=this.findActiveTurnByTurnId(n);if(!a){console.warn(`[SessionTurnManager] Dropping usage for inactive turn ${n} (agentId=${t}).`);return}if(!a.hasAgent(t)){console.warn(`[SessionTurnManager] Dropping usage for turn ${n}: agent ${t} is not part of the turn.`);return}if(this.completingSessions.has(a.sessionId)){this.bufferUsageDuringCompletion(a.sessionId,{agentId:t,inputTokens:r,outputTokens:i});return}this.usageAccumulators.get(a.sessionId)?.add({agentId:t,inputTokens:r,outputTokens:i})})),this.cleanups.push(this.bus.on(D.complete,async t=>{let{agentId:n,outcome:r,error:i}=t.payload,a=r!==`error`;await this.handleAgentCompletion(n,a,a?void 0:i,e)}))}async completeTurn(t,n){if(this.completingSessions.has(t.sessionId))return;this.completingSessions.add(t.sessionId);let r=this.usageAccumulators.get(t.sessionId),i=r?.snapshot();try{await this.bus.requestOptional(e.complete,{turnId:t.turnId,status:n.success?`completed`:`error`,error:n.errors.length>0?n.errors.join(`; `):void 0,...i!==void 0&&{usage:i}});let a=this.bufferedUsageDuringCompletion.get(t.sessionId)??[];if(a.length>0){for(let e of a)r?.add(e);this.bufferedUsageDuringCompletion.delete(t.sessionId);let i=r?.snapshot();await this.bus.requestOptional(e.complete,{turnId:t.turnId,status:n.success?`completed`:`error`,error:n.errors.length>0?n.errors.join(`; `):void 0,...i!==void 0&&{usage:i}})}}catch(e){throw this.completingSessions.delete(t.sessionId),console.error(`[SessionTurnManager] Failed to persist completion for turn ${t.turnId}:`,e),e}r?.clear(),this.activeTurns.delete(t.sessionId),this.usageAccumulators.delete(t.sessionId),this.completingSessions.delete(t.sessionId),await this.bus.emit(O.turn.completed,{sessionId:t.sessionId,turnId:t.turnId,turnNumber:t.turnNumber,success:n.success,error:n.errors.length>0?n.errors.join(`; `):void 0,initiator:t.initiator})}getActiveTurn(e){return this.activeTurns.get(e)}getActiveTurnsMap(){return this.activeTurns}findActiveTurnByTurnId(e){for(let t of this.activeTurns.values())if(t.turnId===e)return t}destroy(){for(let e of this.cleanups)e();this.cleanups.length=0,this.activeTurns.clear(),this.usageAccumulators.clear(),this.completingSessions.clear(),this.bufferedUsageDuringCompletion.clear(),this.syntheticTurnCounters.clear()}async handleAgentCompletion(e,t,n,r){let i=b(this.activeTurns,e);if(!i)return;let a=t?i.markAgentCompleted(e):i.markAgentErrored(e,n??`Unknown error`);for(let r of i.messageIds)await this.bus.emit(O.user_message.completed,{sessionId:i.sessionId,turnId:i.turnId,turnNumber:i.turnNumber,messageId:r,agentId:e,outcome:t?`completed`:`error`,error:n});a.turnComplete&&await r(i,a.result)}bufferUsageDuringCompletion(e,t){let n=this.bufferedUsageDuringCompletion.get(e)??[];n.push(t),this.bufferedUsageDuringCompletion.set(e,n)}},tn=class{bus;turnManager;adapterRegistry;cleanups=[];constructor(e=oe,t){this.bus=e,this.turnManager=new en(e),this.adapterRegistry=new at(e),this.registerSendMessageHandler(),this.turnManager.registerCompletionHandlers(this.completeTurn.bind(this))}registerSendMessageHandler(){this.cleanups.push(this.bus.on(O.sendMessage,async e=>{let{sessionId:t,message:n,agentIds:r,deliveryMode:i,agent:a,source:o,origin:s}=e.payload,c=x(o,e.payload.extensionId),l=e.payload.sessionContext?pe.parse(e.payload.sessionContext):void 0,{sessionId:u,session:p}=await v(this.bus,t,l,e.payload.originWindowId);if(p.agents.length===0){let e=await this.resolveInitialAdapterSelection(a,u,n,l),t=await this.resolveAdapterName(e,u),r=h(e.adapterId)??await this.adapterRegistry.resolveAvailable(t),i=e.providerConfigId===void 0?void 0:await ne(this.bus,e.providerConfigId);i!==void 0&&await re(this.bus,i);let o=await this.bus.request(E.startAgent,{adapterId:r,sessionId:u,role:`lead`,...i!==void 0&&{providerContext:i},...e.model!==void 0&&{model:e.model},...e.reasoningEffort!==void 0&&{reasoningEffort:e.reasoningEffort},...e.cwd!==void 0&&{cwd:e.cwd},...e.systemPrompt!==void 0&&{systemPrompt:e.systemPrompt},...e.allowedTools!==void 0&&{allowedTools:e.allowedTools},...e.disallowedTools!==void 0&&{disallowedTools:e.disallowedTools},...e.env!==void 0&&{env:e.env},...e.mcpSessionContext!==void 0&&{mcpSessionContext:e.mcpSessionContext},...e.allowedDirectories!==void 0&&{allowedDirectories:e.allowedDirectories},...l!==void 0&&{sessionContext:l}});if(!o.success)throw Error(`[SessionOrchestrator.sendMessage] Failed to start agent (sessionId=${u}, adapterName=${t}): ${o.message}`);let s=Date.now();p.agents.push({agentId:o.agentId,adapterId:o.adapterId,adapterName:t,sessionId:u,role:`lead`,status:`idle`,...e.providerConfigId!==void 0&&{providerConfigId:e.providerConfigId},createdAt:s,lastActivityAt:s}),p.leadAgentId=o.agentId,e.providerConfigId!==void 0&&await this.bus.requestOptional(f.updateRuntime,{agentId:o.agentId,providerConfigId:e.providerConfigId})}let g=_(p,r);if(g.length===0)throw Error(`[SessionOrchestrator.sendMessage] No valid target agents found (sessionId=${u})`);let y=new Set;for(let e of g){let t=await this.bus.requestOptional(E.getAgent,{agentId:e.agentId,adapterId:e.adapterId});t.handled&&t.data.agent===null&&y.add(e.agentId)}let b;if(y.size>0){b=await d(this.bus,p);for(let e of g)y.has(e.agentId)&&await this.bus.requestOptional(E.rehydrateAgent,{agentId:e.agentId,adapterId:e.adapterId})}let S=this.turnManager.getActiveTurn(u),ie=!S;S||=await this.turnManager.createTurn(u,g.map(e=>e.agentId),c,e.payload.turnId);let w=crypto.randomUUID();S.addMessage(w);let T=te(n);this.bus.requestOptional(C.append,{message:{messageId:w,turnId:S.turnId,sessionId:u,role:`user`,contentText:m(n),blocks:T,timestamp:Date.now(),...s!==void 0&&{origin:s}}}).catch(e=>{console.warn(`[SessionOrchestrator] Failed to store user message`,{sessionId:u,messageId:w,error:e instanceof Error?e.message:String(e)})});for(let e of g)this.bus.requestOptional(W.record,{messageId:w,agentId:e.agentId,status:`sent`,timestamp:Date.now()}).catch(t=>{console.warn(`[SessionOrchestrator] Failed to record message routing`,{sessionId:u,messageId:w,agentId:e.agentId,error:t instanceof Error?t.message:String(t)})});ie&&await this.bus.emit(O.turn.started,{sessionId:u,turnId:S.turnId,turnNumber:S.turnNumber,messageId:w,agentIds:[...S.agentIds],initiator:S.initiator}),await this.bus.emit(O.user_message.sent,{sessionId:u,turnId:S.turnId,turnNumber:S.turnNumber,messageId:w,content:n,agentIds:g.map(e=>e.agentId),...o!==void 0&&{source:o},...s!==void 0&&{origin:s}});let ae=b?{...l,...b}:l;await ee(this.bus,p,g,n,w,S,i,this.completeTurn.bind(this),ae,e.payload.responseSchema),e.setResult({messageId:w,turnId:S.turnId,sessionId:u})}))}async completeTurn(e,t){await this.turnManager.completeTurn(e,t)}destroy(){for(let e of this.cleanups)e();this.cleanups.length=0,this.turnManager.destroy(),this.adapterRegistry.destroy()}async resolveAdapterName(e,t){let n=h(e.adapterName),r=h(e.adapterId);if(!n&&!r)throw Error(`[SessionOrchestrator.sendMessage] adapterName or adapterId required when session has no agents (sessionId=${t})`);return r?g(this.bus,r,n,`[SessionOrchestrator.sendMessage] (sessionId=${t}) `):n}async resolveInitialAdapterSelection(e,t,n,r){if(!e)throw Error(`[SessionOrchestrator.sendMessage] agent selection required when session has no agents (sessionId=${t})`);if(e.kind===`adapter`)return e;if(e.kind===`canonical-model`)return await this.resolveCanonicalModelSelection(e,t,n,r);throw Error(`[SessionOrchestrator.sendMessage] agent with kind: 'adapter' or 'canonical-model' required when session has no agents (sessionId=${t})`)}async resolveCanonicalModelSelection(e,t,n,r){let i=be(e.model);if(ye(i))throw Error(`[SessionOrchestrator.sendMessage] Invalid canonical model "${e.model}" (sessionId=${t}): ${i.message}`);if(i.kind===`virtual`)throw Error(`[SessionOrchestrator.sendMessage] Virtual canonical models require a host resolver (sessionId=${t})`);let a=await this.bus.request(le.resolve,{parsed:i,context:{sessionId:t,promptText:m(n),...r===void 0?{}:{sessionContext:r}}});return{...e,...a,kind:`adapter`,providerConfigId:e.providerConfigId??a.providerConfigId}}},nn=class{bus;constructor(e){this.bus=e}async getTurnSoFarContext(e){try{let{messages:t}=await this.bus.request(C.getByTurn,{turnId:e});return this.convertSessionMessagesToMessages(t)}catch(e){return e instanceof se||console.warn(`[TurnContextEnricher] Failed to load turn-so-far context:`,e),[]}}async enrichForDeliveryMode(e,t,n){if(n!==`immediate`)return e;let r=await this.getTurnSoFarContext(t);return r.length===0?e:[...e??[],...r]}convertSessionMessagesToMessages(e){return e.map(e=>({role:e.role,blocks:e.blocks}))}};function rn(e){let{bus:t}=e;return t.on(O.getStatusCounts,async e=>{e.payload;let{all:n,active:r,closed:i,archived:a,discovered:o}=await t.request(u.getStatusCounts,{});e.setResult({all:n,active:r,closed:i,archived:a,discovered:o})})}function an(e){let{bus:t}=e;return t.on(O.resume,async e=>{let{sessionId:n}=e.payload,{session:r}=await t.request(u.get,{sessionId:n});if(!r||r.status!==`closed`){e.setResult({success:!1});return}r.status=`active`,r.lastActivityAt=Date.now(),await t.request(u.set,{sessionId:n,session:r}),await t.emit(O.resumed,{sessionId:n}),e.setResult({success:!0})})}function on(e){return e.on(w.listActions,e=>{let t=y.getAll().map(e=>({id:e.id,label:e.label,description:e.description,category:e.category}));e.setResult({actions:t})})}const sn=[{actionId:`strip-reasoning`},{actionId:`strip-tool-outputs`}];function cn(e){return{...e.cwd!==void 0&&{cwd:e.cwd},...e.systemPrompt!==void 0&&{systemPrompt:e.systemPrompt},...e.allowedTools!==void 0&&{allowedTools:e.allowedTools},...e.disallowedTools!==void 0&&{disallowedTools:e.disallowedTools}}}var ln=class{bus;agentToSession=new Map;agentContext=new Map;agentBlocks=new Map;cleanups=[];constructor(e=oe){this.bus=e,this.registerHandlers()}registerHandlers(){this.registerMappingHandlers(),this.registerTurnTrackingHandlers(),this.registerBlockAccumulationHandlers()}registerMappingHandlers(){this.cleanups.push(this.bus.on(O.agent.added,e=>{this.agentToSession.set(e.payload.agentId,e.payload.sessionId)})),this.cleanups.push(this.bus.on(O.closed,e=>{for(let[t,n]of this.agentToSession)n===e.payload.sessionId&&(this.agentToSession.delete(t),this.agentContext.delete(t),this.agentBlocks.delete(t))}))}registerTurnTrackingHandlers(){this.cleanups.push(this.bus.on(O.turn.started,e=>{let{sessionId:t,turnId:n,agentIds:r}=e.payload;for(let e of r){let r=this.agentContext.get(e);this.agentContext.set(e,{...r,sessionId:t,turnId:n}),this.agentBlocks.set(e,[])}})),this.cleanups.push(this.bus.on(O.user_message.acknowledged,e=>{let t=this.agentContext.get(e.payload.agentId);this.agentContext.set(e.payload.agentId,{...t,sessionId:e.payload.sessionId,turnId:e.payload.turnId}),this.agentBlocks.has(e.payload.agentId)||this.agentBlocks.set(e.payload.agentId,[])}))}registerBlockAccumulationHandlers(){this.cleanups.push(this.bus.on(D.message,e=>{let t=this.agentBlocks.get(e.payload.agentId);t&&t.push({type:`text`,content:e.payload.content})})),this.cleanups.push(this.bus.on(D.reasoning,e=>{let t=this.agentBlocks.get(e.payload.agentId);t&&t.push({type:`reasoning`,content:e.payload.content})})),this.cleanups.push(this.bus.on(D.tool.use,e=>{let t=this.agentBlocks.get(e.payload.agentId);t&&t.push({type:`tool_call`,toolCallId:e.payload.toolCallId,name:e.payload.toolName,args:e.payload.args??{}})})),this.cleanups.push(this.bus.on(D.tool.completed,e=>{let t=this.agentBlocks.get(e.payload.agentId);if(t){let n=e.payload.result,r=typeof n==`string`?n:JSON.stringify(n);t.push({type:`tool_output`,toolCallId:e.payload.toolCallId,output:r,isError:e.payload.success===!1})}})),this.cleanups.push(this.bus.on(D.complete,async e=>{if(e.payload._import){this.agentBlocks.delete(e.payload.agentId);return}let{agentId:t,adapterSessionId:n,outcome:r,error:i,message:a,structuredOutputValidation:o}=e.payload;await this.storeAssistantMessage(t,r===`error`?void 0:n,r===`error`?i:void 0,o===void 0?void 0:{content:a})}))}async storeAssistantMessage(e,t,n,r){let i=this.agentContext.get(e);if(!i?.turnId)return;let a=r===void 0?this.agentBlocks.get(e)??[]:r.content===void 0?[]:[{type:`text`,content:r.content}];if(a.length===0&&!n){this.agentBlocks.delete(e);return}let o=a.filter(e=>e.type===`text`).map(e=>e.content).join(`
|
|
3
|
+
`),s=crypto.randomUUID();try{if(!(await this.bus.requestOptional(C.append,{message:{messageId:s,turnId:i.turnId,sessionId:i.sessionId,role:`assistant`,contentText:o||(n?`[Error: ${n}]`:``),blocks:a,agentId:e,adapterSessionId:t,timestamp:Date.now()}})).handled){this.agentBlocks.delete(e);return}let r=await this.bus.requestOptional(C.getByTurn,{turnId:i.turnId});if(r.handled){let t=r.data.messages.find(e=>e.role===`user`);t&&await this.bus.requestOptional(W.record,{messageId:t.messageId,agentId:e,status:`completed`,timestamp:Date.now(),error:n})}}catch(e){console.error(`[SessionBridge] Failed to store assistant message:`,e)}this.agentBlocks.delete(e)}destroy(){for(let e of this.cleanups)e();this.cleanups.length=0,this.agentToSession.clear(),this.agentContext.clear(),this.agentBlocks.clear()}},un=class{bus;_sessionId;_extensionId;_turnId;_parentSessionId;contextTracker;contextContributions=new Map;constructor(e,t,n,r,i,a){this.bus=e,this._sessionId=t,this._extensionId=n,this._turnId=r,this._parentSessionId=i,this.contextTracker=a}get sessionId(){return this._sessionId}get turnId(){return this._turnId}get parentSessionId(){return this._parentSessionId}get extensionId(){return this._extensionId}async sendToAgent(e,t){await this.bus.request(O.sendMessage,{sessionId:this._sessionId,agentIds:[e],message:t,source:`extension`,extensionId:this._extensionId})}contributeContext(e,t){this.contextContributions.set(e,t)}getContributions(){return Object.fromEntries(this.contextContributions)}async fork(e){return(await this.bus.request(O.fork,{sourceSessionId:this._sessionId,name:e.reason})).sessionId}async merge(e,t){await this.bus.request(O.merge,{parentSessionId:this._sessionId,childSessionId:e,summary:t,source:`extension`,extensionId:this._extensionId})}async abandon(e){await this.bus.request(O.abandon,{parentSessionId:this._sessionId,childSessionId:e,source:`extension`,extensionId:this._extensionId})}async requestCompression(e){await this.bus.emit(O.compressionRequested,{sessionId:this._sessionId,reason:e,source:`extension`,extensionId:this._extensionId})}async getContextWindowState(){if(this.contextTracker){let e=this.contextTracker.getSessionState(this._sessionId);if(e)return{currentTokens:e.currentTokens,maxTokens:e.maxTokens,percentage:e.percentage,level:e.level}}let{session:e}=await this.bus.request(O.get,{sessionId:this._sessionId});return!e||e.agents.length===0?{currentTokens:0,maxTokens:1,percentage:0,level:`ok`}:{currentTokens:0,maxTokens:2e5,percentage:0,level:`ok`}}async getChildSessions(){return(await this.bus.request(O.getChildren,{sessionId:this._sessionId})).children.map(e=>e.sessionId)}};function dn(e,t,n,r,i,a){return new un(e,t,n,r,i,a)}function fn(e,t){let n=e?.clientAccountId??null,r=t.clientAccountId??null;return!r||n===r?null:{previousClientAccountId:n,clientAccountId:r}}function G(e,t){let n=t.lastClientIdentityObservation;if(t.clientAccountId!==void 0&&!n)throw Error(`Session "${t.sessionId}" cannot persist clientAccountId without lastClientIdentityObservation`);if(t.clientAccountId!==void 0&&t.clientId===void 0)throw Error(`Session "${t.sessionId}" cannot persist clientAccountId without clientId`);if(n&&t.clientId!==void 0&&t.clientId!==n.clientId)throw Error(`Session "${t.sessionId}" cannot persist clientId "${t.clientId}" because lastClientIdentityObservation belongs to "${n.clientId}"`)}function K(e,t,n){let r=fn(t,n);if(!r)return;let i=n.lastClientIdentityObservation;if(!i)return;let a={sessionId:n.sessionId,clientId:i.clientId,previousClientAccountId:r.previousClientAccountId,clientAccountId:r.clientAccountId,source:i.source,observedAt:i.observedAt,lastClientIdentityObservation:structuredClone(i)};queueMicrotask(()=>{Promise.resolve().then(()=>e.emit(O.clientAccount.changed,a)).catch(e=>{console.error(`[SessionStorage] Failed to emit session.clientAccount.changed:`,e)})})}function pn(e){switch(e){case`fork`:return`fork`;case`subagent`:return`subagent`;case`compress`:return`compress`;case`root`:return;default:return}}function mn(e){switch(e.kind){case`root`:return{kind:`root`,parentAdapterSessionId:null,forkPointMessageId:null};case`fork`:return{kind:`fork`,parentAdapterSessionId:e.parentAdapterSessionId,forkPointMessageId:e.forkPointMessageId};case`subagent`:return{kind:`subagent`,parentAdapterSessionId:e.parentAdapterSessionId,forkPointMessageId:null};case`compress`:return{kind:`compress`,parentAdapterSessionId:e.parentAdapterSessionId,forkPointMessageId:null};default:return e.kind}}function hn(){let e=0;return()=>{let t=Date.now();return e=t>e?t:e+1,e}}const gn=hn();function _n(e,t,n){n!==void 0&&(e[t]=n)}function vn(e,t,n){let r=e.startedAt??n;return{sessionId:t,createdAt:r,lastActivityAt:r,agents:[],status:`discovered`,branchKind:pn(e.kind),adapterName:e.source,adapterSessionId:e.externalSessionId,adapterId:e.adapterId,clientId:e.clientId,isOrchestrated:!1,isImported:!0,title:e.title??void 0,targetWorkingDirectory:e.cwd??void 0,source:e.source,parentExternalSessionId:e.parentAdapterSessionId??void 0,logFilePath:e.logFilePath??void 0,discoveredAt:n,importStatus:`discovered`,forkPointMessageId:e.forkPointMessageId??void 0}}function yn(e,t,n){let r=e.importStatus??`discovered`;r===`discovered`&&(e.status=`discovered`),e.isImported=!0,e.importStatus=r,e.adapterName??=t.source,e.adapterSessionId??=t.externalSessionId,e.source??=t.source,e.discoveredAt??=n}function bn(e,t){t.logFilePath!==void 0&&t.logFilePath!==null&&(e.logFilePath??=t.logFilePath),t.cwd!==null&&(e.targetWorkingDirectory=t.cwd),t.title!==void 0&&t.title!==null&&(e.title=t.title),t.forkPointMessageId!==null&&(e.forkPointMessageId=t.forkPointMessageId),t.parentAdapterSessionId!==null&&(e.parentExternalSessionId=t.parentAdapterSessionId);let n=pn(t.kind);n!==void 0&&(e.branchKind=n),_n(e,`adapterId`,t.adapterId),_n(e,`clientId`,t.clientId)}function xn(e,t,n){t.startedAt!==void 0&&((n===void 0||e.createdAt===n)&&(e.createdAt=t.startedAt),(n===void 0||e.lastActivityAt===n)&&(e.lastActivityAt=t.startedAt))}function Sn(e,t,n){let r=e.discoveredAt;yn(e,t,n),bn(e,t),xn(e,t,r)}function Cn(e,t){if(t.parentExternalSessionId===void 0)return;let n=t.source??t.adapterName,r=Array.from(e.values()).find(e=>e.adapterSessionId===t.parentExternalSessionId&&(e.source??e.adapterName)===n);r&&(t.parentSessionId=r.sessionId,t.rootSessionId=r.rootSessionId??r.sessionId)}function wn(e,t,n){if(n){e.emit(O.created,{sessionId:t.sessionId,parentSessionId:t.parentSessionId??null,branchKind:t.branchKind??null,createdAt:t.createdAt}).catch(e=>console.error(`[SessionStorage] Failed to emit session.created:`,e));return}e.emit(O.updated,{sessionId:t.sessionId,changedProperties:[`source`,`targetWorkingDirectory`,`title`]}).catch(e=>console.error(`[SessionStorage] Failed to emit session.updated:`,e))}function Tn(e){let t=0,n=0,r=0;for(let i of e)i.importStatus===`imported`&&(t+=1),i.importStatus===`tracking`&&(n+=1),i.importStatus===`discovered`&&(r+=1);return{total:e.length,imported:t,tracking:n,discovered:r}}function En(e,t,n){e.emit(O.importStatusChanged,{sessionId:t.sessionId,importStatus:n}).catch(e=>console.error(`[SessionStorage] Failed to emit session.importStatusChanged:`,e));let r=t.source??t.adapterName;n!==`imported`||t.adapterSessionId===void 0||r===void 0||e.emit(O.import.completed,{sessionId:t.sessionId,adapterSessionId:t.adapterSessionId,source:r}).catch(e=>console.error(`[SessionStorage] Failed to emit session.import.completed:`,e))}function Dn(e){let{bus:t,store:n,cloneSession:r,populateAgents:i}=e;return[t.on(u.importUpsert,e=>{let r=e.payload,i=Array.from(n.values()).find(e=>e.adapterSessionId===r.externalSessionId&&e.source===r.source),a=gn(),o=i===void 0,s=i??vn(r,crypto.randomUUID(),a);i?(Sn(i,r,a),i.parentExternalSessionId!==void 0&&i.parentSessionId===void 0&&Cn(n,i)):(n.set(s.sessionId,s),Cn(n,s)),wn(t,s,o),e.setResult({sessionId:s.sessionId,created:o})}),t.on(u.getByLogFilePath,async e=>{let a=Array.from(n.values()).find(t=>t.logFilePath===e.payload.logFilePath);if(!a){e.setResult({session:null});return}let o=await i(t,a.sessionId);e.setResult({session:{...r(a),agents:o}})}),t.on(u.listImported,async e=>{let{source:a,importStatus:o}=e.payload,s=Array.from(n.values()).filter(e=>e.isImported===!0).filter(e=>a===void 0||e.source===a).filter(e=>o===void 0||e.importStatus===o).sort((e,t)=>t.createdAt-e.createdAt),c=await Promise.all(s.map(async e=>({...r(e),agents:await i(t,e.sessionId)})));e.setResult({sessions:c})}),t.on(u.countBySource,e=>{let t=Array.from(n.values()).filter(t=>t.isImported===!0&&t.source===e.payload.source);e.setResult(Tn(t))}),t.on(u.updateImportStatus,e=>{let r=n.get(e.payload.sessionId),i=e.payload.importStatus;if(!r||r.importStatus===i){e.setResult({success:!1});return}r.importStatus=i,i===`imported`&&r.status===`discovered`&&(r.status=`active`),e.setResult({success:!0}),En(t,r,i)})]}async function On(e,t){let n=await e.requestOptional(f.listBySession,{sessionId:t});return n.handled?n.data.agents:[]}function q(e){return structuredClone(e)}function J(e,t,n){n!==void 0&&(e[t]=n)}function kn(e,t,n){n!==void 0&&(e[t]=n??void 0)}function An(e,t){let n=e;return t.status!==`all`&&(n=n.filter(e=>e.status===t.status)),t.executionTargetId!==void 0&&(n=n.filter(e=>e.executionTargetId===t.executionTargetId)),n}function jn(e,t){J(e,`status`,t.status),J(e,`parentSessionId`,t.parentSessionId),J(e,`contextInheritance`,t.contextInheritance),J(e,`rootSessionId`,t.rootSessionId),J(e,`forkPointMessageId`,t.forkPointMessageId),J(e,`branchKind`,t.branchKind),J(e,`isOrchestrated`,t.isOrchestrated),J(e,`clientId`,t.clientId),J(e,`clientAccountId`,t.clientAccountId),J(e,`lastClientIdentityObservation`,t.lastClientIdentityObservation),J(e,`title`,t.title),J(e,`targetWorkingDirectory`,t.targetWorkingDirectory),J(e,`createdAt`,t.createdAt),J(e,`lastActivityAt`,t.lastActivityAt),kn(e,`executionTargetId`,t.executionTargetId),kn(e,`approvalPolicyOverride`,t.approvalPolicyOverride),t.spawningToolCallId===null?e.spawningToolCallId=void 0:t.spawningToolCallId!==void 0&&e.spawningToolCallId===void 0&&(e.spawningToolCallId=t.spawningToolCallId)}function Mn(e,t){return e.on(u.list,async n=>{let{status:r=`all`,limit:i,offset:a=0,includePreview:o=!1,executionTargetId:s}=n.payload,c=An(Array.from(t.values()),{status:r,executionTargetId:s});c.sort((e,t)=>t.lastActivityAt-e.lastActivityAt);let l=c.length;i!==void 0&&(c=c.slice(a,a+i));let u=await Promise.all(c.map(async t=>({...q(t),agents:await On(e,t.sessionId)}))),d=o?u.map(e=>({...e,preview:{messageCount:0,firstUserMessage:null}})):u;n.setResult({sessions:d,total:l})})}function Nn(e,t){return e.on(u.update,async n=>{let r=structuredClone(ge.request.parse(n.payload)),i=t.get(r.sessionId);if(!i){n.setResult({success:!1,clientAccountChanged:!1});return}let a=q(i);G(a,{sessionId:i.sessionId,clientId:r.clientId??i.clientId,clientAccountId:r.clientAccountId??i.clientAccountId,lastClientIdentityObservation:r.lastClientIdentityObservation??i.lastClientIdentityObservation}),jn(i,r),n.setResult({success:!0,clientAccountChanged:(a.clientAccountId??null)!==(i.clientAccountId??null)}),K(e,a,q(i))})}function Pn(e){let t=new Map,n=[];return n.push(e.on(u.get,async n=>{let r=t.get(n.payload.sessionId);if(!r){n.setResult({session:null});return}let i=await On(e,n.payload.sessionId);n.setResult({session:{...q(r),agents:i}})})),n.push(e.on(u.set,async n=>{let{sessionId:r,session:i,ifAbsent:a}=he.parse(n.payload);if(a&&t.has(r)){n.setResult({success:!1,clientAccountChanged:!1});return}let o=structuredClone(i),s=t.get(r)??null,c=s?q(s):null;G(s,o),t.set(r,o),n.setResult({success:!0,clientAccountChanged:(c?.clientAccountId??null)!==(o.clientAccountId??null)}),K(e,c,q(o))})),n.push(e.on(u.delete,async e=>{t.delete(e.payload.sessionId),e.setResult({success:!0}),await e.next()})),n.push(Mn(e,t)),n.push(e.on(u.getChildren,e=>{let{sessionId:n}=e.payload,r=Array.from(t.values()),i=r.filter(e=>e.parentSessionId===n),a=new Set(r.map(e=>e.parentSessionId).filter(e=>!!e)),o=i.map(e=>({sessionId:e.sessionId,title:e.title??null,forkPointMessageId:e.forkPointMessageId??null,branchKind:e.branchKind??null,messageCount:0,hasChildren:a.has(e.sessionId),spawningToolCallId:e.spawningToolCallId}));e.setResult({children:o})})),n.push(e.on(u.getStatusCounts,e=>{e.payload;let n=Array.from(t.values()),r=n.filter(e=>e.status===`active`).length,i=n.filter(e=>e.status===`closed`).length,a=n.filter(e=>e.status===`archived`).length,o=n.filter(e=>e.status===`discovered`).length;e.setResult({all:r+i+a+o,active:r,closed:i,archived:a,discovered:o})})),n.push(Nn(e,t)),n.push(Fn(e,t)),n.push(...Dn({bus:e,store:t,populateAgents:On,cloneSession:q})),()=>n.forEach(e=>e())}function Fn(e,t){return e.on(u.getByAdapterSessionId,async n=>{let{adapterSessionId:r,source:i,adapterName:a}=n.payload,o=Array.from(t.values()).filter(e=>e.adapterSessionId!==void 0&&e.adapterSessionId===r&&(i===void 0||e.source===i)&&(a===void 0||e.adapterName===a)),s=o[0];if(o.length!==1||s===void 0){n.setResult({session:null});return}let c=await e.requestOptional(f.listBySession,{sessionId:s.sessionId}),l=c.handled?c.data.agents:[];n.setResult({session:{...q(s),agents:l}})})}const In=i.postgres,Ln=n.postgres,Y=j({sessions:r,agents:t},{sessions:In,agents:Ln});function Rn(e,t){let n=e?.clientId??null,r=e?.clientAccountId??null,i=e?.lastClientIdentityObservation??null;return F(n===null?V(t.clientId):z(t.clientId,n),r===null?V(t.clientAccountId):z(t.clientAccountId,r),i===null?V(t.lastClientIdentityObservation):z(t.lastClientIdentityObservation,i))}function zn(e){return{agentId:e.agentId,adapterId:e.adapterId,adapterName:e.adapterName,sessionId:e.sessionId,role:e.role,status:e.status,createdAt:e.createdAt,lastActivityAt:e.lastActivityAt,model:e.model??void 0,adapterSessionId:e.adapterSessionId??void 0,cwd:e.cwd??void 0,allowedDirectories:e.allowedDirectories??void 0,providerConfigId:e.providerConfigId??void 0,personaId:e.personaId??void 0,profileId:e.profileId??void 0,harnessId:e.harnessId??void 0,clientId:e.clientId??void 0,compressionMode:e.compressionMode?ue.parse(e.compressionMode):void 0}}function Bn(e){return{agentId:e.agentId,adapterId:e.adapterId,adapterName:e.adapterName,sessionId:e.sessionId,role:e.role,status:e.status,createdAt:e.createdAt,lastActivityAt:e.lastActivityAt,model:e.model??null,adapterSessionId:e.adapterSessionId??null,cwd:e.cwd??null,allowedDirectories:e.allowedDirectories??null,providerConfigId:e.providerConfigId??null,personaId:e.personaId??null,profileId:e.profileId??null,harnessId:e.harnessId??null,clientId:e.clientId??null,compressionMode:e.compressionMode??null}}function Vn(e){let t;for(let n=e.length-1;n>=0;--n)try{e[n]?.()}catch(e){t??=e}if(t)throw t}function Hn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.get,async e=>{let[t]=await n.select().from(r).where(z(r.agentId,e.payload.agentId)).limit(1);e.setResult({agent:t?zn(t):null})})}function Un(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.set,async e=>{let{agent:t}=e.payload,i=Bn(t),a=await n.insert(r).values(i).onConflictDoUpdate({target:r.agentId,set:i});e.setResult({success:M(a)})})}function Wn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.delete,async e=>{let t=await n.delete(r).where(z(r.agentId,e.payload.agentId));e.setResult({success:M(t)})})}function Gn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.listByAdapter,async e=>{let{adapterName:t,status:i}=e.payload,a=[z(r.adapterName,t)];i&&i!==`all`&&a.push(z(r.status,i));let o=a.length>1?F(...a):a[0],s=await n.select().from(r).where(o);e.setResult({agents:s.map(zn)})})}function Kn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.listBySession,async e=>{let{sessionId:t}=e.payload,i=await n.select().from(r).where(z(r.sessionId,t));e.setResult({agents:i.map(zn)})})}function qn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.updateStatus,async e=>{let{agentId:t,status:i}=e.payload,a=Date.now(),o=await n.update(r).set({status:i,lastActivityAt:a}).where(z(r.agentId,t));e.setResult({success:M(o)})})}function Jn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.updateActivity,async e=>{let{agentId:t,lastActivityAt:i}=e.payload,a=await n.update(r).set({lastActivityAt:i}).where(z(r.agentId,t));e.setResult({success:M(a)})})}function Yn(e){let{bus:t,db:n}=e,{agents:r}=N(n,Y);return t.on(f.updateRuntime,async e=>{let{agentId:t,adapterId:i,cwd:a,model:o,allowedDirectories:s,providerConfigId:c}=e.payload,l={lastActivityAt:Date.now()};i!==void 0&&(l.adapterId=i),a!==void 0&&(l.cwd=a),o!==void 0&&(l.model=o),s!==void 0&&(l.allowedDirectories=s),c!==void 0&&(l.providerConfigId=c);let u=await n.update(r).set(l).where(z(r.agentId,t));e.setResult({success:M(u)})})}function Xn(e,t){let n={bus:e,db:t},r=[Hn(n),Un(n),Wn(n),Gn(n),Kn(n),qn(n),Jn(n),Yn(n)];return()=>Vn(r)}function X(e){return e??void 0}function Zn(e){if(e)try{let t=JSON.parse(e),n=ze.safeParse(t);return n.success?n.data:void 0}catch{return}}function Qn(e){if(e)try{let t=JSON.parse(e),n=de.safeParse(t);return n.success?n.data:void 0}catch{return}}function Z(e,t){let n=Qn(e.forkTransforms),r=Zn(e.lastClientIdentityObservation);return{sessionId:e.sessionId,createdAt:e.createdAt,lastActivityAt:e.lastActivityAt,status:e.status,leadAgentId:X(e.leadAgentId),parentSessionId:X(e.parentSessionId),contextInheritance:X(e.contextInheritance),rootSessionId:X(e.rootSessionId),forkPointMessageId:X(e.forkPointMessageId),branchKind:X(e.branchKind),adapterName:X(e.adapterName),adapterSessionId:X(e.adapterSessionId),adapterId:X(e.adapterId),clientId:X(e.clientId),clientAccountId:X(e.clientAccountId),lastClientIdentityObservation:r,isOrchestrated:X(e.isOrchestrated),isImported:X(e.isImported),title:X(e.title),summary:X(e.summary),summaryUpdatedAt:X(e.summaryUpdatedAt),forkTransforms:n,targetWorkingDirectory:X(e.targetWorkingDirectory),executionTargetId:X(e.executionTargetId),agents:t.map(zn),approvalPolicyOverride:X(e.approvalPolicyOverride),spawningToolCallId:X(e.spawningToolCallId),source:X(e.source),parentExternalSessionId:X(e.parentExternalSessionId),logFilePath:X(e.logFilePath),discoveredAt:X(e.discoveredAt),importStatus:X(e.importStatus)}}function $n(e){let t=new Map;for(let n of e){let e=t.get(n.sessionId)??[];e.push(n),t.set(n.sessionId,e)}return t}async function er(e,t,n){if(!n||t.length===0)return{};let{messages:r}=N(e,c),i=e.select({sessionId:r.sessionId,minTimestamp:H`MIN(${r.timestamp})`.as(`min_timestamp`)}).from(r).where(F(z(r.role,`user`),B(r.sessionId,t))).groupBy(r.sessionId).as(`first_user_message_by_session`),a=await e.select({sessionId:r.sessionId,preview:r.contentText}).from(r).innerJoin(i,F(z(r.sessionId,i.sessionId),z(r.timestamp,i.minTimestamp))).where(z(r.role,`user`)),o=new Map;for(let e of a)o.has(e.sessionId)||o.set(e.sessionId,e.preview);let s=await e.select({sessionId:r.sessionId,count:L()}).from(r).where(B(r.sessionId,t)).groupBy(r.sessionId),l=new Map;for(let e of s)l.set(e.sessionId,e.count);return{previewBySession:o,countBySession:l}}function tr(e,t){return{sessionId:e.sessionId,clientId:t.clientId??e.clientId,clientAccountId:t.clientAccountId??e.clientAccountId,lastClientIdentityObservation:t.lastClientIdentityObservation??e.lastClientIdentityObservation}}function nr(e){return e.clientId!==void 0||e.clientAccountId!==void 0||e.lastClientIdentityObservation!==void 0}function rr(e){let{bus:t,db:n}=e,{sessions:r,agents:i}=N(n,Y);return t.on(u.getByAdapterSessionId,async e=>{let{adapterSessionId:t,source:a,adapterName:o}=e.payload,s=[z(r.adapterSessionId,t)];a!==void 0&&s.push(z(r.source,a)),o!==void 0&&s.push(z(r.adapterName,o));let c=await n.select().from(r).where(F(...s)).limit(2),l=c[0];if(c.length!==1||l===void 0){e.setResult({session:null});return}let u=await n.select().from(i).where(z(i.sessionId,l.sessionId));e.setResult({session:Z(l,u)})})}function ir(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y),{messages:i}=N(n,c);return t.on(u.getChildren,async e=>{let{sessionId:t}=e.payload,a=await n.select().from(r).where(z(r.parentSessionId,t));if(a.length===0){e.setResult({children:[]});return}let o=a.map(e=>e.sessionId),s=await n.select({sessionId:i.sessionId,count:L()}).from(i).where(B(i.sessionId,o)).groupBy(i.sessionId),c=new Map;for(let e of s)c.set(e.sessionId,e.count);let l=await n.select({parentSessionId:r.parentSessionId,count:L()}).from(r).where(B(r.parentSessionId,o)).groupBy(r.parentSessionId),u=new Set;for(let e of l)e.parentSessionId&&u.add(e.parentSessionId);let d=a.map(e=>e.forkPointMessageId).filter(e=>e!==null),f=new Map;if(d.length>0){let e=await n.select({messageId:i.messageId,adapterMessageId:i.adapterMessageId}).from(i).where(F(z(i.sessionId,t),B(i.adapterMessageId,d)));for(let t of e)t.adapterMessageId&&f.set(t.adapterMessageId,t.messageId)}let p=a.map(e=>{let t=e.forkPointMessageId,n=t?f.get(t)??t:null;return{sessionId:e.sessionId,title:e.title??null,forkPointMessageId:n,branchKind:e.branchKind??null,messageCount:c.get(e.sessionId)??0,hasChildren:u.has(e.sessionId),spawningToolCallId:e.spawningToolCallId??void 0}});e.setResult({children:p})})}const ar=hn();function or(e,t,n){return t===void 0?H`${e}`:H`
|
|
4
|
+
CASE
|
|
5
|
+
WHEN ${n.discoveredAt} IS NULL OR ${e} = ${n.discoveredAt} THEN ${t}
|
|
6
|
+
ELSE ${e}
|
|
7
|
+
END
|
|
8
|
+
`}function sr(e,t){return{status:H`
|
|
9
|
+
CASE
|
|
10
|
+
WHEN COALESCE(${e.importStatus}, excluded.import_status) = 'discovered' THEN excluded.status
|
|
11
|
+
ELSE ${e.status}
|
|
12
|
+
END
|
|
13
|
+
`,isImported:!0,importStatus:H`COALESCE(${e.importStatus}, excluded.import_status)`,adapterName:H`COALESCE(${e.adapterName}, excluded.adapter_name)`,discoveredAt:H`COALESCE(${e.discoveredAt}, excluded.discovered_at)`,source:H`COALESCE(${e.source}, excluded.source)`,logFilePath:H`COALESCE(${e.logFilePath}, excluded.log_file_path)`,targetWorkingDirectory:H`COALESCE(excluded.target_working_directory, ${e.targetWorkingDirectory})`,title:H`COALESCE(excluded.title, ${e.title})`,forkPointMessageId:H`COALESCE(excluded.fork_point_message_id, ${e.forkPointMessageId})`,parentExternalSessionId:H`COALESCE(excluded.parent_external_session_id, ${e.parentExternalSessionId})`,branchKind:H`COALESCE(excluded.branch_kind, ${e.branchKind})`,adapterId:H`COALESCE(excluded.adapter_id, ${e.adapterId})`,clientId:H`COALESCE(excluded.client_id, ${e.clientId})`,createdAt:or(e.createdAt,t,e),lastActivityAt:or(e.lastActivityAt,t,e)}}function cr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.importUpsert,async e=>{let{externalSessionId:i,source:a,clientId:o,adapterId:s,cwd:c,logFilePath:l,startedAt:u,title:d,kind:f,parentAdapterSessionId:p,forkPointMessageId:m}=e.payload,h=ar(),g=crypto.randomUUID(),_=u??h,v=pn(f)??null,y=p??null,[b]=await n.insert(r).values({sessionId:g,status:`discovered`,isImported:!0,importStatus:`discovered`,adapterName:a,adapterSessionId:i,source:a??null,clientId:o??null,adapterId:s??null,targetWorkingDirectory:c??null,logFilePath:l??null,forkPointMessageId:m??null,branchKind:v,parentExternalSessionId:y,discoveredAt:h,title:d??null,createdAt:_,lastActivityAt:_}).onConflictDoUpdate({target:[r.source,r.adapterSessionId],set:sr(r,u)}).returning({sessionId:r.sessionId,discoveredAt:r.discoveredAt,parentExternalSessionId:r.parentExternalSessionId,parentSessionId:r.parentSessionId}),x=b.sessionId===g;await lr(t,n,b,x,v,_,a),e.setResult({sessionId:b.sessionId,created:x})})}async function lr(e,t,n,r,i,a,o){if(r){let r=await ur(t,n.sessionId,n.parentExternalSessionId,o);e.emit(O.created,{sessionId:n.sessionId,parentSessionId:r,branchKind:i,createdAt:a}).catch(e=>console.error(`[SessionStorage] Failed to emit session.created:`,e))}else n.parentExternalSessionId!==null&&n.parentSessionId===null&&await ur(t,n.sessionId,n.parentExternalSessionId,o),e.emit(O.updated,{sessionId:n.sessionId,changedProperties:[`source`,`targetWorkingDirectory`,`title`]}).catch(e=>console.error(`[SessionStorage] Failed to emit session.updated:`,e))}async function ur(e,t,n,r){let{sessions:i}=N(e,Y);if(n===null)return null;let[a]=await e.select({sessionId:i.sessionId,rootSessionId:i.rootSessionId}).from(i).where(F(z(i.adapterSessionId,n),z(i.source,r))).limit(1);if(!a)return null;let o=a.rootSessionId??a.sessionId;return await e.update(i).set({parentSessionId:a.sessionId,rootSessionId:o}).where(z(i.sessionId,t)),a.sessionId}function dr(e){let{bus:t,db:n}=e,{sessions:r,agents:i}=N(n,Y);return t.on(u.getByLogFilePath,async e=>{let{logFilePath:t}=e.payload,[a]=await n.select().from(r).where(z(r.logFilePath,t)).limit(1);if(!a){e.setResult({session:null});return}let o=await n.select().from(i).where(z(i.sessionId,a.sessionId));e.setResult({session:Z(a,o)})})}function fr(e){let{bus:t,db:n}=e,{sessions:r,agents:i}=N(n,Y);return t.on(u.listImported,async e=>{let{source:t,importStatus:a}=e.payload,o=[z(r.isImported,!0)];t!==void 0&&o.push(z(r.source,t)),a!==void 0&&o.push(z(r.importStatus,a));let s=F(...o),c=await n.select().from(r).where(s).orderBy(R(r.createdAt));if(c.length===0){e.setResult({sessions:[]});return}let l=c.map(e=>e.sessionId),u=$n(await n.select().from(i).where(B(i.sessionId,l)));e.setResult({sessions:c.map(e=>Z(e,u.get(e.sessionId)??[]))})})}function pr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.countBySource,async e=>{let{source:t}=e.payload,i=await n.select({importStatus:r.importStatus,count:H`count(*)`}).from(r).where(F(z(r.isImported,!0),z(r.source,t))).groupBy(r.importStatus),a=0,o=0,s=0,c=0;for(let e of i){let t=Number(e.count);a+=t,e.importStatus===`imported`&&(o+=t),e.importStatus===`tracking`&&(s+=t),e.importStatus===`discovered`&&(c=t)}e.setResult({total:a,imported:o,tracking:s,discovered:c})})}function mr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.updateImportStatus,async e=>{let{sessionId:i,importStatus:a}=e.payload,o=a===`imported`?{status:H`
|
|
14
|
+
CASE
|
|
15
|
+
WHEN ${r.status} = 'discovered' THEN 'active'
|
|
16
|
+
ELSE ${r.status}
|
|
17
|
+
END
|
|
18
|
+
`}:{},[s]=await n.update(r).set({importStatus:a,...o}).where(F(z(r.sessionId,i),Re(V(r.importStatus),H`${r.importStatus} <> ${a}`))).returning({adapterSessionId:r.adapterSessionId,adapterName:r.adapterName,source:r.source}),c=s!==void 0;if(e.setResult({success:c}),c){t.emit(O.importStatusChanged,{sessionId:i,importStatus:a}).catch(e=>console.error(`[SessionStorage] Failed to emit session.importStatusChanged:`,e));let e=s.source??s.adapterName;a===`imported`&&s.adapterSessionId&&e&&t.emit(O.import.completed,{sessionId:i,adapterSessionId:s.adapterSessionId,source:e}).catch(e=>console.error(`[SessionStorage] Failed to emit session.import.completed:`,e))}})}function hr(e,t){let n={bus:e,db:t};return[cr(n),dr(n),fr(n),pr(n),mr(n)]}function Q(e){return e??null}function gr(e){return e?JSON.stringify(e):null}function _r(e){return{lastActivityAt:e.lastActivityAt,status:e.status,leadAgentId:Q(e.leadAgentId),parentSessionId:Q(e.parentSessionId),contextInheritance:Q(e.contextInheritance),rootSessionId:Q(e.rootSessionId),forkPointMessageId:Q(e.forkPointMessageId),branchKind:Q(e.branchKind),adapterName:Q(e.adapterName),adapterSessionId:Q(e.adapterSessionId),adapterId:Q(e.adapterId),clientId:Q(e.clientId),clientAccountId:Q(e.clientAccountId),lastClientIdentityObservation:vr(e.lastClientIdentityObservation),isOrchestrated:e.isOrchestrated??!1,isImported:e.isImported??!1,title:Q(e.title),summary:Q(e.summary),summaryUpdatedAt:Q(e.summaryUpdatedAt),forkTransforms:gr(e.forkTransforms),targetWorkingDirectory:Q(e.targetWorkingDirectory),executionTargetId:Q(e.executionTargetId),approvalPolicyOverride:Q(e.approvalPolicyOverride),spawningToolCallId:Q(e.spawningToolCallId),source:Q(e.source),parentExternalSessionId:Q(e.parentExternalSessionId),logFilePath:Q(e.logFilePath),discoveredAt:Q(e.discoveredAt),importStatus:Q(e.importStatus)}}function vr(e){return e?JSON.stringify(e):null}function $(e,t,n){n!==void 0&&(e[t]=n)}function yr(e,t,n){n!==void 0&&(e[t]=n??null)}function br(e,t){let n={};return $(n,`status`,e.status),$(n,`parentSessionId`,e.parentSessionId),$(n,`contextInheritance`,e.contextInheritance),$(n,`rootSessionId`,e.rootSessionId),$(n,`forkPointMessageId`,e.forkPointMessageId),$(n,`branchKind`,e.branchKind),$(n,`isOrchestrated`,e.isOrchestrated),$(n,`clientId`,e.clientId),$(n,`clientAccountId`,e.clientAccountId),$(n,`title`,e.title),$(n,`targetWorkingDirectory`,e.targetWorkingDirectory),$(n,`createdAt`,e.createdAt),$(n,`lastActivityAt`,e.lastActivityAt),yr(n,`executionTargetId`,e.executionTargetId),yr(n,`approvalPolicyOverride`,e.approvalPolicyOverride),e.spawningToolCallId===null?n.spawningToolCallId=null:e.spawningToolCallId!==void 0&&(n.spawningToolCallId=H`coalesce(${t.spawningToolCallId}, ${e.spawningToolCallId})`),e.lastClientIdentityObservation!==void 0&&(n.lastClientIdentityObservation=vr(e.lastClientIdentityObservation)),n}function xr(e){let{bus:t,db:n}=e,{sessions:r,agents:i}=N(n,Y);return t.on(u.get,async e=>{let[t]=await n.select().from(r).where(z(r.sessionId,e.payload.sessionId)).limit(1);if(!t){e.setResult({session:null});return}let a=await n.select().from(i).where(z(i.sessionId,e.payload.sessionId));e.setResult({session:Z(t,a)})})}function Sr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.set,async e=>{let{sessionId:i,session:a,ifAbsent:o}=he.parse(e.payload),s=_r(a);if(o){G(null,a);let o=M(await n.insert(r).values({sessionId:i,createdAt:a.createdAt,...s}).onConflictDoNothing());e.setResult({success:o,clientAccountChanged:o&&a.clientAccountId!==void 0}),o&&K(t,null,a);return}for(let o=0;o<3;o++){let[o]=await n.select().from(r).where(z(r.sessionId,i)).limit(1),c=o?Z(o,[]):null;if(G(c,a),M(await n.insert(r).values({sessionId:i,createdAt:a.createdAt,...s}).onConflictDoUpdate({target:r.sessionId,set:s,setWhere:Rn(o,r)}))){e.setResult({success:!0,clientAccountChanged:(c?.clientAccountId??null)!==(a.clientAccountId??null)}),K(t,c,a);return}}throw Error(`Failed to write session "${i}" with a stable client-account baseline`)})}function Cr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.delete,async e=>{await n.delete(r).where(z(r.sessionId,e.payload.sessionId)),e.setResult({success:!0})})}function wr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.update,async e=>{let i=ge.request.parse(e.payload),{sessionId:a}=i,o=br(i,r),s=nr(i);if(Object.keys(o).length===0){e.setResult({success:!0,clientAccountChanged:!1});return}if(!s){let t=await n.update(r).set(o).where(z(r.sessionId,a));e.setResult({success:M(t),clientAccountChanged:!1});return}for(let s=0;s<3;s++){let[s]=await n.select().from(r).where(z(r.sessionId,a)).limit(1);if(!s){e.setResult({success:!1,clientAccountChanged:!1});return}let c=Z(s,[]),l=tr(c,i);if(G(c,l),M(await n.update(r).set(o).where(F(z(r.sessionId,a),Rn(s,r))))){e.setResult({success:!0,clientAccountChanged:(c.clientAccountId??null)!==(l.clientAccountId??null)}),K(t,c,l);return}}throw Error(`Failed to update session "${a}" with a stable client-account baseline`)})}function Tr(e,t){let n=[];return e.status!==`all`&&n.push(z(t.status,e.status)),e.executionTargetId!==void 0&&n.push(z(t.executionTargetId,e.executionTargetId)),F(...n)}function Er(e){let{bus:t,db:n}=e,{sessions:r,agents:i}=N(n,Y);return t.on(u.list,async e=>{let{status:t=`all`,limit:a,offset:o=0,includePreview:s=!1,executionTargetId:c}=e.payload,l=Tr({status:t,executionTargetId:c},r),u=l?n.select().from(r).where(l):n.select().from(r),d=a===void 0?await u.orderBy(R(r.lastActivityAt)):await u.orderBy(R(r.lastActivityAt)).limit(a).offset(o),[f]=await(l?n.select({count:L()}).from(r).where(l):n.select({count:L()}).from(r)),p=f?.count??0;if(d.length===0){e.setResult({sessions:[],total:p});return}let m=d.map(e=>e.sessionId),h=$n(await n.select().from(i).where(B(i.sessionId,m))),{previewBySession:g,countBySession:_}=await er(n,m,s),v=d.map(e=>{let t=Z(e,h.get(e.sessionId)??[]);return s&&g&&_?{...t,preview:{messageCount:_.get(e.sessionId)??0,firstUserMessage:g.get(e.sessionId)??null}}:t});e.setResult({sessions:v,total:p})})}function Dr(e){let{bus:t,db:n}=e,{sessions:r}=N(n,Y);return t.on(u.getStatusCounts,async e=>{e.payload;let t=await n.select({status:r.status,count:L()}).from(r).groupBy(r.status),i=0,a=0,o=0,s=0;for(let e of t)e.status===`active`?i=e.count:e.status===`closed`?a=e.count:e.status===`archived`?o=e.count:e.status===`discovered`&&(s=e.count);let c=i+a+o+s;e.setResult({all:c,active:i,closed:a,archived:o,discovered:s})})}function Or(e,t){let n={bus:e,db:t},r=[xr(n),Sr(n),Cr(n),wr(n),Er(n),ir(n),rr(n),Dr(n),...hr(e,t)];return()=>r.forEach(e=>e())}function kr(e,t,n,r,i,a){return t===void 0&&n===void 0&&r===void 0&&i===void 0&&a===void 0?!1:(t!==void 0&&(e.adapterId=t),n!==void 0&&(e.cwd=n),r!==void 0&&(e.model=r),i!==void 0&&(e.allowedDirectories=i),a!==void 0&&(e.providerConfigId=a),!0)}function Ar(e){let t=new Map,n=[];return n.push(e.on(f.get,e=>{let n=t.get(e.payload.agentId)??null;e.setResult({agent:n})})),n.push(e.on(f.set,e=>{t.set(e.payload.agentId,e.payload.agent),e.setResult({success:!0})})),n.push(e.on(f.delete,e=>{let n=t.delete(e.payload.agentId);e.setResult({success:n})})),n.push(e.on(f.listByAdapter,e=>{let{adapterName:n,status:r}=e.payload,i=Array.from(t.values()).filter(e=>e.adapterName===n);r&&r!==`all`&&(i=i.filter(e=>e.status===r)),e.setResult({agents:i})})),n.push(e.on(f.listBySession,e=>{let n=Array.from(t.values()).filter(t=>t.sessionId===e.payload.sessionId);e.setResult({agents:n})})),n.push(e.on(f.updateStatus,e=>{let n=t.get(e.payload.agentId);if(!n){e.setResult({success:!1});return}n.status=e.payload.status,n.lastActivityAt=Date.now(),e.setResult({success:!0})})),n.push(e.on(f.updateActivity,e=>{let n=t.get(e.payload.agentId);if(!n){e.setResult({success:!1});return}n.lastActivityAt=e.payload.lastActivityAt,e.setResult({success:!0})})),n.push(e.on(f.updateRuntime,e=>{let n=t.get(e.payload.agentId);if(!n){e.setResult({success:!1});return}let{adapterId:r,cwd:i,model:a,allowedDirectories:o,providerConfigId:s}=e.payload;if(!kr(n,r,i,a,o,s)){e.setResult({success:!1});return}n.lastActivityAt=Date.now(),e.setResult({success:!0})})),()=>n.forEach(e=>e())}async function jr(e,t){if(t.length===0)return new Map;let{agents:n}=N(e,Y),r=[...new Set(t)],i=await e.select().from(n).where(B(n.sessionId,r)),a=new Map;for(let e of i){let t=a.get(e.sessionId)??[];t.push(e),a.set(e.sessionId,t)}return a}async function Mr(e,t){return P(e).fts.fetchFirstUserMessagePreviews(e,t)}async function Nr(e,t){if(t.length===0)return new Map;let{messages:n}=N(e,c),r=[...new Set(t)],i=await e.select({sessionId:n.sessionId,count:L()}).from(n).where(B(n.sessionId,r)).groupBy(n.sessionId),a=new Map;for(let e of i)a.set(e.sessionId,e.count);return a}function Pr(e){if(e)try{let t=JSON.parse(e);return!t||typeof t!=`object`||Array.isArray(t)?void 0:t}catch{return}}function Fr(e,t,n,r){return{sessionId:e.session_id,createdAt:e.created_at,lastActivityAt:e.last_activity_at,status:e.status,title:e.title??void 0,leadAgentId:e.lead_agent_id??void 0,parentSessionId:e.parent_session_id??void 0,rootSessionId:e.root_session_id??void 0,forkPointMessageId:e.fork_point_message_id??void 0,branchKind:e.branch_kind??void 0,adapterName:e.adapter_name??void 0,adapterSessionId:e.adapter_session_id??void 0,adapterId:e.adapter_id??void 0,isOrchestrated:e.is_orchestrated===null?void 0:!!e.is_orchestrated,isImported:e.is_imported===null?void 0:!!e.is_imported,summary:e.summary??void 0,summaryUpdatedAt:e.summary_updated_at??void 0,forkTransforms:Pr(e.fork_transforms),targetWorkingDirectory:e.target_working_directory??void 0,agents:t.map(e=>({agentId:e.agentId,adapterId:e.adapterId,adapterName:e.adapterName,sessionId:e.sessionId,role:e.role,status:e.status,createdAt:e.createdAt,lastActivityAt:e.lastActivityAt,model:e.model??void 0,adapterSessionId:e.adapterSessionId??void 0,cwd:e.cwd??void 0})),preview:{messageCount:r.get(e.session_id)??0,firstUserMessage:n.get(e.session_id)??null}}}function Ir(e,t){let n=P(t).fts,r=[];return r.push(e.on(u.search,async e=>{let{query:r,limit:i=20,status:a=`all`,isImported:o}=e.payload,s=r.trim();if(!s){e.setResult({sessions:[],total:0});return}let c={query:s,likePattern:`%${s.toLowerCase()}%`,status:a===`all`?void 0:a,isImported:o},l=await n.searchSessionRows(t,{...c,limit:i});if(l.length===0){e.setResult({sessions:[],total:0});return}let u=await n.countSessionMatches(t,c),d=l.map(e=>e.session_id),f=await jr(t,d),p=await Mr(t,d),m=await Nr(t,d),h=l.map(e=>Fr(e,f.get(e.session_id)??[],p,m));e.setResult({sessions:h,total:u})})),()=>r.forEach(e=>e())}async function Lr(e,t){return(await Me(e).all(H`
|
|
19
|
+
WITH RECURSIVE ancestors AS (
|
|
20
|
+
SELECT session_id, parent_session_id
|
|
21
|
+
FROM sessions
|
|
22
|
+
WHERE session_id = ${t}
|
|
23
|
+
|
|
24
|
+
UNION ALL
|
|
25
|
+
|
|
26
|
+
SELECT s.session_id, s.parent_session_id
|
|
27
|
+
FROM sessions s
|
|
28
|
+
JOIN ancestors a ON s.session_id = a.parent_session_id
|
|
29
|
+
)
|
|
30
|
+
SELECT session_id FROM ancestors
|
|
31
|
+
`)).map(e=>e.session_id)}var Rr=class{bus;options;cleanups=[];transform;constructor(e=oe,t={}){this.bus=e,this.options=t,this.transform=t.transform??(e=>e),this.registerHandlers()}async emitStorageEvent(e,t,n){let r={sessionId:t,eventId:crypto.randomUUID(),timestamp:Date.now(),type:e,payload:n},i=this.transform(r);i&&await this.bus.request(s.append,{event:i})}registerHandler(e,t){this.cleanups.push(this.bus.on(e,(async e=>{try{await this.emitStorageEvent(t,e.payload.sessionId,e.payload)}catch(e){console.error(`[SessionLogger] Failed to emit ${t} to storage:`,e)}})))}registerHandlers(){this.registerHandler(O.agent.added,`agent.added`),this.registerHandler(O.turn.started,`turn.started`),this.registerHandler(O.turn.completed,`turn.completed`),this.registerHandler(O.branch.created,`branch.created`)}destroy(){for(let e of this.cleanups)e();this.cleanups.length=0}};const zr=je(`import_cursors`,e=>({filePath:e.text(`file_path`).primaryKey(),bytesRead:e.int8(`bytes_read`).notNull(),lastModified:e.text(`last_modified`).notNull(),updatedAt:e.epochMs(`updated_at`).notNull()})),Br=zr.sqlite,Vr=zr.postgres,Hr=j({importCursors:Br},{importCursors:Vr});function Ur(e,t){let{importCursors:n}=N(t,Hr),r=[];return r.push(e.on(Be.get,async e=>{let{filePath:r}=e.payload,i=(await t.select().from(n).where(z(n.filePath,r)).limit(1))[0];if(!i){e.setResult({cursor:null});return}e.setResult({cursor:{filePath:i.filePath,bytesRead:i.bytesRead,lastModified:i.lastModified}})})),r.push(e.on(Be.set,async e=>{let{filePath:r,bytesRead:i,lastModified:a}=e.payload;await t.insert(n).values({filePath:r,bytesRead:i,lastModified:a,updatedAt:Date.now()}).onConflictDoUpdate({target:n.filePath,set:{bytesRead:i,lastModified:a,updatedAt:Date.now()}}),e.setResult({success:!0})})),r.push(e.on(Be.delete,async e=>{let{filePath:r}=e.payload,i=await t.delete(n).where(z(n.filePath,r));e.setResult({success:M(i)})})),()=>{r.forEach(e=>e())}}De(`embeddings`,{id:Te(`id`).primaryKey({autoIncrement:!0}),entityType:A(`entity_type`).notNull(),entityId:A(`entity_id`).notNull(),model:A(`model`).notNull(),dimensions:Te(`dimensions`).notNull(),content:A(`content`),embedding:Ce(`embedding`,{mode:`buffer`}).notNull(),createdAt:Te(`created_at`).notNull()},e=>[we(`idx_embeddings_entity`).on(e.entityType,e.entityId),we(`idx_embeddings_model`).on(e.model),Oe(`idx_embeddings_unique`).on(e.entityType,e.entityId,e.model)]);function Wr(e){if(e.byteLength%4!=0)throw Error(`Invalid embedding blob: byte length ${e.byteLength} is not a multiple of 4 (IEEE-754 f32 lanes)`);return e instanceof ArrayBuffer?new Float32Array(e):e.byteOffset%4==0?new Float32Array(e.buffer,e.byteOffset,e.byteLength/4):new Float32Array(Uint8Array.from(e).buffer)}var Gr=class{rawSql;engine;knownTables=new Set;constructor(e){this.rawSql=Me(e),this.engine=Ne(this.rawSql.dialect)}slugify(e){return e.replace(/[^a-zA-Z0-9]/g,`_`).toLowerCase()}hashModel(e){let t=0;for(let n=0;n<e.length;n++)t=t*31+e.charCodeAt(n)>>>0;return t.toString(36)}getTableName(e){return`embeddings_idx_${this.slugify(e)}_${this.hashModel(e)}`}async ensureIndexTable(e,t){let n=this.getTableName(e);if(this.knownTables.has(n))return n;let r=H.identifier(n),i=H.raw(this.engine.capabilities.binaryColumnType);return await this.rawSql.run(H`CREATE TABLE IF NOT EXISTS ${r} (
|
|
32
|
+
entity_type TEXT NOT NULL,
|
|
33
|
+
entity_id TEXT NOT NULL,
|
|
34
|
+
embedding ${i} NOT NULL,
|
|
35
|
+
PRIMARY KEY (entity_type, entity_id)
|
|
36
|
+
)`),this.knownTables.add(n),n}async upsertIndexed(e,t,n,r,i){let a=await this.ensureIndexTable(e,t),o=new Uint8Array(i.buffer,i.byteOffset,i.byteLength),s=H.identifier(a);await this.rawSql.run(H`INSERT INTO ${s} (entity_type, entity_id, embedding)
|
|
37
|
+
VALUES (${n}, ${r}, ${o})
|
|
38
|
+
ON CONFLICT(entity_type, entity_id) DO UPDATE SET
|
|
39
|
+
embedding = excluded.embedding`)}async searchSimilar(e,t,n=10){let r=this.getTableName(e);if(!this.knownTables.has(r)){if(!await this.engine.capabilities.tableExists(this.rawSql,r))return[];this.knownTables.add(r)}let i=H.identifier(r),a=await this.rawSql.all(H`SELECT entity_type, entity_id, embedding FROM ${i}`);return a.length===0?[]:a.map(e=>{let n=Wr(e.embedding),r=this.euclideanDistance(t,n);return{entityType:e.entity_type,entityId:e.entity_id,distance:r}}).sort((e,t)=>e.distance-t.distance).slice(0,n)}async deleteByEntity(e,t,n){let r=this.getTableName(e);if(!this.knownTables.has(r)){if(!await this.engine.capabilities.tableExists(this.rawSql,r))return;this.knownTables.add(r)}let i=H.identifier(r);await this.rawSql.run(H`DELETE FROM ${i} WHERE entity_type = ${t} AND entity_id = ${n}`)}euclideanDistance(e,t){let n=0;for(let r=0;r<e.length;r++){let i=e[r]-t[r];n+=i*i}return Math.sqrt(n)}},Kr=class{sessionId;parentSessionId;status=`active`;_turns=[];_completedTurnIds=new Set;bus;constructor(e){this.sessionId=e.sessionId??crypto.randomUUID(),this.parentSessionId=e.parentSessionId,this.bus=e.bus}get turns(){return this._turns}async startTurn(e){if(this.status!==`active`)throw Error(`Cannot start turn on non-active session`);let t=new S({sessionId:this.sessionId,agentIds:e.agentIds,turnNumber:e.turnNumber,turnId:e.turnId});return this._turns.push(t),t.addMessage(e.messageId),await this.emit(O.turn.started,{turnId:t.turnId,turnNumber:t.turnNumber,agentIds:[...t.agentIds],messageId:e.messageId}),t}getActiveTurn(){for(let e=this._turns.length-1;e>=0;e--){let t=this._turns[e];if(!this._completedTurnIds.has(t.turnId))return t}}async completeTurn(e){if(!e.isComplete())throw Error(`Turn ${e.turnId} is not complete yet`);this._completedTurnIds.add(e.turnId);let t=e.getResult();await this.emit(O.turn.completed,{turnId:e.turnId,turnNumber:e.turnNumber,success:t.success,error:t.errors.length>0?t.errors.join(`; `):void 0})}async emit(e,t){await this.bus.emit(e,{...t,sessionId:this.sessionId})}};function qr(e,t){let{sessions:n}=N(t,Y);async function r(i,a,o,s=0){if(s>100)throw Error(`Cycle detected in session lineage (depth > 100)`);let c=await t.select({adapterSessionId:n.adapterSessionId,sessionId:n.sessionId,parentSessionId:n.parentSessionId}).from(n).where(F(z(n.parentExternalSessionId,i),z(n.source,a)));for(let t of c)t.parentSessionId!==null&&await e.request(u.update,{sessionId:t.sessionId,rootSessionId:o}),t.adapterSessionId!==null&&await r(t.adapterSessionId,a,o,s+1)}return e.on(O.import.completed,async i=>{let{adapterSessionId:a,sessionId:o,source:s}=i.payload,c=await t.select({sessionId:n.sessionId,adapterSessionId:n.adapterSessionId,branchKind:n.branchKind}).from(n).where(F(z(n.parentExternalSessionId,a),z(n.source,s),V(n.parentSessionId)));if(c.length===0)return;let{session:l}=await e.request(u.get,{sessionId:o}),d=l?.rootSessionId??o;for(let t of c)await e.request(u.update,{sessionId:t.sessionId,parentSessionId:o,rootSessionId:d,...t.branchKind===null?{}:{branchKind:t.branchKind}}),t.adapterSessionId!==null&&await r(t.adapterSessionId,s,d)})}const Jr=new Set([`Agent`,`spawn_subagent`]),Yr=`[^A-Za-z0-9_-]`;function Xr(e){return e.replaceAll(/[.*+?^${}()|[\]\\]/g,`\\$&`)}function Zr(e,t){return t.test(e)}async function Qr(e,t){let n=[],r,i=0;do{let a=await e.request(C.getBySession,{sessionId:t,order:`asc`,...r===void 0?{}:{after:r}});if(n.push(...a.messages),r=a.nextCursor??void 0,i+=1,r!==void 0&&i>=1e3)throw Error(`Exceeded 1000 message pages while loading session ${t}`)}while(r!==void 0);return n}function $r(e){let t=[];for(let n of e)for(let e of n.blocks)e.type===`tool_call`&&Jr.has(e.name)&&t.push({toolCallId:e.toolCallId});return t}function ei(e,t){let n=new Map;for(let r of e)for(let e of r.blocks)if(e.type===`tool_output`){for(let r of t)if(Zr(e.output,r.pattern)){let t=n.get(e.toolCallId)??new Set;t.add(r.id),n.set(e.toolCallId,t)}}let r=new Map;for(let[e,t]of n)if(t.size===1){let[n]=t;r.set(e,n)}return r}function ti(e){let t=new Map,n=new Set;for(let r of e)if(!(r===null||n.has(r.adapterSessionId))){if(t.has(r.adapterSessionId)){t.delete(r.adapterSessionId),n.add(r.adapterSessionId);continue}t.set(r.adapterSessionId,r.sessionId)}return t}function ni(e){return[...e].map(e=>{let t=Xr(e);return{id:e,pattern:RegExp(`(^|${Yr})${t}($|${Yr})`)}})}async function ri(e,t,n){let{children:r}=await e.request(u.getChildren,{sessionId:n}),i=r.filter(e=>e.branchKind===`compress`);if(i.length===0)return;let{session:a}=await e.request(u.get,{sessionId:t}),o=a?.adapterSessionId;if(!o)return;let s=ni(new Set([o])),c=(await Promise.all(i.map(async t=>{let n=await Qr(e,t.sessionId),r=$r(n);if(r.length===0)return null;let i=ei(n,s);if(i.size===0)return null;let a=[...i.entries()].filter(([,e])=>e===o);if(a.length!==1)return null;let[c]=a[0];return r.some(e=>e.toolCallId===c)?{parentSessionId:t.sessionId,toolCallId:c}:null}))).filter(e=>e!==null);c.length===1&&await e.request(u.update,{sessionId:t,parentSessionId:c[0].parentSessionId,spawningToolCallId:c[0].toolCallId})}async function ii(e,t,n){let r=t.parentExternalSessionId,i=t.source??n;if(!r||!i)return;let a=t.sessionId,{session:o}=await e.request(u.getByAdapterSessionId,{adapterSessionId:r,source:i}),s=o?.sessionId;if(!s)return;let{children:c}=await e.request(u.getChildren,{sessionId:s}),l=await ai(e,c);if(l.size===0)return;let d=await Qr(e,a),f=$r(d);if(f.length===0)return;let p=ei(d,ni(new Set(l.keys()))),m=new Map;for(let e of f){let t=p.get(e.toolCallId);t!==void 0&&m.set(t,(m.get(t)??0)+1)}let h=new Map;for(let e of f){let t=p.get(e.toolCallId),n=t===void 0?void 0:l.get(t);n!==void 0&&t!==void 0&&m.get(t)===1&&h.set(n,e.toolCallId)}if(h.size===0)return;let g=[...h].map(async([t,n])=>{try{await e.request(u.update,{sessionId:t,parentSessionId:a,spawningToolCallId:n})}catch(e){console.error(`[CompressLineageResolver] Failed to re-parent subagent`,{compressChildSessionId:a,parentMakaioSessionId:s,childSessionId:t,toolCallId:n,error:e})}});await Promise.allSettled(g)}async function ai(e,t){return ti(await Promise.all(t.filter(e=>e.branchKind===`subagent`).map(async t=>{let{session:n}=await e.request(u.get,{sessionId:t.sessionId});return n?.adapterSessionId?{sessionId:t.sessionId,adapterSessionId:n.adapterSessionId}:null})))}function oi(e){return e.on(O.import.completed,async t=>{try{let{sessionId:n,source:r}=t.payload,{session:i}=await e.request(u.get,{sessionId:n});if(!i)return;if(i.branchKind===`subagent`&&i.parentSessionId!==void 0){await ri(e,n,i.parentSessionId);return}if(i.branchKind!==`compress`)return;await ii(e,i,r)}catch(e){console.error(`[CompressLineageResolver] Failed to resolve compress lineage`,{payload:t.payload,error:e})}})}function si(e){return[...e].map(e=>{let t=Xr(e);return{id:e,pattern:RegExp(`(^|${Yr})${t}($|${Yr})`)}})}async function ci(e,t,n){return ti(await Promise.all(n.filter(e=>e.branchKind===`subagent`&&e.spawningToolCallId===void 0).map(async n=>{let{session:r}=await e.request(u.get,{sessionId:n.sessionId}),i=r?.source??r?.adapterName;return r?.adapterSessionId&&i===t?{sessionId:n.sessionId,adapterSessionId:r.adapterSessionId}:null})))}function li(e){return e.on(O.import.completed,async t=>{try{let{sessionId:n,source:r}=t.payload,{children:i}=await e.request(u.getChildren,{sessionId:n}),a=await ci(e,r,i),o=new Set(a.keys());if(o.size===0)return;let s=await Qr(e,n),c=$r(s);if(c.length===0)return;let l=ei(s,si(o)),d=new Map;for(let e of c){let t=l.get(e.toolCallId);t!==void 0&&d.set(t,(d.get(t)??0)+1)}let f=new Map;for(let e of c){let t=l.get(e.toolCallId),n=t===void 0?void 0:a.get(t);n!==void 0&&t!==void 0&&d.get(t)===1&&f.set(n,e.toolCallId)}let p=[...f].map(async([t,r])=>{try{let{session:n}=await e.request(u.get,{sessionId:t});if(n?.spawningToolCallId!==void 0)return;await e.request(u.update,{sessionId:t,spawningToolCallId:r})}catch(e){console.error(`Failed to persist spawning tool call correlation`,{parentSessionId:n,childSessionId:t,toolCallId:r,error:e})}});await Promise.allSettled(p)}catch(e){console.error(`Failed to backfill spawningToolCallId for imported session`,{payload:t.payload,error:e})}})}function ui(e){return e.on(E.session.discovered,async t=>{let n=me.safeParse(t.payload);if(!n.success)throw console.error(`[registerSessionDiscoveredHandler] Invalid adapter.session.discovered payload`,{issues:n.error.issues}),n.error;let{adapterId:r,adapterSessionId:i,adapterName:a,cwd:o,title:s,logFilePath:c,startedAt:l,kind:d,parentAdapterSessionId:f,forkPointMessageId:p}=n.data,m=mn({kind:d,parentAdapterSessionId:f??null,forkPointMessageId:p??null});await e.request(u.importUpsert,{externalSessionId:i,source:a,adapterId:r,cwd:o??null,...s===void 0?{}:{title:s},...c===void 0?{}:{logFilePath:c},...l===void 0?{}:{startedAt:l},...m})})}var di=class{bus;agentStates=new Map;sessionStates=new Map;unsubscribe;staleThresholdMs;constructor(e,t){this.bus=e,this.staleThresholdMs=t?.staleThresholdMs??36e5}start(){this.unsubscribe||=this.bus.on(D.contextWindow.updated,e=>{let{agentId:t,sessionId:n,currentTokens:r,maxTokens:i,percentage:a,level:o,cachedTokens:s}=e.payload;if(!n)return;let c={agentId:t,sessionId:n,currentTokens:r,maxTokens:i,percentage:a,level:o,cachedTokens:s,updatedAt:Date.now()};this.agentStates.set(t,c),this.recomputeSessionState(n)})}stop(){this.unsubscribe?.(),this.unsubscribe=void 0,this.agentStates.clear(),this.sessionStates.clear()}getSessionState(e){return this.sessionStates.get(e)}clearSession(e){this.sessionStates.delete(e);for(let[t,n]of this.agentStates)n.sessionId===e&&this.agentStates.delete(t)}recomputeSessionState(e){let t=Date.now(),n;for(let[r,i]of this.agentStates){if(t-i.updatedAt>this.staleThresholdMs){this.agentStates.delete(r);continue}i.sessionId===e&&(!n||i.percentage>n.percentage)&&(n=i)}n&&this.sessionStates.set(e,{currentTokens:n.currentTokens,maxTokens:n.maxTokens,percentage:n.percentage,level:n.level,worstAgentId:n.agentId,lastUpdatedAt:n.updatedAt})}};export{ln as A,Jt as B,Z as C,mn as D,pn as E,an as F,Pt as G,qt as H,nn as I,at as J,wt as K,tn as L,sn as M,on as N,un as O,rn as P,en as R,$n as S,Pn as T,Kt as U,W as V,Lt as W,Ue as X,rt as Y,Fr as _,qr as a,Or as b,Ur as c,Rr as d,Lr as f,Mr as g,Nr as h,oi as i,cn as j,dn as k,Br as l,jr as m,ui as n,Kr as o,Ir as p,dt as q,li as r,Gr as s,di as t,zr as u,Pr as v,Xn as w,er as x,Ar as y,Qt as z};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{t as e}from"./jsonl-transport-
|
|
1
|
+
import{t as e}from"./jsonl-transport-C21tpVfe.mjs";import{CorrelationTracker as t,DEFAULT_REQUEST_TIMEOUT_MS as n,handleCorrelationResponse as r,trackMessageCorrelation as i}from"@makaio/framework/bus";var a=class{name;spawnOptions;jsonl=null;handlers=new Set;correlations=new t;handshakeComplete=!1;terminalError=null;localSubscriptions=new Map;readyResolve=null;readyReject=null;onNewReadySession=void 0;onConnected=void 0;onDisconnected=void 0;ready;constructor(e){this.name=e.name??`stdio-server`,this.spawnOptions=e.spawn,this.ready=this.createReadyPromise()}async connect(){if(this.jsonl!==null)throw Error(`StdioServerTransport: already connected`);this.readyResolve===null&&this.readyReject===null&&(this.ready=this.createReadyPromise()),this.handshakeComplete=!1,this.terminalError=null;let t=e(this.spawnOptions);this.jsonl=t,t.onMessage(e=>{this.jsonl===t&&this.handleInbound(e)}),t.onError(e=>{this.jsonl===t&&this.terminateSession(e,!0)}),t.process.once(`exit`,e=>{this.jsonl===t&&this.terminateSession(Error(`Child process exited (code ${e??`signal`}) before subscribe-sync handshake completed`),!1)}),this.localSubscriptions.size>0&&this.sendSubscribeMessage()}async send(e,t){if(this.jsonl===null)throw Error(`StdioServerTransport: not connected`);return this.jsonl.send(e),i(e,this.correlations,t??n)}onReceive(e){return this.handlers.add(e),()=>{this.handlers.delete(e)}}async disconnect(){let e=this.jsonl;this.jsonl=null,this.handshakeComplete=!1,this.terminalError=null,this.readyResolve?.(),this.readyResolve=null,this.readyReject=null,this.correlations.cleanup(),e?.close()}async subscribe(e,t,n=[]){this.localSubscriptions.set(e,{priorities:n,filter:t}),this.jsonl!==null&&this.sendSubscribeMessage(e,t,n)}async unsubscribe(e){let t=this.localSubscriptions.delete(e);this.jsonl!==null&&t&&this.jsonl.send({type:`unsubscribe`,subjects:{[e]:[]}})}isReady(){return this.jsonl!==null&&this.terminalError===null&&this.handshakeComplete&&this.jsonl.process.exitCode===null}cancelRequest(e,t){this.correlations.cancel(e,t)}createReadyPromise(){let e=new Promise((e,t)=>{this.readyResolve=e,this.readyReject=t});return this.onNewReadySession?.(e),e}terminateSession(e,t){let n=this.jsonl;this.jsonl=null,this.handshakeComplete=!1,this.terminalError=e,this.readyReject?.(e),this.readyResolve=null,this.readyReject=null,this.correlations.cleanup(),t&&n?.close(),this.onDisconnected?.()}async handleInbound(e){if(typeof e!=`object`||!e||typeof e.type!=`string`)return;let t=e;if(t.type!==`heartbeat`){if(t.type===`subscribe-sync-complete`){this.handshakeComplete=!0,this.readyResolve?.(),this.readyResolve=null,this.readyReject=null,this.jsonl?.send({type:`subscribe-sync-complete`}),this.onConnected?.();return}if(!r(t,this.correlations))for(let e of this.handlers)try{await e(t,{transportName:this.name})}catch{}}}sendSubscribeMessage(e,t,n=[]){if(this.jsonl===null)return;if(e!==void 0){this.jsonl.send({type:`subscribe`,subjects:{[e]:n},...t===void 0?{}:{filters:{[e]:t}}});return}let r={},i={},a=!1;for(let[e,t]of this.localSubscriptions)r[e]=t.priorities,t.filter!==void 0&&(i[e]=t.filter,a=!0);this.jsonl.send({type:`subscribe`,subjects:r,...a?{filters:i}:{}})}};export{a as StdioServerTransport};
|
|
@@ -1,78 +1,2 @@
|
|
|
1
|
-
import { t as
|
|
2
|
-
|
|
3
|
-
//#region storage/drizzle/src/client.d.ts
|
|
4
|
-
/**
|
|
5
|
-
* Configuration options for the database client.
|
|
6
|
-
*/
|
|
7
|
-
interface DatabaseClientConfig {
|
|
8
|
-
/**
|
|
9
|
-
* Database URL.
|
|
10
|
-
* Supports libSQL / SQLite connection strings:
|
|
11
|
-
* - `file:./path/to/db.db` for local SQLite files
|
|
12
|
-
* - `libsql://host` for remote libSQL/Turso
|
|
13
|
-
* - `http://localhost:8080` for local libSQL server
|
|
14
|
-
* - `:memory:` for an in-process in-memory database
|
|
15
|
-
*
|
|
16
|
-
* Defaults to `'file:./makaio.db'`.
|
|
17
|
-
*/
|
|
18
|
-
url?: string;
|
|
19
|
-
/**
|
|
20
|
-
* Authentication token for remote databases (Turso).
|
|
21
|
-
* Not required for local file-based or in-memory databases.
|
|
22
|
-
*/
|
|
23
|
-
authToken?: string;
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* Result of creating a database client.
|
|
27
|
-
*/
|
|
28
|
-
interface DatabaseClient {
|
|
29
|
-
/** The drizzle ORM instance */
|
|
30
|
-
db: MakaioDatabase;
|
|
31
|
-
/** Close the database connection. Safe to call multiple times. */
|
|
32
|
-
close(): void;
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Creates a drizzle ORM instance backed by the appropriate SQLite driver for
|
|
36
|
-
* the current runtime.
|
|
37
|
-
*
|
|
38
|
-
* **Driver selection (runtime-conditional):**
|
|
39
|
-
* - **Bun + local URL** (`file:` or `:memory:`) — uses the built-in `bun:sqlite`
|
|
40
|
-
* driver via `drizzle-orm/bun-sqlite`. The module is loaded dynamically so
|
|
41
|
-
* this file is safe to import under Node.js.
|
|
42
|
-
* - **Bun + remote URL** (`libsql:`, `http:`, `https:`, …) — stays on
|
|
43
|
-
* `@libsql/client` via `drizzle-orm/libsql`; `bun:sqlite` cannot handle
|
|
44
|
-
* remote connections.
|
|
45
|
-
* - **Node.js** — always uses `@libsql/client` via `drizzle-orm/libsql`.
|
|
46
|
-
*
|
|
47
|
-
* For local databases, automatically enables:
|
|
48
|
-
* - `file:` URLs: WAL journal mode, 5-second busy timeout, and foreign key enforcement
|
|
49
|
-
* - `:memory:`: foreign key enforcement only
|
|
50
|
-
*
|
|
51
|
-
* SEAM: This factory allows swapping the database backend by providing
|
|
52
|
-
* different connection URLs (local file, Turso, libSQL server).
|
|
53
|
-
* @param config - Database configuration options
|
|
54
|
-
* @returns Database client with drizzle ORM instance and close method
|
|
55
|
-
* @example
|
|
56
|
-
* ```typescript
|
|
57
|
-
* import { createDatabaseClient } from '@makaio/framework/storage/drizzle/client';
|
|
58
|
-
*
|
|
59
|
-
* // Local development with file-based SQLite
|
|
60
|
-
* const { db, close } = await createDatabaseClient();
|
|
61
|
-
*
|
|
62
|
-
* // Production with Turso
|
|
63
|
-
* const { db, close } = await createDatabaseClient({
|
|
64
|
-
* url: process.env.TURSO_DATABASE_URL,
|
|
65
|
-
* authToken: process.env.TURSO_AUTH_TOKEN,
|
|
66
|
-
* });
|
|
67
|
-
*
|
|
68
|
-
* // Use with storage handlers
|
|
69
|
-
* import { registerDrizzleSessionStorage } from '@makaio/framework/services/session';
|
|
70
|
-
* registerDrizzleSessionStorage(bus, db, ctx);
|
|
71
|
-
*
|
|
72
|
-
* // Close when done
|
|
73
|
-
* close();
|
|
74
|
-
* ```
|
|
75
|
-
*/
|
|
76
|
-
declare function createDatabaseClient(config?: DatabaseClientConfig): Promise<DatabaseClient>;
|
|
77
|
-
//#endregion
|
|
78
|
-
export { DatabaseClient, DatabaseClientConfig, createDatabaseClient };
|
|
1
|
+
import { i as createDatabaseClient, n as DatabaseClientConfig, r as PostgresClientOptions, t as DatabaseClient } from "../../client-BJVDImPV.mjs";
|
|
2
|
+
export { DatabaseClient, DatabaseClientConfig, PostgresClientOptions, createDatabaseClient };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import{a as e,h as t,n}from"../../registry-RG-bkw3c.mjs";async function r(r={}){if(r.url!==void 0){let n=e(r.url);if(n.kind===`missing-engine`)throw Error(t(n.dialect,n.packageName));if(n.kind===`engine`)return n.engine.createClient(r)}return n(`sqlite`).createClient(r)}export{r as createDatabaseClient};
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import * as _$drizzle_orm_pg_core0 from "drizzle-orm/pg-core";
|
|
2
|
+
import * as _$drizzle_orm0 from "drizzle-orm";
|
|
3
|
+
|
|
4
|
+
//#region storage/drizzle/src/columns/postgres.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Postgres column bundle for the storage dialect design.
|
|
7
|
+
*
|
|
8
|
+
* These helpers encode the fixed SQLite→Postgres column mapping table so that
|
|
9
|
+
* twin schema files stay mechanically in sync with their canonical counterparts:
|
|
10
|
+
*
|
|
11
|
+
* | Bundle | SQL type (Postgres) |
|
|
12
|
+
* |----------------------|----------------------------------------------------------|
|
|
13
|
+
* | `epochMs` | `bigint` ('number' mode, int53-safe) |
|
|
14
|
+
* | `bool` | `boolean` |
|
|
15
|
+
* | `jsonCol` | `jsonb` |
|
|
16
|
+
* | `autoPk` | `bigint GENERATED ALWAYS AS IDENTITY PRIMARY KEY` |
|
|
17
|
+
* | `float8` | `double precision` |
|
|
18
|
+
*
|
|
19
|
+
* **Accepted divergences (jsonCol → jsonb):** jsonb silently rejects `\u0000`
|
|
20
|
+
* escapes, normalizes key order, and drops duplicate keys. Plain `text` columns
|
|
21
|
+
* holding hand-stringified JSON stay `text` on both dialects — this bundle is
|
|
22
|
+
* for structured JSON that drizzle serializes and deserializes.
|
|
23
|
+
*
|
|
24
|
+
* **Partial-index predicate rewrites:** boolean partial indexes use `= 1` on
|
|
25
|
+
* SQLite and `= true` on Postgres. Postgres twin schema files must rewrite such
|
|
26
|
+
* predicates to `= true` in their `.where()` clauses — drizzle-kit emits DDL
|
|
27
|
+
* mechanically from the twin source, and `= 1` against a native boolean column
|
|
28
|
+
* is a type error on Postgres.
|
|
29
|
+
*
|
|
30
|
+
* **`autoPk` monotonicity caveat:** identity values are strictly increasing per
|
|
31
|
+
* single writer. Cursor pagination over this key assumes a single writer
|
|
32
|
+
* process.
|
|
33
|
+
*
|
|
34
|
+
* **`epochMs` precision:** stored as `bigint` in JavaScript `'number'` mode
|
|
35
|
+
* (int53-safe). No SQL date arithmetic is performed in the framework; the
|
|
36
|
+
* column holds raw millisecond offsets.
|
|
37
|
+
*
|
|
38
|
+
* **`float8` vs `real`:** Postgres `real` is 4-byte and would silently narrow
|
|
39
|
+
* values that are 8-byte in SQLite. `double precision` preserves the range.
|
|
40
|
+
* @packageDocumentation
|
|
41
|
+
*/
|
|
42
|
+
/**
|
|
43
|
+
* Unix-epoch-milliseconds timestamp column.
|
|
44
|
+
* SQLite: `integer`. Postgres twin: `bigint` in `'number'` mode (int53-safe;
|
|
45
|
+
* no SQL date arithmetic exists in the framework).
|
|
46
|
+
* @param name - SQL column name.
|
|
47
|
+
* @returns Chainable Postgres `bigint` ('number' mode) column builder.
|
|
48
|
+
*/
|
|
49
|
+
declare const epochMs: (name: string) => _$drizzle_orm_pg_core0.PgBigInt53BuilderInitial<string>;
|
|
50
|
+
/**
|
|
51
|
+
* Boolean flag column.
|
|
52
|
+
* SQLite: `integer` in `'boolean'` mode. Postgres twin: native `boolean`.
|
|
53
|
+
* Partial-index predicates over these columns are `= 1` on SQLite and
|
|
54
|
+
* `= true` on Postgres.
|
|
55
|
+
* @param name - SQL column name.
|
|
56
|
+
* @returns Chainable Postgres `boolean` column builder.
|
|
57
|
+
*/
|
|
58
|
+
declare const bool: (name: string) => _$drizzle_orm_pg_core0.PgBooleanBuilderInitial<string>;
|
|
59
|
+
/**
|
|
60
|
+
* Structured JSON column (drizzle serializes/deserializes).
|
|
61
|
+
* SQLite: `text` in `'json'` mode. Postgres twin: `jsonb` (accepted divergence:
|
|
62
|
+
* jsonb rejects `\u0000` escapes, normalizes key order, drops duplicate keys).
|
|
63
|
+
* NOT for hand-stringified JSON held in plain `text` columns — those stay `text`.
|
|
64
|
+
* @param name - SQL column name.
|
|
65
|
+
* @typeParam T - Deserialized value type pinned via `$type`.
|
|
66
|
+
* @returns Chainable Postgres `jsonb` column builder typed as `T`.
|
|
67
|
+
*/
|
|
68
|
+
declare const jsonCol: <T>(name: string) => _$drizzle_orm0.$Type<_$drizzle_orm_pg_core0.PgJsonbBuilderInitial<string>, T>;
|
|
69
|
+
/**
|
|
70
|
+
* Auto-generated integer primary key.
|
|
71
|
+
* SQLite: `integer ... PRIMARY KEY AUTOINCREMENT`. Postgres twin:
|
|
72
|
+
* `bigint GENERATED ALWAYS AS IDENTITY PRIMARY KEY` (`'number'` mode).
|
|
73
|
+
* Monotonicity note: identity values are strictly increasing per single
|
|
74
|
+
* writer; cursor pagination over this key assumes a single writer process.
|
|
75
|
+
* @param name - SQL column name.
|
|
76
|
+
* @returns Chainable Postgres identity `bigint` primary-key column builder.
|
|
77
|
+
*/
|
|
78
|
+
declare const autoPk: (name: string) => _$drizzle_orm0.IsPrimaryKey<_$drizzle_orm0.NotNull<_$drizzle_orm0.IsIdentity<_$drizzle_orm_pg_core0.PgBigInt53BuilderInitial<string>, "always">>>;
|
|
79
|
+
/**
|
|
80
|
+
* Eight-byte floating-point column.
|
|
81
|
+
* SQLite: `real` (always 8-byte). Postgres twin: `double precision` —
|
|
82
|
+
* Postgres `real` is 4-byte and would silently narrow.
|
|
83
|
+
* @param name - SQL column name.
|
|
84
|
+
* @returns Chainable Postgres `double precision` column builder.
|
|
85
|
+
*/
|
|
86
|
+
declare const float8: (name: string) => _$drizzle_orm_pg_core0.PgDoublePrecisionBuilderInitial<string>;
|
|
87
|
+
//#endregion
|
|
88
|
+
export { autoPk, bool, epochMs, float8, jsonCol };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{bigint as e,boolean as t,doublePrecision as n,jsonb as r}from"drizzle-orm/pg-core";const i=t=>e(t,{mode:`number`}),a=e=>t(e),o=e=>r(e).$type(),s=t=>e(t,{mode:`number`}).generatedAlwaysAsIdentity().primaryKey(),c=e=>n(e);export{s as autoPk,a as bool,i as epochMs,c as float8,o as jsonCol};
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import * as _$drizzle_orm_sqlite_core0 from "drizzle-orm/sqlite-core";
|
|
2
|
+
import * as _$drizzle_orm0 from "drizzle-orm";
|
|
3
|
+
|
|
4
|
+
//#region storage/drizzle/src/columns/sqlite.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* SQLite column bundle for the storage dialect design.
|
|
7
|
+
*
|
|
8
|
+
* These helpers encode the fixed SQLite→Postgres column mapping table so that
|
|
9
|
+
* twin schema files stay mechanically in sync with their canonical counterparts:
|
|
10
|
+
*
|
|
11
|
+
* | SQLite bundle | SQL type (SQLite) | Postgres twin |
|
|
12
|
+
* |----------------------|------------------------------|-------------------------|
|
|
13
|
+
* | `epochMs` | `integer` | `bigint` ('number' mode)|
|
|
14
|
+
* | `bool` | `integer` (boolean mode) | `boolean` |
|
|
15
|
+
* | `jsonCol` | `text` (json mode) | `jsonb` |
|
|
16
|
+
* | `autoPk` | `integer PRIMARY KEY AUTOINCREMENT` | `bigint GENERATED ALWAYS AS IDENTITY PRIMARY KEY` |
|
|
17
|
+
* | `float8` | `real` (8-byte) | `double precision` |
|
|
18
|
+
*
|
|
19
|
+
* **Accepted divergences (jsonCol → jsonb):** jsonb silently rejects `\u0000`
|
|
20
|
+
* escapes, normalizes key order, and drops duplicate keys. Plain `text` columns
|
|
21
|
+
* holding hand-stringified JSON stay `text` on both dialects — this bundle is
|
|
22
|
+
* for structured JSON that drizzle serializes and deserializes.
|
|
23
|
+
*
|
|
24
|
+
* **Partial-index predicate rewrites:** boolean partial indexes use `= 1` on
|
|
25
|
+
* SQLite and `= true` on Postgres. Postgres twin schema files must rewrite such
|
|
26
|
+
* predicates to `= true` in their `.where()` clauses — drizzle-kit emits DDL
|
|
27
|
+
* mechanically from the twin source, and `= 1` against a native boolean column
|
|
28
|
+
* is a type error on Postgres.
|
|
29
|
+
*
|
|
30
|
+
* **`autoPk` monotonicity caveat:** identity values are strictly increasing per
|
|
31
|
+
* single writer. Cursor pagination over this key assumes a single writer
|
|
32
|
+
* process.
|
|
33
|
+
* @packageDocumentation
|
|
34
|
+
*/
|
|
35
|
+
/**
|
|
36
|
+
* Unix-epoch-milliseconds timestamp column.
|
|
37
|
+
* SQLite: `integer`. Postgres twin: `bigint` in `'number'` mode (int53-safe;
|
|
38
|
+
* no SQL date arithmetic exists in the framework).
|
|
39
|
+
* @param name - SQL column name.
|
|
40
|
+
* @returns Chainable SQLite `integer` column builder.
|
|
41
|
+
*/
|
|
42
|
+
declare const epochMs: (name: string) => _$drizzle_orm_sqlite_core0.SQLiteIntegerBuilderInitial<string>;
|
|
43
|
+
/**
|
|
44
|
+
* Boolean flag column.
|
|
45
|
+
* SQLite: `integer` in `'boolean'` mode. Postgres twin: native `boolean`.
|
|
46
|
+
* Partial-index predicates over these columns are `= 1` on SQLite and
|
|
47
|
+
* `= true` on Postgres.
|
|
48
|
+
* @param name - SQL column name.
|
|
49
|
+
* @returns Chainable SQLite boolean-mode `integer` column builder.
|
|
50
|
+
*/
|
|
51
|
+
declare const bool: (name: string) => _$drizzle_orm_sqlite_core0.SQLiteBooleanBuilderInitial<string>;
|
|
52
|
+
/**
|
|
53
|
+
* Structured JSON column (drizzle serializes/deserializes).
|
|
54
|
+
* SQLite: `text` in `'json'` mode. Postgres twin: `jsonb` (accepted divergence:
|
|
55
|
+
* jsonb rejects `\u0000` escapes, normalizes key order, drops duplicate keys).
|
|
56
|
+
* NOT for hand-stringified JSON held in plain `text` columns — those stay `text`.
|
|
57
|
+
* @param name - SQL column name.
|
|
58
|
+
* @typeParam T - Deserialized value type pinned via `$type`.
|
|
59
|
+
* @returns Chainable SQLite json-mode `text` column builder typed as `T`.
|
|
60
|
+
*/
|
|
61
|
+
declare const jsonCol: <T>(name: string) => _$drizzle_orm0.$Type<_$drizzle_orm_sqlite_core0.SQLiteTextJsonBuilderInitial<string>, T>;
|
|
62
|
+
/**
|
|
63
|
+
* Auto-generated integer primary key.
|
|
64
|
+
* SQLite: `integer ... PRIMARY KEY AUTOINCREMENT`. Postgres twin:
|
|
65
|
+
* `bigint GENERATED ALWAYS AS IDENTITY PRIMARY KEY` (`'number'` mode).
|
|
66
|
+
* Monotonicity note: identity values are strictly increasing per single
|
|
67
|
+
* writer; cursor pagination over this key assumes a single writer process.
|
|
68
|
+
* @param name - SQL column name.
|
|
69
|
+
* @returns Chainable SQLite autoincrement integer primary-key column builder.
|
|
70
|
+
*/
|
|
71
|
+
declare const autoPk: (name: string) => _$drizzle_orm0.IsPrimaryKey<_$drizzle_orm0.HasDefault<_$drizzle_orm0.NotNull<_$drizzle_orm_sqlite_core0.SQLiteIntegerBuilderInitial<string>>>>;
|
|
72
|
+
/**
|
|
73
|
+
* Eight-byte floating-point column.
|
|
74
|
+
* SQLite: `real` (always 8-byte). Postgres twin: `double precision` —
|
|
75
|
+
* Postgres `real` is 4-byte and would silently narrow.
|
|
76
|
+
* @param name - SQL column name.
|
|
77
|
+
* @returns Chainable SQLite `real` column builder.
|
|
78
|
+
*/
|
|
79
|
+
declare const float8: (name: string) => _$drizzle_orm_sqlite_core0.SQLiteRealBuilderInitial<string>;
|
|
80
|
+
//#endregion
|
|
81
|
+
export { autoPk, bool, epochMs, float8, jsonCol };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{integer as e,real as t,text as n}from"drizzle-orm/sqlite-core";const r=t=>e(t),i=t=>e(t,{mode:`boolean`}),a=e=>n(e,{mode:`json`}).$type(),o=t=>e(t).primaryKey({autoIncrement:!0}),s=e=>t(e);export{o as autoPk,i as bool,r as epochMs,s as float8,a as jsonCol};
|