@jingyi0605/codingns 0.4.0 → 0.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bin/codingns.mjs +425 -1
- package/dist/public/assets/AdaptiveButlerPage-B153lk5H.css +1 -0
- package/dist/public/assets/AdaptiveButlerPage-SffCV4Vb.js +3 -0
- package/dist/public/assets/App-DUAg5urj.css +1 -0
- package/dist/public/assets/App-WOLwMld_.js +30 -0
- package/dist/public/assets/BootstrapPage--zExdgfM.js +1 -0
- package/dist/public/assets/ConversationPage-D9pzRmOg.js +2 -0
- package/dist/public/assets/DesktopDetachPreviewPage-DvI9CIKi.js +1 -0
- package/dist/public/assets/DesktopWindowPage-D8FpOSLE.js +2 -0
- package/dist/public/assets/FileContextPanel-C8T7oqRN.js +1 -0
- package/dist/public/assets/GitSidebar-Bze7DNnc.js +6 -0
- package/dist/public/assets/MobileCreateSessionSheet-CXSKMnYn.js +1 -0
- package/dist/public/assets/MobileSheet-Gzc14EpR.js +1 -0
- package/dist/public/assets/MobileTopHeaderFrame-BWorAJ1C.js +1 -0
- package/dist/public/assets/MobileWorkspaceSwitcherHeader-DOr4pTUq.js +1 -0
- package/dist/public/assets/ServerSettingsModal-BYB0GvTl.js +1 -0
- package/dist/public/assets/SessionIndexPage-CR3IARXX.js +1 -0
- package/dist/public/assets/SettingsPage-B_BQtnwE.js +1 -0
- package/dist/public/assets/TerminalManagerPanel-PQ-EM64j.js +1 -0
- package/dist/public/assets/{TerminalPage-6jHZV9Mh.js → TerminalPage-CvnHXBhw.js} +19 -19
- package/dist/public/assets/TerminalRuntimeFallbackModal-D7Aq186N.js +1 -0
- package/dist/public/assets/ToolFilesPage-Qzkc6K2I.js +1 -0
- package/dist/public/assets/ToolGitPage-BdNDN-cV.js +1 -0
- package/dist/public/assets/ToolProcessesPage-EXJ9DHWI.js +1 -0
- package/dist/public/assets/ToolsHomePage-CjF3CWzR.js +1 -0
- package/dist/public/assets/WorkbenchLandingPage-DZPk4SmX.js +1 -0
- package/dist/public/assets/WorkbenchLayout-rwQib5In.js +3 -0
- package/dist/public/assets/WorkbenchModal-B09hC9b5.js +1 -0
- package/dist/public/assets/WorkbenchShellRoute-Cerk5uK7.js +1 -0
- package/dist/public/assets/WorkbenchShellRoute-DsW4mBTX.css +1 -0
- package/dist/public/assets/WorkspaceDebugDetailPage-Bcq8s-Ma.js +1 -0
- package/dist/public/assets/WorkspaceDetailPage-DNAa8pKr.js +1 -0
- package/dist/public/assets/WorkspaceHomePage-BoiLuACV.js +1 -0
- package/dist/public/assets/butler-records-events-DgWCG364.js +1 -0
- package/dist/public/assets/client-runtime-manager-CRQ-F5d2.js +1 -0
- package/dist/public/assets/default-session-permission-mode-D0wZ9Jek.js +1 -0
- package/dist/public/assets/event-DvH9tcej.js +1 -0
- package/dist/public/assets/file-tree-icon-Dp_xhVfD.js +31 -0
- package/dist/public/assets/index-C2G8Gmf1.js +42 -0
- package/dist/public/assets/index-CpPTUeA3.css +1 -0
- package/dist/public/assets/preferences-service-gOt2ZjKZ.js +1 -0
- package/dist/public/assets/session-runtime-machine-Dq3pW-UF.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-BMT-rSEe.js +1 -0
- package/dist/public/assets/useRegisteredDebugTemplates-zMcEOGca.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 +62 -1
- package/dist/server/modules/assistant-capability/assistant-capability-controller.js +58 -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 +66 -3
- package/dist/server/modules/assistant-capability/assistant-capability-service.js +173 -1
- 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 +2 -0
- package/dist/server/modules/butler/assistant-automation-service.js +46 -0
- package/dist/server/modules/butler/assistant-automation-service.js.map +1 -1
- 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 +16 -2
- package/dist/server/modules/butler/assistant-sandbox-service.js +137 -4
- package/dist/server/modules/butler/assistant-sandbox-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 +4 -1
- package/dist/server/modules/butler/butler-control-session-service.js +20 -1
- package/dist/server/modules/butler/butler-control-session-service.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 +32 -4
- package/dist/server/modules/butler/butler-follow-up-service.js +436 -331
- package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
- package/dist/server/modules/butler/butler-inbox-analysis-service.d.ts +1 -1
- 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-session-service.d.ts +3 -1
- package/dist/server/modules/butler/butler-session-service.js +15 -1
- package/dist/server/modules/butler/butler-session-service.js.map +1 -1
- package/dist/server/modules/butler/butler-workspace-context.d.ts +1 -1
- package/dist/server/modules/butler/butler-workspace-context.js +54 -28
- package/dist/server/modules/butler/butler-workspace-context.js.map +1 -1
- package/dist/server/modules/client/client-controller.js +1 -1
- package/dist/server/modules/client/client-controller.js.map +1 -1
- package/dist/server/modules/client/client-service.d.ts +16 -2
- package/dist/server/modules/client/client-service.js +21 -3
- package/dist/server/modules/client/client-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/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 +112 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js +966 -0
- package/dist/server/modules/relay-tunnel/relay-tunnel-service.js.map +1 -0
- 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 +17 -0
- package/dist/server/modules/sessions/session-history-service.js +150 -1
- 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.js +34 -18
- 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-permission-request-service.d.ts +1 -0
- package/dist/server/modules/sessions/session-permission-request-service.js +200 -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/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-types.d.ts +3 -0
- package/dist/server/modules/tasks/task-types.js +3 -0
- package/dist/server/modules/tasks/task-types.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/workbench/snapshot-revision.d.ts +4 -0
- package/dist/server/modules/workbench/snapshot-revision.js +13 -0
- package/dist/server/modules/workbench/snapshot-revision.js.map +1 -0
- package/dist/server/modules/workbench/workbench-service.d.ts +1 -0
- package/dist/server/modules/workbench/workbench-service.js +3 -2
- package/dist/server/modules/workbench/workbench-service.js.map +1 -1
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.d.ts +6 -1
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js +10 -8
- package/dist/server/modules/workbench/workspace-panel-snapshot-service.js.map +1 -1
- package/dist/server/routes/assistant.js +30 -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/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 +10 -0
- package/dist/server/server/create-server.js +83 -13
- 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-task-repository.d.ts +2 -0
- package/dist/server/storage/repositories/assistant-automation-task-repository.js +8 -2
- package/dist/server/storage/repositories/assistant-automation-task-repository.js.map +1 -1
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.d.ts +1 -0
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js +27 -0
- package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js.map +1 -1
- 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-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/sqlite/client.js +297 -2
- package/dist/server/storage/sqlite/client.js.map +1 -1
- package/dist/server/storage/sqlite/schema.sql +122 -4
- package/dist/server/types/domain.d.ts +91 -1
- package/dist/server/ws/workbench-ws-hub.js +225 -99
- 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 +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/claude-code.js +11 -1
- 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 +11 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/codex.js +132 -21
- 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 +2 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/gemini.js +53 -1
- 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 +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/kimi.js +10 -1
- 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 +1 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.js +30 -0
- package/node_modules/@codingns/session-sync-core/dist/providers/opencode.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 +145 -58
- package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/services.d.ts +1 -0
- package/node_modules/@codingns/session-sync-core/dist/services.js +7 -0
- package/node_modules/@codingns/session-sync-core/dist/services.js.map +1 -1
- package/node_modules/@codingns/session-sync-core/dist/types.d.ts +2 -0
- package/package.json +1 -1
- package/scripts/postinstall.mjs +0 -33
- package/dist/public/assets/index-CSVhg7I8.js +0 -123
- package/dist/public/assets/index-Ce1VX19m.css +0 -1
|
@@ -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"}
|
|
@@ -10,6 +10,9 @@ export class ButlerFollowUpTaskRepository {
|
|
|
10
10
|
project_id,
|
|
11
11
|
butler_session_id,
|
|
12
12
|
session_id,
|
|
13
|
+
provider_id,
|
|
14
|
+
assistant_butler_session_id,
|
|
15
|
+
assistant_session_id,
|
|
13
16
|
created_by_user_id,
|
|
14
17
|
objective,
|
|
15
18
|
completion_criteria,
|
|
@@ -29,8 +32,8 @@ export class ButlerFollowUpTaskRepository {
|
|
|
29
32
|
created_at,
|
|
30
33
|
updated_at,
|
|
31
34
|
completed_at
|
|
32
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
33
|
-
.run(record.id, record.projectId, record.butlerSessionId, record.sessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt);
|
|
35
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
36
|
+
.run(record.id, record.projectId, record.butlerSessionId, record.sessionId, record.providerId, record.assistantButlerSessionId, record.assistantSessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt);
|
|
34
37
|
return record;
|
|
35
38
|
}
|
|
36
39
|
findById(id) {
|
|
@@ -40,6 +43,9 @@ export class ButlerFollowUpTaskRepository {
|
|
|
40
43
|
project_id,
|
|
41
44
|
butler_session_id,
|
|
42
45
|
session_id,
|
|
46
|
+
provider_id,
|
|
47
|
+
assistant_butler_session_id,
|
|
48
|
+
assistant_session_id,
|
|
43
49
|
created_by_user_id,
|
|
44
50
|
objective,
|
|
45
51
|
completion_criteria,
|
|
@@ -71,6 +77,9 @@ export class ButlerFollowUpTaskRepository {
|
|
|
71
77
|
project_id,
|
|
72
78
|
butler_session_id,
|
|
73
79
|
session_id,
|
|
80
|
+
provider_id,
|
|
81
|
+
assistant_butler_session_id,
|
|
82
|
+
assistant_session_id,
|
|
74
83
|
created_by_user_id,
|
|
75
84
|
objective,
|
|
76
85
|
completion_criteria,
|
|
@@ -124,6 +133,9 @@ export class ButlerFollowUpTaskRepository {
|
|
|
124
133
|
project_id,
|
|
125
134
|
butler_session_id,
|
|
126
135
|
session_id,
|
|
136
|
+
provider_id,
|
|
137
|
+
assistant_butler_session_id,
|
|
138
|
+
assistant_session_id,
|
|
127
139
|
created_by_user_id,
|
|
128
140
|
objective,
|
|
129
141
|
completion_criteria,
|
|
@@ -166,6 +178,9 @@ export class ButlerFollowUpTaskRepository {
|
|
|
166
178
|
SET project_id = ?,
|
|
167
179
|
butler_session_id = ?,
|
|
168
180
|
session_id = ?,
|
|
181
|
+
provider_id = ?,
|
|
182
|
+
assistant_butler_session_id = ?,
|
|
183
|
+
assistant_session_id = ?,
|
|
169
184
|
created_by_user_id = ?,
|
|
170
185
|
objective = ?,
|
|
171
186
|
completion_criteria = ?,
|
|
@@ -186,7 +201,7 @@ export class ButlerFollowUpTaskRepository {
|
|
|
186
201
|
updated_at = ?,
|
|
187
202
|
completed_at = ?
|
|
188
203
|
WHERE id = ?`)
|
|
189
|
-
.run(record.projectId, record.butlerSessionId, record.sessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt, record.id);
|
|
204
|
+
.run(record.projectId, record.butlerSessionId, record.sessionId, record.providerId, record.assistantButlerSessionId, record.assistantSessionId, record.createdByUserId, record.objective, record.completionCriteria, record.maxAutoContinueCount, record.status, record.checkIntervalSeconds, record.lastCheckedAt, record.nextCheckAt, record.lastObservedRunningState, record.lastObservedMessageAt, record.lastObservedMessageCount, record.lastAutomationSummary, record.lastAutomationAt, record.autoContinueCount, record.waitingReason, JSON.stringify(record.rounds), record.createdAt, record.updatedAt, record.completedAt, record.id);
|
|
190
205
|
return this.findById(record.id);
|
|
191
206
|
}
|
|
192
207
|
}
|
|
@@ -196,6 +211,9 @@ function mapRow(row) {
|
|
|
196
211
|
projectId: row.project_id,
|
|
197
212
|
butlerSessionId: row.butler_session_id,
|
|
198
213
|
sessionId: row.session_id,
|
|
214
|
+
providerId: row.provider_id,
|
|
215
|
+
assistantButlerSessionId: row.assistant_butler_session_id,
|
|
216
|
+
assistantSessionId: row.assistant_session_id,
|
|
199
217
|
createdByUserId: row.created_by_user_id,
|
|
200
218
|
objective: row.objective,
|
|
201
219
|
completionCriteria: row.completion_criteria,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"butler-follow-up-task-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-follow-up-task-repository.ts"],"names":[],"mappings":"AASA,MAAM,OAAO,4BAA4B;IACV;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN
|
|
1
|
+
{"version":3,"file":"butler-follow-up-task-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/butler-follow-up-task-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { InstanceRelayTunnelIdentity } from "../../types/domain.js";
|
|
3
|
+
export declare class InstanceRelayTunnelIdentityRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
findIdentity(): InstanceRelayTunnelIdentity | null;
|
|
7
|
+
upsertIdentity(identity: InstanceRelayTunnelIdentity): InstanceRelayTunnelIdentity;
|
|
8
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
export class InstanceRelayTunnelIdentityRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
findIdentity() {
|
|
7
|
+
const row = this.db
|
|
8
|
+
.prepare(`SELECT
|
|
9
|
+
key_algorithm,
|
|
10
|
+
private_key_pem,
|
|
11
|
+
public_key_pem,
|
|
12
|
+
key_fingerprint,
|
|
13
|
+
created_at,
|
|
14
|
+
updated_at
|
|
15
|
+
FROM instance_relay_tunnel_identity
|
|
16
|
+
WHERE id = 'default'`)
|
|
17
|
+
.get();
|
|
18
|
+
return row ? mapIdentityRow(row) : null;
|
|
19
|
+
}
|
|
20
|
+
upsertIdentity(identity) {
|
|
21
|
+
this.db
|
|
22
|
+
.prepare(`INSERT INTO instance_relay_tunnel_identity (
|
|
23
|
+
id,
|
|
24
|
+
key_algorithm,
|
|
25
|
+
private_key_pem,
|
|
26
|
+
public_key_pem,
|
|
27
|
+
key_fingerprint,
|
|
28
|
+
created_at,
|
|
29
|
+
updated_at
|
|
30
|
+
) VALUES ('default', ?, ?, ?, ?, ?, ?)
|
|
31
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
32
|
+
key_algorithm = excluded.key_algorithm,
|
|
33
|
+
private_key_pem = excluded.private_key_pem,
|
|
34
|
+
public_key_pem = excluded.public_key_pem,
|
|
35
|
+
key_fingerprint = excluded.key_fingerprint,
|
|
36
|
+
created_at = excluded.created_at,
|
|
37
|
+
updated_at = excluded.updated_at`)
|
|
38
|
+
.run(identity.keyAlgorithm, identity.privateKeyPem, identity.publicKeyPem, identity.keyFingerprint, identity.createdAt, identity.updatedAt);
|
|
39
|
+
return identity;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
function mapIdentityRow(row) {
|
|
43
|
+
return {
|
|
44
|
+
keyAlgorithm: row.key_algorithm,
|
|
45
|
+
privateKeyPem: row.private_key_pem,
|
|
46
|
+
publicKeyPem: row.public_key_pem,
|
|
47
|
+
keyFingerprint: row.key_fingerprint,
|
|
48
|
+
createdAt: row.created_at,
|
|
49
|
+
updatedAt: row.updated_at
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=instance-relay-tunnel-identity-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-relay-tunnel-identity-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/instance-relay-tunnel-identity-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,qCAAqC;IACnB;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,YAAY;QACV,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;8BAQsB,CACvB;aACA,GAAG,EAAgD,CAAC;QAEvD,OAAO,GAAG,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1C,CAAC;IAED,cAAc,CAAC,QAAqC;QAClD,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;2CAemC,CACpC;aACA,GAAG,CACF,QAAQ,CAAC,YAAY,EACrB,QAAQ,CAAC,aAAa,EACtB,QAAQ,CAAC,YAAY,EACrB,QAAQ,CAAC,cAAc,EACvB,QAAQ,CAAC,SAAS,EAClB,QAAQ,CAAC,SAAS,CACnB,CAAC;QAEJ,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAWD,SAAS,cAAc,CAAC,GAAmC;IACzD,OAAO;QACL,YAAY,EAAE,GAAG,CAAC,aAAa;QAC/B,aAAa,EAAE,GAAG,CAAC,eAAe;QAClC,YAAY,EAAE,GAAG,CAAC,cAAc;QAChC,cAAc,EAAE,GAAG,CAAC,eAAe;QACnC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type Database from "better-sqlite3";
|
|
2
|
+
import type { InstanceRelayTunnelConfig, InstanceRelayTunnelStatus } from "../../types/domain.js";
|
|
3
|
+
export declare class InstanceRelayTunnelRepository {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(db: Database.Database);
|
|
6
|
+
findConfig(): InstanceRelayTunnelConfig | null;
|
|
7
|
+
upsertConfig(config: InstanceRelayTunnelConfig): InstanceRelayTunnelConfig;
|
|
8
|
+
findStatus(): InstanceRelayTunnelStatus | null;
|
|
9
|
+
upsertStatus(status: InstanceRelayTunnelStatus): InstanceRelayTunnelStatus;
|
|
10
|
+
}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
export class InstanceRelayTunnelRepository {
|
|
2
|
+
db;
|
|
3
|
+
constructor(db) {
|
|
4
|
+
this.db = db;
|
|
5
|
+
}
|
|
6
|
+
findConfig() {
|
|
7
|
+
const row = this.db
|
|
8
|
+
.prepare(`SELECT
|
|
9
|
+
activated,
|
|
10
|
+
enabled,
|
|
11
|
+
provider,
|
|
12
|
+
relay_base_url,
|
|
13
|
+
control_base_url,
|
|
14
|
+
control_access_token_ciphertext,
|
|
15
|
+
control_account_email,
|
|
16
|
+
control_session_expires_at,
|
|
17
|
+
account_id,
|
|
18
|
+
tunnel_domain,
|
|
19
|
+
binding_id,
|
|
20
|
+
host_public_key,
|
|
21
|
+
host_key_fingerprint,
|
|
22
|
+
local_target_base_url,
|
|
23
|
+
local_target_source,
|
|
24
|
+
updated_at
|
|
25
|
+
FROM instance_relay_tunnel_config
|
|
26
|
+
WHERE id = 'default'`)
|
|
27
|
+
.get();
|
|
28
|
+
return row ? mapConfigRow(row) : null;
|
|
29
|
+
}
|
|
30
|
+
upsertConfig(config) {
|
|
31
|
+
this.db
|
|
32
|
+
.prepare(`INSERT INTO instance_relay_tunnel_config (
|
|
33
|
+
id,
|
|
34
|
+
activated,
|
|
35
|
+
enabled,
|
|
36
|
+
provider,
|
|
37
|
+
relay_base_url,
|
|
38
|
+
control_base_url,
|
|
39
|
+
control_access_token_ciphertext,
|
|
40
|
+
control_account_email,
|
|
41
|
+
control_session_expires_at,
|
|
42
|
+
account_id,
|
|
43
|
+
tunnel_domain,
|
|
44
|
+
binding_id,
|
|
45
|
+
host_public_key,
|
|
46
|
+
host_key_fingerprint,
|
|
47
|
+
local_target_base_url,
|
|
48
|
+
local_target_source,
|
|
49
|
+
updated_at
|
|
50
|
+
) VALUES ('default', ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
51
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
52
|
+
activated = excluded.activated,
|
|
53
|
+
enabled = excluded.enabled,
|
|
54
|
+
provider = excluded.provider,
|
|
55
|
+
relay_base_url = excluded.relay_base_url,
|
|
56
|
+
control_base_url = excluded.control_base_url,
|
|
57
|
+
control_access_token_ciphertext = excluded.control_access_token_ciphertext,
|
|
58
|
+
control_account_email = excluded.control_account_email,
|
|
59
|
+
control_session_expires_at = excluded.control_session_expires_at,
|
|
60
|
+
account_id = excluded.account_id,
|
|
61
|
+
tunnel_domain = excluded.tunnel_domain,
|
|
62
|
+
binding_id = excluded.binding_id,
|
|
63
|
+
host_public_key = excluded.host_public_key,
|
|
64
|
+
host_key_fingerprint = excluded.host_key_fingerprint,
|
|
65
|
+
local_target_base_url = excluded.local_target_base_url,
|
|
66
|
+
local_target_source = excluded.local_target_source,
|
|
67
|
+
updated_at = excluded.updated_at`)
|
|
68
|
+
.run(config.activated ? 1 : 0, config.enabled ? 1 : 0, config.provider, config.relayBaseUrl, config.controlBaseUrl, config.controlAccessTokenCiphertext, config.controlAccountEmail, config.controlSessionExpiresAt, config.accountId, config.tunnelDomain, config.bindingId, config.hostPublicKey, config.hostKeyFingerprint, config.localTargetBaseUrl, config.localTargetBaseUrlSource ?? "default", config.updatedAt);
|
|
69
|
+
return config;
|
|
70
|
+
}
|
|
71
|
+
findStatus() {
|
|
72
|
+
const row = this.db
|
|
73
|
+
.prepare(`SELECT
|
|
74
|
+
phase,
|
|
75
|
+
connected,
|
|
76
|
+
binding_id,
|
|
77
|
+
tunnel_domain,
|
|
78
|
+
host_fingerprint,
|
|
79
|
+
traffic_used_bytes,
|
|
80
|
+
traffic_remaining_bytes,
|
|
81
|
+
quota_reset_at,
|
|
82
|
+
last_error,
|
|
83
|
+
observed_at
|
|
84
|
+
FROM instance_relay_tunnel_status
|
|
85
|
+
WHERE id = 'default'`)
|
|
86
|
+
.get();
|
|
87
|
+
return row ? mapStatusRow(row) : null;
|
|
88
|
+
}
|
|
89
|
+
upsertStatus(status) {
|
|
90
|
+
this.db
|
|
91
|
+
.prepare(`INSERT INTO instance_relay_tunnel_status (
|
|
92
|
+
id,
|
|
93
|
+
phase,
|
|
94
|
+
connected,
|
|
95
|
+
binding_id,
|
|
96
|
+
tunnel_domain,
|
|
97
|
+
host_fingerprint,
|
|
98
|
+
traffic_used_bytes,
|
|
99
|
+
traffic_remaining_bytes,
|
|
100
|
+
quota_reset_at,
|
|
101
|
+
last_error,
|
|
102
|
+
observed_at
|
|
103
|
+
) VALUES ('default', ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
104
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
105
|
+
phase = excluded.phase,
|
|
106
|
+
connected = excluded.connected,
|
|
107
|
+
binding_id = excluded.binding_id,
|
|
108
|
+
tunnel_domain = excluded.tunnel_domain,
|
|
109
|
+
host_fingerprint = excluded.host_fingerprint,
|
|
110
|
+
traffic_used_bytes = excluded.traffic_used_bytes,
|
|
111
|
+
traffic_remaining_bytes = excluded.traffic_remaining_bytes,
|
|
112
|
+
quota_reset_at = excluded.quota_reset_at,
|
|
113
|
+
last_error = excluded.last_error,
|
|
114
|
+
observed_at = excluded.observed_at`)
|
|
115
|
+
.run(status.phase, status.connected ? 1 : 0, status.bindingId, status.tunnelDomain, status.hostFingerprint, status.trafficUsedBytes, status.trafficRemainingBytes, status.quotaResetAt, status.lastError, status.observedAt);
|
|
116
|
+
return status;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
function mapConfigRow(row) {
|
|
120
|
+
return {
|
|
121
|
+
activated: Boolean(row.activated),
|
|
122
|
+
enabled: Boolean(row.enabled),
|
|
123
|
+
provider: row.provider,
|
|
124
|
+
relayBaseUrl: row.relay_base_url,
|
|
125
|
+
controlBaseUrl: row.control_base_url,
|
|
126
|
+
controlAccessTokenCiphertext: row.control_access_token_ciphertext,
|
|
127
|
+
controlAccountEmail: row.control_account_email,
|
|
128
|
+
controlSessionExpiresAt: row.control_session_expires_at,
|
|
129
|
+
accountId: row.account_id,
|
|
130
|
+
tunnelDomain: row.tunnel_domain,
|
|
131
|
+
bindingId: row.binding_id,
|
|
132
|
+
hostPublicKey: row.host_public_key,
|
|
133
|
+
hostKeyFingerprint: row.host_key_fingerprint,
|
|
134
|
+
localTargetBaseUrl: row.local_target_base_url,
|
|
135
|
+
localTargetBaseUrlSource: row.local_target_source,
|
|
136
|
+
updatedAt: row.updated_at
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
function mapStatusRow(row) {
|
|
140
|
+
return {
|
|
141
|
+
phase: row.phase,
|
|
142
|
+
connected: Boolean(row.connected),
|
|
143
|
+
bindingId: row.binding_id,
|
|
144
|
+
tunnelDomain: row.tunnel_domain,
|
|
145
|
+
hostFingerprint: row.host_fingerprint,
|
|
146
|
+
trafficUsedBytes: row.traffic_used_bytes,
|
|
147
|
+
trafficRemainingBytes: row.traffic_remaining_bytes,
|
|
148
|
+
quotaResetAt: row.quota_reset_at,
|
|
149
|
+
lastError: row.last_error,
|
|
150
|
+
observedAt: row.observed_at
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
//# sourceMappingURL=instance-relay-tunnel-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-relay-tunnel-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/instance-relay-tunnel-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@ export class InstanceTailscaleRepository {
|
|
|
5
5
|
}
|
|
6
6
|
findConfig() {
|
|
7
7
|
const row = this.db
|
|
8
|
-
.prepare(`SELECT enabled, control_server_url, hostname, state_dir, updated_at
|
|
8
|
+
.prepare(`SELECT activated, enabled, control_server_url, hostname, state_dir, updated_at
|
|
9
9
|
FROM instance_tailscale_config
|
|
10
10
|
WHERE id = 'default'`)
|
|
11
11
|
.get();
|
|
@@ -15,19 +15,21 @@ export class InstanceTailscaleRepository {
|
|
|
15
15
|
this.db
|
|
16
16
|
.prepare(`INSERT INTO instance_tailscale_config (
|
|
17
17
|
id,
|
|
18
|
+
activated,
|
|
18
19
|
enabled,
|
|
19
20
|
control_server_url,
|
|
20
21
|
hostname,
|
|
21
22
|
state_dir,
|
|
22
23
|
updated_at
|
|
23
|
-
) VALUES ('default', ?, ?, ?, ?, ?)
|
|
24
|
+
) VALUES ('default', ?, ?, ?, ?, ?, ?)
|
|
24
25
|
ON CONFLICT(id) DO UPDATE SET
|
|
26
|
+
activated = excluded.activated,
|
|
25
27
|
enabled = excluded.enabled,
|
|
26
28
|
control_server_url = excluded.control_server_url,
|
|
27
29
|
hostname = excluded.hostname,
|
|
28
30
|
state_dir = excluded.state_dir,
|
|
29
31
|
updated_at = excluded.updated_at`)
|
|
30
|
-
.run(config.enabled ? 1 : 0, config.controlServerUrl, config.hostname, config.stateDir, config.updatedAt);
|
|
32
|
+
.run(config.activated ? 1 : 0, config.enabled ? 1 : 0, config.controlServerUrl, config.hostname, config.stateDir, config.updatedAt);
|
|
31
33
|
return config;
|
|
32
34
|
}
|
|
33
35
|
findStatus() {
|
|
@@ -86,6 +88,7 @@ export class InstanceTailscaleRepository {
|
|
|
86
88
|
}
|
|
87
89
|
function mapConfigRow(row) {
|
|
88
90
|
return {
|
|
91
|
+
activated: Boolean(row.activated),
|
|
89
92
|
enabled: Boolean(row.enabled),
|
|
90
93
|
controlServerUrl: row.control_server_url,
|
|
91
94
|
hostname: row.hostname,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"instance-tailscale-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/instance-tailscale-repository.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,UAAU;QACR,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;8BAEsB,CACvB;aACA,GAAG,EAA4C,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN
|
|
1
|
+
{"version":3,"file":"instance-tailscale-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/instance-tailscale-repository.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,2BAA2B;IACT;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,UAAU;QACR,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;8BAEsB,CACvB;aACA,GAAG,EAA4C,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;2CAemC,CACpC;aACA,GAAG,CACF,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACxB,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,UAAU;QACR,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;;8BAcsB,CACvB;aACA,GAAG,EAA4C,CAAC;QAEnD,OAAO,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,YAAY,CAAC,MAA+B;QAC1C,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;;;;;;;;;;;;;6CA2BqC,CACtC;aACA,GAAG,CACF,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACxB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,gBAAgB,EACvB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,UAAU,CAClB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;CACF;AA0BD,SAAS,YAAY,CAAC,GAA+B;IACnD,OAAO;QACL,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;QACjC,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;QAC7B,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC;AAED,SAAS,YAAY,CAAC,GAA+B;IACnD,OAAO;QACL,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,SAAS,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;QACjC,QAAQ,EAAE,GAAG,CAAC,SAAS;QACvB,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,gBAAgB,EAAE,GAAG,CAAC,kBAAkB;QACxC,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,UAAU,EAAE,GAAG,CAAC,WAAW;KAC5B,CAAC;AACJ,CAAC"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import type Database from "better-sqlite3";
|
|
2
|
-
import type { ManagedSkillRecord } from "../../types/domain.js";
|
|
2
|
+
import type { ManagedSkillRecord, SkillScope } from "../../types/domain.js";
|
|
3
3
|
export declare class ManagedSkillRepository {
|
|
4
4
|
private readonly db;
|
|
5
5
|
constructor(db: Database.Database);
|
|
6
6
|
findById(id: string): ManagedSkillRecord | null;
|
|
7
7
|
findByDirectoryName(directoryName: string): ManagedSkillRecord | null;
|
|
8
|
+
findByScopeAndDirectoryName(scope: SkillScope, directoryName: string): ManagedSkillRecord | null;
|
|
8
9
|
list(): ManagedSkillRecord[];
|
|
9
10
|
upsert(record: ManagedSkillRecord): ManagedSkillRecord;
|
|
10
11
|
delete(id: string): boolean;
|
|
@@ -8,6 +8,7 @@ export class ManagedSkillRepository {
|
|
|
8
8
|
.prepare(`SELECT
|
|
9
9
|
id,
|
|
10
10
|
name,
|
|
11
|
+
scope,
|
|
11
12
|
directory_name,
|
|
12
13
|
source_type,
|
|
13
14
|
source_path,
|
|
@@ -21,10 +22,14 @@ export class ManagedSkillRepository {
|
|
|
21
22
|
return row ? mapManagedSkillRow(row) : null;
|
|
22
23
|
}
|
|
23
24
|
findByDirectoryName(directoryName) {
|
|
25
|
+
return this.findByScopeAndDirectoryName("workspace", directoryName);
|
|
26
|
+
}
|
|
27
|
+
findByScopeAndDirectoryName(scope, directoryName) {
|
|
24
28
|
const row = this.db
|
|
25
29
|
.prepare(`SELECT
|
|
26
30
|
id,
|
|
27
31
|
name,
|
|
32
|
+
scope,
|
|
28
33
|
directory_name,
|
|
29
34
|
source_type,
|
|
30
35
|
source_path,
|
|
@@ -33,8 +38,9 @@ export class ManagedSkillRepository {
|
|
|
33
38
|
created_at,
|
|
34
39
|
updated_at
|
|
35
40
|
FROM managed_skills
|
|
36
|
-
WHERE
|
|
37
|
-
|
|
41
|
+
WHERE scope = ?
|
|
42
|
+
AND directory_name = ?`)
|
|
43
|
+
.get(scope, directoryName);
|
|
38
44
|
return row ? mapManagedSkillRow(row) : null;
|
|
39
45
|
}
|
|
40
46
|
list() {
|
|
@@ -42,6 +48,7 @@ export class ManagedSkillRepository {
|
|
|
42
48
|
.prepare(`SELECT
|
|
43
49
|
id,
|
|
44
50
|
name,
|
|
51
|
+
scope,
|
|
45
52
|
directory_name,
|
|
46
53
|
source_type,
|
|
47
54
|
source_path,
|
|
@@ -59,6 +66,7 @@ export class ManagedSkillRepository {
|
|
|
59
66
|
.prepare(`INSERT INTO managed_skills (
|
|
60
67
|
id,
|
|
61
68
|
name,
|
|
69
|
+
scope,
|
|
62
70
|
directory_name,
|
|
63
71
|
source_type,
|
|
64
72
|
source_path,
|
|
@@ -66,16 +74,17 @@ export class ManagedSkillRepository {
|
|
|
66
74
|
managed_state,
|
|
67
75
|
created_at,
|
|
68
76
|
updated_at
|
|
69
|
-
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
77
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
70
78
|
ON CONFLICT(id) DO UPDATE SET
|
|
71
79
|
name = excluded.name,
|
|
80
|
+
scope = excluded.scope,
|
|
72
81
|
directory_name = excluded.directory_name,
|
|
73
82
|
source_type = excluded.source_type,
|
|
74
83
|
source_path = excluded.source_path,
|
|
75
84
|
content_hash = excluded.content_hash,
|
|
76
85
|
managed_state = excluded.managed_state,
|
|
77
86
|
updated_at = excluded.updated_at`)
|
|
78
|
-
.run(record.id, record.name, record.directoryName, record.sourceType, record.sourcePath, record.contentHash, record.managedState, record.createdAt, record.updatedAt);
|
|
87
|
+
.run(record.id, record.name, record.scope, record.directoryName, record.sourceType, record.sourcePath, record.contentHash, record.managedState, record.createdAt, record.updatedAt);
|
|
79
88
|
return record;
|
|
80
89
|
}
|
|
81
90
|
delete(id) {
|
|
@@ -90,6 +99,7 @@ function mapManagedSkillRow(row) {
|
|
|
90
99
|
return {
|
|
91
100
|
id: row.id,
|
|
92
101
|
name: row.name,
|
|
102
|
+
scope: row.scope,
|
|
93
103
|
directoryName: row.directory_name,
|
|
94
104
|
sourceType: row.source_type,
|
|
95
105
|
sourcePath: row.source_path,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"managed-skill-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/managed-skill-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN
|
|
1
|
+
{"version":3,"file":"managed-skill-repository.js","sourceRoot":"","sources":["../../../../src/storage/repositories/managed-skill-repository.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,sBAAsB;IACJ;IAA7B,YAA6B,EAAqB;QAArB,OAAE,GAAF,EAAE,CAAmB;IAAG,CAAC;IAEtD,QAAQ,CAAC,EAAU;QACjB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;sBAYc,CACf;aACA,GAAG,CAAC,EAAE,CAAgC,CAAC;QAE1C,OAAO,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED,mBAAmB,CAAC,aAAqB;QACvC,OAAO,IAAI,CAAC,2BAA2B,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;IACtE,CAAC;IAED,2BAA2B,CAAC,KAAiB,EAAE,aAAqB;QAClE,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CACN;;;;;;;;;;;;;kCAa0B,CAC3B;aACA,GAAG,CAAC,KAAK,EAAE,aAAa,CAAgC,CAAC;QAE5D,OAAO,GAAG,CAAC,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC9C,CAAC;IAED,IAAI;QACF,OAAO,IAAI,CAAC,EAAE;aACX,OAAO,CACN;;;;;;;;;;;;2DAYmD,CACpD;aACA,GAAG,EAAE;aACL,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,kBAAkB,CAAC,GAAsB,CAAC,CAAC,CAAC;IAC9D,CAAC;IAED,MAAM,CAAC,MAA0B;QAC/B,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;;;;;;;;;;;;;;;;;;;4CAoBoC,CACrC;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,IAAI,EACX,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,aAAa,EACpB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,SAAS,CACjB,CAAC;QAEJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,MAAM,CAAC,EAAU;QACf,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE;aACnB,OAAO,CACN;sBACc,CACf;aACA,GAAG,CAAC,EAAE,CAAC,CAAC;QAEX,OAAO,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;IAC5B,CAAC;CACF;AAeD,SAAS,kBAAkB,CAAC,GAAoB;IAC9C,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,IAAI,EAAE,GAAG,CAAC,IAAI;QACd,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,aAAa,EAAE,GAAG,CAAC,cAAc;QACjC,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,UAAU,EAAE,GAAG,CAAC,WAAW;QAC3B,WAAW,EAAE,GAAG,CAAC,YAAY;QAC7B,YAAY,EAAE,GAAG,CAAC,aAAa;QAC/B,SAAS,EAAE,GAAG,CAAC,UAAU;QACzB,SAAS,EAAE,GAAG,CAAC,UAAU;KAC1B,CAAC;AACJ,CAAC"}
|
|
@@ -4,10 +4,12 @@ export declare class SessionMessageAttachmentRepository {
|
|
|
4
4
|
private readonly db;
|
|
5
5
|
constructor(db: Database.Database);
|
|
6
6
|
listBySessionAndClientRequest(sessionId: string, clientRequestId: string): SessionMessageAttachmentRecord[];
|
|
7
|
+
listBySession(sessionId: string): SessionMessageAttachmentRecord[];
|
|
7
8
|
listBySessionAndMessageIds(sessionId: string, messageIds: string[]): SessionMessageAttachmentRecord[];
|
|
8
9
|
findBySessionAndId(sessionId: string, attachmentId: string): SessionMessageAttachmentRecord | null;
|
|
9
10
|
insert(record: SessionMessageAttachmentRecord): void;
|
|
10
11
|
bindMessage(sessionId: string, clientRequestId: string, messageId: string): void;
|
|
11
12
|
listUnboundBySessionAndClientRequest(sessionId: string, clientRequestId: string): SessionMessageAttachmentRecord[];
|
|
12
13
|
deleteByIds(attachmentIds: string[]): void;
|
|
14
|
+
deleteBySession(sessionId: string): void;
|
|
13
15
|
}
|