daycare-cli 2026.2.3 → 2026.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/upgrade.d.ts +5 -0
- package/dist/commands/upgrade.d.ts.map +1 -0
- package/dist/commands/upgrade.js +22 -0
- package/dist/commands/upgrade.js.map +1 -0
- package/dist/config/configResolve.d.ts.map +1 -1
- package/dist/config/configResolve.js +2 -0
- package/dist/config/configResolve.js.map +1 -1
- package/dist/config/configResolve.spec.js +11 -0
- package/dist/config/configResolve.spec.js.map +1 -1
- package/dist/config/configSettingsParse.d.ts.map +1 -1
- package/dist/config/configSettingsParse.js +2 -1
- package/dist/config/configSettingsParse.js.map +1 -1
- package/dist/config/configSettingsParse.spec.js +8 -0
- package/dist/config/configSettingsParse.spec.js.map +1 -1
- package/dist/config/configTypes.d.ts +1 -0
- package/dist/config/configTypes.d.ts.map +1 -1
- package/dist/engine/agents/agent.d.ts +1 -1
- package/dist/engine/agents/agent.d.ts.map +1 -1
- package/dist/engine/agents/agent.js +34 -20
- package/dist/engine/agents/agent.js.map +1 -1
- package/dist/engine/agents/agent.spec.js +40 -41
- package/dist/engine/agents/agent.spec.js.map +1 -1
- package/dist/engine/agents/agentSystem.d.ts +7 -1
- package/dist/engine/agents/agentSystem.d.ts.map +1 -1
- package/dist/engine/agents/agentSystem.js +28 -16
- package/dist/engine/agents/agentSystem.js.map +1 -1
- package/dist/engine/agents/ops/agentBackgroundList.d.ts +1 -1
- package/dist/engine/agents/ops/agentBackgroundList.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentBackgroundList.js +8 -34
- package/dist/engine/agents/ops/agentBackgroundList.js.map +1 -1
- package/dist/engine/agents/ops/agentDescriptorRead.d.ts +2 -2
- package/dist/engine/agents/ops/agentDescriptorRead.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentDescriptorRead.js +5 -72
- package/dist/engine/agents/ops/agentDescriptorRead.js.map +1 -1
- package/dist/engine/agents/ops/agentDescriptorWrite.d.ts +1 -1
- package/dist/engine/agents/ops/agentDescriptorWrite.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentDescriptorWrite.js +17 -10
- package/dist/engine/agents/ops/agentDescriptorWrite.js.map +1 -1
- package/dist/engine/agents/ops/agentDescriptorWrite.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.spec.js +49 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentHistoryAppend.d.ts +2 -2
- package/dist/engine/agents/ops/agentHistoryAppend.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentHistoryAppend.js +23 -10
- package/dist/engine/agents/ops/agentHistoryAppend.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryContext.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentHistoryContext.js +0 -11
- package/dist/engine/agents/ops/agentHistoryContext.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryContext.spec.js +4 -7
- package/dist/engine/agents/ops/agentHistoryContext.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryLoad.d.ts +1 -1
- package/dist/engine/agents/ops/agentHistoryLoad.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentHistoryLoad.js +6 -19
- package/dist/engine/agents/ops/agentHistoryLoad.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryLoad.spec.js +38 -8
- package/dist/engine/agents/ops/agentHistoryLoad.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryLoadAll.d.ts +1 -1
- package/dist/engine/agents/ops/agentHistoryLoadAll.js +3 -3
- package/dist/engine/agents/ops/agentHistoryLoadAll.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryLoadAll.spec.js +33 -14
- package/dist/engine/agents/ops/agentHistoryLoadAll.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentHistoryPendingRlmResolve.spec.js +1 -1
- package/dist/engine/agents/ops/agentHistoryPendingRlmResolve.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentHistorySummary.js +0 -2
- package/dist/engine/agents/ops/agentHistorySummary.js.map +1 -1
- package/dist/engine/agents/ops/agentHistorySummary.spec.js +2 -7
- package/dist/engine/agents/ops/agentHistorySummary.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentInbox.d.ts +14 -1
- package/dist/engine/agents/ops/agentInbox.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentInbox.js +21 -0
- package/dist/engine/agents/ops/agentInbox.js.map +1 -1
- package/dist/engine/agents/ops/agentInbox.spec.js +36 -0
- package/dist/engine/agents/ops/agentInbox.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentList.d.ts +1 -1
- package/dist/engine/agents/ops/agentList.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentList.js +9 -35
- package/dist/engine/agents/ops/agentList.js.map +1 -1
- package/dist/engine/agents/ops/agentLoopRun.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentLoopRun.js +59 -73
- package/dist/engine/agents/ops/agentLoopRun.js.map +1 -1
- package/dist/engine/agents/ops/agentLoopRun.spec.js +46 -2
- package/dist/engine/agents/ops/agentLoopRun.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentPermanentList.d.ts +1 -1
- package/dist/engine/agents/ops/agentPermanentList.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentPermanentList.js +8 -31
- package/dist/engine/agents/ops/agentPermanentList.js.map +1 -1
- package/dist/engine/agents/ops/agentStateRead.d.ts +2 -2
- package/dist/engine/agents/ops/agentStateRead.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentStateRead.js +19 -74
- package/dist/engine/agents/ops/agentStateRead.js.map +1 -1
- package/dist/engine/agents/ops/agentStateRead.spec.js +25 -28
- package/dist/engine/agents/ops/agentStateRead.spec.js.map +1 -1
- package/dist/engine/agents/ops/agentStateWrite.d.ts +2 -2
- package/dist/engine/agents/ops/agentStateWrite.d.ts.map +1 -1
- package/dist/engine/agents/ops/agentStateWrite.js +16 -16
- package/dist/engine/agents/ops/agentStateWrite.js.map +1 -1
- package/dist/engine/agents/ops/agentTypes.d.ts +7 -7
- package/dist/engine/agents/ops/agentTypes.d.ts.map +1 -1
- package/dist/engine/apps/appExecute.spec.js +39 -20
- package/dist/engine/apps/appExecute.spec.js.map +1 -1
- package/dist/engine/engine.d.ts.map +1 -1
- package/dist/engine/engine.js +7 -1
- package/dist/engine/engine.js.map +1 -1
- package/dist/engine/engine.spec.js +2 -0
- package/dist/engine/engine.spec.js.map +1 -1
- package/dist/engine/modules/rlm/rlmExecute.d.ts +10 -1
- package/dist/engine/modules/rlm/rlmExecute.d.ts.map +1 -1
- package/dist/engine/modules/rlm/rlmExecute.js +35 -1
- package/dist/engine/modules/rlm/rlmExecute.js.map +1 -1
- package/dist/engine/modules/rlm/rlmRestore.d.ts +2 -2
- package/dist/engine/modules/rlm/rlmRestore.d.ts.map +1 -1
- package/dist/engine/modules/rlm/rlmRestore.js +35 -1
- package/dist/engine/modules/rlm/rlmRestore.js.map +1 -1
- package/dist/engine/modules/rlm/rlmTool.d.ts.map +1 -1
- package/dist/engine/modules/rlm/rlmTool.js +9 -1
- package/dist/engine/modules/rlm/rlmTool.js.map +1 -1
- package/dist/engine/modules/tools/agentCompactTool.d.ts +7 -0
- package/dist/engine/modules/tools/agentCompactTool.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentCompactTool.js +63 -0
- package/dist/engine/modules/tools/agentCompactTool.js.map +1 -0
- package/dist/engine/modules/tools/agentCompactTool.spec.d.ts +2 -0
- package/dist/engine/modules/tools/agentCompactTool.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentCompactTool.spec.js +54 -0
- package/dist/engine/modules/tools/agentCompactTool.spec.js.map +1 -0
- package/dist/engine/modules/tools/agentResetTool.d.ts +7 -0
- package/dist/engine/modules/tools/agentResetTool.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentResetTool.js +68 -0
- package/dist/engine/modules/tools/agentResetTool.js.map +1 -0
- package/dist/engine/modules/tools/agentResetTool.spec.d.ts +2 -0
- package/dist/engine/modules/tools/agentResetTool.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentResetTool.spec.js +62 -0
- package/dist/engine/modules/tools/agentResetTool.spec.js.map +1 -0
- package/dist/engine/modules/tools/background.d.ts.map +1 -1
- package/dist/engine/modules/tools/background.js +40 -2
- package/dist/engine/modules/tools/background.js.map +1 -1
- package/dist/engine/modules/tools/permanentAgentToolBuild.d.ts.map +1 -1
- package/dist/engine/modules/tools/permanentAgentToolBuild.js +8 -2
- package/dist/engine/modules/tools/permanentAgentToolBuild.js.map +1 -1
- package/dist/engine/modules/tools/sessionHistoryToolBuild.js +1 -9
- package/dist/engine/modules/tools/sessionHistoryToolBuild.js.map +1 -1
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js +3 -3
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js.map +1 -1
- package/dist/engine/modules/tools/toolListContextBuild.d.ts.map +1 -1
- package/dist/engine/modules/tools/toolListContextBuild.js +3 -1
- package/dist/engine/modules/tools/toolListContextBuild.js.map +1 -1
- package/dist/engine/modules/tools/toolListContextBuild.spec.js +19 -0
- package/dist/engine/modules/tools/toolListContextBuild.spec.js.map +1 -1
- package/dist/main.js +6 -0
- package/dist/main.js.map +1 -1
- package/dist/plugins/dashboard/site/404.html +1 -1
- package/dist/plugins/dashboard/site/agent.html +1 -1
- package/dist/plugins/dashboard/site/agent.txt +1 -1
- package/dist/plugins/dashboard/site/agents.html +1 -1
- package/dist/plugins/dashboard/site/agents.txt +1 -1
- package/dist/plugins/dashboard/site/automations.html +1 -1
- package/dist/plugins/dashboard/site/automations.txt +1 -1
- package/dist/plugins/dashboard/site/connectors.html +1 -1
- package/dist/plugins/dashboard/site/connectors.txt +1 -1
- package/dist/plugins/dashboard/site/index.html +1 -1
- package/dist/plugins/dashboard/site/index.txt +1 -1
- package/dist/plugins/dashboard/site/processes.html +1 -1
- package/dist/plugins/dashboard/site/processes.txt +1 -1
- package/dist/plugins/dashboard/site/providers.html +1 -1
- package/dist/plugins/dashboard/site/providers.txt +1 -1
- package/dist/plugins/dashboard/site/signals.html +1 -1
- package/dist/plugins/dashboard/site/signals.txt +1 -1
- package/dist/plugins/dashboard/site/telemetry.html +1 -1
- package/dist/plugins/dashboard/site/telemetry.txt +1 -1
- package/dist/plugins/dashboard/site/tools.html +1 -1
- package/dist/plugins/dashboard/site/tools.txt +1 -1
- package/dist/plugins/shell/tool.js +2 -2
- package/dist/plugins/shell/tool.js.map +1 -1
- package/dist/plugins/telegram/connector.d.ts.map +1 -1
- package/dist/plugins/telegram/connector.js +3 -2
- package/dist/plugins/telegram/connector.js.map +1 -1
- package/dist/plugins/upgrade/plugin.spec.js +12 -1
- package/dist/plugins/upgrade/plugin.spec.js.map +1 -1
- package/dist/prompts/SYSTEM_AGENCY.md +10 -1
- package/dist/settings.d.ts +1 -0
- package/dist/settings.d.ts.map +1 -1
- package/dist/settings.js.map +1 -1
- package/dist/storage/agentDb.spec.d.ts +2 -0
- package/dist/storage/agentDb.spec.d.ts.map +1 -0
- package/dist/storage/agentDb.spec.js +113 -0
- package/dist/storage/agentDb.spec.js.map +1 -0
- package/dist/storage/agentDbList.d.ts +8 -0
- package/dist/storage/agentDbList.d.ts.map +1 -0
- package/dist/storage/agentDbList.js +17 -0
- package/dist/storage/agentDbList.js.map +1 -0
- package/dist/storage/agentDbParse.d.ts +7 -0
- package/dist/storage/agentDbParse.d.ts.map +1 -0
- package/dist/storage/agentDbParse.js +19 -0
- package/dist/storage/agentDbParse.js.map +1 -0
- package/dist/storage/agentDbRead.d.ts +8 -0
- package/dist/storage/agentDbRead.d.ts.map +1 -0
- package/dist/storage/agentDbRead.js +20 -0
- package/dist/storage/agentDbRead.js.map +1 -0
- package/dist/storage/agentDbWrite.d.ts +8 -0
- package/dist/storage/agentDbWrite.d.ts.map +1 -0
- package/dist/storage/agentDbWrite.js +38 -0
- package/dist/storage/agentDbWrite.js.map +1 -0
- package/dist/storage/databaseOpen.d.ts +7 -0
- package/dist/storage/databaseOpen.d.ts.map +1 -0
- package/dist/storage/databaseOpen.js +21 -0
- package/dist/storage/databaseOpen.js.map +1 -0
- package/dist/storage/databaseOpen.spec.d.ts +2 -0
- package/dist/storage/databaseOpen.spec.d.ts.map +1 -0
- package/dist/storage/databaseOpen.spec.js +27 -0
- package/dist/storage/databaseOpen.spec.js.map +1 -0
- package/dist/storage/databaseOpenEnsured.d.ts +7 -0
- package/dist/storage/databaseOpenEnsured.d.ts.map +1 -0
- package/dist/storage/databaseOpenEnsured.js +17 -0
- package/dist/storage/databaseOpenEnsured.js.map +1 -0
- package/dist/storage/databaseTypes.d.ts +47 -0
- package/dist/storage/databaseTypes.d.ts.map +1 -0
- package/dist/storage/databaseTypes.js +2 -0
- package/dist/storage/databaseTypes.js.map +1 -0
- package/dist/storage/migrations/20260219_import_files.d.ts +3 -0
- package/dist/storage/migrations/20260219_import_files.d.ts.map +1 -0
- package/dist/storage/migrations/20260219_import_files.js +205 -0
- package/dist/storage/migrations/20260219_import_files.js.map +1 -0
- package/dist/storage/migrations/20260219_initial.d.ts +3 -0
- package/dist/storage/migrations/20260219_initial.d.ts.map +1 -0
- package/dist/storage/migrations/20260219_initial.js +42 -0
- package/dist/storage/migrations/20260219_initial.js.map +1 -0
- package/dist/storage/migrations/_migrations.d.ts +3 -0
- package/dist/storage/migrations/_migrations.d.ts.map +1 -0
- package/dist/storage/migrations/_migrations.js +7 -0
- package/dist/storage/migrations/_migrations.js.map +1 -0
- package/dist/storage/migrations/migrationPending.d.ts +8 -0
- package/dist/storage/migrations/migrationPending.d.ts.map +1 -0
- package/dist/storage/migrations/migrationPending.js +18 -0
- package/dist/storage/migrations/migrationPending.js.map +1 -0
- package/dist/storage/migrations/migrationPending.spec.d.ts +2 -0
- package/dist/storage/migrations/migrationPending.spec.d.ts.map +1 -0
- package/dist/storage/migrations/migrationPending.spec.js +42 -0
- package/dist/storage/migrations/migrationPending.spec.js.map +1 -0
- package/dist/storage/migrations/migrationRun.d.ts +7 -0
- package/dist/storage/migrations/migrationRun.d.ts.map +1 -0
- package/dist/storage/migrations/migrationRun.js +31 -0
- package/dist/storage/migrations/migrationRun.js.map +1 -0
- package/dist/storage/migrations/migrationRun.spec.d.ts +2 -0
- package/dist/storage/migrations/migrationRun.spec.d.ts.map +1 -0
- package/dist/storage/migrations/migrationRun.spec.js +41 -0
- package/dist/storage/migrations/migrationRun.spec.js.map +1 -0
- package/dist/storage/migrations/migrationTypes.d.ts +6 -0
- package/dist/storage/migrations/migrationTypes.d.ts.map +1 -0
- package/dist/storage/migrations/migrationTypes.js +2 -0
- package/dist/storage/migrations/migrationTypes.js.map +1 -0
- package/dist/storage/sessionDb.spec.d.ts +2 -0
- package/dist/storage/sessionDb.spec.d.ts.map +1 -0
- package/dist/storage/sessionDb.spec.js +94 -0
- package/dist/storage/sessionDb.spec.js.map +1 -0
- package/dist/storage/sessionDbCreate.d.ts +14 -0
- package/dist/storage/sessionDbCreate.d.ts.map +1 -0
- package/dist/storage/sessionDbCreate.js +27 -0
- package/dist/storage/sessionDbCreate.js.map +1 -0
- package/dist/storage/sessionDbListForAgent.d.ts +8 -0
- package/dist/storage/sessionDbListForAgent.d.ts.map +1 -0
- package/dist/storage/sessionDbListForAgent.js +19 -0
- package/dist/storage/sessionDbListForAgent.js.map +1 -0
- package/dist/storage/sessionDbParse.d.ts +7 -0
- package/dist/storage/sessionDbParse.d.ts.map +1 -0
- package/dist/storage/sessionDbParse.js +14 -0
- package/dist/storage/sessionDbParse.js.map +1 -0
- package/dist/storage/sessionDbRead.d.ts +8 -0
- package/dist/storage/sessionDbRead.d.ts.map +1 -0
- package/dist/storage/sessionDbRead.js +20 -0
- package/dist/storage/sessionDbRead.js.map +1 -0
- package/dist/storage/sessionHistoryDb.spec.d.ts +2 -0
- package/dist/storage/sessionHistoryDb.spec.d.ts.map +1 -0
- package/dist/storage/sessionHistoryDb.spec.js +100 -0
- package/dist/storage/sessionHistoryDb.spec.js.map +1 -0
- package/dist/storage/sessionHistoryDbAppend.d.ts +12 -0
- package/dist/storage/sessionHistoryDbAppend.d.ts.map +1 -0
- package/dist/storage/sessionHistoryDbAppend.js +19 -0
- package/dist/storage/sessionHistoryDbAppend.js.map +1 -0
- package/dist/storage/sessionHistoryDbLoad.d.ts +7 -0
- package/dist/storage/sessionHistoryDbLoad.d.ts.map +1 -0
- package/dist/storage/sessionHistoryDbLoad.js +21 -0
- package/dist/storage/sessionHistoryDbLoad.js.map +1 -0
- package/dist/storage/sessionHistoryDbLoadAll.d.ts +7 -0
- package/dist/storage/sessionHistoryDbLoadAll.d.ts.map +1 -0
- package/dist/storage/sessionHistoryDbLoadAll.js +27 -0
- package/dist/storage/sessionHistoryDbLoadAll.js.map +1 -0
- package/dist/storage/sessionHistoryRecordParse.d.ts +8 -0
- package/dist/storage/sessionHistoryRecordParse.d.ts.map +1 -0
- package/dist/storage/sessionHistoryRecordParse.js +18 -0
- package/dist/storage/sessionHistoryRecordParse.js.map +1 -0
- package/dist/storage/sessionHistoryRecordParse.spec.d.ts +2 -0
- package/dist/storage/sessionHistoryRecordParse.spec.d.ts.map +1 -0
- package/dist/storage/sessionHistoryRecordParse.spec.js +29 -0
- package/dist/storage/sessionHistoryRecordParse.spec.js.map +1 -0
- package/dist/storage/storageUpgrade.d.ts +11 -0
- package/dist/storage/storageUpgrade.d.ts.map +1 -0
- package/dist/storage/storageUpgrade.js +27 -0
- package/dist/storage/storageUpgrade.js.map +1 -0
- package/dist/storage/storageUpgrade.spec.d.ts +2 -0
- package/dist/storage/storageUpgrade.spec.d.ts.map +1 -0
- package/dist/storage/storageUpgrade.spec.js +27 -0
- package/dist/storage/storageUpgrade.spec.js.map +1 -0
- package/package.json +1 -1
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.d.ts +0 -8
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.d.ts.map +0 -1
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.js +0 -179
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.js.map +0 -1
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.spec.d.ts +0 -2
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.spec.d.ts.map +0 -1
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.spec.js +0 -114
- package/dist/engine/agents/ops/agentHistoryRecordsLoad.spec.js.map +0 -1
- /package/dist/plugins/dashboard/site/_next/static/{yMBYZ8deK2p0mAiBZ2gXo → QaLNk-eKmEa2hNSDaTRmr}/_buildManifest.js +0 -0
- /package/dist/plugins/dashboard/site/_next/static/{yMBYZ8deK2p0mAiBZ2gXo → QaLNk-eKmEa2hNSDaTRmr}/_ssgManifest.js +0 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { DatabaseSync as DatabaseSyncType } from "node:sqlite";
|
|
2
|
+
/**
|
|
3
|
+
* Opens a SQLite database and applies required connection pragmas.
|
|
4
|
+
* Expects: dbPath is absolute and writable by the current process.
|
|
5
|
+
*/
|
|
6
|
+
export declare function databaseOpen(dbPath: string): DatabaseSyncType;
|
|
7
|
+
//# sourceMappingURL=databaseOpen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpen.d.ts","sourceRoot":"","sources":["../../sources/storage/databaseOpen.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAKpE;;;GAGG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB,CAW7D"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { mkdirSync } from "node:fs";
|
|
2
|
+
import { createRequire } from "node:module";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
const nodeRequire = createRequire(import.meta.url);
|
|
5
|
+
const { DatabaseSync } = nodeRequire("node:sqlite");
|
|
6
|
+
/**
|
|
7
|
+
* Opens a SQLite database and applies required connection pragmas.
|
|
8
|
+
* Expects: dbPath is absolute and writable by the current process.
|
|
9
|
+
*/
|
|
10
|
+
export function databaseOpen(dbPath) {
|
|
11
|
+
if (dbPath !== ":memory:") {
|
|
12
|
+
mkdirSync(path.dirname(dbPath), { recursive: true });
|
|
13
|
+
}
|
|
14
|
+
const db = new DatabaseSync(dbPath);
|
|
15
|
+
if (dbPath !== ":memory:") {
|
|
16
|
+
db.exec("PRAGMA journal_mode=WAL;");
|
|
17
|
+
}
|
|
18
|
+
db.exec("PRAGMA foreign_keys=ON;");
|
|
19
|
+
return db;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=databaseOpen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpen.js","sourceRoot":"","sources":["../../sources/storage/databaseOpen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,IAAI,MAAM,WAAW,CAAC;AAG7B,MAAM,WAAW,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACnD,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC,aAAa,CAAiC,CAAC;AAEpF;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,MAAc;IACzC,IAAI,MAAM,KAAK,UAAU,EAAE,CAAC;QAC1B,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,MAAM,EAAE,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC;IACpC,IAAI,MAAM,KAAK,UAAU,EAAE,CAAC;QAC1B,EAAE,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC;IACtC,CAAC;IACD,EAAE,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;IACnC,OAAO,EAAE,CAAC;AACZ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpen.spec.d.ts","sourceRoot":"","sources":["../../sources/storage/databaseOpen.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { mkdtemp, rm } from "node:fs/promises";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import { databaseOpen } from "./databaseOpen.js";
|
|
6
|
+
describe("databaseOpen", () => {
|
|
7
|
+
it("creates the database file and enables WAL + foreign keys", async () => {
|
|
8
|
+
const dir = await mkdtemp(path.join(os.tmpdir(), "daycare-db-open-"));
|
|
9
|
+
const dbPath = path.join(dir, "daycare.db");
|
|
10
|
+
try {
|
|
11
|
+
const db = databaseOpen(dbPath);
|
|
12
|
+
const journal = db
|
|
13
|
+
.prepare("PRAGMA journal_mode")
|
|
14
|
+
.get();
|
|
15
|
+
const foreignKeys = db
|
|
16
|
+
.prepare("PRAGMA foreign_keys")
|
|
17
|
+
.get();
|
|
18
|
+
db.close();
|
|
19
|
+
expect(journal?.journal_mode?.toLowerCase()).toBe("wal");
|
|
20
|
+
expect(foreignKeys?.foreign_keys).toBe(1);
|
|
21
|
+
}
|
|
22
|
+
finally {
|
|
23
|
+
await rm(dir, { recursive: true, force: true });
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=databaseOpen.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpen.spec.js","sourceRoot":"","sources":["../../sources/storage/databaseOpen.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,0DAA0D,EAAE,KAAK,IAAI,EAAE;QACxE,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,kBAAkB,CAAC,CAAC,CAAC;QACtE,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;QAC5C,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;YAChC,MAAM,OAAO,GAAG,EAAE;iBACf,OAAO,CAAC,qBAAqB,CAAC;iBAC9B,GAAG,EAA2C,CAAC;YAClD,MAAM,WAAW,GAAG,EAAE;iBACnB,OAAO,CAAC,qBAAqB,CAAC;iBAC9B,GAAG,EAA2C,CAAC;YAClD,EAAE,CAAC,KAAK,EAAE,CAAC;YAEX,MAAM,CAAC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACzD,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5C,CAAC;gBAAS,CAAC;YACT,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QAClD,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { DatabaseSync as DatabaseSyncType } from "node:sqlite";
|
|
2
|
+
/**
|
|
3
|
+
* Opens a database and ensures schema migrations have been applied.
|
|
4
|
+
* Expects: dbPath is stable for the lifetime of a process.
|
|
5
|
+
*/
|
|
6
|
+
export declare function databaseOpenEnsured(dbPath: string): DatabaseSyncType;
|
|
7
|
+
//# sourceMappingURL=databaseOpenEnsured.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpenEnsured.d.ts","sourceRoot":"","sources":["../../sources/storage/databaseOpenEnsured.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,IAAI,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAOpE;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,MAAM,GAAG,gBAAgB,CAQpE"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { databaseOpen } from "./databaseOpen.js";
|
|
2
|
+
import { migrationRun } from "./migrations/migrationRun.js";
|
|
3
|
+
const migratedDbPaths = new Set();
|
|
4
|
+
/**
|
|
5
|
+
* Opens a database and ensures schema migrations have been applied.
|
|
6
|
+
* Expects: dbPath is stable for the lifetime of a process.
|
|
7
|
+
*/
|
|
8
|
+
export function databaseOpenEnsured(dbPath) {
|
|
9
|
+
const db = databaseOpen(dbPath);
|
|
10
|
+
if (migratedDbPaths.has(dbPath)) {
|
|
11
|
+
return db;
|
|
12
|
+
}
|
|
13
|
+
migrationRun(db);
|
|
14
|
+
migratedDbPaths.add(dbPath);
|
|
15
|
+
return db;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=databaseOpenEnsured.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseOpenEnsured.js","sourceRoot":"","sources":["../../sources/storage/databaseOpenEnsured.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAE5D,MAAM,eAAe,GAAG,IAAI,GAAG,EAAU,CAAC;AAE1C;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAc;IAChD,MAAM,EAAE,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IAChC,IAAI,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;QAChC,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,YAAY,CAAC,EAAE,CAAC,CAAC;IACjB,eAAe,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAC5B,OAAO,EAAE,CAAC;AACZ,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { AgentDescriptor, AgentLifecycleState, AgentTokenEntry, AgentTokenStats, SessionPermissions } from "@/types";
|
|
2
|
+
export type DatabaseAgentRow = {
|
|
3
|
+
id: string;
|
|
4
|
+
type: AgentDescriptor["type"];
|
|
5
|
+
descriptor: string;
|
|
6
|
+
active_session_id: string | null;
|
|
7
|
+
permissions: string;
|
|
8
|
+
tokens: string | null;
|
|
9
|
+
stats: string;
|
|
10
|
+
lifecycle: AgentLifecycleState;
|
|
11
|
+
created_at: number;
|
|
12
|
+
updated_at: number;
|
|
13
|
+
};
|
|
14
|
+
export type DatabaseSessionRow = {
|
|
15
|
+
id: string;
|
|
16
|
+
agent_id: string;
|
|
17
|
+
inference_session_id: string | null;
|
|
18
|
+
created_at: number;
|
|
19
|
+
reset_message: string | null;
|
|
20
|
+
};
|
|
21
|
+
export type DatabaseSessionHistoryRow = {
|
|
22
|
+
id: number;
|
|
23
|
+
session_id: string;
|
|
24
|
+
type: string;
|
|
25
|
+
at: number;
|
|
26
|
+
data: string;
|
|
27
|
+
};
|
|
28
|
+
export type AgentDbRecord = {
|
|
29
|
+
id: string;
|
|
30
|
+
type: AgentDescriptor["type"];
|
|
31
|
+
descriptor: AgentDescriptor;
|
|
32
|
+
activeSessionId: string | null;
|
|
33
|
+
permissions: SessionPermissions;
|
|
34
|
+
tokens: AgentTokenEntry | null;
|
|
35
|
+
stats: AgentTokenStats;
|
|
36
|
+
lifecycle: AgentLifecycleState;
|
|
37
|
+
createdAt: number;
|
|
38
|
+
updatedAt: number;
|
|
39
|
+
};
|
|
40
|
+
export type SessionDbRecord = {
|
|
41
|
+
id: string;
|
|
42
|
+
agentId: string;
|
|
43
|
+
inferenceSessionId: string | null;
|
|
44
|
+
createdAt: number;
|
|
45
|
+
resetMessage: string | null;
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=databaseTypes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseTypes.d.ts","sourceRoot":"","sources":["../../sources/storage/databaseTypes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,eAAe,EACf,mBAAmB,EACnB,eAAe,EACf,eAAe,EACf,kBAAkB,EACnB,MAAM,SAAS,CAAC;AAEjB,MAAM,MAAM,gBAAgB,GAAG;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,mBAAmB,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,oBAAoB,EAAE,MAAM,GAAG,IAAI,CAAC;IACpC,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,EAAE,EAAE,MAAM,CAAC;IACX,UAAU,EAAE,MAAM,CAAC;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,eAAe,CAAC,MAAM,CAAC,CAAC;IAC9B,UAAU,EAAE,eAAe,CAAC;IAC5B,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,WAAW,EAAE,kBAAkB,CAAC;IAChC,MAAM,EAAE,eAAe,GAAG,IAAI,CAAC;IAC/B,KAAK,EAAE,eAAe,CAAC;IACvB,SAAS,EAAE,mBAAmB,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"databaseTypes.js","sourceRoot":"","sources":["../../sources/storage/databaseTypes.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260219_import_files.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/20260219_import_files.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAWrD,eAAO,MAAM,4BAA4B,EAAE,SA6G1C,CAAC"}
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync } from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { createId } from "@paralleldrive/cuid2";
|
|
4
|
+
export const migration20260219ImportFiles = {
|
|
5
|
+
name: "20260219_import_files",
|
|
6
|
+
up(db) {
|
|
7
|
+
const existing = db
|
|
8
|
+
.prepare("SELECT COUNT(*) AS count FROM agents")
|
|
9
|
+
.get();
|
|
10
|
+
if ((existing?.count ?? 0) > 0) {
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
const dbPath = databasePathResolve(db);
|
|
14
|
+
if (!dbPath) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const dataDir = path.dirname(dbPath);
|
|
18
|
+
const agentsDir = path.join(dataDir, "agents");
|
|
19
|
+
if (!existsSync(agentsDir)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const entries = readdirSync(agentsDir, { withFileTypes: true });
|
|
23
|
+
for (const entry of entries) {
|
|
24
|
+
if (!entry.isDirectory()) {
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
const agentId = entry.name;
|
|
28
|
+
const basePath = path.join(agentsDir, agentId);
|
|
29
|
+
const descriptor = legacyDescriptorRead(basePath);
|
|
30
|
+
const state = legacyStateRead(basePath);
|
|
31
|
+
if (!descriptor || !state) {
|
|
32
|
+
continue;
|
|
33
|
+
}
|
|
34
|
+
db.prepare(`
|
|
35
|
+
INSERT INTO agents (
|
|
36
|
+
id,
|
|
37
|
+
type,
|
|
38
|
+
descriptor,
|
|
39
|
+
active_session_id,
|
|
40
|
+
permissions,
|
|
41
|
+
tokens,
|
|
42
|
+
stats,
|
|
43
|
+
lifecycle,
|
|
44
|
+
created_at,
|
|
45
|
+
updated_at
|
|
46
|
+
) VALUES (?, ?, ?, NULL, ?, ?, ?, ?, ?, ?)
|
|
47
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
48
|
+
type = excluded.type,
|
|
49
|
+
descriptor = excluded.descriptor,
|
|
50
|
+
permissions = excluded.permissions,
|
|
51
|
+
tokens = excluded.tokens,
|
|
52
|
+
stats = excluded.stats,
|
|
53
|
+
lifecycle = excluded.lifecycle,
|
|
54
|
+
updated_at = excluded.updated_at
|
|
55
|
+
`).run(agentId, descriptor.type, JSON.stringify(descriptor), JSON.stringify(state.permissions), state.tokens ? JSON.stringify(state.tokens) : null, JSON.stringify(state.stats), state.state, state.createdAt, state.updatedAt);
|
|
56
|
+
const historyRecords = legacyHistoryRead(path.join(basePath, "history.jsonl"));
|
|
57
|
+
const sessions = legacySessionsBuild(historyRecords, state);
|
|
58
|
+
for (const session of sessions) {
|
|
59
|
+
db.prepare(`
|
|
60
|
+
INSERT INTO sessions (
|
|
61
|
+
id,
|
|
62
|
+
agent_id,
|
|
63
|
+
inference_session_id,
|
|
64
|
+
created_at,
|
|
65
|
+
reset_message
|
|
66
|
+
) VALUES (?, ?, ?, ?, ?)
|
|
67
|
+
`).run(session.id, agentId, session.inferenceSessionId, session.createdAt, session.resetMessage);
|
|
68
|
+
for (const record of session.records) {
|
|
69
|
+
const { type, at, ...data } = record;
|
|
70
|
+
db.prepare(`
|
|
71
|
+
INSERT INTO session_history (session_id, type, at, data)
|
|
72
|
+
VALUES (?, ?, ?, ?)
|
|
73
|
+
`).run(session.id, type, at, JSON.stringify(data));
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
const activeSessionId = sessions[sessions.length - 1]?.id ?? null;
|
|
77
|
+
db.prepare("UPDATE agents SET active_session_id = ? WHERE id = ?").run(activeSessionId, agentId);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
function databasePathResolve(db) {
|
|
82
|
+
const rows = db.prepare("PRAGMA database_list").all();
|
|
83
|
+
const main = rows.find((row) => row.name === "main") ?? rows[0];
|
|
84
|
+
const file = main?.file?.trim() ?? "";
|
|
85
|
+
return file.length > 0 ? file : null;
|
|
86
|
+
}
|
|
87
|
+
function legacyDescriptorRead(basePath) {
|
|
88
|
+
const filePath = path.join(basePath, "descriptor.json");
|
|
89
|
+
try {
|
|
90
|
+
const raw = readFileSync(filePath, "utf8");
|
|
91
|
+
return JSON.parse(raw);
|
|
92
|
+
}
|
|
93
|
+
catch {
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
function legacyStateRead(basePath) {
|
|
98
|
+
const filePath = path.join(basePath, "state.json");
|
|
99
|
+
try {
|
|
100
|
+
const raw = readFileSync(filePath, "utf8");
|
|
101
|
+
const parsed = JSON.parse(raw);
|
|
102
|
+
return {
|
|
103
|
+
inferenceSessionId: typeof parsed.inferenceSessionId === "string" ? parsed.inferenceSessionId : undefined,
|
|
104
|
+
permissions: parsed.permissions ?? {
|
|
105
|
+
workingDir: "/",
|
|
106
|
+
writeDirs: [],
|
|
107
|
+
readDirs: [],
|
|
108
|
+
network: false,
|
|
109
|
+
events: false
|
|
110
|
+
},
|
|
111
|
+
tokens: parsed.tokens ?? null,
|
|
112
|
+
stats: parsed.stats ?? {},
|
|
113
|
+
createdAt: typeof parsed.createdAt === "number" && Number.isFinite(parsed.createdAt)
|
|
114
|
+
? parsed.createdAt
|
|
115
|
+
: Date.now(),
|
|
116
|
+
updatedAt: typeof parsed.updatedAt === "number" && Number.isFinite(parsed.updatedAt)
|
|
117
|
+
? parsed.updatedAt
|
|
118
|
+
: Date.now(),
|
|
119
|
+
state: parsed.state === "active" || parsed.state === "sleeping" || parsed.state === "dead"
|
|
120
|
+
? parsed.state
|
|
121
|
+
: parsed.sleeping
|
|
122
|
+
? "sleeping"
|
|
123
|
+
: "active"
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
catch {
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
function legacyHistoryRead(filePath) {
|
|
131
|
+
if (!existsSync(filePath)) {
|
|
132
|
+
return [];
|
|
133
|
+
}
|
|
134
|
+
const records = [];
|
|
135
|
+
const lines = readFileSync(filePath, "utf8").split("\n");
|
|
136
|
+
for (const line of lines) {
|
|
137
|
+
const trimmed = line.trim();
|
|
138
|
+
if (!trimmed) {
|
|
139
|
+
continue;
|
|
140
|
+
}
|
|
141
|
+
try {
|
|
142
|
+
const parsed = JSON.parse(trimmed);
|
|
143
|
+
records.push(parsed);
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
continue;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
return records;
|
|
150
|
+
}
|
|
151
|
+
function legacySessionsBuild(records, state) {
|
|
152
|
+
if (records.length === 0) {
|
|
153
|
+
return [
|
|
154
|
+
{
|
|
155
|
+
id: createId(),
|
|
156
|
+
inferenceSessionId: state.inferenceSessionId ?? null,
|
|
157
|
+
createdAt: state.createdAt,
|
|
158
|
+
resetMessage: null,
|
|
159
|
+
records: []
|
|
160
|
+
}
|
|
161
|
+
];
|
|
162
|
+
}
|
|
163
|
+
const sessions = [];
|
|
164
|
+
let current = null;
|
|
165
|
+
const sessionEnsure = (createdAt, resetMessage) => {
|
|
166
|
+
const session = {
|
|
167
|
+
id: createId(),
|
|
168
|
+
inferenceSessionId: null,
|
|
169
|
+
createdAt,
|
|
170
|
+
resetMessage,
|
|
171
|
+
records: []
|
|
172
|
+
};
|
|
173
|
+
sessions.push(session);
|
|
174
|
+
current = session;
|
|
175
|
+
return session;
|
|
176
|
+
};
|
|
177
|
+
for (const record of records) {
|
|
178
|
+
if (record.type === "start") {
|
|
179
|
+
sessionEnsure(record.at, null);
|
|
180
|
+
continue;
|
|
181
|
+
}
|
|
182
|
+
if (record.type === "reset") {
|
|
183
|
+
sessionEnsure(record.at, record.message ?? null);
|
|
184
|
+
continue;
|
|
185
|
+
}
|
|
186
|
+
const target = current ?? sessionEnsure(record.at, null);
|
|
187
|
+
target.records.push(record);
|
|
188
|
+
}
|
|
189
|
+
const last = sessions[sessions.length - 1];
|
|
190
|
+
if (last) {
|
|
191
|
+
last.inferenceSessionId = state.inferenceSessionId ?? null;
|
|
192
|
+
}
|
|
193
|
+
return sessions.length > 0
|
|
194
|
+
? sessions
|
|
195
|
+
: [
|
|
196
|
+
{
|
|
197
|
+
id: createId(),
|
|
198
|
+
inferenceSessionId: state.inferenceSessionId ?? null,
|
|
199
|
+
createdAt: state.createdAt,
|
|
200
|
+
resetMessage: null,
|
|
201
|
+
records: []
|
|
202
|
+
}
|
|
203
|
+
];
|
|
204
|
+
}
|
|
205
|
+
//# sourceMappingURL=20260219_import_files.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260219_import_files.js","sourceRoot":"","sources":["../../../sources/storage/migrations/20260219_import_files.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260219_initial.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/20260219_initial.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAErD,eAAO,MAAM,wBAAwB,EAAE,SAwCtC,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
export const migration20260219Initial = {
|
|
2
|
+
name: "20260219_initial",
|
|
3
|
+
up(db) {
|
|
4
|
+
db.exec(`
|
|
5
|
+
CREATE TABLE IF NOT EXISTS agents (
|
|
6
|
+
id TEXT PRIMARY KEY,
|
|
7
|
+
type TEXT NOT NULL,
|
|
8
|
+
descriptor TEXT NOT NULL,
|
|
9
|
+
active_session_id TEXT,
|
|
10
|
+
permissions TEXT NOT NULL,
|
|
11
|
+
tokens TEXT,
|
|
12
|
+
stats TEXT NOT NULL DEFAULT '{}',
|
|
13
|
+
lifecycle TEXT NOT NULL DEFAULT 'active',
|
|
14
|
+
created_at INTEGER NOT NULL,
|
|
15
|
+
updated_at INTEGER NOT NULL
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
CREATE TABLE IF NOT EXISTS sessions (
|
|
19
|
+
id TEXT PRIMARY KEY,
|
|
20
|
+
agent_id TEXT NOT NULL,
|
|
21
|
+
inference_session_id TEXT,
|
|
22
|
+
created_at INTEGER NOT NULL,
|
|
23
|
+
reset_message TEXT,
|
|
24
|
+
FOREIGN KEY (agent_id) REFERENCES agents(id) ON DELETE CASCADE
|
|
25
|
+
);
|
|
26
|
+
|
|
27
|
+
CREATE INDEX IF NOT EXISTS idx_sessions_agent_id ON sessions(agent_id);
|
|
28
|
+
|
|
29
|
+
CREATE TABLE IF NOT EXISTS session_history (
|
|
30
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
31
|
+
session_id TEXT NOT NULL,
|
|
32
|
+
type TEXT NOT NULL,
|
|
33
|
+
at INTEGER NOT NULL,
|
|
34
|
+
data TEXT NOT NULL,
|
|
35
|
+
FOREIGN KEY (session_id) REFERENCES sessions(id) ON DELETE CASCADE
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
CREATE INDEX IF NOT EXISTS idx_session_history_session ON session_history(session_id);
|
|
39
|
+
`);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=20260219_initial.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"20260219_initial.js","sourceRoot":"","sources":["../../../sources/storage/migrations/20260219_initial.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,wBAAwB,GAAc;IACjD,IAAI,EAAE,kBAAkB;IACxB,EAAE,CAAC,EAAE;QACH,EAAE,CAAC,IAAI,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmCP,CAAC,CAAC;IACL,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_migrations.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/_migrations.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAIrD,eAAO,MAAM,UAAU,EAAE,SAAS,EAGjC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { migration20260219ImportFiles } from "./20260219_import_files.js";
|
|
2
|
+
import { migration20260219Initial } from "./20260219_initial.js";
|
|
3
|
+
export const migrations = [
|
|
4
|
+
migration20260219Initial,
|
|
5
|
+
migration20260219ImportFiles
|
|
6
|
+
];
|
|
7
|
+
//# sourceMappingURL=_migrations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_migrations.js","sourceRoot":"","sources":["../../../sources/storage/migrations/_migrations.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,4BAA4B,EAAE,MAAM,4BAA4B,CAAC;AAC1E,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEjE,MAAM,CAAC,MAAM,UAAU,GAAgB;IACrC,wBAAwB;IACxB,4BAA4B;CAC7B,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { DatabaseSync } from "node:sqlite";
|
|
2
|
+
import type { Migration } from "./migrationTypes.js";
|
|
3
|
+
/**
|
|
4
|
+
* Returns migrations that are not yet recorded in the _migrations table.
|
|
5
|
+
* Expects: migration names are unique.
|
|
6
|
+
*/
|
|
7
|
+
export declare function migrationPending(db: DatabaseSync, migrations: Migration[]): Migration[];
|
|
8
|
+
//# sourceMappingURL=migrationPending.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationPending.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationPending.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAErD;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,SAAS,EAAE,CAevF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Returns migrations that are not yet recorded in the _migrations table.
|
|
3
|
+
* Expects: migration names are unique.
|
|
4
|
+
*/
|
|
5
|
+
export function migrationPending(db, migrations) {
|
|
6
|
+
const table = db
|
|
7
|
+
.prepare("SELECT name FROM sqlite_master WHERE type = 'table' AND name = '_migrations' LIMIT 1")
|
|
8
|
+
.get();
|
|
9
|
+
if (!table?.name) {
|
|
10
|
+
return [...migrations];
|
|
11
|
+
}
|
|
12
|
+
const appliedRows = db
|
|
13
|
+
.prepare("SELECT name FROM _migrations")
|
|
14
|
+
.all();
|
|
15
|
+
const applied = new Set(appliedRows.map((row) => row.name));
|
|
16
|
+
return migrations.filter((migration) => !applied.has(migration.name));
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=migrationPending.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationPending.js","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationPending.ts"],"names":[],"mappings":"AAGA;;;GAGG;AACH,MAAM,UAAU,gBAAgB,CAAC,EAAgB,EAAE,UAAuB;IACxE,MAAM,KAAK,GAAG,EAAE;SACb,OAAO,CACN,sFAAsF,CACvF;SACA,GAAG,EAAmC,CAAC;IAC1C,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC;QACjB,OAAO,CAAC,GAAG,UAAU,CAAC,CAAC;IACzB,CAAC;IAED,MAAM,WAAW,GAAG,EAAE;SACnB,OAAO,CAAC,8BAA8B,CAAC;SACvC,GAAG,EAA6B,CAAC;IACpC,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;IAC5D,OAAO,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;AACxE,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationPending.spec.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationPending.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { mkdtemp, rm } from "node:fs/promises";
|
|
2
|
+
import os from "node:os";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import { describe, expect, it } from "vitest";
|
|
5
|
+
import { databaseOpen } from "../databaseOpen.js";
|
|
6
|
+
import { migrations } from "./_migrations.js";
|
|
7
|
+
import { migrationPending } from "./migrationPending.js";
|
|
8
|
+
describe("migrationPending", () => {
|
|
9
|
+
it("returns all migrations when _migrations is missing", async () => {
|
|
10
|
+
const dir = await mkdtemp(path.join(os.tmpdir(), "daycare-migration-pending-"));
|
|
11
|
+
const dbPath = path.join(dir, "daycare.db");
|
|
12
|
+
try {
|
|
13
|
+
const db = databaseOpen(dbPath);
|
|
14
|
+
const pending = migrationPending(db, migrations);
|
|
15
|
+
db.close();
|
|
16
|
+
expect(pending.map((entry) => entry.name)).toEqual(migrations.map((entry) => entry.name));
|
|
17
|
+
}
|
|
18
|
+
finally {
|
|
19
|
+
await rm(dir, { recursive: true, force: true });
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
it("filters already-applied migrations", async () => {
|
|
23
|
+
const dir = await mkdtemp(path.join(os.tmpdir(), "daycare-migration-pending-"));
|
|
24
|
+
const dbPath = path.join(dir, "daycare.db");
|
|
25
|
+
try {
|
|
26
|
+
const db = databaseOpen(dbPath);
|
|
27
|
+
db.exec("CREATE TABLE IF NOT EXISTS _migrations (name TEXT PRIMARY KEY, applied_at INTEGER NOT NULL)");
|
|
28
|
+
const firstMigration = migrations[0];
|
|
29
|
+
if (!firstMigration) {
|
|
30
|
+
throw new Error("Missing base migration");
|
|
31
|
+
}
|
|
32
|
+
db.prepare("INSERT INTO _migrations (name, applied_at) VALUES (?, ?)").run(firstMigration.name, Date.now());
|
|
33
|
+
const pending = migrationPending(db, migrations);
|
|
34
|
+
db.close();
|
|
35
|
+
expect(pending.map((entry) => entry.name)).toEqual(migrations.slice(1).map((entry) => entry.name));
|
|
36
|
+
}
|
|
37
|
+
finally {
|
|
38
|
+
await rm(dir, { recursive: true, force: true });
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
});
|
|
42
|
+
//# sourceMappingURL=migrationPending.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationPending.spec.js","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationPending.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { DatabaseSync } from "node:sqlite";
|
|
2
|
+
/**
|
|
3
|
+
* Applies pending migrations in order and records each successful migration.
|
|
4
|
+
* Expects: migration definitions are deterministic and side-effect free outside SQL.
|
|
5
|
+
*/
|
|
6
|
+
export declare function migrationRun(db: DatabaseSync): string[];
|
|
7
|
+
//# sourceMappingURL=migrationRun.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationRun.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationRun.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAIhD;;;GAGG;AACH,wBAAgB,YAAY,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,EAAE,CA4BvD"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { migrations } from "./_migrations.js";
|
|
2
|
+
import { migrationPending } from "./migrationPending.js";
|
|
3
|
+
/**
|
|
4
|
+
* Applies pending migrations in order and records each successful migration.
|
|
5
|
+
* Expects: migration definitions are deterministic and side-effect free outside SQL.
|
|
6
|
+
*/
|
|
7
|
+
export function migrationRun(db) {
|
|
8
|
+
db.exec(`
|
|
9
|
+
CREATE TABLE IF NOT EXISTS _migrations (
|
|
10
|
+
name TEXT PRIMARY KEY,
|
|
11
|
+
applied_at INTEGER NOT NULL
|
|
12
|
+
);
|
|
13
|
+
`);
|
|
14
|
+
const pending = migrationPending(db, migrations);
|
|
15
|
+
const applied = [];
|
|
16
|
+
for (const migration of pending) {
|
|
17
|
+
db.exec("BEGIN");
|
|
18
|
+
try {
|
|
19
|
+
migration.up(db);
|
|
20
|
+
db.prepare("INSERT INTO _migrations (name, applied_at) VALUES (?, ?)").run(migration.name, Date.now());
|
|
21
|
+
db.exec("COMMIT");
|
|
22
|
+
applied.push(migration.name);
|
|
23
|
+
}
|
|
24
|
+
catch (error) {
|
|
25
|
+
db.exec("ROLLBACK");
|
|
26
|
+
throw error;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
return applied;
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=migrationRun.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationRun.js","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationRun.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAEzD;;;GAGG;AACH,MAAM,UAAU,YAAY,CAAC,EAAgB;IAC3C,EAAE,CAAC,IAAI,CAAC;;;;;GAKP,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,gBAAgB,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IACjD,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,KAAK,MAAM,SAAS,IAAI,OAAO,EAAE,CAAC;QAChC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACjB,IAAI,CAAC;YACH,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YACjB,EAAE,CAAC,OAAO,CAAC,0DAA0D,CAAC,CAAC,GAAG,CACxE,SAAS,CAAC,IAAI,EACd,IAAI,CAAC,GAAG,EAAE,CACX,CAAC;YACF,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAClB,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpB,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrationRun.spec.d.ts","sourceRoot":"","sources":["../../../sources/storage/migrations/migrationRun.spec.ts"],"names":[],"mappings":""}
|