@jingyi0605/codingns 0.6.1 → 0.7.0
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/bin/codingns.mjs +225 -0
- package/dist/public/assets/AdaptiveButlerPage-B8mg25ze.js +3 -0
- package/dist/public/assets/{App-Dsf3ooXU.js → App-C2lNmeKL.js} +6 -6
- package/dist/public/assets/{BootstrapPage-CE0m1qSR.js → BootstrapPage-CAVA-a8h.js} +1 -1
- package/dist/public/assets/ConversationPage-B6BGOX4C.js +6 -0
- package/dist/public/assets/{DesktopDetachPreviewPage-Dxarr_Wf.js → DesktopDetachPreviewPage-B37DUL15.js} +1 -1
- package/dist/public/assets/{DesktopWindowPage-VytPwJ4c.js → DesktopWindowPage-CDA6l7lm.js} +1 -1
- package/dist/public/assets/{FileContextPanel-DwFzLsOp.js → FileContextPanel-CMGTtAB6.js} +1 -1
- package/dist/public/assets/{GitSidebar-CH6WqTrM.js → GitSidebar--DCqBiGL.js} +1 -1
- package/dist/public/assets/{MobileCreateSessionSheet-DcxKM00P.js → MobileCreateSessionSheet-THIrIzJ3.js} +1 -1
- package/dist/public/assets/{MobileTopHeaderFrame-C5rIKQT6.js → MobileTopHeaderFrame-D-X7pVnV.js} +1 -1
- package/dist/public/assets/{MobileWorkspaceSwitcherHeader-CfUnHgv_.js → MobileWorkspaceSwitcherHeader-Cczi7RYu.js} +1 -1
- package/dist/public/assets/{RelayConnectEntryPage-CgMvVZwa.js → RelayConnectEntryPage-D417tgWj.js} +1 -1
- package/dist/public/assets/{ServerSettingsModal-CFul__z1.js → ServerSettingsModal-BdTxbRbU.js} +1 -1
- package/dist/public/assets/SessionIndexPage-D5iefVcc.js +1 -0
- package/dist/public/assets/SettingsPage-iCFe_DHP.js +2 -0
- package/dist/public/assets/{TerminalManagerPanel-BbORd-ee.js → TerminalManagerPanel-CtldwWz8.js} +1 -1
- package/dist/public/assets/{TerminalPage-DWHv6mlu.js → TerminalPage-DAzQTmQC.js} +19 -19
- package/dist/public/assets/{TerminalRuntimeFallbackModal-B29YxbQe.js → TerminalRuntimeFallbackModal-DLOhAvaq.js} +1 -1
- package/dist/public/assets/{ToolFilesPage-Dx9cv9hu.js → ToolFilesPage-D7thcDEv.js} +1 -1
- package/dist/public/assets/{ToolGitPage-D7H3vAia.js → ToolGitPage-uPRsxdcn.js} +1 -1
- package/dist/public/assets/{ToolProcessesPage-PqQWxsy-.js → ToolProcessesPage-B1uOk0Ef.js} +1 -1
- package/dist/public/assets/{ToolsHomePage-CX05Pe_4.js → ToolsHomePage-rU3V8mmh.js} +1 -1
- package/dist/public/assets/{WorkbenchLandingPage-CchkAC75.js → WorkbenchLandingPage-BudM2C69.js} +1 -1
- package/dist/public/assets/WorkbenchLayout-Dybarc1V.js +244 -0
- package/dist/public/assets/WorkbenchModal-DMQutm1x.js +1 -0
- package/dist/public/assets/WorkbenchShellRoute-Cy4WBbzq.js +1 -0
- package/dist/public/assets/{WorkbenchShellRoute-RGZpA0_J.css → WorkbenchShellRoute-DhQo_0vu.css} +1 -1
- package/dist/public/assets/{WorkspaceDebugDetailPage-Deqy2_pO.js → WorkspaceDebugDetailPage-CHqo-uDf.js} +1 -1
- package/dist/public/assets/{WorkspaceDetailPage-Cvf-ZdlB.js → WorkspaceDetailPage-CGkAH1W-.js} +1 -1
- package/dist/public/assets/{WorkspaceHomePage-Dsyvqyk1.js → WorkspaceHomePage-CfuPVITd.js} +1 -1
- package/dist/public/assets/{client-runtime-manager-DROQJ9v3.js → client-runtime-manager-CKbtaemV.js} +1 -1
- package/dist/public/assets/file-tree-icon-Bc0KADEl.js +3 -0
- package/dist/public/assets/index-DNRyROOG.css +1 -0
- package/dist/public/assets/index-oGylLBIX.js +42 -0
- package/dist/public/assets/{login-direct-candidate-resolver-DotM530R.js → login-direct-candidate-resolver-DjJMbqB7.js} +1 -1
- package/dist/public/assets/model-switch-api-T55eW6D4.js +1 -0
- package/dist/public/assets/{preferences-service-BG6GKG29.js → preferences-service-BTKBl5xM.js} +1 -1
- package/dist/public/assets/realtime-client-ww7MnbTD.js +1 -0
- package/dist/public/assets/{relay-entry-pmr-c42O.js → relay-entry-sdeFnTbY.js} +1 -1
- package/dist/public/assets/styles-BjPytabP.css +1 -0
- package/dist/public/assets/{terminal-runtime-meta-8_uRZf7h.js → terminal-runtime-meta-Cvt1ID92.js} +1 -1
- package/dist/public/assets/{useRegisteredDebugTemplates-DWX7LXQu.js → useRegisteredDebugTemplates-O-ymgLd9.js} +1 -1
- package/dist/public/index.html +2 -2
- package/dist/server/config/env.js +21 -1
- package/dist/server/config/env.js.map +1 -1
- package/dist/server/config/opencode-base-url-resolver.d.ts +16 -0
- package/dist/server/config/opencode-base-url-resolver.js +154 -0
- package/dist/server/config/opencode-base-url-resolver.js.map +1 -1
- package/dist/server/helpers/wechat-claw-runtime/main.d.ts +1 -0
- package/dist/server/helpers/wechat-claw-runtime/main.js +38 -0
- package/dist/server/helpers/wechat-claw-runtime/main.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/errors.d.ts +5 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/errors.js +32 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/errors.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/login-service.d.ts +16 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/login-service.js +209 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/login-service.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/poll-service.d.ts +18 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/poll-service.js +135 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/poll-service.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.d.ts +34 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js +394 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/send-service.d.ts +9 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/send-service.js +64 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/send-service.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/types.d.ts +167 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/types.js +3 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/types.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/wechat-api-client.d.ts +34 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/wechat-api-client.js +160 -0
- package/dist/server/helpers/wechat-claw-runtime/modules/wechat-api-client.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/routes/accounts.d.ts +9 -0
- package/dist/server/helpers/wechat-claw-runtime/routes/accounts.js +24 -0
- package/dist/server/helpers/wechat-claw-runtime/routes/accounts.js.map +1 -0
- package/dist/server/helpers/wechat-claw-runtime/server.d.ts +5 -0
- package/dist/server/helpers/wechat-claw-runtime/server.js +36 -0
- package/dist/server/helpers/wechat-claw-runtime/server.js.map +1 -0
- package/dist/server/middlewares/auth-guard.js +4 -1
- package/dist/server/middlewares/auth-guard.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +4 -1
- package/dist/server/modules/assistant-capability/assistant-capability-service.js +12 -1
- package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -1
- package/dist/server/modules/butler/butler-control-session-service.d.ts +20 -2
- package/dist/server/modules/butler/butler-control-session-service.js +121 -74
- package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-profile-service.d.ts +3 -1
- package/dist/server/modules/butler/butler-profile-service.js +16 -4
- package/dist/server/modules/butler/butler-profile-service.js.map +1 -1
- package/dist/server/modules/butler/butler-session-service.js +44 -15
- package/dist/server/modules/butler/butler-session-service.js.map +1 -1
- package/dist/server/modules/channels/channel-bridge-service.d.ts +55 -0
- package/dist/server/modules/channels/channel-bridge-service.js +340 -0
- package/dist/server/modules/channels/channel-bridge-service.js.map +1 -0
- package/dist/server/modules/channels/channel-controller.d.ts +52 -0
- package/dist/server/modules/channels/channel-controller.js +54 -0
- package/dist/server/modules/channels/channel-controller.js.map +1 -0
- package/dist/server/modules/channels/channel-delivery-service.d.ts +63 -0
- package/dist/server/modules/channels/channel-delivery-service.js +429 -0
- package/dist/server/modules/channels/channel-delivery-service.js.map +1 -0
- package/dist/server/modules/channels/channel-gateway-controller.d.ts +15 -0
- package/dist/server/modules/channels/channel-gateway-controller.js +16 -0
- package/dist/server/modules/channels/channel-gateway-controller.js.map +1 -0
- package/dist/server/modules/channels/channel-gateway-service.d.ts +24 -0
- package/dist/server/modules/channels/channel-gateway-service.js +56 -0
- package/dist/server/modules/channels/channel-gateway-service.js.map +1 -0
- package/dist/server/modules/channels/channel-platform-adapters.d.ts +46 -0
- package/dist/server/modules/channels/channel-platform-adapters.js +315 -0
- package/dist/server/modules/channels/channel-platform-adapters.js.map +1 -0
- package/dist/server/modules/channels/channel-platform-catalog.d.ts +3 -0
- package/dist/server/modules/channels/channel-platform-catalog.js +42 -0
- package/dist/server/modules/channels/channel-platform-catalog.js.map +1 -0
- package/dist/server/modules/channels/channel-polling-scheduler.d.ts +31 -0
- package/dist/server/modules/channels/channel-polling-scheduler.js +93 -0
- package/dist/server/modules/channels/channel-polling-scheduler.js.map +1 -0
- package/dist/server/modules/channels/channel-polling-service.d.ts +46 -0
- package/dist/server/modules/channels/channel-polling-service.js +176 -0
- package/dist/server/modules/channels/channel-polling-service.js.map +1 -0
- package/dist/server/modules/channels/channel-service.d.ts +108 -0
- package/dist/server/modules/channels/channel-service.js +397 -0
- package/dist/server/modules/channels/channel-service.js.map +1 -0
- package/dist/server/modules/channels/wechat-claw-client.d.ts +51 -0
- package/dist/server/modules/channels/wechat-claw-client.js +245 -0
- package/dist/server/modules/channels/wechat-claw-client.js.map +1 -0
- package/dist/server/modules/channels/wechat-claw-runtime-boundary.d.ts +4 -0
- package/dist/server/modules/channels/wechat-claw-runtime-boundary.js +13 -0
- package/dist/server/modules/channels/wechat-claw-runtime-boundary.js.map +1 -0
- package/dist/server/modules/channels/wechat-claw-runtime-client.d.ts +14 -0
- package/dist/server/modules/channels/wechat-claw-runtime-client.js +95 -0
- package/dist/server/modules/channels/wechat-claw-runtime-client.js.map +1 -0
- package/dist/server/modules/channels/wechat-claw-runtime-manager.d.ts +16 -0
- package/dist/server/modules/channels/wechat-claw-runtime-manager.js +133 -0
- package/dist/server/modules/channels/wechat-claw-runtime-manager.js.map +1 -0
- package/dist/server/modules/channels/wechat-claw-runtime-types.d.ts +1 -0
- package/dist/server/modules/channels/wechat-claw-runtime-types.js +2 -0
- package/dist/server/modules/channels/wechat-claw-runtime-types.js.map +1 -0
- package/dist/server/modules/opencli/opencli-bridge-skill-service.d.ts +12 -0
- package/dist/server/modules/opencli/opencli-bridge-skill-service.js +125 -0
- package/dist/server/modules/opencli/opencli-bridge-skill-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-catalog-service.d.ts +50 -0
- package/dist/server/modules/opencli/opencli-catalog-service.js +345 -0
- package/dist/server/modules/opencli/opencli-catalog-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-controller.d.ts +13 -0
- package/dist/server/modules/opencli/opencli-controller.js +30 -0
- package/dist/server/modules/opencli/opencli-controller.js.map +1 -0
- package/dist/server/modules/opencli/opencli-health-service.d.ts +28 -0
- package/dist/server/modules/opencli/opencli-health-service.js +106 -0
- package/dist/server/modules/opencli/opencli-health-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-install-discovery.d.ts +23 -0
- package/dist/server/modules/opencli/opencli-install-discovery.js +130 -0
- package/dist/server/modules/opencli/opencli-install-discovery.js.map +1 -0
- package/dist/server/modules/opencli/opencli-management-service.d.ts +59 -0
- package/dist/server/modules/opencli/opencli-management-service.js +152 -0
- package/dist/server/modules/opencli/opencli-management-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-runtime-builder.d.ts +11 -0
- package/dist/server/modules/opencli/opencli-runtime-builder.js +214 -0
- package/dist/server/modules/opencli/opencli-runtime-builder.js.map +1 -0
- package/dist/server/modules/opencli/opencli-runtime-layout.d.ts +3 -0
- package/dist/server/modules/opencli/opencli-runtime-layout.js +11 -0
- package/dist/server/modules/opencli/opencli-runtime-layout.js.map +1 -0
- package/dist/server/modules/opencli/opencli-runtime-profile-service.d.ts +29 -0
- package/dist/server/modules/opencli/opencli-runtime-profile-service.js +104 -0
- package/dist/server/modules/opencli/opencli-runtime-profile-service.js.map +1 -0
- package/dist/server/modules/opencli/opencli-runtime-resolver.d.ts +29 -0
- package/dist/server/modules/opencli/opencli-runtime-resolver.js +110 -0
- package/dist/server/modules/opencli/opencli-runtime-resolver.js.map +1 -0
- package/dist/server/modules/opencli/opencli-session-prompt-service.d.ts +11 -0
- package/dist/server/modules/opencli/opencli-session-prompt-service.js +66 -0
- package/dist/server/modules/opencli/opencli-session-prompt-service.js.map +1 -0
- package/dist/server/modules/provider/provider-catalog-service.d.ts +45 -0
- package/dist/server/modules/provider/provider-catalog-service.js +204 -0
- package/dist/server/modules/provider/provider-catalog-service.js.map +1 -0
- package/dist/server/modules/provider/provider-controller.d.ts +16 -2
- package/dist/server/modules/provider/provider-controller.js +49 -6
- package/dist/server/modules/provider/provider-controller.js.map +1 -1
- package/dist/server/modules/provider/provider-disabled.d.ts +8 -0
- package/dist/server/modules/provider/provider-disabled.js +45 -0
- package/dist/server/modules/provider/provider-disabled.js.map +1 -0
- package/dist/server/modules/provider/provider-discovery-helper-client.d.ts +1 -0
- package/dist/server/modules/provider/provider-discovery-helper-client.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-helper-process.js +3 -3
- package/dist/server/modules/provider/provider-discovery-helper-process.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-runtime.d.ts +1 -1
- package/dist/server/modules/provider/provider-discovery-runtime.js +12 -8
- package/dist/server/modules/provider/provider-discovery-runtime.js.map +1 -1
- package/dist/server/modules/provider/provider-runtime-state-service.d.ts +24 -0
- package/dist/server/modules/provider/provider-runtime-state-service.js +141 -0
- package/dist/server/modules/provider/provider-runtime-state-service.js.map +1 -0
- package/dist/server/modules/sessions/claude-compatible-provider-registry.d.ts +16 -0
- package/dist/server/modules/sessions/claude-compatible-provider-registry.js +91 -0
- package/dist/server/modules/sessions/claude-compatible-provider-registry.js.map +1 -0
- package/dist/server/modules/sessions/session-history-service.d.ts +9 -3
- package/dist/server/modules/sessions/session-history-service.js +198 -62
- package/dist/server/modules/sessions/session-history-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-router-service.js +9 -4
- package/dist/server/modules/sessions/session-live-runtime-router-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-service.d.ts +8 -4
- package/dist/server/modules/sessions/session-live-runtime-service.js +99 -88
- package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
- package/dist/server/modules/sessions/session-permission-request-service.d.ts +5 -2
- package/dist/server/modules/sessions/session-permission-request-service.js +26 -27
- package/dist/server/modules/sessions/session-permission-request-service.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-config-service.d.ts +18 -1
- package/dist/server/modules/sessions/session-provider-config-service.js +142 -17
- package/dist/server/modules/sessions/session-provider-config-service.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-error-mapper.js +7 -0
- package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
- package/dist/server/modules/skills/skill-manager-service.d.ts +5 -0
- package/dist/server/modules/skills/skill-manager-service.js +26 -0
- package/dist/server/modules/skills/skill-manager-service.js.map +1 -1
- package/dist/server/modules/tasks/task-helper-process-handlers.d.ts +1 -0
- package/dist/server/modules/tasks/task-helper-process-handlers.js +1 -1
- package/dist/server/modules/tasks/task-helper-process-handlers.js.map +1 -1
- package/dist/server/modules/tasks/task-types.d.ts +2 -0
- package/dist/server/modules/tasks/task-types.js +2 -0
- package/dist/server/modules/tasks/task-types.js.map +1 -1
- package/dist/server/routes/channels.d.ts +3 -0
- package/dist/server/routes/channels.js +16 -0
- package/dist/server/routes/channels.js.map +1 -0
- package/dist/server/routes/opencli.d.ts +3 -0
- package/dist/server/routes/opencli.js +7 -0
- package/dist/server/routes/opencli.js.map +1 -0
- package/dist/server/routes/providers.js +5 -2
- package/dist/server/routes/providers.js.map +1 -1
- package/dist/server/routes/public.d.ts +2 -1
- package/dist/server/routes/public.js +3 -1
- package/dist/server/routes/public.js.map +1 -1
- package/dist/server/server/create-server.d.ts +30 -0
- package/dist/server/server/create-server.js +104 -12
- package/dist/server/server/create-server.js.map +1 -1
- package/dist/server/shared/http/error-handler.js +59 -3
- package/dist/server/shared/http/error-handler.js.map +1 -1
- package/dist/server/storage/repositories/channel-account-repository.d.ts +12 -0
- package/dist/server/storage/repositories/channel-account-repository.js +153 -0
- package/dist/server/storage/repositories/channel-account-repository.js.map +1 -0
- package/dist/server/storage/repositories/channel-delivery-repository.d.ts +13 -0
- package/dist/server/storage/repositories/channel-delivery-repository.js +156 -0
- package/dist/server/storage/repositories/channel-delivery-repository.js.map +1 -0
- package/dist/server/storage/repositories/channel-inbound-event-repository.d.ts +12 -0
- package/dist/server/storage/repositories/channel-inbound-event-repository.js +144 -0
- package/dist/server/storage/repositories/channel-inbound-event-repository.js.map +1 -0
- package/dist/server/storage/repositories/channel-thread-repository.d.ts +12 -0
- package/dist/server/storage/repositories/channel-thread-repository.js +152 -0
- package/dist/server/storage/repositories/channel-thread-repository.js.map +1 -0
- package/dist/server/storage/repositories/opencli-catalog-entry-repository.d.ts +9 -0
- package/dist/server/storage/repositories/opencli-catalog-entry-repository.js +85 -0
- package/dist/server/storage/repositories/opencli-catalog-entry-repository.js.map +1 -0
- package/dist/server/storage/repositories/opencli-provider-repository.d.ts +8 -0
- package/dist/server/storage/repositories/opencli-provider-repository.js +88 -0
- package/dist/server/storage/repositories/opencli-provider-repository.js.map +1 -0
- package/dist/server/storage/repositories/opencli-runtime-profile-repository.d.ts +11 -0
- package/dist/server/storage/repositories/opencli-runtime-profile-repository.js +127 -0
- package/dist/server/storage/repositories/opencli-runtime-profile-repository.js.map +1 -0
- package/dist/server/storage/repositories/provider-control-repository.d.ts +9 -0
- package/dist/server/storage/repositories/provider-control-repository.js +51 -0
- package/dist/server/storage/repositories/provider-control-repository.js.map +1 -0
- package/dist/server/storage/repositories/provider-runtime-state-repository.d.ts +9 -0
- package/dist/server/storage/repositories/provider-runtime-state-repository.js +50 -0
- package/dist/server/storage/repositories/provider-runtime-state-repository.js.map +1 -0
- package/dist/server/storage/sqlite/client.js +53 -0
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +180 -0
- package/dist/server/types/domain.d.ts +132 -0
- package/dist/server/ws/workbench-ws-hub.js +8 -2
- package/dist/server/ws/workbench-ws-hub.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +28 -11
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +61 -8
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.d.ts +5 -0
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.js +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/legna-runtime.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.d.ts +3 -0
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js +94 -21
- package/node_modules/@codingns/session-sync-core/dist/runtime/opencode-runtime.js.map +1 -1
- package/package.json +1 -1
- package/dist/public/assets/AdaptiveButlerPage-Dw72U3hG.js +0 -3
- package/dist/public/assets/ConversationPage-8wOY7SX-.js +0 -4
- package/dist/public/assets/SessionIndexPage-B-tRhBXC.js +0 -1
- package/dist/public/assets/SettingsPage-C9LGxSQZ.js +0 -1
- package/dist/public/assets/WorkbenchLayout-pOZvEqp7.js +0 -3
- package/dist/public/assets/WorkbenchModal-ColqvV6a.js +0 -1
- package/dist/public/assets/WorkbenchShellRoute-C0_h4lP6.js +0 -1
- package/dist/public/assets/file-tree-icon-Bp3Ntt7u.js +0 -31
- package/dist/public/assets/index-B84Po2NA.css +0 -1
- package/dist/public/assets/index-C-0oeG_5.js +0 -42
- package/dist/public/assets/model-switch-api-Bh9nYslz.js +0 -1
- package/dist/public/assets/session-runtime-machine-YN84QBlr.js +0 -21
- package/dist/public/assets/styles-CsEMfdaS.css +0 -1
- /package/dist/public/assets/{styles-DRVvx_kv.js → styles-lhQGDlPF.js} +0 -0
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import { createHash } from "node:crypto";
|
|
1
2
|
import { isAppError } from "../errors/app-error.js";
|
|
3
|
+
const EXPECTED_REQUEST_WARNING_DEDUP_TTL_MS = 2_000;
|
|
4
|
+
const expectedRequestWarningLogAtByKey = new Map();
|
|
2
5
|
export function sendError(reply, statusCode, errorCode, detail, field, data) {
|
|
3
6
|
return reply.status(statusCode).send({
|
|
4
7
|
error_code: errorCode,
|
|
@@ -15,12 +18,65 @@ export function setErrorHandler(error, request, reply) {
|
|
|
15
18
|
errorName: error.name,
|
|
16
19
|
errorMessage: error.message
|
|
17
20
|
};
|
|
18
|
-
// Host 当前关闭了 Fastify 内置 logger,这里显式写 stderr,避免 500 只有前端提示没有后端痕迹。
|
|
19
|
-
console.error("[host-error]", requestContext, error);
|
|
20
|
-
request.log.error(error);
|
|
21
21
|
if (isAppError(error)) {
|
|
22
|
+
if (shouldLogAsExpectedRequestWarning(error)) {
|
|
23
|
+
if (shouldEmitExpectedRequestWarning(error, request)) {
|
|
24
|
+
console.warn("[host-warning]", {
|
|
25
|
+
...requestContext,
|
|
26
|
+
statusCode: error.statusCode,
|
|
27
|
+
errorCode: error.errorCode
|
|
28
|
+
});
|
|
29
|
+
request.log.warn({
|
|
30
|
+
err: error,
|
|
31
|
+
...requestContext,
|
|
32
|
+
statusCode: error.statusCode,
|
|
33
|
+
errorCode: error.errorCode
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return sendError(reply, error.statusCode, error.errorCode, error.message, error.field, error.data);
|
|
37
|
+
}
|
|
38
|
+
// Host 当前关闭了 Fastify 内置 logger,这里显式写 stderr,避免 500 只有前端提示没有后端痕迹。
|
|
39
|
+
console.error("[host-error]", requestContext, error);
|
|
40
|
+
request.log.error(error);
|
|
22
41
|
return sendError(reply, error.statusCode, error.errorCode, error.message, error.field, error.data);
|
|
23
42
|
}
|
|
43
|
+
console.error("[host-error]", requestContext, error);
|
|
44
|
+
request.log.error(error);
|
|
24
45
|
return sendError(reply, 500, "INTERNAL_ERROR", "服务内部错误");
|
|
25
46
|
}
|
|
47
|
+
function shouldLogAsExpectedRequestWarning(error) {
|
|
48
|
+
if (error.statusCode !== 401) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
51
|
+
return (error.errorCode === "UNAUTHORIZED"
|
|
52
|
+
|| error.errorCode === "TOKEN_INVALID"
|
|
53
|
+
|| error.errorCode === "TOKEN_EXPIRED");
|
|
54
|
+
}
|
|
55
|
+
function shouldEmitExpectedRequestWarning(error, request) {
|
|
56
|
+
pruneExpiredExpectedRequestWarnings();
|
|
57
|
+
const now = Date.now();
|
|
58
|
+
const warningKey = [
|
|
59
|
+
error.statusCode,
|
|
60
|
+
error.errorCode,
|
|
61
|
+
readAuthorizationFingerprint(request)
|
|
62
|
+
].join(":");
|
|
63
|
+
const lastLoggedAt = expectedRequestWarningLogAtByKey.get(warningKey);
|
|
64
|
+
expectedRequestWarningLogAtByKey.set(warningKey, now);
|
|
65
|
+
return !lastLoggedAt || now - lastLoggedAt > EXPECTED_REQUEST_WARNING_DEDUP_TTL_MS;
|
|
66
|
+
}
|
|
67
|
+
function pruneExpiredExpectedRequestWarnings() {
|
|
68
|
+
const now = Date.now();
|
|
69
|
+
for (const [warningKey, loggedAt] of expectedRequestWarningLogAtByKey.entries()) {
|
|
70
|
+
if (now - loggedAt > EXPECTED_REQUEST_WARNING_DEDUP_TTL_MS) {
|
|
71
|
+
expectedRequestWarningLogAtByKey.delete(warningKey);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
function readAuthorizationFingerprint(request) {
|
|
76
|
+
const authorization = request.headers.authorization;
|
|
77
|
+
if (!authorization) {
|
|
78
|
+
return "anonymous";
|
|
79
|
+
}
|
|
80
|
+
return createHash("sha1").update(authorization).digest("hex").slice(0, 12);
|
|
81
|
+
}
|
|
26
82
|
//# sourceMappingURL=error-handler.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error-handler.js","sourceRoot":"","sources":["../../../../src/shared/http/error-handler.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"error-handler.js","sourceRoot":"","sources":["../../../../src/shared/http/error-handler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { ChannelAccount } from "../../types/domain.js";
|
|
3
|
+
export declare class ChannelAccountRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
listByUserId(userId: string): ChannelAccount[];
|
|
7
|
+
findById(id: string): ChannelAccount | null;
|
|
8
|
+
listActiveByConnectionModes(connectionModes: ChannelAccount["connectionMode"][]): ChannelAccount[];
|
|
9
|
+
create(record: ChannelAccount): ChannelAccount;
|
|
10
|
+
update(record: ChannelAccount): ChannelAccount;
|
|
11
|
+
delete(id: string): boolean;
|
|
12
|
+
}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
export class ChannelAccountRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
listByUserId(userId) {
|
|
7
|
+
return this.db
|
|
8
|
+
.prepare(`SELECT
|
|
9
|
+
id,
|
|
10
|
+
user_id,
|
|
11
|
+
platform_code,
|
|
12
|
+
display_name,
|
|
13
|
+
provider_id,
|
|
14
|
+
connection_mode,
|
|
15
|
+
status,
|
|
16
|
+
config_json,
|
|
17
|
+
runtime_state_json,
|
|
18
|
+
last_inbound_at,
|
|
19
|
+
last_outbound_at,
|
|
20
|
+
last_error,
|
|
21
|
+
created_at,
|
|
22
|
+
updated_at
|
|
23
|
+
FROM channel_accounts
|
|
24
|
+
WHERE user_id = ?
|
|
25
|
+
ORDER BY updated_at DESC, created_at DESC`)
|
|
26
|
+
.all(userId)
|
|
27
|
+
.map((row) => mapChannelAccountRow(row));
|
|
28
|
+
}
|
|
29
|
+
findById(id) {
|
|
30
|
+
const row = this.db
|
|
31
|
+
.prepare(`SELECT
|
|
32
|
+
id,
|
|
33
|
+
user_id,
|
|
34
|
+
platform_code,
|
|
35
|
+
display_name,
|
|
36
|
+
provider_id,
|
|
37
|
+
connection_mode,
|
|
38
|
+
status,
|
|
39
|
+
config_json,
|
|
40
|
+
runtime_state_json,
|
|
41
|
+
last_inbound_at,
|
|
42
|
+
last_outbound_at,
|
|
43
|
+
last_error,
|
|
44
|
+
created_at,
|
|
45
|
+
updated_at
|
|
46
|
+
FROM channel_accounts
|
|
47
|
+
WHERE id = ?`)
|
|
48
|
+
.get(id);
|
|
49
|
+
return row ? mapChannelAccountRow(row) : null;
|
|
50
|
+
}
|
|
51
|
+
listActiveByConnectionModes(connectionModes) {
|
|
52
|
+
if (connectionModes.length === 0) {
|
|
53
|
+
return [];
|
|
54
|
+
}
|
|
55
|
+
const placeholders = connectionModes.map(() => "?").join(", ");
|
|
56
|
+
return this.db
|
|
57
|
+
.prepare(`SELECT
|
|
58
|
+
id,
|
|
59
|
+
user_id,
|
|
60
|
+
platform_code,
|
|
61
|
+
display_name,
|
|
62
|
+
provider_id,
|
|
63
|
+
connection_mode,
|
|
64
|
+
status,
|
|
65
|
+
config_json,
|
|
66
|
+
runtime_state_json,
|
|
67
|
+
last_inbound_at,
|
|
68
|
+
last_outbound_at,
|
|
69
|
+
last_error,
|
|
70
|
+
created_at,
|
|
71
|
+
updated_at
|
|
72
|
+
FROM channel_accounts
|
|
73
|
+
WHERE status IN ('active', 'degraded')
|
|
74
|
+
AND connection_mode IN (${placeholders})
|
|
75
|
+
ORDER BY updated_at DESC, created_at DESC`)
|
|
76
|
+
.all(...connectionModes)
|
|
77
|
+
.map((row) => mapChannelAccountRow(row));
|
|
78
|
+
}
|
|
79
|
+
create(record) {
|
|
80
|
+
this.db
|
|
81
|
+
.prepare(`INSERT INTO channel_accounts (
|
|
82
|
+
id,
|
|
83
|
+
user_id,
|
|
84
|
+
platform_code,
|
|
85
|
+
display_name,
|
|
86
|
+
provider_id,
|
|
87
|
+
connection_mode,
|
|
88
|
+
status,
|
|
89
|
+
config_json,
|
|
90
|
+
runtime_state_json,
|
|
91
|
+
last_inbound_at,
|
|
92
|
+
last_outbound_at,
|
|
93
|
+
last_error,
|
|
94
|
+
created_at,
|
|
95
|
+
updated_at
|
|
96
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
97
|
+
.run(record.id, record.userId, record.platformCode, record.displayName, record.providerId, record.connectionMode, record.status, JSON.stringify(record.config), JSON.stringify(record.runtimeState), record.lastInboundAt, record.lastOutboundAt, record.lastError, record.createdAt, record.updatedAt);
|
|
98
|
+
return record;
|
|
99
|
+
}
|
|
100
|
+
update(record) {
|
|
101
|
+
this.db
|
|
102
|
+
.prepare(`UPDATE channel_accounts
|
|
103
|
+
SET display_name = ?,
|
|
104
|
+
provider_id = ?,
|
|
105
|
+
connection_mode = ?,
|
|
106
|
+
status = ?,
|
|
107
|
+
config_json = ?,
|
|
108
|
+
runtime_state_json = ?,
|
|
109
|
+
last_inbound_at = ?,
|
|
110
|
+
last_outbound_at = ?,
|
|
111
|
+
last_error = ?,
|
|
112
|
+
updated_at = ?
|
|
113
|
+
WHERE id = ?`)
|
|
114
|
+
.run(record.displayName, record.providerId, record.connectionMode, record.status, JSON.stringify(record.config), JSON.stringify(record.runtimeState), record.lastInboundAt, record.lastOutboundAt, record.lastError, record.updatedAt, record.id);
|
|
115
|
+
return record;
|
|
116
|
+
}
|
|
117
|
+
delete(id) {
|
|
118
|
+
const result = this.db
|
|
119
|
+
.prepare("DELETE FROM channel_accounts WHERE id = ?")
|
|
120
|
+
.run(id);
|
|
121
|
+
return result.changes > 0;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
function mapChannelAccountRow(row) {
|
|
125
|
+
return {
|
|
126
|
+
id: row.id,
|
|
127
|
+
userId: row.user_id,
|
|
128
|
+
platformCode: row.platform_code,
|
|
129
|
+
displayName: row.display_name,
|
|
130
|
+
providerId: row.provider_id,
|
|
131
|
+
connectionMode: row.connection_mode,
|
|
132
|
+
status: row.status,
|
|
133
|
+
config: parseJsonObject(row.config_json),
|
|
134
|
+
runtimeState: parseJsonObject(row.runtime_state_json),
|
|
135
|
+
lastInboundAt: row.last_inbound_at,
|
|
136
|
+
lastOutboundAt: row.last_outbound_at,
|
|
137
|
+
lastError: row.last_error,
|
|
138
|
+
createdAt: row.created_at,
|
|
139
|
+
updatedAt: row.updated_at
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
function parseJsonObject(raw) {
|
|
143
|
+
try {
|
|
144
|
+
const parsed = JSON.parse(raw);
|
|
145
|
+
return parsed && typeof parsed === "object" && !Array.isArray(parsed)
|
|
146
|
+
? parsed
|
|
147
|
+
: {};
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
return {};
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=channel-account-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-account-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/channel-account-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { ChannelDelivery } from "../../types/domain.js";
|
|
3
|
+
export declare class ChannelDeliveryRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
findById(id: string): ChannelDelivery | null;
|
|
7
|
+
findByInboundEventId(inboundEventId: string): ChannelDelivery | null;
|
|
8
|
+
listByAccountId(channelAccountId: string, limit?: number): ChannelDelivery[];
|
|
9
|
+
countByAccountId(channelAccountId: string): number;
|
|
10
|
+
listRetryableFailures(limit?: number): ChannelDelivery[];
|
|
11
|
+
create(record: ChannelDelivery): ChannelDelivery;
|
|
12
|
+
update(record: ChannelDelivery): ChannelDelivery;
|
|
13
|
+
}
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
export class ChannelDeliveryRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
findById(id) {
|
|
7
|
+
const row = this.db
|
|
8
|
+
.prepare(`SELECT
|
|
9
|
+
id,
|
|
10
|
+
channel_account_id,
|
|
11
|
+
thread_id,
|
|
12
|
+
inbound_event_id,
|
|
13
|
+
control_session_id,
|
|
14
|
+
session_id,
|
|
15
|
+
text_content,
|
|
16
|
+
provider_message_ref,
|
|
17
|
+
status,
|
|
18
|
+
error_message,
|
|
19
|
+
created_at,
|
|
20
|
+
updated_at
|
|
21
|
+
FROM channel_deliveries
|
|
22
|
+
WHERE id = ?
|
|
23
|
+
LIMIT 1`)
|
|
24
|
+
.get(id);
|
|
25
|
+
return row ? mapChannelDeliveryRow(row) : null;
|
|
26
|
+
}
|
|
27
|
+
findByInboundEventId(inboundEventId) {
|
|
28
|
+
const row = this.db
|
|
29
|
+
.prepare(`SELECT
|
|
30
|
+
id,
|
|
31
|
+
channel_account_id,
|
|
32
|
+
thread_id,
|
|
33
|
+
inbound_event_id,
|
|
34
|
+
control_session_id,
|
|
35
|
+
session_id,
|
|
36
|
+
text_content,
|
|
37
|
+
provider_message_ref,
|
|
38
|
+
status,
|
|
39
|
+
error_message,
|
|
40
|
+
created_at,
|
|
41
|
+
updated_at
|
|
42
|
+
FROM channel_deliveries
|
|
43
|
+
WHERE inbound_event_id = ?
|
|
44
|
+
ORDER BY created_at DESC
|
|
45
|
+
LIMIT 1`)
|
|
46
|
+
.get(inboundEventId);
|
|
47
|
+
return row ? mapChannelDeliveryRow(row) : null;
|
|
48
|
+
}
|
|
49
|
+
listByAccountId(channelAccountId, limit = 50) {
|
|
50
|
+
return this.db
|
|
51
|
+
.prepare(`SELECT
|
|
52
|
+
id,
|
|
53
|
+
channel_account_id,
|
|
54
|
+
thread_id,
|
|
55
|
+
inbound_event_id,
|
|
56
|
+
control_session_id,
|
|
57
|
+
session_id,
|
|
58
|
+
text_content,
|
|
59
|
+
provider_message_ref,
|
|
60
|
+
status,
|
|
61
|
+
error_message,
|
|
62
|
+
created_at,
|
|
63
|
+
updated_at
|
|
64
|
+
FROM channel_deliveries
|
|
65
|
+
WHERE channel_account_id = ?
|
|
66
|
+
ORDER BY created_at DESC
|
|
67
|
+
LIMIT ?`)
|
|
68
|
+
.all(channelAccountId, limit)
|
|
69
|
+
.map((row) => mapChannelDeliveryRow(row));
|
|
70
|
+
}
|
|
71
|
+
countByAccountId(channelAccountId) {
|
|
72
|
+
const row = this.db
|
|
73
|
+
.prepare(`SELECT COUNT(*) AS count
|
|
74
|
+
FROM channel_deliveries
|
|
75
|
+
WHERE channel_account_id = ?`)
|
|
76
|
+
.get(channelAccountId);
|
|
77
|
+
return row.count;
|
|
78
|
+
}
|
|
79
|
+
listRetryableFailures(limit = 100) {
|
|
80
|
+
return this.db
|
|
81
|
+
.prepare(`SELECT
|
|
82
|
+
id,
|
|
83
|
+
channel_account_id,
|
|
84
|
+
thread_id,
|
|
85
|
+
inbound_event_id,
|
|
86
|
+
control_session_id,
|
|
87
|
+
session_id,
|
|
88
|
+
text_content,
|
|
89
|
+
provider_message_ref,
|
|
90
|
+
status,
|
|
91
|
+
error_message,
|
|
92
|
+
created_at,
|
|
93
|
+
updated_at
|
|
94
|
+
FROM channel_deliveries
|
|
95
|
+
WHERE status = 'failed'
|
|
96
|
+
AND TRIM(text_content) <> ''
|
|
97
|
+
AND thread_id IS NOT NULL
|
|
98
|
+
AND inbound_event_id IS NOT NULL
|
|
99
|
+
ORDER BY updated_at ASC
|
|
100
|
+
LIMIT ?`)
|
|
101
|
+
.all(limit)
|
|
102
|
+
.map((row) => mapChannelDeliveryRow(row));
|
|
103
|
+
}
|
|
104
|
+
create(record) {
|
|
105
|
+
this.db
|
|
106
|
+
.prepare(`INSERT INTO channel_deliveries (
|
|
107
|
+
id,
|
|
108
|
+
channel_account_id,
|
|
109
|
+
thread_id,
|
|
110
|
+
inbound_event_id,
|
|
111
|
+
control_session_id,
|
|
112
|
+
session_id,
|
|
113
|
+
text_content,
|
|
114
|
+
provider_message_ref,
|
|
115
|
+
status,
|
|
116
|
+
error_message,
|
|
117
|
+
created_at,
|
|
118
|
+
updated_at
|
|
119
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
120
|
+
.run(record.id, record.channelAccountId, record.threadId, record.inboundEventId, record.controlSessionId, record.sessionId, record.textContent, record.providerMessageRef, record.status, record.errorMessage, record.createdAt, record.updatedAt);
|
|
121
|
+
return record;
|
|
122
|
+
}
|
|
123
|
+
update(record) {
|
|
124
|
+
this.db
|
|
125
|
+
.prepare(`UPDATE channel_deliveries
|
|
126
|
+
SET thread_id = ?,
|
|
127
|
+
inbound_event_id = ?,
|
|
128
|
+
control_session_id = ?,
|
|
129
|
+
session_id = ?,
|
|
130
|
+
text_content = ?,
|
|
131
|
+
provider_message_ref = ?,
|
|
132
|
+
status = ?,
|
|
133
|
+
error_message = ?,
|
|
134
|
+
updated_at = ?
|
|
135
|
+
WHERE id = ?`)
|
|
136
|
+
.run(record.threadId, record.inboundEventId, record.controlSessionId, record.sessionId, record.textContent, record.providerMessageRef, record.status, record.errorMessage, record.updatedAt, record.id);
|
|
137
|
+
return record;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
function mapChannelDeliveryRow(row) {
|
|
141
|
+
return {
|
|
142
|
+
id: row.id,
|
|
143
|
+
channelAccountId: row.channel_account_id,
|
|
144
|
+
threadId: row.thread_id,
|
|
145
|
+
inboundEventId: row.inbound_event_id,
|
|
146
|
+
controlSessionId: row.control_session_id,
|
|
147
|
+
sessionId: row.session_id,
|
|
148
|
+
textContent: row.text_content,
|
|
149
|
+
providerMessageRef: row.provider_message_ref,
|
|
150
|
+
status: row.status,
|
|
151
|
+
errorMessage: row.error_message,
|
|
152
|
+
createdAt: row.created_at,
|
|
153
|
+
updatedAt: row.updated_at
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
//# sourceMappingURL=channel-delivery-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-delivery-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/channel-delivery-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { ChannelInboundEvent } from "../../types/domain.js";
|
|
3
|
+
export declare class ChannelInboundEventRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
findById(id: string): ChannelInboundEvent | null;
|
|
7
|
+
listByAccountId(channelAccountId: string, limit?: number): ChannelInboundEvent[];
|
|
8
|
+
countByAccountId(channelAccountId: string): number;
|
|
9
|
+
findByAccountAndExternalEventId(channelAccountId: string, externalEventId: string): ChannelInboundEvent | null;
|
|
10
|
+
create(record: ChannelInboundEvent): ChannelInboundEvent;
|
|
11
|
+
update(record: ChannelInboundEvent): ChannelInboundEvent;
|
|
12
|
+
}
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
export class ChannelInboundEventRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
findById(id) {
|
|
7
|
+
const row = this.db
|
|
8
|
+
.prepare(`SELECT
|
|
9
|
+
id,
|
|
10
|
+
channel_account_id,
|
|
11
|
+
external_event_id,
|
|
12
|
+
external_conversation_key,
|
|
13
|
+
external_user_id,
|
|
14
|
+
control_session_id,
|
|
15
|
+
session_id,
|
|
16
|
+
text_content,
|
|
17
|
+
payload_json,
|
|
18
|
+
status,
|
|
19
|
+
error_message,
|
|
20
|
+
received_at,
|
|
21
|
+
processed_at
|
|
22
|
+
FROM channel_inbound_events
|
|
23
|
+
WHERE id = ?
|
|
24
|
+
LIMIT 1`)
|
|
25
|
+
.get(id);
|
|
26
|
+
return row ? mapChannelInboundEventRow(row) : null;
|
|
27
|
+
}
|
|
28
|
+
listByAccountId(channelAccountId, limit = 50) {
|
|
29
|
+
return this.db
|
|
30
|
+
.prepare(`SELECT
|
|
31
|
+
id,
|
|
32
|
+
channel_account_id,
|
|
33
|
+
external_event_id,
|
|
34
|
+
external_conversation_key,
|
|
35
|
+
external_user_id,
|
|
36
|
+
control_session_id,
|
|
37
|
+
session_id,
|
|
38
|
+
text_content,
|
|
39
|
+
payload_json,
|
|
40
|
+
status,
|
|
41
|
+
error_message,
|
|
42
|
+
received_at,
|
|
43
|
+
processed_at
|
|
44
|
+
FROM channel_inbound_events
|
|
45
|
+
WHERE channel_account_id = ?
|
|
46
|
+
ORDER BY received_at DESC
|
|
47
|
+
LIMIT ?`)
|
|
48
|
+
.all(channelAccountId, limit)
|
|
49
|
+
.map((row) => mapChannelInboundEventRow(row));
|
|
50
|
+
}
|
|
51
|
+
countByAccountId(channelAccountId) {
|
|
52
|
+
const row = this.db
|
|
53
|
+
.prepare(`SELECT COUNT(*) AS count
|
|
54
|
+
FROM channel_inbound_events
|
|
55
|
+
WHERE channel_account_id = ?`)
|
|
56
|
+
.get(channelAccountId);
|
|
57
|
+
return row.count;
|
|
58
|
+
}
|
|
59
|
+
findByAccountAndExternalEventId(channelAccountId, externalEventId) {
|
|
60
|
+
const row = this.db
|
|
61
|
+
.prepare(`SELECT
|
|
62
|
+
id,
|
|
63
|
+
channel_account_id,
|
|
64
|
+
external_event_id,
|
|
65
|
+
external_conversation_key,
|
|
66
|
+
external_user_id,
|
|
67
|
+
control_session_id,
|
|
68
|
+
session_id,
|
|
69
|
+
text_content,
|
|
70
|
+
payload_json,
|
|
71
|
+
status,
|
|
72
|
+
error_message,
|
|
73
|
+
received_at,
|
|
74
|
+
processed_at
|
|
75
|
+
FROM channel_inbound_events
|
|
76
|
+
WHERE channel_account_id = ?
|
|
77
|
+
AND external_event_id = ?`)
|
|
78
|
+
.get(channelAccountId, externalEventId);
|
|
79
|
+
return row ? mapChannelInboundEventRow(row) : null;
|
|
80
|
+
}
|
|
81
|
+
create(record) {
|
|
82
|
+
this.db
|
|
83
|
+
.prepare(`INSERT INTO channel_inbound_events (
|
|
84
|
+
id,
|
|
85
|
+
channel_account_id,
|
|
86
|
+
external_event_id,
|
|
87
|
+
external_conversation_key,
|
|
88
|
+
external_user_id,
|
|
89
|
+
control_session_id,
|
|
90
|
+
session_id,
|
|
91
|
+
text_content,
|
|
92
|
+
payload_json,
|
|
93
|
+
status,
|
|
94
|
+
error_message,
|
|
95
|
+
received_at,
|
|
96
|
+
processed_at
|
|
97
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
98
|
+
.run(record.id, record.channelAccountId, record.externalEventId, record.externalConversationKey, record.externalUserId, record.controlSessionId, record.sessionId, record.textContent, JSON.stringify(record.payload), record.status, record.errorMessage, record.receivedAt, record.processedAt);
|
|
99
|
+
return record;
|
|
100
|
+
}
|
|
101
|
+
update(record) {
|
|
102
|
+
this.db
|
|
103
|
+
.prepare(`UPDATE channel_inbound_events
|
|
104
|
+
SET control_session_id = ?,
|
|
105
|
+
session_id = ?,
|
|
106
|
+
text_content = ?,
|
|
107
|
+
payload_json = ?,
|
|
108
|
+
status = ?,
|
|
109
|
+
error_message = ?,
|
|
110
|
+
processed_at = ?
|
|
111
|
+
WHERE id = ?`)
|
|
112
|
+
.run(record.controlSessionId, record.sessionId, record.textContent, JSON.stringify(record.payload), record.status, record.errorMessage, record.processedAt, record.id);
|
|
113
|
+
return record;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
function mapChannelInboundEventRow(row) {
|
|
117
|
+
return {
|
|
118
|
+
id: row.id,
|
|
119
|
+
channelAccountId: row.channel_account_id,
|
|
120
|
+
externalEventId: row.external_event_id,
|
|
121
|
+
externalConversationKey: row.external_conversation_key,
|
|
122
|
+
externalUserId: row.external_user_id,
|
|
123
|
+
controlSessionId: row.control_session_id,
|
|
124
|
+
sessionId: row.session_id,
|
|
125
|
+
textContent: row.text_content,
|
|
126
|
+
payload: parseJsonObject(row.payload_json),
|
|
127
|
+
status: row.status,
|
|
128
|
+
errorMessage: row.error_message,
|
|
129
|
+
receivedAt: row.received_at,
|
|
130
|
+
processedAt: row.processed_at
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
function parseJsonObject(raw) {
|
|
134
|
+
try {
|
|
135
|
+
const parsed = JSON.parse(raw);
|
|
136
|
+
return parsed && typeof parsed === "object" && !Array.isArray(parsed)
|
|
137
|
+
? parsed
|
|
138
|
+
: {};
|
|
139
|
+
}
|
|
140
|
+
catch {
|
|
141
|
+
return {};
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=channel-inbound-event-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"channel-inbound-event-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/channel-inbound-event-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { ChannelThread } from "../../types/domain.js";
|
|
3
|
+
export declare class ChannelThreadRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
findById(id: string): ChannelThread | null;
|
|
7
|
+
listByAccountId(channelAccountId: string, limit?: number): ChannelThread[];
|
|
8
|
+
countByAccountId(channelAccountId: string): number;
|
|
9
|
+
findByAccountAndConversationKey(channelAccountId: string, externalConversationKey: string): ChannelThread | null;
|
|
10
|
+
create(record: ChannelThread): ChannelThread;
|
|
11
|
+
update(record: ChannelThread): ChannelThread;
|
|
12
|
+
}
|