binary-collections 2.0.13 → 2.0.14
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/binaries/binary-executor.cjs +307 -238
- package/binaries/clean-nodemodule.cjs +307 -238
- package/binaries/clean-nodemodules.cjs +307 -238
- package/binaries/composer.cjs +323 -0
- package/binaries/composer.cmd +2 -0
- package/binaries/composer.phar +0 -0
- package/binaries/dev.cjs +307 -238
- package/binaries/empty.cjs +307 -238
- package/binaries/git-reduce-size.cjs +307 -238
- package/binaries/javakill.cjs +307 -238
- package/binaries/kill-process.cjs +307 -238
- package/binaries/nodekill.cjs +307 -238
- package/binaries/prod.cjs +307 -238
- package/binaries/py.cjs +307 -238
- package/binaries/rmfind.cjs +307 -238
- package/binaries/rmx.cjs +307 -238
- package/binaries/submodule-token.cjs +307 -238
- package/binaries/test-cjs.cjs +307 -238
- package/binaries/test-esm.cjs +307 -238
- package/binaries/yarn-clean.cjs +307 -238
- package/binaries/yc.cjs +307 -238
- package/binaries/ycw.cjs +307 -238
- package/docs-src/binary-collections.md +1 -1
- package/docs-src/clean-github-actions-caches.md +1 -1
- package/docs-src/copy-move-file.md +1 -4
- package/docs-src/del-ps.md +1 -1
- package/docs-src/find-node-modules.md +1 -1
- package/docs-src/generate-test-ci.md +56 -0
- package/docs-src/get-latest-workflow-status.md +100 -0
- package/docs-src/git-diff.md +1 -1
- package/docs-src/git-fix.md +1 -1
- package/docs-src/git-purge.md +1 -1
- package/docs-src/kill-night-crows.md +1 -1
- package/docs-src/node-cache-cleaner.md +2 -2
- package/docs-src/node-package-packer.md +1 -1
- package/docs-src/opencode-cli.md +127 -0
- package/docs-src/package-resolutions-updater.md +1 -1
- package/docs-src/rmpath.md +1 -1
- package/docs-src/run-by-checksum.md +1 -1
- package/docs-src/submodule-remove.md +1 -1
- package/docs-src/upload-backend.md +29 -0
- package/docs-src/vscode-cli.md +84 -0
- package/docs-src/workflow-badge.md +120 -0
- package/lib/binary-collections/config.cjs +14 -2
- package/lib/binary-collections/config.d.cts +10 -0
- package/lib/binary-collections/config.mjs +2 -2
- package/lib/binary-collections/findScript.cjs +43 -21
- package/lib/binary-collections/findScript.mjs +2 -2
- package/lib/binary-collections/listScript.cjs +43 -21
- package/lib/binary-collections/listScript.mjs +2 -2
- package/lib/binary-collections.cjs +43 -21
- package/lib/binary-collections.mjs +6 -6
- package/lib/chunk-2SJKVOTN.mjs +146 -0
- package/lib/{chunk-2MN4VPV2.mjs → chunk-3F6EIHYG.mjs} +2 -2
- package/lib/chunk-546KAIYT.mjs +113 -0
- package/lib/chunk-56BVU63B.mjs +86 -0
- package/lib/chunk-5WAOOOGZ.mjs +77 -0
- package/lib/chunk-72XTQ3CK.mjs +45 -0
- package/lib/chunk-7N52Z4IJ.mjs +39 -0
- package/lib/chunk-7Q6YEUQF.mjs +246 -0
- package/lib/{chunk-NQXUYO67.mjs → chunk-AJ3OIYYP.mjs} +43 -21
- package/lib/chunk-AQZ7LMFS.mjs +100 -0
- package/lib/chunk-BDCMTOZI.mjs +246 -0
- package/lib/chunk-BEUM4LH4.mjs +184 -0
- package/lib/{chunk-TBWXE7ST.mjs → chunk-BO4TZS4Q.mjs} +5 -2
- package/lib/chunk-CM3IC5YC.mjs +226 -0
- package/lib/{chunk-FLYSZFLW.mjs → chunk-D42YBRZW.mjs} +1 -1
- package/lib/chunk-FR3DMHJC.mjs +146 -0
- package/lib/chunk-I3O5ZRYU.mjs +77 -0
- package/lib/chunk-J4M5EL5P.mjs +108 -0
- package/lib/chunk-JK3MG2KF.mjs +236 -0
- package/lib/chunk-JMUFQSPE.mjs +184 -0
- package/lib/chunk-JVMLKHD2.mjs +62 -0
- package/lib/chunk-KAT2JNLZ.mjs +146 -0
- package/lib/{chunk-CD3HF3LK.mjs → chunk-KRCPFWIF.mjs} +6 -3
- package/lib/chunk-LACQTD5V.mjs +225 -0
- package/lib/chunk-MCCMMZSM.mjs +60 -0
- package/lib/chunk-OA2RKEY3.mjs +162 -0
- package/lib/{chunk-X2B3X7D4.mjs → chunk-PAZH45HS.mjs} +7 -1
- package/lib/chunk-QZMGBDSA.mjs +32 -0
- package/lib/chunk-RKPIBGKE.mjs +61 -0
- package/lib/chunk-SARIXFHP.mjs +44 -0
- package/lib/chunk-SJYP66BO.mjs +62 -0
- package/lib/chunk-SWUAEY4H.mjs +44 -0
- package/lib/chunk-TP3O2JGW.mjs +88 -0
- package/lib/chunk-UAIF5VIA.mjs +89 -0
- package/lib/chunk-UDZBVKXH.mjs +94 -0
- package/lib/chunk-UEOWRYAN.mjs +32 -0
- package/lib/chunk-UHPFLJXH.mjs +227 -0
- package/lib/chunk-UYNBNLV5.mjs +113 -0
- package/lib/chunk-WOC4FZ6F.mjs +164 -0
- package/lib/chunk-X7UVQ6ZC.mjs +183 -0
- package/lib/{chunk-RDN6HF5Z.mjs → chunk-XI67TI46.mjs} +1 -1
- package/lib/chunk-XW5NZAKI.mjs +82 -0
- package/lib/chunk-YLV4QATP.mjs +86 -0
- package/lib/chunk-YWSLMAQ7.mjs +65 -0
- package/lib/chunk-ZB4IQ6VJ.mjs +46 -0
- package/lib/cross-env/index.mjs +3 -3
- package/lib/del-gradle.cjs +1 -1
- package/lib/del-gradle.mjs +22 -16
- package/lib/del-node-modules.cjs +1 -1
- package/lib/del-node-modules.mjs +148 -142
- package/lib/find-node-modules-cli.cjs +1 -1
- package/lib/find-node-modules-cli.mjs +10 -4
- package/lib/{git-diff-cli.cjs → git/git-diff-cli.cjs} +18 -6
- package/lib/{git-diff-cli.mjs → git/git-diff-cli.mjs} +7 -7
- package/lib/{git-diff.cjs → git/git-diff.cjs} +16 -4
- package/lib/{git-diff.js → git/git-diff.js} +3 -3
- package/lib/{git-diff.mjs → git/git-diff.mjs} +6 -6
- package/lib/{git-fix.cjs → git/git-fix.cjs} +134 -3
- package/lib/{git-fix.mjs → git/git-fix.mjs} +19 -14
- package/lib/{git-purge.cjs → git/git-purge.cjs} +1 -1
- package/lib/{git-purge.mjs → git/git-purge.mjs} +4 -4
- package/lib/git/user-config.cjs +131 -1
- package/lib/git/user-config.mjs +3 -1
- package/lib/{clean-github-actions-caches-cli.cjs → github-workflows/clean-github-actions-caches-cli.cjs} +38 -10
- package/lib/{clean-github-actions-caches-cli.mjs → github-workflows/clean-github-actions-caches-cli.mjs} +7 -6
- package/lib/{clean-github-actions-caches.cjs → github-workflows/clean-github-actions-caches.cjs} +38 -10
- package/lib/{clean-github-actions-caches.mjs → github-workflows/clean-github-actions-caches.mjs} +5 -4
- package/lib/github-workflows/generate-test-ci-step-cli.cjs +240 -0
- package/lib/github-workflows/generate-test-ci-step-cli.d.mts +2 -0
- package/lib/github-workflows/generate-test-ci-step-cli.mjs +132 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.cjs +541 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.d.mts +2 -0
- package/lib/github-workflows/get-latest-workflow-status-cli.mjs +61 -0
- package/lib/github-workflows/get-latest-workflow-status.cjs +56 -0
- package/lib/github-workflows/get-latest-workflow-status.d.mts +1 -0
- package/lib/github-workflows/get-latest-workflow-status.mjs +8 -0
- package/lib/github-workflows/utils.cjs +271 -0
- package/lib/github-workflows/utils.d.cts +76 -0
- package/lib/github-workflows/utils.mjs +8 -0
- package/lib/github-workflows/workflow-badge-cli.cjs +722 -0
- package/lib/github-workflows/workflow-badge-cli.d.mts +2 -0
- package/lib/github-workflows/workflow-badge-cli.mjs +98 -0
- package/lib/github-workflows/workflow-badge-generator.cjs +200 -0
- package/lib/github-workflows/workflow-badge-generator.d.mts +14 -0
- package/lib/github-workflows/workflow-badge-generator.mjs +8 -0
- package/lib/github-workflows/workflow-test-data.cjs +73 -0
- package/lib/github-workflows/workflow-test-data.d.cts +63 -0
- package/lib/github-workflows/workflow-test-data.mjs +6 -0
- package/lib/opencode/cli/auth-rotate.cjs +143 -0
- package/lib/opencode/cli/auth-rotate.d.ts +1 -0
- package/lib/opencode/cli/auth-rotate.js +70 -0
- package/lib/opencode/cli/auth-rotate.mjs +10 -0
- package/lib/opencode/cli/list-projects.cjs +184 -0
- package/lib/opencode/cli/list-projects.d.ts +1 -0
- package/lib/opencode/cli/list-projects.js +32 -0
- package/lib/opencode/cli/list-projects.mjs +11 -0
- package/lib/opencode/cli/list-sessions.cjs +215 -0
- package/lib/opencode/cli/list-sessions.d.ts +1 -0
- package/lib/opencode/cli/list-sessions.js +45 -0
- package/lib/opencode/cli/list-sessions.mjs +11 -0
- package/lib/opencode/database.cjs +349 -0
- package/lib/opencode/database.d.ts +91 -0
- package/lib/opencode/database.js +252 -0
- package/lib/opencode/database.mjs +28 -0
- package/lib/opencode/database.runner.cjs +145 -0
- package/lib/opencode/database.runner.d.ts +1 -0
- package/lib/opencode/database.runner.js +56 -0
- package/lib/opencode/database.runner.mjs +37 -0
- package/lib/opencode/opencode-zen.runner.cjs +48 -0
- package/lib/opencode/opencode-zen.runner.d.mts +1 -0
- package/lib/opencode/opencode-zen.runner.mjs +31 -0
- package/lib/opencode/sqlite.cjs +114 -0
- package/lib/opencode/sqlite.d.ts +18 -0
- package/lib/opencode/sqlite.js +82 -0
- package/lib/opencode/sqlite.mjs +10 -0
- package/lib/opencode/storage.cjs +124 -0
- package/lib/opencode/storage.d.ts +27 -0
- package/lib/opencode/storage.js +101 -0
- package/lib/opencode/storage.mjs +38 -0
- package/lib/opencode/storage.runner.cjs +50 -0
- package/lib/opencode/storage.runner.d.ts +1 -0
- package/lib/opencode/storage.runner.js +13 -0
- package/lib/opencode/storage.runner.mjs +29 -0
- package/lib/opencode/types.cjs +17 -0
- package/lib/opencode/types.d.ts +31 -0
- package/lib/opencode/types.js +2 -0
- package/lib/opencode/types.mjs +7 -0
- package/lib/opencode/utils/check-api.cjs +59 -0
- package/lib/opencode/utils/check-api.d.ts +12 -0
- package/lib/opencode/utils/check-api.js +46 -0
- package/lib/opencode/utils/check-api.mjs +8 -0
- package/lib/opencode-cli.cjs +473 -0
- package/lib/opencode-cli.d.ts +2 -0
- package/lib/opencode-cli.js +115 -0
- package/lib/opencode-cli.mjs +111 -0
- package/lib/package-resolutions-updater-cli.cjs +181 -154
- package/lib/package-resolutions-updater-cli.mjs +3 -2
- package/lib/package-resolutions-updater.cjs +181 -154
- package/lib/package-resolutions-updater.d.mts +12 -3
- package/lib/package-resolutions-updater.mjs +3 -2
- package/lib/print-directory-tree.cjs +131 -3
- package/lib/print-directory-tree.mjs +6 -3
- package/lib/rmpath-cli.cjs +131 -5
- package/lib/rmpath-cli.mjs +3 -1
- package/lib/rmpath.cjs +147 -11
- package/lib/rmpath.mjs +3 -1
- package/lib/run-by-checksum/hash.cjs +18 -2
- package/lib/run-by-checksum/hash.d.ts +4 -1
- package/lib/run-by-checksum/hash.js +38 -4
- package/lib/run-by-checksum/hash.mjs +1 -1
- package/lib/run-by-checksum/run.cjs +18 -2
- package/lib/run-by-checksum/run.mjs +2 -2
- package/lib/run-by-checksum-cli.cjs +18 -2
- package/lib/run-by-checksum-cli.mjs +2 -2
- package/lib/submodule-install.cjs +130 -4
- package/lib/submodule-install.mjs +5 -4
- package/lib/submodule-remove-cli.cjs +131 -5
- package/lib/submodule-remove-cli.mjs +3 -1
- package/lib/submodule-remove.cjs +146 -5
- package/lib/submodule-remove.mjs +3 -1
- package/lib/utils/findEnvFiles.cjs +3 -0
- package/lib/utils/findEnvFiles.d.cts +2 -2
- package/lib/utils/findEnvFiles.mjs +1 -1
- package/lib/vscode/project.cjs +0 -0
- package/lib/vscode/project.d.ts +0 -0
- package/lib/vscode/project.js +1 -0
- package/lib/vscode/project.mjs +7 -0
- package/lib/vscode/storage.cjs +138 -0
- package/lib/vscode/storage.d.ts +51 -0
- package/lib/vscode/storage.js +169 -0
- package/lib/vscode/storage.mjs +42 -0
- package/lib/vscode/storage.runner.cjs +125 -0
- package/lib/vscode/storage.runner.d.ts +1 -0
- package/lib/vscode/storage.runner.js +47 -0
- package/lib/vscode/storage.runner.mjs +60 -0
- package/lib/vscode-cli.cjs +155 -0
- package/lib/vscode-cli.d.ts +2 -0
- package/lib/vscode-cli.js +80 -0
- package/lib/vscode-cli.mjs +71 -0
- package/package.json +43 -21
- package/readme.md +41 -8
- package/releases/readme.md +1 -1
- package/src/github-workflows/generate-test-ci-step-cli.mjs +126 -0
- package/vendor/clue/ndjson-react/README.md +365 -0
- package/vendor/composer/pcre/README.md +189 -0
- package/vendor/composer/semver/README.md +99 -0
- package/vendor/composer/xdebug-handler/README.md +305 -0
- package/vendor/ergebnis/agent-detector/README.md +107 -0
- package/vendor/evenement/evenement/README.md +64 -0
- package/vendor/fidry/cpu-core-counter/README.md +138 -0
- package/vendor/friendsofphp/php-cs-fixer/README.md +97 -0
- package/vendor/psr/container/README.md +13 -0
- package/vendor/psr/event-dispatcher/README.md +6 -0
- package/vendor/psr/log/README.md +58 -0
- package/vendor/react/cache/README.md +367 -0
- package/vendor/react/child-process/README.md +619 -0
- package/vendor/react/dns/README.md +453 -0
- package/vendor/react/event-loop/README.md +930 -0
- package/vendor/react/promise/README.md +722 -0
- package/vendor/react/socket/README.md +1564 -0
- package/vendor/react/stream/README.md +1249 -0
- package/vendor/sebastian/diff/README.md +151 -0
- package/vendor/symfony/console/README.md +30 -0
- package/vendor/symfony/deprecation-contracts/README.md +26 -0
- package/vendor/symfony/event-dispatcher/README.md +25 -0
- package/vendor/symfony/event-dispatcher-contracts/README.md +9 -0
- package/vendor/symfony/filesystem/README.md +23 -0
- package/vendor/symfony/finder/README.md +24 -0
- package/vendor/symfony/options-resolver/README.md +25 -0
- package/vendor/symfony/polyfill-ctype/README.md +12 -0
- package/vendor/symfony/polyfill-intl-grapheme/README.md +32 -0
- package/vendor/symfony/polyfill-intl-normalizer/README.md +14 -0
- package/vendor/symfony/polyfill-mbstring/README.md +13 -0
- package/vendor/symfony/polyfill-php80/README.md +25 -0
- package/vendor/symfony/polyfill-php81/README.md +18 -0
- package/vendor/symfony/polyfill-php84/README.md +23 -0
- package/vendor/symfony/polyfill-php85/README.md +20 -0
- package/vendor/symfony/process/README.md +23 -0
- package/vendor/symfony/service-contracts/README.md +9 -0
- package/vendor/symfony/stopwatch/README.md +52 -0
- package/vendor/symfony/string/README.md +24 -0
- package/lib/del-gradle.js +0 -16
- package/lib/del-node-modules.js +0 -211
- package/lib/find-node-modules-cli.js +0 -4
- /package/lib/{clean-github-actions-caches-cli.d.cts → del-gradle.d.cts} +0 -0
- /package/lib/{del-gradle.d.ts → del-node-modules.d.cts} +0 -0
- /package/lib/{find-node-modules-cli.d.ts → find-node-modules-cli.d.cts} +0 -0
- /package/lib/{git-diff-cli.d.ts → git/git-diff-cli.d.ts} +0 -0
- /package/lib/{git-diff-cli.js → git/git-diff-cli.js} +0 -0
- /package/lib/{git-diff.d.ts → git/git-diff.d.ts} +0 -0
- /package/lib/{git-fix.d.cts → git/git-fix.d.cts} +0 -0
- /package/lib/{git-purge.d.cts → git/git-purge.d.cts} +0 -0
- /package/lib/{del-node-modules.d.ts → github-workflows/clean-github-actions-caches-cli.d.cts} +0 -0
- /package/lib/{clean-github-actions-caches.d.cts → github-workflows/clean-github-actions-caches.d.cts} +0 -0
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
+
mod
|
|
26
|
+
));
|
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
+
|
|
29
|
+
// src/opencode/database.ts
|
|
30
|
+
var database_exports = {};
|
|
31
|
+
__export(database_exports, {
|
|
32
|
+
checkDatabase: () => checkDatabase,
|
|
33
|
+
deleteAllProjectSessions: () => deleteAllProjectSessions,
|
|
34
|
+
deleteAllSessions: () => deleteAllSessions,
|
|
35
|
+
deleteSession: () => deleteSession,
|
|
36
|
+
deleteSessionById: () => deleteSessionById,
|
|
37
|
+
loadMessages: () => loadMessages,
|
|
38
|
+
loadParts: () => loadParts,
|
|
39
|
+
loadProjects: () => loadProjects,
|
|
40
|
+
loadSessions: () => loadSessions,
|
|
41
|
+
loadTranscript: () => loadTranscript
|
|
42
|
+
});
|
|
43
|
+
module.exports = __toCommonJS(database_exports);
|
|
44
|
+
|
|
45
|
+
// src/opencode/storage.ts
|
|
46
|
+
var import_upath = __toESM(require("upath"), 1);
|
|
47
|
+
var import_os = __toESM(require("os"), 1);
|
|
48
|
+
var import_fs_extra = __toESM(require("fs-extra"), 1);
|
|
49
|
+
var import_jsonc_parser = require("jsonc-parser");
|
|
50
|
+
var OPCODE_DIR = import_upath.default.join(import_os.default.homedir(), ".local/share/opencode");
|
|
51
|
+
var CONFIG_DIR = import_upath.default.join(import_os.default.homedir(), ".config/opencode");
|
|
52
|
+
var CACHE_DIR = import_upath.default.join(import_os.default.homedir(), ".cache/opencode");
|
|
53
|
+
var LOG_DIR = import_upath.default.join(OPCODE_DIR, "log");
|
|
54
|
+
var AUTH_PATH = import_upath.default.join(OPCODE_DIR, "auth.json");
|
|
55
|
+
var PROJECT_DIR = import_upath.default.join(OPCODE_DIR, "project");
|
|
56
|
+
var STORAGE_PATH = import_upath.default.join(OPCODE_DIR, "storage");
|
|
57
|
+
var SESSION_PATH = import_upath.default.join(STORAGE_PATH, "session");
|
|
58
|
+
var SESSION_DIFF_DIR = import_upath.default.join(STORAGE_PATH, "session_diff");
|
|
59
|
+
var DATABASE_PATH = import_upath.default.join(OPCODE_DIR, "opencode.db");
|
|
60
|
+
|
|
61
|
+
// src/opencode/sqlite.ts
|
|
62
|
+
var import_better_sqlite3 = __toESM(require("better-sqlite3"), 1);
|
|
63
|
+
var import_fs_extra2 = __toESM(require("fs-extra"), 1);
|
|
64
|
+
var import_upath2 = __toESM(require("upath"), 1);
|
|
65
|
+
var DEFAULT_DB_PATH = import_upath2.default.join(process.cwd(), "data", "database", "db.sqlite");
|
|
66
|
+
var SQLite = class {
|
|
67
|
+
constructor(dbPath = DEFAULT_DB_PATH) {
|
|
68
|
+
const dir = import_upath2.default.dirname(dbPath);
|
|
69
|
+
if (!import_fs_extra2.default.existsSync(dir)) {
|
|
70
|
+
import_fs_extra2.default.mkdirSync(dir, { recursive: true });
|
|
71
|
+
}
|
|
72
|
+
this.db = new import_better_sqlite3.default(dbPath);
|
|
73
|
+
this.db.pragma("journal_mode = WAL");
|
|
74
|
+
this.db.pragma("synchronous = NORMAL");
|
|
75
|
+
this.db.pragma("temp_store = MEMORY");
|
|
76
|
+
this.db.pragma("foreign_keys = ON");
|
|
77
|
+
}
|
|
78
|
+
// -------------------------
|
|
79
|
+
// Migration / schema init
|
|
80
|
+
// -------------------------
|
|
81
|
+
migrate(schemaFilePath) {
|
|
82
|
+
const schema = import_fs_extra2.default.readFileSync(schemaFilePath, "utf-8");
|
|
83
|
+
this.db.exec(schema);
|
|
84
|
+
}
|
|
85
|
+
// -------------------------
|
|
86
|
+
// Core query helpers
|
|
87
|
+
// -------------------------
|
|
88
|
+
prepare(sql) {
|
|
89
|
+
return this.db.prepare(sql);
|
|
90
|
+
}
|
|
91
|
+
get(sql, params = {}) {
|
|
92
|
+
return this.db.prepare(sql).get(params);
|
|
93
|
+
}
|
|
94
|
+
all(sql, params = {}) {
|
|
95
|
+
return this.db.prepare(sql).all(params);
|
|
96
|
+
}
|
|
97
|
+
run(sql, params = {}) {
|
|
98
|
+
return this.db.prepare(sql).run(params);
|
|
99
|
+
}
|
|
100
|
+
// -------------------------
|
|
101
|
+
// Transactions
|
|
102
|
+
// -------------------------
|
|
103
|
+
transaction(fn) {
|
|
104
|
+
const trx = this.db.transaction(fn);
|
|
105
|
+
return trx();
|
|
106
|
+
}
|
|
107
|
+
// -------------------------
|
|
108
|
+
// Upsert helper (very useful for build cache)
|
|
109
|
+
// -------------------------
|
|
110
|
+
upsert(sql, params = {}) {
|
|
111
|
+
return this.db.prepare(sql).run(params);
|
|
112
|
+
}
|
|
113
|
+
// -------------------------
|
|
114
|
+
// Bulk insert helper
|
|
115
|
+
// -------------------------
|
|
116
|
+
insertMany(sql, rows) {
|
|
117
|
+
const stmt = this.db.prepare(sql);
|
|
118
|
+
const trx = this.db.transaction((rows2) => {
|
|
119
|
+
for (const row of rows2) {
|
|
120
|
+
stmt.run(row);
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
trx(rows);
|
|
124
|
+
}
|
|
125
|
+
// -------------------------
|
|
126
|
+
// Utility
|
|
127
|
+
// -------------------------
|
|
128
|
+
close() {
|
|
129
|
+
this.db.close();
|
|
130
|
+
}
|
|
131
|
+
// Raw access if needed (escape hatch)
|
|
132
|
+
raw() {
|
|
133
|
+
return this.db;
|
|
134
|
+
}
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
// src/opencode/database.ts
|
|
138
|
+
var import_fs_extra3 = __toESM(require("fs-extra"), 1);
|
|
139
|
+
var import_node_child_process = require("child_process");
|
|
140
|
+
async function checkDatabase() {
|
|
141
|
+
if (!import_fs_extra3.default.existsSync(DATABASE_PATH)) {
|
|
142
|
+
console.error("No OpenCode database found. Run opencode (v1.2.0+) at least once to create the database.");
|
|
143
|
+
return false;
|
|
144
|
+
}
|
|
145
|
+
try {
|
|
146
|
+
const db = new SQLite(DATABASE_PATH);
|
|
147
|
+
try {
|
|
148
|
+
const rows = db.all("SELECT name FROM sqlite_master WHERE type='table' AND name='session'");
|
|
149
|
+
if (rows.length === 0) {
|
|
150
|
+
console.error(
|
|
151
|
+
"OpenCode database exists but is missing expected tables. Try running opencode to complete the migration."
|
|
152
|
+
);
|
|
153
|
+
return false;
|
|
154
|
+
}
|
|
155
|
+
return true;
|
|
156
|
+
} finally {
|
|
157
|
+
db.close();
|
|
158
|
+
}
|
|
159
|
+
} catch (error) {
|
|
160
|
+
if (error instanceof Error) {
|
|
161
|
+
console.error(`Could not open OpenCode database: ${error.message}`);
|
|
162
|
+
} else {
|
|
163
|
+
console.error("Could not open OpenCode database.");
|
|
164
|
+
}
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
function toProject(row) {
|
|
169
|
+
let sandboxes = [];
|
|
170
|
+
try {
|
|
171
|
+
sandboxes = JSON.parse(row.sandboxes);
|
|
172
|
+
} catch {
|
|
173
|
+
}
|
|
174
|
+
return {
|
|
175
|
+
id: row.id,
|
|
176
|
+
worktree: row.worktree,
|
|
177
|
+
vcs: row.vcs,
|
|
178
|
+
name: row.name,
|
|
179
|
+
sandboxes,
|
|
180
|
+
time: {
|
|
181
|
+
created: row.time_created,
|
|
182
|
+
updated: row.time_updated
|
|
183
|
+
}
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
function toSession(row) {
|
|
187
|
+
const session = {
|
|
188
|
+
id: row.id,
|
|
189
|
+
slug: row.slug,
|
|
190
|
+
version: row.version,
|
|
191
|
+
projectID: row.project_id,
|
|
192
|
+
directory: row.directory,
|
|
193
|
+
parentID: row.parent_id ?? void 0,
|
|
194
|
+
title: row.title,
|
|
195
|
+
time: {
|
|
196
|
+
created: row.time_created,
|
|
197
|
+
updated: row.time_updated,
|
|
198
|
+
compacting: row.time_compacting ?? void 0,
|
|
199
|
+
archived: row.time_archived ?? void 0
|
|
200
|
+
}
|
|
201
|
+
};
|
|
202
|
+
if (row.summary_files != null) {
|
|
203
|
+
session.summary = {
|
|
204
|
+
additions: row.summary_additions ?? 0,
|
|
205
|
+
deletions: row.summary_deletions ?? 0,
|
|
206
|
+
files: row.summary_files
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
if (row.share_url) {
|
|
210
|
+
session.share = { url: row.share_url };
|
|
211
|
+
}
|
|
212
|
+
return session;
|
|
213
|
+
}
|
|
214
|
+
function toMessage(id, sessionID, dataJson) {
|
|
215
|
+
const data = JSON.parse(dataJson);
|
|
216
|
+
return {
|
|
217
|
+
id,
|
|
218
|
+
sessionID,
|
|
219
|
+
role: data.role,
|
|
220
|
+
time: data.time,
|
|
221
|
+
parentID: data.parentID,
|
|
222
|
+
modelID: data.modelID,
|
|
223
|
+
providerID: data.providerID,
|
|
224
|
+
agent: data.agent,
|
|
225
|
+
mode: data.mode,
|
|
226
|
+
cost: data.cost,
|
|
227
|
+
tokens: data.tokens,
|
|
228
|
+
finish: data.finish
|
|
229
|
+
};
|
|
230
|
+
}
|
|
231
|
+
function toPart(id, messageID, sessionID, dataJson) {
|
|
232
|
+
const data = JSON.parse(dataJson);
|
|
233
|
+
return {
|
|
234
|
+
id,
|
|
235
|
+
messageID,
|
|
236
|
+
sessionID,
|
|
237
|
+
type: data.type,
|
|
238
|
+
text: data.text,
|
|
239
|
+
tool: data.tool,
|
|
240
|
+
state: data.state
|
|
241
|
+
};
|
|
242
|
+
}
|
|
243
|
+
async function loadProjects() {
|
|
244
|
+
const rows = query("SELECT id, worktree, vcs, name, time_created, time_updated, sandboxes FROM project");
|
|
245
|
+
return rows.map(toProject);
|
|
246
|
+
}
|
|
247
|
+
async function loadSessions() {
|
|
248
|
+
const rows = query(
|
|
249
|
+
`SELECT id, project_id, parent_id, slug, directory, title, version,
|
|
250
|
+
share_url, summary_additions, summary_deletions, summary_files,
|
|
251
|
+
time_created, time_updated, time_compacting, time_archived
|
|
252
|
+
FROM session
|
|
253
|
+
WHERE parent_id IS NULL
|
|
254
|
+
ORDER BY time_updated DESC`
|
|
255
|
+
);
|
|
256
|
+
return rows.map(toSession);
|
|
257
|
+
}
|
|
258
|
+
async function loadMessages(sessionID) {
|
|
259
|
+
const rows = query(
|
|
260
|
+
`SELECT id, session_id, data FROM message WHERE session_id = '${escapeSql(sessionID)}' ORDER BY id ASC`
|
|
261
|
+
);
|
|
262
|
+
return rows.map((row) => toMessage(row.id, row.session_id, row.data));
|
|
263
|
+
}
|
|
264
|
+
async function loadParts(messageID) {
|
|
265
|
+
const rows = query(
|
|
266
|
+
`SELECT id, message_id, session_id, data FROM part WHERE message_id = '${escapeSql(messageID)}' ORDER BY id ASC`
|
|
267
|
+
);
|
|
268
|
+
return rows.map((row) => toPart(row.id, row.message_id, row.session_id, row.data));
|
|
269
|
+
}
|
|
270
|
+
async function loadTranscript(sessionID) {
|
|
271
|
+
const sid = escapeSql(sessionID);
|
|
272
|
+
const rows = query(
|
|
273
|
+
`SELECT m.id AS message_id, m.data AS message_data,
|
|
274
|
+
p.id AS part_id, p.message_id AS part_message_id,
|
|
275
|
+
p.session_id AS part_session_id, p.data AS part_data
|
|
276
|
+
FROM message m
|
|
277
|
+
LEFT JOIN part p ON p.message_id = m.id
|
|
278
|
+
WHERE m.session_id = '${sid}'
|
|
279
|
+
ORDER BY m.id ASC, p.id ASC`
|
|
280
|
+
);
|
|
281
|
+
const entriesMap = /* @__PURE__ */ new Map();
|
|
282
|
+
for (const row of rows) {
|
|
283
|
+
let entry = entriesMap.get(row.message_id);
|
|
284
|
+
if (!entry) {
|
|
285
|
+
entry = {
|
|
286
|
+
message: toMessage(row.message_id, sessionID, row.message_data),
|
|
287
|
+
parts: []
|
|
288
|
+
};
|
|
289
|
+
entriesMap.set(row.message_id, entry);
|
|
290
|
+
}
|
|
291
|
+
if (row.part_id && row.part_data && row.part_message_id && row.part_session_id) {
|
|
292
|
+
const part = toPart(row.part_id, row.part_message_id, row.part_session_id, row.part_data);
|
|
293
|
+
if (part.type === "text" && part.text || part.type === "tool") {
|
|
294
|
+
entry.parts.push(part);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
return Array.from(entriesMap.values()).filter((entry) => entry.parts.length > 0);
|
|
299
|
+
}
|
|
300
|
+
function runSql(query2) {
|
|
301
|
+
const dbPath = DATABASE_PATH;
|
|
302
|
+
(0, import_node_child_process.execSync)(`sqlite3 "${dbPath}"`, {
|
|
303
|
+
input: query2,
|
|
304
|
+
timeout: 1e4
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
async function deleteSession(session) {
|
|
308
|
+
const sid = escapeSql(session.id);
|
|
309
|
+
runSql(
|
|
310
|
+
`WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
|
|
311
|
+
);
|
|
312
|
+
}
|
|
313
|
+
async function deleteSessionById(id) {
|
|
314
|
+
const sid = escapeSql(id);
|
|
315
|
+
runSql(
|
|
316
|
+
`WITH RECURSIVE descendants(id) AS (SELECT id FROM session WHERE id = '${sid}' UNION ALL SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id) DELETE FROM session WHERE id IN (SELECT id FROM descendants);`
|
|
317
|
+
);
|
|
318
|
+
}
|
|
319
|
+
async function deleteAllSessions() {
|
|
320
|
+
runSql(`DELETE FROM part; DELETE FROM message; DELETE FROM session;`);
|
|
321
|
+
}
|
|
322
|
+
async function deleteAllProjectSessions(projectID) {
|
|
323
|
+
const pid = escapeSql(projectID);
|
|
324
|
+
runSql(`DELETE FROM session WHERE project_id = '${pid}'; DELETE FROM project WHERE id = '${pid}';`);
|
|
325
|
+
}
|
|
326
|
+
function query(sql) {
|
|
327
|
+
const db = new SQLite(DATABASE_PATH);
|
|
328
|
+
try {
|
|
329
|
+
return db.all(sql);
|
|
330
|
+
} finally {
|
|
331
|
+
db.close();
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
function escapeSql(value) {
|
|
335
|
+
return value.replace(/'/g, "''");
|
|
336
|
+
}
|
|
337
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
338
|
+
0 && (module.exports = {
|
|
339
|
+
checkDatabase,
|
|
340
|
+
deleteAllProjectSessions,
|
|
341
|
+
deleteAllSessions,
|
|
342
|
+
deleteSession,
|
|
343
|
+
deleteSessionById,
|
|
344
|
+
loadMessages,
|
|
345
|
+
loadParts,
|
|
346
|
+
loadProjects,
|
|
347
|
+
loadSessions,
|
|
348
|
+
loadTranscript
|
|
349
|
+
});
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
export declare function checkDatabase(): Promise<boolean>;
|
|
2
|
+
export interface Project {
|
|
3
|
+
id: string;
|
|
4
|
+
worktree: string;
|
|
5
|
+
vcs: string | null;
|
|
6
|
+
name: string | null;
|
|
7
|
+
sandboxes: unknown[];
|
|
8
|
+
time: {
|
|
9
|
+
created: number;
|
|
10
|
+
updated: number;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export interface Session {
|
|
14
|
+
id: string;
|
|
15
|
+
slug: string;
|
|
16
|
+
version: string;
|
|
17
|
+
projectID: string;
|
|
18
|
+
directory: string;
|
|
19
|
+
parentID?: string;
|
|
20
|
+
title: string;
|
|
21
|
+
time: {
|
|
22
|
+
created: number;
|
|
23
|
+
updated: number;
|
|
24
|
+
compacting?: number;
|
|
25
|
+
archived?: number;
|
|
26
|
+
};
|
|
27
|
+
summary?: {
|
|
28
|
+
additions: number;
|
|
29
|
+
deletions: number;
|
|
30
|
+
files: number;
|
|
31
|
+
};
|
|
32
|
+
share?: {
|
|
33
|
+
url: string;
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
export interface Message {
|
|
37
|
+
id: string;
|
|
38
|
+
sessionID: string;
|
|
39
|
+
role: 'user' | 'assistant';
|
|
40
|
+
time: {
|
|
41
|
+
created: number;
|
|
42
|
+
completed?: number;
|
|
43
|
+
};
|
|
44
|
+
parentID?: string;
|
|
45
|
+
modelID?: string;
|
|
46
|
+
providerID?: string;
|
|
47
|
+
agent?: string;
|
|
48
|
+
mode?: string;
|
|
49
|
+
cost?: number;
|
|
50
|
+
tokens?: {
|
|
51
|
+
input: number;
|
|
52
|
+
output: number;
|
|
53
|
+
reasoning: number;
|
|
54
|
+
cache: {
|
|
55
|
+
read: number;
|
|
56
|
+
write: number;
|
|
57
|
+
};
|
|
58
|
+
};
|
|
59
|
+
finish?: string;
|
|
60
|
+
}
|
|
61
|
+
export interface ToolState {
|
|
62
|
+
status?: string;
|
|
63
|
+
input?: Record<string, unknown>;
|
|
64
|
+
output?: string;
|
|
65
|
+
}
|
|
66
|
+
export interface Part {
|
|
67
|
+
id: string;
|
|
68
|
+
sessionID: string;
|
|
69
|
+
messageID: string;
|
|
70
|
+
type: string;
|
|
71
|
+
text?: string;
|
|
72
|
+
tool?: string;
|
|
73
|
+
state?: ToolState;
|
|
74
|
+
}
|
|
75
|
+
export declare function loadProjects(): Promise<Project[]>;
|
|
76
|
+
export declare function loadSessions(): Promise<Session[]>;
|
|
77
|
+
export declare function loadMessages(sessionID: string): Promise<Message[]>;
|
|
78
|
+
export declare function loadParts(messageID: string): Promise<Part[]>;
|
|
79
|
+
export interface TranscriptEntry {
|
|
80
|
+
message: Message;
|
|
81
|
+
parts: Part[];
|
|
82
|
+
}
|
|
83
|
+
export interface SessionWithProject {
|
|
84
|
+
session: Session;
|
|
85
|
+
project: Project | undefined;
|
|
86
|
+
}
|
|
87
|
+
export declare function loadTranscript(sessionID: string): Promise<TranscriptEntry[]>;
|
|
88
|
+
export declare function deleteSession(session: Session): Promise<void>;
|
|
89
|
+
export declare function deleteSessionById(id: string): Promise<void>;
|
|
90
|
+
export declare function deleteAllSessions(): Promise<void>;
|
|
91
|
+
export declare function deleteAllProjectSessions(projectID: string): Promise<void>;
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.checkDatabase = checkDatabase;
|
|
16
|
+
exports.loadProjects = loadProjects;
|
|
17
|
+
exports.loadSessions = loadSessions;
|
|
18
|
+
exports.loadMessages = loadMessages;
|
|
19
|
+
exports.loadParts = loadParts;
|
|
20
|
+
exports.loadTranscript = loadTranscript;
|
|
21
|
+
exports.deleteSession = deleteSession;
|
|
22
|
+
exports.deleteSessionById = deleteSessionById;
|
|
23
|
+
exports.deleteAllSessions = deleteAllSessions;
|
|
24
|
+
exports.deleteAllProjectSessions = deleteAllProjectSessions;
|
|
25
|
+
const storage_js_1 = require("./storage.js");
|
|
26
|
+
const sqlite_js_1 = require("./sqlite.js");
|
|
27
|
+
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
28
|
+
const node_child_process_1 = require("node:child_process");
|
|
29
|
+
function checkDatabase() {
|
|
30
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
+
if (!fs_extra_1.default.existsSync(storage_js_1.DATABASE_PATH)) {
|
|
32
|
+
console.error('No OpenCode database found. Run opencode (v1.2.0+) at least once to create the database.');
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
try {
|
|
36
|
+
const db = new sqlite_js_1.SQLite(storage_js_1.DATABASE_PATH);
|
|
37
|
+
try {
|
|
38
|
+
const rows = db.all("SELECT name FROM sqlite_master WHERE type='table' AND name='session'");
|
|
39
|
+
// console.log('Database tables:', rows.map((r) => r.name).join(', '));
|
|
40
|
+
if (rows.length === 0) {
|
|
41
|
+
console.error('OpenCode database exists but is missing expected tables. Try running opencode to complete the migration.');
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
finally {
|
|
47
|
+
db.close();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
if (error instanceof Error) {
|
|
52
|
+
console.error(`Could not open OpenCode database: ${error.message}`);
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
console.error('Could not open OpenCode database.');
|
|
56
|
+
}
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
function toProject(row) {
|
|
62
|
+
let sandboxes = [];
|
|
63
|
+
try {
|
|
64
|
+
sandboxes = JSON.parse(row.sandboxes);
|
|
65
|
+
}
|
|
66
|
+
catch (_a) {
|
|
67
|
+
// ignore malformed JSON
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
id: row.id,
|
|
71
|
+
worktree: row.worktree,
|
|
72
|
+
vcs: row.vcs,
|
|
73
|
+
name: row.name,
|
|
74
|
+
sandboxes,
|
|
75
|
+
time: {
|
|
76
|
+
created: row.time_created,
|
|
77
|
+
updated: row.time_updated
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
function toSession(row) {
|
|
82
|
+
var _a, _b, _c, _d, _e;
|
|
83
|
+
const session = {
|
|
84
|
+
id: row.id,
|
|
85
|
+
slug: row.slug,
|
|
86
|
+
version: row.version,
|
|
87
|
+
projectID: row.project_id,
|
|
88
|
+
directory: row.directory,
|
|
89
|
+
parentID: (_a = row.parent_id) !== null && _a !== void 0 ? _a : undefined,
|
|
90
|
+
title: row.title,
|
|
91
|
+
time: {
|
|
92
|
+
created: row.time_created,
|
|
93
|
+
updated: row.time_updated,
|
|
94
|
+
compacting: (_b = row.time_compacting) !== null && _b !== void 0 ? _b : undefined,
|
|
95
|
+
archived: (_c = row.time_archived) !== null && _c !== void 0 ? _c : undefined
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
if (row.summary_files != null) {
|
|
99
|
+
session.summary = {
|
|
100
|
+
additions: (_d = row.summary_additions) !== null && _d !== void 0 ? _d : 0,
|
|
101
|
+
deletions: (_e = row.summary_deletions) !== null && _e !== void 0 ? _e : 0,
|
|
102
|
+
files: row.summary_files
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
if (row.share_url) {
|
|
106
|
+
session.share = { url: row.share_url };
|
|
107
|
+
}
|
|
108
|
+
return session;
|
|
109
|
+
}
|
|
110
|
+
function toMessage(id, sessionID, dataJson) {
|
|
111
|
+
const data = JSON.parse(dataJson);
|
|
112
|
+
return {
|
|
113
|
+
id,
|
|
114
|
+
sessionID,
|
|
115
|
+
role: data.role,
|
|
116
|
+
time: data.time,
|
|
117
|
+
parentID: data.parentID,
|
|
118
|
+
modelID: data.modelID,
|
|
119
|
+
providerID: data.providerID,
|
|
120
|
+
agent: data.agent,
|
|
121
|
+
mode: data.mode,
|
|
122
|
+
cost: data.cost,
|
|
123
|
+
tokens: data.tokens,
|
|
124
|
+
finish: data.finish
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
function toPart(id, messageID, sessionID, dataJson) {
|
|
128
|
+
const data = JSON.parse(dataJson);
|
|
129
|
+
return {
|
|
130
|
+
id,
|
|
131
|
+
messageID,
|
|
132
|
+
sessionID,
|
|
133
|
+
type: data.type,
|
|
134
|
+
text: data.text,
|
|
135
|
+
tool: data.tool,
|
|
136
|
+
state: data.state
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
function loadProjects() {
|
|
140
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
141
|
+
const rows = query('SELECT id, worktree, vcs, name, time_created, time_updated, sandboxes FROM project');
|
|
142
|
+
return rows.map(toProject);
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
function loadSessions() {
|
|
146
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
147
|
+
const rows = query(`SELECT id, project_id, parent_id, slug, directory, title, version,
|
|
148
|
+
share_url, summary_additions, summary_deletions, summary_files,
|
|
149
|
+
time_created, time_updated, time_compacting, time_archived
|
|
150
|
+
FROM session
|
|
151
|
+
WHERE parent_id IS NULL
|
|
152
|
+
ORDER BY time_updated DESC`);
|
|
153
|
+
return rows.map(toSession);
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
function loadMessages(sessionID) {
|
|
157
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
158
|
+
const rows = query(`SELECT id, session_id, data FROM message WHERE session_id = '${escapeSql(sessionID)}' ORDER BY id ASC`);
|
|
159
|
+
return rows.map((row) => toMessage(row.id, row.session_id, row.data));
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
function loadParts(messageID) {
|
|
163
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
164
|
+
const rows = query(`SELECT id, message_id, session_id, data FROM part WHERE message_id = '${escapeSql(messageID)}' ORDER BY id ASC`);
|
|
165
|
+
return rows.map((row) => toPart(row.id, row.message_id, row.session_id, row.data));
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
function loadTranscript(sessionID) {
|
|
169
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
170
|
+
const sid = escapeSql(sessionID);
|
|
171
|
+
const rows = query(`SELECT m.id AS message_id, m.data AS message_data,
|
|
172
|
+
p.id AS part_id, p.message_id AS part_message_id,
|
|
173
|
+
p.session_id AS part_session_id, p.data AS part_data
|
|
174
|
+
FROM message m
|
|
175
|
+
LEFT JOIN part p ON p.message_id = m.id
|
|
176
|
+
WHERE m.session_id = '${sid}'
|
|
177
|
+
ORDER BY m.id ASC, p.id ASC`);
|
|
178
|
+
// Group rows by message
|
|
179
|
+
const entriesMap = new Map();
|
|
180
|
+
for (const row of rows) {
|
|
181
|
+
let entry = entriesMap.get(row.message_id);
|
|
182
|
+
if (!entry) {
|
|
183
|
+
entry = {
|
|
184
|
+
message: toMessage(row.message_id, sessionID, row.message_data),
|
|
185
|
+
parts: []
|
|
186
|
+
};
|
|
187
|
+
entriesMap.set(row.message_id, entry);
|
|
188
|
+
}
|
|
189
|
+
if (row.part_id && row.part_data && row.part_message_id && row.part_session_id) {
|
|
190
|
+
const part = toPart(row.part_id, row.part_message_id, row.part_session_id, row.part_data);
|
|
191
|
+
if ((part.type === 'text' && part.text) || part.type === 'tool') {
|
|
192
|
+
entry.parts.push(part);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
// Only include entries that have relevant parts
|
|
197
|
+
return Array.from(entriesMap.values()).filter((entry) => entry.parts.length > 0);
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
function runSql(query) {
|
|
201
|
+
const dbPath = storage_js_1.DATABASE_PATH;
|
|
202
|
+
(0, node_child_process_1.execSync)(`sqlite3 "${dbPath}"`, {
|
|
203
|
+
input: query,
|
|
204
|
+
timeout: 10000
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
function deleteSession(session) {
|
|
208
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
209
|
+
const sid = escapeSql(session.id);
|
|
210
|
+
runSql(`WITH RECURSIVE descendants(id) AS (` +
|
|
211
|
+
`SELECT id FROM session WHERE id = '${sid}' ` +
|
|
212
|
+
`UNION ALL ` +
|
|
213
|
+
`SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id` +
|
|
214
|
+
`) ` +
|
|
215
|
+
`DELETE FROM session WHERE id IN (SELECT id FROM descendants);`);
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
function deleteSessionById(id) {
|
|
219
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
220
|
+
const sid = escapeSql(id);
|
|
221
|
+
runSql(`WITH RECURSIVE descendants(id) AS (` +
|
|
222
|
+
`SELECT id FROM session WHERE id = '${sid}' ` +
|
|
223
|
+
`UNION ALL ` +
|
|
224
|
+
`SELECT s.id FROM session s JOIN descendants d ON s.parent_id = d.id` +
|
|
225
|
+
`) ` +
|
|
226
|
+
`DELETE FROM session WHERE id IN (SELECT id FROM descendants);`);
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
function deleteAllSessions() {
|
|
230
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
231
|
+
runSql(`DELETE FROM part; DELETE FROM message; DELETE FROM session;`);
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
function deleteAllProjectSessions(projectID) {
|
|
235
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
236
|
+
const pid = escapeSql(projectID);
|
|
237
|
+
runSql(`DELETE FROM session WHERE project_id = '${pid}'; DELETE FROM project WHERE id = '${pid}';`);
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
/** Run a read-only query using the SQLite class. */
|
|
241
|
+
function query(sql) {
|
|
242
|
+
const db = new sqlite_js_1.SQLite(storage_js_1.DATABASE_PATH);
|
|
243
|
+
try {
|
|
244
|
+
return db.all(sql);
|
|
245
|
+
}
|
|
246
|
+
finally {
|
|
247
|
+
db.close();
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
function escapeSql(value) {
|
|
251
|
+
return value.replace(/'/g, "''");
|
|
252
|
+
}
|