@jingyi0605/codingns 0.3.6 → 0.5.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/README.md +3 -0
- package/bin/codingns.mjs +913 -1
- package/dist/public/assets/AdaptiveButlerPage-B153lk5H.css +1 -0
- package/dist/public/assets/AdaptiveButlerPage-R-XZw7pd.js +3 -0
- package/dist/public/assets/App-DUAg5urj.css +1 -0
- package/dist/public/assets/App-DkvE5EyM.js +30 -0
- package/dist/public/assets/BootstrapPage-Vu5oEJ8z.js +1 -0
- package/dist/public/assets/ConversationPage-Cjpg6g0J.js +2 -0
- package/dist/public/assets/DesktopDetachPreviewPage-BgeEqbc5.js +1 -0
- package/dist/public/assets/DesktopWindowPage-1WelvxdH.js +2 -0
- package/dist/public/assets/FileContextPanel-D_ghXJuW.js +1 -0
- package/dist/public/assets/GitSidebar-D9f9Jxwr.js +6 -0
- package/dist/public/assets/MobileCreateSessionSheet-DLq5qPkx.js +1 -0
- package/dist/public/assets/MobileSheet-DLg-gX1t.js +1 -0
- package/dist/public/assets/MobileTopHeaderFrame-DArgZI7L.js +1 -0
- package/dist/public/assets/MobileWorkspaceSwitcherHeader-0ywJKfBQ.js +1 -0
- package/dist/public/assets/ServerSettingsModal-izoYMx9U.js +1 -0
- package/dist/public/assets/SessionIndexPage-C5aG8FIv.js +1 -0
- package/dist/public/assets/SettingsPage-HJIC-P-4.js +1 -0
- package/dist/public/assets/TerminalManagerPanel-DpyUTo9k.js +1 -0
- package/dist/public/assets/{TerminalPage-D00S4KM6.js → TerminalPage-CtKXIU0h.js} +19 -19
- package/dist/public/assets/TerminalRuntimeFallbackModal-CRhOQOsT.js +1 -0
- package/dist/public/assets/ToolFilesPage-DcYPsS-e.js +1 -0
- package/dist/public/assets/ToolGitPage-CsPl89ty.js +1 -0
- package/dist/public/assets/ToolProcessesPage-D0dvR8xK.js +1 -0
- package/dist/public/assets/ToolsHomePage-4fP-KRiv.js +1 -0
- package/dist/public/assets/WorkbenchLandingPage-kvlfyxRo.js +1 -0
- package/dist/public/assets/WorkbenchLayout-ByFw4eeu.js +3 -0
- package/dist/public/assets/WorkbenchModal-Ctob14VR.js +1 -0
- package/dist/public/assets/WorkbenchShellRoute-BUITtdAg.css +1 -0
- package/dist/public/assets/WorkbenchShellRoute-Kw7JEZI3.js +1 -0
- package/dist/public/assets/WorkspaceDebugDetailPage-Com5kEXJ.js +1 -0
- package/dist/public/assets/WorkspaceDetailPage-D0Lrx4Uz.js +1 -0
- package/dist/public/assets/WorkspaceHomePage-wR8d3aP9.js +1 -0
- package/dist/public/assets/butler-records-events-DgWCG364.js +1 -0
- package/dist/public/assets/default-session-permission-mode-CcGwR4Kk.js +1 -0
- package/dist/public/assets/event-DvH9tcej.js +1 -0
- package/dist/public/assets/file-tree-icon-UFVoVzhM.js +31 -0
- package/dist/public/assets/index-Byp9hJ0c.js +42 -0
- package/dist/public/assets/index-_52jxu4a.css +1 -0
- package/dist/public/assets/preferences-service-KIYeE2gk.js +1 -0
- package/dist/public/assets/session-runtime-machine-0KNSSPp5.js +17 -0
- package/dist/public/assets/styles-BWPBZvze.css +1 -0
- package/dist/public/assets/styles-CSUx5LGe.js +1 -0
- package/dist/public/assets/terminal-runtime-meta-AWXJpN4r.js +1 -0
- package/dist/public/assets/useRegisteredDebugTemplates-DBDRdptr.js +1 -0
- package/dist/public/assets/window-BWqRixxq.js +1 -0
- package/dist/public/index.html +2 -2
- package/dist/server/middlewares/auth-guard.d.ts +4 -0
- package/dist/server/middlewares/auth-guard.js +42 -4
- package/dist/server/middlewares/auth-guard.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +234 -0
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js +365 -0
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -1
- package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +262 -2
- package/dist/server/modules/assistant-capability/assistant-capability-service.js +737 -3
- package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -1
- package/dist/server/modules/auth/auth-controller.d.ts +11 -1
- package/dist/server/modules/auth/auth-controller.js +61 -2
- package/dist/server/modules/auth/auth-controller.js.map +1 -1
- package/dist/server/modules/auth/auth-device-display-name.d.ts +10 -0
- package/dist/server/modules/auth/auth-device-display-name.js +190 -0
- package/dist/server/modules/auth/auth-device-display-name.js.map +1 -0
- package/dist/server/modules/auth/auth-service.d.ts +80 -5
- package/dist/server/modules/auth/auth-service.js +333 -23
- package/dist/server/modules/auth/auth-service.js.map +1 -1
- package/dist/server/modules/butler/assistant-automation-service.d.ts +112 -0
- package/dist/server/modules/butler/assistant-automation-service.js +832 -0
- package/dist/server/modules/butler/assistant-automation-service.js.map +1 -0
- package/dist/server/modules/butler/assistant-automation-trigger.d.ts +94 -0
- package/dist/server/modules/butler/assistant-automation-trigger.js +400 -0
- package/dist/server/modules/butler/assistant-automation-trigger.js.map +1 -0
- package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.d.ts +32 -0
- package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js +93 -0
- package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js.map +1 -0
- package/dist/server/modules/butler/assistant-sandbox-service.d.ts +69 -0
- package/dist/server/modules/butler/assistant-sandbox-service.js +399 -0
- package/dist/server/modules/butler/assistant-sandbox-service.js.map +1 -0
- package/dist/server/modules/butler/butler-action-context-service.d.ts +4 -1
- package/dist/server/modules/butler/butler-action-context-service.js +8 -2
- package/dist/server/modules/butler/butler-action-context-service.js.map +1 -1
- package/dist/server/modules/butler/butler-auth-service.js +7 -2
- package/dist/server/modules/butler/butler-auth-service.js.map +1 -1
- package/dist/server/modules/butler/butler-control-session-service.d.ts +11 -1
- package/dist/server/modules/butler/butler-control-session-service.js +173 -40
- package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-control-timer-scheduler.d.ts +32 -0
- package/dist/server/modules/butler/butler-control-timer-scheduler.js +93 -0
- package/dist/server/modules/butler/butler-control-timer-scheduler.js.map +1 -0
- package/dist/server/modules/butler/butler-control-timer-service.d.ts +42 -0
- package/dist/server/modules/butler/butler-control-timer-service.js +132 -0
- package/dist/server/modules/butler/butler-control-timer-service.js.map +1 -0
- package/dist/server/modules/butler/butler-controller.d.ts +42 -2
- package/dist/server/modules/butler/butler-controller.js +79 -12
- package/dist/server/modules/butler/butler-controller.js.map +1 -1
- package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.d.ts +2 -1
- package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js +27 -25
- package/dist/server/modules/butler/butler-follow-up-evaluation-instruction-adapter.js.map +1 -1
- package/dist/server/modules/butler/butler-follow-up-service.d.ts +41 -5
- package/dist/server/modules/butler/butler-follow-up-service.js +568 -371
- package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
- package/dist/server/modules/butler/butler-inbox-analysis-service.d.ts +4 -1
- package/dist/server/modules/butler/butler-inbox-analysis-service.js +18 -4
- package/dist/server/modules/butler/butler-inbox-analysis-service.js.map +1 -1
- package/dist/server/modules/butler/butler-inbox-service.js +1 -0
- package/dist/server/modules/butler/butler-inbox-service.js.map +1 -1
- package/dist/server/modules/butler/butler-profile-service.js +2 -5
- package/dist/server/modules/butler/butler-profile-service.js.map +1 -1
- package/dist/server/modules/butler/butler-project-service.d.ts +3 -1
- package/dist/server/modules/butler/butler-project-service.js +7 -1
- package/dist/server/modules/butler/butler-project-service.js.map +1 -1
- package/dist/server/modules/butler/butler-session-service.d.ts +5 -1
- package/dist/server/modules/butler/butler-session-service.js +26 -1
- package/dist/server/modules/butler/butler-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-session-summary-service.js +2 -1
- package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
- package/dist/server/modules/butler/butler-workspace-context.d.ts +4 -1
- package/dist/server/modules/butler/butler-workspace-context.js +204 -58
- package/dist/server/modules/butler/butler-workspace-context.js.map +1 -1
- package/dist/server/modules/butler/patrol-execution-service.js +2 -1
- package/dist/server/modules/butler/patrol-execution-service.js.map +1 -1
- package/dist/server/modules/butler/provider-adapter-registry.d.ts +3 -0
- package/dist/server/modules/butler/provider-adapter-registry.js +18 -1
- package/dist/server/modules/butler/provider-adapter-registry.js.map +1 -1
- package/dist/server/modules/butler/verification-run-service.d.ts +9 -2
- package/dist/server/modules/butler/verification-run-service.js +188 -34
- package/dist/server/modules/butler/verification-run-service.js.map +1 -1
- package/dist/server/modules/debug-target/debug-target-controller.js +1 -1
- package/dist/server/modules/debug-target/debug-target-controller.js.map +1 -1
- package/dist/server/modules/debug-target/debug-target-service.d.ts +7 -2
- package/dist/server/modules/debug-target/debug-target-service.js +563 -100
- package/dist/server/modules/debug-target/debug-target-service.js.map +1 -1
- package/dist/server/modules/git/git-command-helper-client.d.ts +1 -0
- package/dist/server/modules/git/git-command-helper-client.js +19 -26
- package/dist/server/modules/git/git-command-helper-client.js.map +1 -1
- package/dist/server/modules/git/git-command-runner.js +19 -1
- package/dist/server/modules/git/git-command-runner.js.map +1 -1
- package/dist/server/modules/preferences/profile-service.d.ts +3 -1
- package/dist/server/modules/preferences/profile-service.js +74 -3
- package/dist/server/modules/preferences/profile-service.js.map +1 -1
- package/dist/server/modules/provider/provider-controller.d.ts +1 -1
- package/dist/server/modules/provider/provider-controller.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-helper-client.d.ts +5 -3
- package/dist/server/modules/provider/provider-discovery-helper-client.js +129 -43
- package/dist/server/modules/provider/provider-discovery-helper-client.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-helper-process.js +44 -0
- package/dist/server/modules/provider/provider-discovery-helper-process.js.map +1 -1
- package/dist/server/modules/provider/provider-discovery-runtime.js +83 -3
- package/dist/server/modules/provider/provider-discovery-runtime.js.map +1 -1
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-identity-service.d.ts +10 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-identity-service.js +48 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-identity-service.js.map +1 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-packets.d.ts +48 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-packets.js +11 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-packets.js.map +1 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-protocol.d.ts +74 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-protocol.js +302 -0
- package/dist/server/modules/relay-tunnel/crypto/relay-tunnel-protocol.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-controller.d.ts +33 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-controller.js +57 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-controller.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-edge-proof.d.ts +9 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-edge-proof.js +25 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-edge-proof.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-gateway-service.d.ts +18 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-gateway-service.js +230 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-gateway-service.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-runtime-adapter.d.ts +41 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-runtime-adapter.js +443 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-runtime-adapter.js.map +1 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.d.ts +111 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js +771 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js.map +1 -0
- package/dist/server/modules/sessions/claude-runtime-helper-client.js +23 -1
- package/dist/server/modules/sessions/claude-runtime-helper-client.js.map +1 -1
- package/dist/server/modules/sessions/codex-app-server-helper-client.d.ts +2 -1
- package/dist/server/modules/sessions/codex-app-server-helper-client.js +78 -0
- package/dist/server/modules/sessions/codex-app-server-helper-client.js.map +1 -1
- package/dist/server/modules/sessions/codex-app-server-helper-process.js +84 -2
- package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
- package/dist/server/modules/sessions/provider-session-delete-cli.d.ts +15 -0
- package/dist/server/modules/sessions/provider-session-delete-cli.js +148 -0
- package/dist/server/modules/sessions/provider-session-delete-cli.js.map +1 -0
- package/dist/server/modules/sessions/session-controller.d.ts +4 -1
- package/dist/server/modules/sessions/session-controller.js +4 -0
- package/dist/server/modules/sessions/session-controller.js.map +1 -1
- package/dist/server/modules/sessions/session-history-service.d.ts +24 -1
- package/dist/server/modules/sessions/session-history-service.js +401 -42
- package/dist/server/modules/sessions/session-history-service.js.map +1 -1
- package/dist/server/modules/sessions/session-live-runtime-router-service.d.ts +25 -0
- package/dist/server/modules/sessions/session-live-runtime-router-service.js +42 -0
- package/dist/server/modules/sessions/session-live-runtime-router-service.js.map +1 -0
- package/dist/server/modules/sessions/session-live-runtime-service.d.ts +6 -0
- package/dist/server/modules/sessions/session-live-runtime-service.js +130 -28
- package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
- package/dist/server/modules/sessions/session-message-attachment-service.d.ts +1 -0
- package/dist/server/modules/sessions/session-message-attachment-service.js +22 -0
- package/dist/server/modules/sessions/session-message-attachment-service.js.map +1 -1
- package/dist/server/modules/sessions/session-message-origin-utils.d.ts +12 -0
- package/dist/server/modules/sessions/session-message-origin-utils.js +45 -0
- package/dist/server/modules/sessions/session-message-origin-utils.js.map +1 -0
- package/dist/server/modules/sessions/session-permission-request-service.d.ts +1 -0
- package/dist/server/modules/sessions/session-permission-request-service.js +367 -5
- package/dist/server/modules/sessions/session-permission-request-service.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-error-mapper.js +32 -0
- package/dist/server/modules/sessions/session-provider-error-mapper.js.map +1 -1
- package/dist/server/modules/sessions/session-provider-usage-guard-service.d.ts +37 -0
- package/dist/server/modules/sessions/session-provider-usage-guard-service.js +179 -0
- package/dist/server/modules/sessions/session-provider-usage-guard-service.js.map +1 -0
- package/dist/server/modules/sessions/session-provider-usage-limit.d.ts +17 -0
- package/dist/server/modules/sessions/session-provider-usage-limit.js +465 -0
- package/dist/server/modules/sessions/session-provider-usage-limit.js.map +1 -0
- package/dist/server/modules/skills/assistant-runtime-skill-catalog.d.ts +8 -0
- package/dist/server/modules/skills/assistant-runtime-skill-catalog.js +26 -0
- package/dist/server/modules/skills/assistant-runtime-skill-catalog.js.map +1 -0
- package/dist/server/modules/skills/assistant-runtime-skill-cleanup.d.ts +9 -0
- package/dist/server/modules/skills/assistant-runtime-skill-cleanup.js +55 -0
- package/dist/server/modules/skills/assistant-runtime-skill-cleanup.js.map +1 -0
- package/dist/server/modules/skills/builtin-skill-service.js +1 -6
- package/dist/server/modules/skills/builtin-skill-service.js.map +1 -1
- package/dist/server/modules/skills/builtin-skills/codingns-assistant/SKILL.md +19 -12
- package/dist/server/modules/skills/builtin-skills/codingns-assistant/references/cli-workflow.md +9 -3
- package/dist/server/modules/skills/skill-controller.d.ts +2 -2
- package/dist/server/modules/skills/skill-controller.js +9 -1
- package/dist/server/modules/skills/skill-controller.js.map +1 -1
- package/dist/server/modules/skills/skill-manager-service.d.ts +26 -1
- package/dist/server/modules/skills/skill-manager-service.js +346 -90
- package/dist/server/modules/skills/skill-manager-service.js.map +1 -1
- package/dist/server/modules/skills/skill-name-policy.d.ts +2 -0
- package/dist/server/modules/skills/skill-name-policy.js +10 -0
- package/dist/server/modules/skills/skill-name-policy.js.map +1 -0
- package/dist/server/modules/tailscale/tailscale-service.d.ts +2 -0
- package/dist/server/modules/tailscale/tailscale-service.js +21 -8
- package/dist/server/modules/tailscale/tailscale-service.js.map +1 -1
- package/dist/server/modules/tasks/task-helper-client.d.ts +5 -2
- package/dist/server/modules/tasks/task-helper-client.js +118 -38
- package/dist/server/modules/tasks/task-helper-client.js.map +1 -1
- package/dist/server/modules/tasks/task-helper-process.js +94 -3
- package/dist/server/modules/tasks/task-helper-process.js.map +1 -1
- package/dist/server/modules/tasks/task-types.d.ts +6 -0
- package/dist/server/modules/tasks/task-types.js +7 -1
- package/dist/server/modules/tasks/task-types.js.map +1 -1
- package/dist/server/modules/terminal/command-template-service.d.ts +9 -0
- package/dist/server/modules/terminal/command-template-service.js +87 -5
- package/dist/server/modules/terminal/command-template-service.js.map +1 -1
- package/dist/server/modules/terminal/template-reverse-proxy-service.js +71 -3
- package/dist/server/modules/terminal/template-reverse-proxy-service.js.map +1 -1
- package/dist/server/modules/terminal/terminal-controller.d.ts +3 -0
- package/dist/server/modules/terminal/terminal-controller.js +41 -0
- package/dist/server/modules/terminal/terminal-controller.js.map +1 -1
- package/dist/server/modules/workbench/workbench-service.d.ts +3 -0
- package/dist/server/modules/workbench/workbench-service.js +4 -3
- package/dist/server/modules/workbench/workbench-service.js.map +1 -1
- package/dist/server/modules/workbench/workspace-file-watcher.d.ts +14 -6
- package/dist/server/modules/workbench/workspace-file-watcher.js +267 -57
- package/dist/server/modules/workbench/workspace-file-watcher.js.map +1 -1
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +2 -0
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +32 -3
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -1
- package/dist/server/modules/worktree/worktree-manager.d.ts +9 -1
- package/dist/server/modules/worktree/worktree-manager.js +9 -1
- package/dist/server/modules/worktree/worktree-manager.js.map +1 -1
- package/dist/server/routes/assistant.js +49 -0
- package/dist/server/routes/assistant.js.map +1 -1
- package/dist/server/routes/auth.js +4 -0
- package/dist/server/routes/auth.js.map +1 -1
- package/dist/server/routes/butler.js +5 -0
- package/dist/server/routes/butler.js.map +1 -1
- package/dist/server/routes/sessions.js +1 -0
- package/dist/server/routes/sessions.js.map +1 -1
- package/dist/server/routes/system.d.ts +2 -1
- package/dist/server/routes/system.js +13 -1
- package/dist/server/routes/system.js.map +1 -1
- package/dist/server/server/create-server.d.ts +18 -0
- package/dist/server/server/create-server.js +113 -20
- package/dist/server/server/create-server.js.map +1 -1
- package/dist/server/shared/utils/tokens.d.ts +3 -1
- package/dist/server/shared/utils/tokens.js +9 -2
- package/dist/server/shared/utils/tokens.js.map +1 -1
- package/dist/server/storage/repositories/assistant-automation-run-repository.d.ts +12 -0
- package/dist/server/storage/repositories/assistant-automation-run-repository.js +139 -0
- package/dist/server/storage/repositories/assistant-automation-run-repository.js.map +1 -0
- package/dist/server/storage/repositories/assistant-automation-task-repository.d.ts +17 -0
- package/dist/server/storage/repositories/assistant-automation-task-repository.js +179 -0
- package/dist/server/storage/repositories/assistant-automation-task-repository.js.map +1 -0
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.d.ts +18 -0
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js +191 -0
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js.map +1 -0
- package/dist/server/storage/repositories/auth-device-repository.d.ts +22 -0
- package/dist/server/storage/repositories/auth-device-repository.js +97 -0
- package/dist/server/storage/repositories/auth-device-repository.js.map +1 -0
- package/dist/server/storage/repositories/auth-device-session-repository.d.ts +17 -0
- package/dist/server/storage/repositories/auth-device-session-repository.js +82 -0
- package/dist/server/storage/repositories/auth-device-session-repository.js.map +1 -0
- package/dist/server/storage/repositories/auth-login-event-repository.d.ts +9 -0
- package/dist/server/storage/repositories/auth-login-event-repository.js +53 -0
- package/dist/server/storage/repositories/auth-login-event-repository.js.map +1 -0
- package/dist/server/storage/repositories/auth-token-repository.d.ts +4 -0
- package/dist/server/storage/repositories/auth-token-repository.js +58 -5
- package/dist/server/storage/repositories/auth-token-repository.js.map +1 -1
- package/dist/server/storage/repositories/butler-control-session-repository.js +27 -3
- package/dist/server/storage/repositories/butler-control-session-repository.js.map +1 -1
- package/dist/server/storage/repositories/butler-control-timer-repository.d.ts +15 -0
- package/dist/server/storage/repositories/butler-control-timer-repository.js +157 -0
- package/dist/server/storage/repositories/butler-control-timer-repository.js.map +1 -0
- package/dist/server/storage/repositories/butler-follow-up-task-repository.js +21 -3
- package/dist/server/storage/repositories/butler-follow-up-task-repository.js.map +1 -1
- package/dist/server/storage/repositories/instance-relay-tunnel-identity-repository.d.ts +8 -0
- package/dist/server/storage/repositories/instance-relay-tunnel-identity-repository.js +52 -0
- package/dist/server/storage/repositories/instance-relay-tunnel-identity-repository.js.map +1 -0
- package/dist/server/storage/repositories/instance-relay-tunnel-repository.d.ts +10 -0
- package/dist/server/storage/repositories/instance-relay-tunnel-repository.js +153 -0
- package/dist/server/storage/repositories/instance-relay-tunnel-repository.js.map +1 -0
- package/dist/server/storage/repositories/instance-tailscale-repository.js +6 -3
- package/dist/server/storage/repositories/instance-tailscale-repository.js.map +1 -1
- package/dist/server/storage/repositories/managed-skill-repository.d.ts +2 -1
- package/dist/server/storage/repositories/managed-skill-repository.js +14 -4
- package/dist/server/storage/repositories/managed-skill-repository.js.map +1 -1
- package/dist/server/storage/repositories/session-message-attachment-repository.d.ts +2 -0
- package/dist/server/storage/repositories/session-message-attachment-repository.js +24 -0
- package/dist/server/storage/repositories/session-message-attachment-repository.js.map +1 -1
- package/dist/server/storage/repositories/user-preference-profile-repository.js +6 -3
- package/dist/server/storage/repositories/user-preference-profile-repository.js.map +1 -1
- package/dist/server/storage/sqlite/client.js +534 -2
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +228 -4
- package/dist/server/types/domain.d.ts +170 -2
- package/dist/server/ws/workbench-ws-hub.d.ts +14 -8
- package/dist/server/ws/workbench-ws-hub.js +369 -209
- package/dist/server/ws/workbench-ws-hub.js.map +1 -1
- package/dist/server/ws/ws-auth-guard.js +1 -4
- package/dist/server/ws/ws-auth-guard.js.map +1 -1
- package/dist/server/ws/ws-server.d.ts +1 -1
- package/dist/server/ws/ws-server.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.js +80 -0
- package/node_modules/@codingns/session-sync-core/dist/codex-resume-history.js.map +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.d.ts +5 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +122 -4
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.d.ts +17 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +437 -51
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.d.ts +7 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +240 -27
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.d.ts +5 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js +108 -2
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.d.ts +3 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +101 -8
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js +4 -1
- package/node_modules/@codingns/session-sync-core/dist/providers/utils.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js +44 -0
- package/node_modules/@codingns/session-sync-core/dist/runtime/claude-runtime.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.d.ts +5 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +153 -60
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/runtime/types.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/services.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/services.js +24 -8
- package/node_modules/@codingns/session-sync-core/dist/services.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/types.d.ts +6 -0
- package/package.json +1 -1
- package/scripts/postinstall.mjs +0 -33
- package/dist/public/assets/index-BlOinYqR.js +0 -122
- package/dist/public/assets/index-Dg_7g6lA.css +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-device-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-device-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { AuthDeviceSessionRecord } from "../../types/domain.js";
|
|
3
|
+
export declare class AuthDeviceSessionRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
create(record: AuthDeviceSessionRecord): void;
|
|
7
|
+
findById(id: string): AuthDeviceSessionRecord | null;
|
|
8
|
+
listActiveByUser(userId: string): AuthDeviceSessionRecord[];
|
|
9
|
+
updateBinding(id: string, input: {
|
|
10
|
+
deviceId: string | null;
|
|
11
|
+
accessTokenId: string | null;
|
|
12
|
+
refreshTokenId: string | null;
|
|
13
|
+
updatedAt: string;
|
|
14
|
+
}): void;
|
|
15
|
+
revokeByIds(ids: string[], revokedAt: string): void;
|
|
16
|
+
revokeById(id: string, revokedAt: string): void;
|
|
17
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
export class AuthDeviceSessionRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
create(record) {
|
|
7
|
+
this.db
|
|
8
|
+
.prepare(`INSERT INTO auth_device_sessions (
|
|
9
|
+
id,
|
|
10
|
+
user_id,
|
|
11
|
+
device_id,
|
|
12
|
+
access_token_id,
|
|
13
|
+
refresh_token_id,
|
|
14
|
+
revoked_at,
|
|
15
|
+
created_at,
|
|
16
|
+
updated_at
|
|
17
|
+
)
|
|
18
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
19
|
+
.run(record.id, record.userId, record.deviceId, record.accessTokenId, record.refreshTokenId, record.revokedAt, record.createdAt, record.updatedAt);
|
|
20
|
+
}
|
|
21
|
+
findById(id) {
|
|
22
|
+
const row = this.db
|
|
23
|
+
.prepare(`SELECT id, user_id, device_id, access_token_id, refresh_token_id, revoked_at, created_at, updated_at
|
|
24
|
+
FROM auth_device_sessions
|
|
25
|
+
WHERE id = ?`)
|
|
26
|
+
.get(id);
|
|
27
|
+
return row ? mapDeviceSessionRow(row) : null;
|
|
28
|
+
}
|
|
29
|
+
listActiveByUser(userId) {
|
|
30
|
+
return this.db
|
|
31
|
+
.prepare(`SELECT id, user_id, device_id, access_token_id, refresh_token_id, revoked_at, created_at, updated_at
|
|
32
|
+
FROM auth_device_sessions
|
|
33
|
+
WHERE user_id = ?
|
|
34
|
+
AND revoked_at IS NULL
|
|
35
|
+
ORDER BY updated_at DESC`)
|
|
36
|
+
.all(userId)
|
|
37
|
+
.map((row) => mapDeviceSessionRow(row));
|
|
38
|
+
}
|
|
39
|
+
updateBinding(id, input) {
|
|
40
|
+
this.db
|
|
41
|
+
.prepare(`UPDATE auth_device_sessions
|
|
42
|
+
SET device_id = ?,
|
|
43
|
+
access_token_id = ?,
|
|
44
|
+
refresh_token_id = ?,
|
|
45
|
+
updated_at = ?
|
|
46
|
+
WHERE id = ?`)
|
|
47
|
+
.run(input.deviceId, input.accessTokenId, input.refreshTokenId, input.updatedAt, id);
|
|
48
|
+
}
|
|
49
|
+
revokeByIds(ids, revokedAt) {
|
|
50
|
+
if (ids.length === 0) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
const placeholders = ids.map(() => "?").join(", ");
|
|
54
|
+
this.db
|
|
55
|
+
.prepare(`UPDATE auth_device_sessions
|
|
56
|
+
SET revoked_at = ?,
|
|
57
|
+
updated_at = ?
|
|
58
|
+
WHERE id IN (${placeholders}) AND revoked_at IS NULL`)
|
|
59
|
+
.run(revokedAt, revokedAt, ...ids);
|
|
60
|
+
}
|
|
61
|
+
revokeById(id, revokedAt) {
|
|
62
|
+
this.db
|
|
63
|
+
.prepare(`UPDATE auth_device_sessions
|
|
64
|
+
SET revoked_at = ?,
|
|
65
|
+
updated_at = ?
|
|
66
|
+
WHERE id = ? AND revoked_at IS NULL`)
|
|
67
|
+
.run(revokedAt, revokedAt, id);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function mapDeviceSessionRow(row) {
|
|
71
|
+
return {
|
|
72
|
+
id: row.id,
|
|
73
|
+
userId: row.user_id,
|
|
74
|
+
deviceId: row.device_id,
|
|
75
|
+
accessTokenId: row.access_token_id,
|
|
76
|
+
refreshTokenId: row.refresh_token_id,
|
|
77
|
+
revokedAt: row.revoked_at,
|
|
78
|
+
createdAt: row.created_at,
|
|
79
|
+
updatedAt: row.updated_at
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=auth-device-session-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-device-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-device-session-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA+B;QACpC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;yCAUiC,CAClC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,cAAc,EACrB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;sBAEc,CACf;aACA,GAAG,CAAC,EAAE,CAAiC,CAAC;QAE3C,OAAO,GAAG,CAAC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,CAAC;IAED,gBAAgB,CAAC,MAAc;QAC7B,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;kCAI0B,CAC3B;aACA,GAAG,CAAC,MAAM,CAAC;aACX,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,mBAAmB,CAAC,GAAuB,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,aAAa,CACX,EAAU,EACV,KAKC;QAED,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;sBAKc,CACf;aACA,GAAG,CAAC,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACzF,CAAC;IAED,WAAW,CAAC,GAAa,EAAE,SAAiB;QAC1C,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;wBAGgB,YAAY,0BAA0B,CACvD;aACA,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,GAAG,GAAG,CAAC,CAAC;IACvC,CAAC;IAED,UAAU,CAAC,EAAU,EAAE,SAAiB;QACtC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;6CAGqC,CACtC;aACA,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;IACnC,CAAC;CACF;AAaD,SAAS,mBAAmB,CAAC,GAAqB;IAChD,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,aAAa,EAAE,GAAG,CAAC,eAAe;QAClC,cAAc,EAAE,GAAG,CAAC,gBAAgB;QACpC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { AuthLoginEventRecord } from "../../types/domain.js";
|
|
3
|
+
export declare class AuthLoginEventRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
create(record: AuthLoginEventRecord): void;
|
|
7
|
+
listRecentByUser(userId: string, limit: number): AuthLoginEventRecord[];
|
|
8
|
+
trimToLatest(userId: string, limit: number): void;
|
|
9
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
export class AuthLoginEventRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
create(record) {
|
|
7
|
+
this.db
|
|
8
|
+
.prepare(`INSERT INTO auth_login_events (
|
|
9
|
+
id,
|
|
10
|
+
user_id,
|
|
11
|
+
device_id,
|
|
12
|
+
client_type,
|
|
13
|
+
source_address,
|
|
14
|
+
occurred_at
|
|
15
|
+
)
|
|
16
|
+
VALUES (?, ?, ?, ?, ?, ?)`)
|
|
17
|
+
.run(record.id, record.userId, record.deviceId, record.clientType, record.sourceAddress, record.occurredAt);
|
|
18
|
+
}
|
|
19
|
+
listRecentByUser(userId, limit) {
|
|
20
|
+
return this.db
|
|
21
|
+
.prepare(`SELECT id, user_id, device_id, client_type, source_address, occurred_at
|
|
22
|
+
FROM auth_login_events
|
|
23
|
+
WHERE user_id = ?
|
|
24
|
+
ORDER BY occurred_at DESC, id DESC
|
|
25
|
+
LIMIT ?`)
|
|
26
|
+
.all(userId, limit)
|
|
27
|
+
.map((row) => mapLoginEventRow(row));
|
|
28
|
+
}
|
|
29
|
+
trimToLatest(userId, limit) {
|
|
30
|
+
this.db
|
|
31
|
+
.prepare(`DELETE FROM auth_login_events
|
|
32
|
+
WHERE user_id = ?
|
|
33
|
+
AND id NOT IN (
|
|
34
|
+
SELECT id
|
|
35
|
+
FROM auth_login_events
|
|
36
|
+
WHERE user_id = ?
|
|
37
|
+
ORDER BY occurred_at DESC, id DESC
|
|
38
|
+
LIMIT ?
|
|
39
|
+
)`)
|
|
40
|
+
.run(userId, userId, limit);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
function mapLoginEventRow(row) {
|
|
44
|
+
return {
|
|
45
|
+
id: row.id,
|
|
46
|
+
userId: row.user_id,
|
|
47
|
+
deviceId: row.device_id,
|
|
48
|
+
clientType: row.client_type,
|
|
49
|
+
sourceAddress: row.source_address,
|
|
50
|
+
occurredAt: row.occurred_at
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=auth-login-event-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth-login-event-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-login-event-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,wBAAwB;IACN;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA4B;QACjC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;mCAQ2B,CAC5B;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,CAClB,CAAC;IACN,CAAC;IAED,gBAAgB,CAAC,MAAc,EAAE,KAAa;QAC5C,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;iBAIS,CACV;aACA,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC;aAClB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,gBAAgB,CAAC,GAAoB,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,KAAa;QACxC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;aAQK,CACN;aACA,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;IAChC,CAAC;CACF;AAWD,SAAS,gBAAgB,CAAC,GAAkB;IAC1C,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,UAAU,EAAE,GAAG,CAAC,WAAW;KAC5B,CAAC;AACJ,CAAC"}
|
|
@@ -5,5 +5,9 @@ export declare class AuthTokenRepository {
|
|
|
5
5
|
constructor(db: Database.Database);
|
|
6
6
|
create(record: AuthTokenRecord): void;
|
|
7
7
|
findByHash(tokenHash: string, tokenType?: "access" | "refresh"): AuthTokenRecord | null;
|
|
8
|
+
findById(id: string): AuthTokenRecord | null;
|
|
8
9
|
revokeByHash(tokenHash: string, revokedAt: string): void;
|
|
10
|
+
revokeByDeviceSessionIds(deviceSessionIds: string[], revokedAt: string): void;
|
|
11
|
+
revokeLegacyTokensByUser(userId: string, revokedAt: string): void;
|
|
12
|
+
listActiveLegacyRefreshTokensByUser(userId: string, now: string): AuthTokenRecord[];
|
|
9
13
|
}
|
|
@@ -5,24 +5,42 @@ export class AuthTokenRepository {
|
|
|
5
5
|
}
|
|
6
6
|
create(record) {
|
|
7
7
|
this.db
|
|
8
|
-
.prepare(`INSERT INTO auth_tokens (
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
.prepare(`INSERT INTO auth_tokens (
|
|
9
|
+
id,
|
|
10
|
+
user_id,
|
|
11
|
+
token_type,
|
|
12
|
+
token_hash,
|
|
13
|
+
device_session_id,
|
|
14
|
+
caller_kind,
|
|
15
|
+
expires_at,
|
|
16
|
+
revoked_at,
|
|
17
|
+
created_at
|
|
18
|
+
)
|
|
19
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
20
|
+
.run(record.id, record.userId, record.tokenType, record.tokenHash, record.deviceSessionId, record.callerKind, record.expiresAt, record.revokedAt, record.createdAt);
|
|
11
21
|
}
|
|
12
22
|
findByHash(tokenHash, tokenType) {
|
|
13
23
|
const row = tokenType
|
|
14
24
|
? this.db
|
|
15
|
-
.prepare(`SELECT id, user_id, token_type, token_hash, expires_at, revoked_at, created_at
|
|
25
|
+
.prepare(`SELECT id, user_id, token_type, token_hash, device_session_id, caller_kind, expires_at, revoked_at, created_at
|
|
16
26
|
FROM auth_tokens
|
|
17
27
|
WHERE token_hash = ? AND token_type = ?`)
|
|
18
28
|
.get(tokenHash, tokenType)
|
|
19
29
|
: this.db
|
|
20
|
-
.prepare(`SELECT id, user_id, token_type, token_hash, expires_at, revoked_at, created_at
|
|
30
|
+
.prepare(`SELECT id, user_id, token_type, token_hash, device_session_id, caller_kind, expires_at, revoked_at, created_at
|
|
21
31
|
FROM auth_tokens
|
|
22
32
|
WHERE token_hash = ?`)
|
|
23
33
|
.get(tokenHash);
|
|
24
34
|
return row ? mapTokenRow(row) : null;
|
|
25
35
|
}
|
|
36
|
+
findById(id) {
|
|
37
|
+
const row = this.db
|
|
38
|
+
.prepare(`SELECT id, user_id, token_type, token_hash, device_session_id, caller_kind, expires_at, revoked_at, created_at
|
|
39
|
+
FROM auth_tokens
|
|
40
|
+
WHERE id = ?`)
|
|
41
|
+
.get(id);
|
|
42
|
+
return row ? mapTokenRow(row) : null;
|
|
43
|
+
}
|
|
26
44
|
revokeByHash(tokenHash, revokedAt) {
|
|
27
45
|
this.db
|
|
28
46
|
.prepare(`UPDATE auth_tokens
|
|
@@ -30,6 +48,39 @@ export class AuthTokenRepository {
|
|
|
30
48
|
WHERE token_hash = ? AND revoked_at IS NULL`)
|
|
31
49
|
.run(revokedAt, tokenHash);
|
|
32
50
|
}
|
|
51
|
+
revokeByDeviceSessionIds(deviceSessionIds, revokedAt) {
|
|
52
|
+
if (deviceSessionIds.length === 0) {
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
const placeholders = deviceSessionIds.map(() => "?").join(", ");
|
|
56
|
+
this.db
|
|
57
|
+
.prepare(`UPDATE auth_tokens
|
|
58
|
+
SET revoked_at = ?
|
|
59
|
+
WHERE device_session_id IN (${placeholders}) AND revoked_at IS NULL`)
|
|
60
|
+
.run(revokedAt, ...deviceSessionIds);
|
|
61
|
+
}
|
|
62
|
+
revokeLegacyTokensByUser(userId, revokedAt) {
|
|
63
|
+
this.db
|
|
64
|
+
.prepare(`UPDATE auth_tokens
|
|
65
|
+
SET revoked_at = ?
|
|
66
|
+
WHERE user_id = ?
|
|
67
|
+
AND device_session_id IS NULL
|
|
68
|
+
AND revoked_at IS NULL`)
|
|
69
|
+
.run(revokedAt, userId);
|
|
70
|
+
}
|
|
71
|
+
listActiveLegacyRefreshTokensByUser(userId, now) {
|
|
72
|
+
return this.db
|
|
73
|
+
.prepare(`SELECT id, user_id, token_type, token_hash, device_session_id, caller_kind, expires_at, revoked_at, created_at
|
|
74
|
+
FROM auth_tokens
|
|
75
|
+
WHERE user_id = ?
|
|
76
|
+
AND token_type = 'refresh'
|
|
77
|
+
AND device_session_id IS NULL
|
|
78
|
+
AND revoked_at IS NULL
|
|
79
|
+
AND expires_at > ?
|
|
80
|
+
ORDER BY created_at DESC`)
|
|
81
|
+
.all(userId, now)
|
|
82
|
+
.map((row) => mapTokenRow(row));
|
|
83
|
+
}
|
|
33
84
|
}
|
|
34
85
|
function mapTokenRow(row) {
|
|
35
86
|
return {
|
|
@@ -37,6 +88,8 @@ function mapTokenRow(row) {
|
|
|
37
88
|
userId: row.user_id,
|
|
38
89
|
tokenType: row.token_type,
|
|
39
90
|
tokenHash: row.token_hash,
|
|
91
|
+
deviceSessionId: row.device_session_id,
|
|
92
|
+
callerKind: row.caller_kind,
|
|
40
93
|
expiresAt: row.expires_at,
|
|
41
94
|
revokedAt: row.revoked_at,
|
|
42
95
|
createdAt: row.created_at
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth-token-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-token-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,mBAAmB;IACD;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAuB;QAC5B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN
|
|
1
|
+
{"version":3,"file":"auth-token-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/auth-token-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,mBAAmB;IACD;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAAuB;QAC5B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;4CAWoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;IACN,CAAC;IAED,UAAU,CAAC,SAAiB,EAAE,SAAgC;QAC5D,MAAM,GAAG,GAAG,SAAS;YACnB,CAAC,CAAE,IAAI,CAAC,EAAE;iBACL,OAAO,CACN;;qDAEyC,CAC1C;iBACA,GAAG,CAAC,SAAS,EAAE,SAAS,CAA0B;YACvD,CAAC,CAAE,IAAI,CAAC,EAAE;iBACL,OAAO,CACN;;kCAEsB,CACvB;iBACA,GAAG,CAAC,SAAS,CAA0B,CAAC;QAE/C,OAAO,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACvC,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;sBAEc,CACf;aACA,GAAG,CAAC,EAAE,CAAyB,CAAC;QAEnC,OAAO,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,SAAiB,EAAE,SAAiB;QAC/C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;qDAE6C,CAC9C;aACA,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAC/B,CAAC;IAED,wBAAwB,CAAC,gBAA0B,EAAE,SAAiB;QACpE,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAClC,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAChE,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;uCAE+B,YAAY,0BAA0B,CACtE;aACA,GAAG,CAAC,SAAS,EAAE,GAAG,gBAAgB,CAAC,CAAC;IACzC,CAAC;IAED,wBAAwB,CAAC,MAAc,EAAE,SAAiB;QACxD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;kCAI0B,CAC3B;aACA,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,mCAAmC,CAAC,MAAc,EAAE,GAAW;QAC7D,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;kCAO0B,CAC3B;aACA,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC;aAChB,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,WAAW,CAAC,GAAe,CAAC,CAAC,CAAC;IAChD,CAAC;CACF;AAcD,SAAS,WAAW,CAAC,GAAa;IAChC,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,MAAM,EAAE,GAAG,CAAC,OAAO;QACnB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,eAAe,EAAE,GAAG,CAAC,iBAAiB;QACtC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
|
|
@@ -12,13 +12,16 @@ export class ButlerControlSessionRepository {
|
|
|
12
12
|
purpose,
|
|
13
13
|
title,
|
|
14
14
|
source_item_id,
|
|
15
|
+
model,
|
|
16
|
+
reasoning_level,
|
|
17
|
+
permission_mode,
|
|
15
18
|
status,
|
|
16
19
|
last_context_version,
|
|
17
20
|
last_summary,
|
|
18
21
|
created_at,
|
|
19
22
|
updated_at
|
|
20
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
21
|
-
.run(record.id, record.providerId, record.sessionId, record.purpose, record.title, record.sourceItemId, record.status, record.lastContextVersion, record.lastSummary, record.createdAt, record.updatedAt);
|
|
23
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
24
|
+
.run(record.id, record.providerId, record.sessionId, record.purpose, record.title, record.sourceItemId, record.model, record.reasoningLevel, record.permissionMode, record.status, record.lastContextVersion, record.lastSummary, record.createdAt, record.updatedAt);
|
|
22
25
|
return record;
|
|
23
26
|
}
|
|
24
27
|
findById(id) {
|
|
@@ -30,6 +33,9 @@ export class ButlerControlSessionRepository {
|
|
|
30
33
|
purpose,
|
|
31
34
|
title,
|
|
32
35
|
source_item_id,
|
|
36
|
+
model,
|
|
37
|
+
reasoning_level,
|
|
38
|
+
permission_mode,
|
|
33
39
|
status,
|
|
34
40
|
last_context_version,
|
|
35
41
|
last_summary,
|
|
@@ -49,6 +55,9 @@ export class ButlerControlSessionRepository {
|
|
|
49
55
|
purpose,
|
|
50
56
|
title,
|
|
51
57
|
source_item_id,
|
|
58
|
+
model,
|
|
59
|
+
reasoning_level,
|
|
60
|
+
permission_mode,
|
|
52
61
|
status,
|
|
53
62
|
last_context_version,
|
|
54
63
|
last_summary,
|
|
@@ -70,6 +79,9 @@ export class ButlerControlSessionRepository {
|
|
|
70
79
|
purpose,
|
|
71
80
|
title,
|
|
72
81
|
source_item_id,
|
|
82
|
+
model,
|
|
83
|
+
reasoning_level,
|
|
84
|
+
permission_mode,
|
|
73
85
|
status,
|
|
74
86
|
last_context_version,
|
|
75
87
|
last_summary,
|
|
@@ -92,6 +104,9 @@ export class ButlerControlSessionRepository {
|
|
|
92
104
|
purpose,
|
|
93
105
|
title,
|
|
94
106
|
source_item_id,
|
|
107
|
+
model,
|
|
108
|
+
reasoning_level,
|
|
109
|
+
permission_mode,
|
|
95
110
|
status,
|
|
96
111
|
last_context_version,
|
|
97
112
|
last_summary,
|
|
@@ -112,6 +127,9 @@ export class ButlerControlSessionRepository {
|
|
|
112
127
|
purpose,
|
|
113
128
|
title,
|
|
114
129
|
source_item_id,
|
|
130
|
+
model,
|
|
131
|
+
reasoning_level,
|
|
132
|
+
permission_mode,
|
|
115
133
|
status,
|
|
116
134
|
last_context_version,
|
|
117
135
|
last_summary,
|
|
@@ -135,12 +153,15 @@ export class ButlerControlSessionRepository {
|
|
|
135
153
|
SET purpose = ?,
|
|
136
154
|
title = ?,
|
|
137
155
|
source_item_id = ?,
|
|
156
|
+
model = ?,
|
|
157
|
+
reasoning_level = ?,
|
|
158
|
+
permission_mode = ?,
|
|
138
159
|
status = ?,
|
|
139
160
|
last_context_version = ?,
|
|
140
161
|
last_summary = ?,
|
|
141
162
|
updated_at = ?
|
|
142
163
|
WHERE id = ?`)
|
|
143
|
-
.run(record.purpose, record.title, record.sourceItemId, record.status, record.lastContextVersion, record.lastSummary, record.updatedAt, record.id);
|
|
164
|
+
.run(record.purpose, record.title, record.sourceItemId, record.model, record.reasoningLevel, record.permissionMode, record.status, record.lastContextVersion, record.lastSummary, record.updatedAt, record.id);
|
|
144
165
|
return record;
|
|
145
166
|
}
|
|
146
167
|
}
|
|
@@ -152,6 +173,9 @@ function mapButlerControlSessionRow(row) {
|
|
|
152
173
|
purpose: row.purpose,
|
|
153
174
|
title: row.title,
|
|
154
175
|
sourceItemId: row.source_item_id,
|
|
176
|
+
model: row.model,
|
|
177
|
+
reasoningLevel: row.reasoning_level,
|
|
178
|
+
permissionMode: row.permission_mode,
|
|
155
179
|
status: row.status,
|
|
156
180
|
lastContextVersion: row.last_context_version,
|
|
157
181
|
lastSummary: row.last_summary,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"butler-control-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-control-session-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,8BAA8B;IACZ;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA4B;QACjC,IAAI,CAAC,EAAE;aACJ,OAAO,CACN
|
|
1
|
+
{"version":3,"file":"butler-control-session-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-control-session-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { ButlerControlTimer, ButlerControlTimerStatus } from "../../types/domain.js";
|
|
3
|
+
export declare class ButlerControlTimerRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
create(record: ButlerControlTimer): ButlerControlTimer;
|
|
7
|
+
findById(id: string): ButlerControlTimer | null;
|
|
8
|
+
list(filters?: {
|
|
9
|
+
statuses?: ButlerControlTimerStatus[];
|
|
10
|
+
controlSessionId?: string;
|
|
11
|
+
limit?: number;
|
|
12
|
+
}): ButlerControlTimer[];
|
|
13
|
+
listDueActive(referenceAt: string, limit?: number): ButlerControlTimer[];
|
|
14
|
+
update(record: ButlerControlTimer): ButlerControlTimer;
|
|
15
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
export class ButlerControlTimerRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
create(record) {
|
|
7
|
+
this.db
|
|
8
|
+
.prepare(`INSERT INTO butler_control_timers (
|
|
9
|
+
id,
|
|
10
|
+
control_session_id,
|
|
11
|
+
session_id,
|
|
12
|
+
user_id,
|
|
13
|
+
project_id,
|
|
14
|
+
target_session_id,
|
|
15
|
+
title,
|
|
16
|
+
content,
|
|
17
|
+
due_at,
|
|
18
|
+
status,
|
|
19
|
+
triggered_at,
|
|
20
|
+
last_error,
|
|
21
|
+
created_at,
|
|
22
|
+
updated_at,
|
|
23
|
+
cancelled_at
|
|
24
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
25
|
+
.run(record.id, record.controlSessionId, record.sessionId, record.userId, record.projectId, record.targetSessionId, record.title, record.content, record.dueAt, record.status, record.triggeredAt, record.lastError, record.createdAt, record.updatedAt, record.cancelledAt);
|
|
26
|
+
return record;
|
|
27
|
+
}
|
|
28
|
+
findById(id) {
|
|
29
|
+
const row = this.db
|
|
30
|
+
.prepare(`SELECT
|
|
31
|
+
id,
|
|
32
|
+
control_session_id,
|
|
33
|
+
session_id,
|
|
34
|
+
user_id,
|
|
35
|
+
project_id,
|
|
36
|
+
target_session_id,
|
|
37
|
+
title,
|
|
38
|
+
content,
|
|
39
|
+
due_at,
|
|
40
|
+
status,
|
|
41
|
+
triggered_at,
|
|
42
|
+
last_error,
|
|
43
|
+
created_at,
|
|
44
|
+
updated_at,
|
|
45
|
+
cancelled_at
|
|
46
|
+
FROM butler_control_timers
|
|
47
|
+
WHERE id = ?`)
|
|
48
|
+
.get(id);
|
|
49
|
+
return row ? mapRow(row) : null;
|
|
50
|
+
}
|
|
51
|
+
list(filters = {}) {
|
|
52
|
+
const whereParts = [];
|
|
53
|
+
const values = [];
|
|
54
|
+
if (filters.statuses?.length) {
|
|
55
|
+
whereParts.push(`status IN (${filters.statuses.map(() => "?").join(", ")})`);
|
|
56
|
+
values.push(...filters.statuses);
|
|
57
|
+
}
|
|
58
|
+
if (filters.controlSessionId?.trim()) {
|
|
59
|
+
whereParts.push("control_session_id = ?");
|
|
60
|
+
values.push(filters.controlSessionId.trim());
|
|
61
|
+
}
|
|
62
|
+
const whereClause = whereParts.length > 0 ? `WHERE ${whereParts.join(" AND ")}` : "";
|
|
63
|
+
const limitClause = filters.limit ? "LIMIT ?" : "";
|
|
64
|
+
if (filters.limit) {
|
|
65
|
+
values.push(filters.limit);
|
|
66
|
+
}
|
|
67
|
+
return this.db
|
|
68
|
+
.prepare(`SELECT
|
|
69
|
+
id,
|
|
70
|
+
control_session_id,
|
|
71
|
+
session_id,
|
|
72
|
+
user_id,
|
|
73
|
+
project_id,
|
|
74
|
+
target_session_id,
|
|
75
|
+
title,
|
|
76
|
+
content,
|
|
77
|
+
due_at,
|
|
78
|
+
status,
|
|
79
|
+
triggered_at,
|
|
80
|
+
last_error,
|
|
81
|
+
created_at,
|
|
82
|
+
updated_at,
|
|
83
|
+
cancelled_at
|
|
84
|
+
FROM butler_control_timers
|
|
85
|
+
${whereClause}
|
|
86
|
+
ORDER BY due_at ASC, created_at ASC
|
|
87
|
+
${limitClause}`)
|
|
88
|
+
.all(...values)
|
|
89
|
+
.map((row) => mapRow(row));
|
|
90
|
+
}
|
|
91
|
+
listDueActive(referenceAt, limit = 20) {
|
|
92
|
+
return this.db
|
|
93
|
+
.prepare(`SELECT
|
|
94
|
+
id,
|
|
95
|
+
control_session_id,
|
|
96
|
+
session_id,
|
|
97
|
+
user_id,
|
|
98
|
+
project_id,
|
|
99
|
+
target_session_id,
|
|
100
|
+
title,
|
|
101
|
+
content,
|
|
102
|
+
due_at,
|
|
103
|
+
status,
|
|
104
|
+
triggered_at,
|
|
105
|
+
last_error,
|
|
106
|
+
created_at,
|
|
107
|
+
updated_at,
|
|
108
|
+
cancelled_at
|
|
109
|
+
FROM butler_control_timers
|
|
110
|
+
WHERE status = 'active'
|
|
111
|
+
AND due_at <= ?
|
|
112
|
+
ORDER BY due_at ASC, created_at ASC
|
|
113
|
+
LIMIT ?`)
|
|
114
|
+
.all(referenceAt, limit)
|
|
115
|
+
.map((row) => mapRow(row));
|
|
116
|
+
}
|
|
117
|
+
update(record) {
|
|
118
|
+
this.db
|
|
119
|
+
.prepare(`UPDATE butler_control_timers
|
|
120
|
+
SET control_session_id = ?,
|
|
121
|
+
session_id = ?,
|
|
122
|
+
user_id = ?,
|
|
123
|
+
project_id = ?,
|
|
124
|
+
target_session_id = ?,
|
|
125
|
+
title = ?,
|
|
126
|
+
content = ?,
|
|
127
|
+
due_at = ?,
|
|
128
|
+
status = ?,
|
|
129
|
+
triggered_at = ?,
|
|
130
|
+
last_error = ?,
|
|
131
|
+
updated_at = ?,
|
|
132
|
+
cancelled_at = ?
|
|
133
|
+
WHERE id = ?`)
|
|
134
|
+
.run(record.controlSessionId, record.sessionId, record.userId, record.projectId, record.targetSessionId, record.title, record.content, record.dueAt, record.status, record.triggeredAt, record.lastError, record.updatedAt, record.cancelledAt, record.id);
|
|
135
|
+
return record;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
function mapRow(row) {
|
|
139
|
+
return {
|
|
140
|
+
id: row.id,
|
|
141
|
+
controlSessionId: row.control_session_id,
|
|
142
|
+
sessionId: row.session_id,
|
|
143
|
+
userId: row.user_id,
|
|
144
|
+
projectId: row.project_id,
|
|
145
|
+
targetSessionId: row.target_session_id,
|
|
146
|
+
title: row.title,
|
|
147
|
+
content: row.content,
|
|
148
|
+
dueAt: row.due_at,
|
|
149
|
+
status: row.status,
|
|
150
|
+
triggeredAt: row.triggered_at,
|
|
151
|
+
lastError: row.last_error,
|
|
152
|
+
createdAt: row.created_at,
|
|
153
|
+
updatedAt: row.updated_at,
|
|
154
|
+
cancelledAt: row.cancelled_at
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=butler-control-timer-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"butler-control-timer-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-control-timer-repository.ts"],"names":[],"mappings":"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"}
|