clawvault 3.1.0 → 3.2.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/README.md +422 -141
- package/bin/clawvault.js +10 -2
- package/bin/command-registration.test.js +3 -1
- package/bin/command-runtime.js +9 -1
- package/bin/register-core-commands.js +23 -28
- package/bin/register-maintenance-commands.js +39 -3
- package/bin/register-query-commands.js +58 -29
- package/bin/register-tailscale-commands.js +106 -0
- package/bin/register-task-commands.js +18 -1
- package/bin/register-task-commands.test.js +16 -0
- package/bin/register-vault-operations-commands.js +29 -1
- package/bin/register-workgraph-commands.js +451 -0
- package/dashboard/lib/graph-diff.js +104 -0
- package/dashboard/lib/graph-diff.test.js +75 -0
- package/dashboard/lib/vault-parser.js +556 -0
- package/dashboard/lib/vault-parser.test.js +254 -0
- package/dashboard/public/app.js +796 -0
- package/dashboard/public/index.html +52 -0
- package/dashboard/public/styles.css +221 -0
- package/dashboard/server.js +374 -0
- package/dist/{chunk-C7OK5WKP.js → chunk-2JQ3O2YL.js} +4 -4
- package/dist/{chunk-VR5NE7PZ.js → chunk-2RAZ4ZFE.js} +1 -1
- package/dist/{chunk-F2JEUD4J.js → chunk-4ITRXIVT.js} +5 -7
- package/dist/{chunk-GUKMRGM7.js → chunk-4OXMU5S2.js} +1 -1
- package/dist/chunk-5PJ4STIC.js +465 -0
- package/dist/{chunk-62YTUT6J.js → chunk-AZYOKJYC.js} +2 -2
- package/dist/chunk-BSJ6RIT7.js +447 -0
- package/dist/chunk-ECRZL5XR.js +50 -0
- package/dist/chunk-ERNE2FZ5.js +189 -0
- package/dist/{chunk-WAZ3NLWL.js → chunk-F55HGNU4.js} +0 -47
- package/dist/{chunk-VGLOTGAS.js → chunk-FAKNOB7Y.js} +2 -2
- package/dist/{chunk-QK3UCXWL.js → chunk-FHFUXL6G.js} +2 -2
- package/dist/chunk-GNJL4YGR.js +79 -0
- package/dist/chunk-HR4KN6S2.js +152 -0
- package/dist/{chunk-OZ7RIXTO.js → chunk-IIOU45CK.js} +1 -1
- package/dist/chunk-IJBFGPCS.js +33 -0
- package/dist/chunk-IVRIKYFE.js +520 -0
- package/dist/chunk-K7PNYS45.js +93 -0
- package/dist/chunk-MDIH26GC.js +183 -0
- package/dist/{chunk-LYHGEHXG.js → chunk-MFAWT5O5.js} +0 -1
- package/dist/{chunk-H34S76MB.js → chunk-MNPUYCHQ.js} +6 -6
- package/dist/chunk-NTOPJI7W.js +207 -0
- package/dist/{chunk-QBLMXKF2.js → chunk-OIWVQYQF.js} +1 -1
- package/dist/chunk-PG56HX5T.js +154 -0
- package/dist/{chunk-LNJA2UGL.js → chunk-PI4WMLMG.js} +7 -84
- package/dist/chunk-QMHPQYUV.js +363 -0
- package/dist/{chunk-H62BP7RI.js → chunk-QPDDIHXE.js} +209 -43
- package/dist/{chunk-N2AXRYLC.js → chunk-QWQ3TIKS.js} +1 -1
- package/dist/{chunk-3DHXQHYG.js → chunk-R2MIW5G7.js} +1 -1
- package/dist/{chunk-SJSFRIYS.js → chunk-S5OJEGFG.js} +2 -2
- package/dist/chunk-SS4B7P7V.js +99 -0
- package/dist/chunk-TIGW564L.js +628 -0
- package/dist/chunk-U67V476Y.js +35 -0
- package/dist/{chunk-JY6FYXIT.js → chunk-UCQAOZHW.js} +6 -11
- package/dist/{chunk-ITPEXLHA.js → chunk-URXDAUVH.js} +24 -5
- package/dist/chunk-WIOLLGAD.js +190 -0
- package/dist/{chunk-3WRJEKN4.js → chunk-WJVWINEM.js} +72 -8
- package/dist/chunk-WMGIIABP.js +15 -0
- package/dist/{chunk-33UGEQRT.js → chunk-X3SPPUFG.js} +151 -64
- package/dist/{chunk-3NSBOUT3.js → chunk-Y3TIJEBP.js} +314 -79
- package/dist/chunk-Y6VJKXGL.js +373 -0
- package/dist/{chunk-LI4O6NVK.js → chunk-YDWHS4LJ.js} +49 -9
- package/dist/{chunk-U55BGUAU.js → chunk-YNIPYN4F.js} +5 -5
- package/dist/chunk-YXQCA6B7.js +226 -0
- package/dist/cli/index.js +26 -22
- package/dist/commands/archive.js +3 -3
- package/dist/commands/backlog.js +3 -3
- package/dist/commands/blocked.js +3 -3
- package/dist/commands/canvas.d.ts +15 -0
- package/dist/commands/canvas.js +200 -0
- package/dist/commands/checkpoint.js +2 -2
- package/dist/commands/compat.js +2 -2
- package/dist/commands/context.js +7 -5
- package/dist/commands/doctor.d.ts +11 -7
- package/dist/commands/doctor.js +16 -14
- package/dist/commands/embed.js +5 -6
- package/dist/commands/entities.js +2 -2
- package/dist/commands/graph.js +3 -3
- package/dist/commands/inject.d.ts +1 -1
- package/dist/commands/inject.js +4 -5
- package/dist/commands/kanban.js +4 -4
- package/dist/commands/link.js +2 -2
- package/dist/commands/migrate-observations.js +4 -4
- package/dist/commands/observe.d.ts +0 -1
- package/dist/commands/observe.js +13 -12
- package/dist/commands/project.js +5 -5
- package/dist/commands/rebuild-embeddings.d.ts +21 -0
- package/dist/commands/rebuild-embeddings.js +91 -0
- package/dist/commands/rebuild.js +12 -11
- package/dist/commands/recover.js +3 -3
- package/dist/commands/reflect.js +6 -7
- package/dist/commands/repair-session.js +1 -1
- package/dist/commands/replay.js +14 -14
- package/dist/commands/session-recap.js +1 -1
- package/dist/commands/setup.d.ts +2 -89
- package/dist/commands/setup.js +3 -21
- package/dist/commands/shell-init.js +1 -1
- package/dist/commands/sleep.d.ts +1 -1
- package/dist/commands/sleep.js +18 -17
- package/dist/commands/status.d.ts +2 -0
- package/dist/commands/status.js +40 -30
- package/dist/commands/sync-bd.d.ts +10 -0
- package/dist/commands/sync-bd.js +10 -0
- package/dist/commands/tailscale.d.ts +52 -0
- package/dist/commands/tailscale.js +26 -0
- package/dist/commands/task.js +4 -4
- package/dist/commands/template.js +2 -2
- package/dist/commands/wake.d.ts +1 -1
- package/dist/commands/wake.js +11 -10
- package/dist/index.d.ts +334 -191
- package/dist/index.js +432 -108
- package/dist/{inject-Bzi5E-By.d.ts → inject-DYUrDqQO.d.ts} +3 -3
- package/dist/ledger-B7g7jhqG.d.ts +44 -0
- package/dist/lib/auto-linker.js +1 -1
- package/dist/lib/canvas-layout.d.ts +115 -0
- package/dist/lib/canvas-layout.js +35 -0
- package/dist/lib/config.d.ts +27 -3
- package/dist/lib/config.js +4 -2
- package/dist/lib/entity-index.js +1 -1
- package/dist/lib/project-utils.js +4 -4
- package/dist/lib/session-repair.js +1 -1
- package/dist/lib/session-utils.js +1 -1
- package/dist/lib/tailscale.d.ts +225 -0
- package/dist/lib/tailscale.js +50 -0
- package/dist/lib/task-utils.js +3 -3
- package/dist/lib/template-engine.js +1 -1
- package/dist/lib/webdav.d.ts +109 -0
- package/dist/lib/webdav.js +35 -0
- package/dist/plugin/index.d.ts +344 -28
- package/dist/plugin/index.js +3919 -227
- package/dist/registry-BR4326o0.d.ts +30 -0
- package/dist/store-CA-6sKCJ.d.ts +34 -0
- package/dist/thread-B9LhXNU0.d.ts +41 -0
- package/dist/{types-Y2_Um2Ls.d.ts → types-BbWJoC1c.d.ts} +1 -44
- package/dist/workgraph/index.d.ts +5 -0
- package/dist/workgraph/index.js +23 -0
- package/dist/workgraph/ledger.d.ts +2 -0
- package/dist/workgraph/ledger.js +25 -0
- package/dist/workgraph/registry.d.ts +2 -0
- package/dist/workgraph/registry.js +19 -0
- package/dist/workgraph/store.d.ts +2 -0
- package/dist/workgraph/store.js +25 -0
- package/dist/workgraph/thread.d.ts +2 -0
- package/dist/workgraph/thread.js +25 -0
- package/dist/workgraph/types.d.ts +54 -0
- package/dist/workgraph/types.js +7 -0
- package/hooks/clawvault/HOOK.md +113 -0
- package/hooks/clawvault/handler.js +1559 -0
- package/hooks/clawvault/handler.test.js +510 -0
- package/hooks/clawvault/openclaw.plugin.json +72 -0
- package/openclaw.plugin.json +235 -30
- package/package.json +20 -20
- package/dist/chunk-3RG5ZIWI.js +0 -10
- package/dist/chunk-3ZIH425O.js +0 -871
- package/dist/chunk-6U6MK36V.js +0 -205
- package/dist/chunk-CMB7UL7C.js +0 -327
- package/dist/chunk-D2H45LON.js +0 -1074
- package/dist/chunk-E7MFQB6D.js +0 -163
- package/dist/chunk-GQSLDZTS.js +0 -560
- package/dist/chunk-MFM6K7PU.js +0 -374
- package/dist/chunk-MXSSG3QU.js +0 -42
- package/dist/chunk-OCGVIN3L.js +0 -88
- package/dist/chunk-PAH27GSN.js +0 -108
- package/dist/chunk-YCUNCH2I.js +0 -78
- package/dist/cli/index.cjs +0 -8584
- package/dist/cli/index.d.cts +0 -5
- package/dist/commands/archive.cjs +0 -287
- package/dist/commands/archive.d.cts +0 -11
- package/dist/commands/backlog.cjs +0 -721
- package/dist/commands/backlog.d.cts +0 -53
- package/dist/commands/blocked.cjs +0 -204
- package/dist/commands/blocked.d.cts +0 -26
- package/dist/commands/checkpoint.cjs +0 -244
- package/dist/commands/checkpoint.d.cts +0 -41
- package/dist/commands/compat.cjs +0 -294
- package/dist/commands/compat.d.cts +0 -28
- package/dist/commands/context.cjs +0 -2990
- package/dist/commands/context.d.cts +0 -2
- package/dist/commands/doctor.cjs +0 -2986
- package/dist/commands/doctor.d.cts +0 -21
- package/dist/commands/embed.cjs +0 -232
- package/dist/commands/embed.d.cts +0 -17
- package/dist/commands/entities.cjs +0 -141
- package/dist/commands/entities.d.cts +0 -7
- package/dist/commands/graph.cjs +0 -501
- package/dist/commands/graph.d.cts +0 -21
- package/dist/commands/inject.cjs +0 -1636
- package/dist/commands/inject.d.cts +0 -2
- package/dist/commands/kanban.cjs +0 -884
- package/dist/commands/kanban.d.cts +0 -63
- package/dist/commands/link.cjs +0 -965
- package/dist/commands/link.d.cts +0 -11
- package/dist/commands/migrate-observations.cjs +0 -362
- package/dist/commands/migrate-observations.d.cts +0 -19
- package/dist/commands/observe.cjs +0 -4099
- package/dist/commands/observe.d.cts +0 -23
- package/dist/commands/project.cjs +0 -1341
- package/dist/commands/project.d.cts +0 -85
- package/dist/commands/rebuild.cjs +0 -3136
- package/dist/commands/rebuild.d.cts +0 -11
- package/dist/commands/recover.cjs +0 -361
- package/dist/commands/recover.d.cts +0 -38
- package/dist/commands/reflect.cjs +0 -1008
- package/dist/commands/reflect.d.cts +0 -11
- package/dist/commands/repair-session.cjs +0 -457
- package/dist/commands/repair-session.d.cts +0 -38
- package/dist/commands/replay.cjs +0 -4103
- package/dist/commands/replay.d.cts +0 -16
- package/dist/commands/session-recap.cjs +0 -353
- package/dist/commands/session-recap.d.cts +0 -27
- package/dist/commands/setup.cjs +0 -1278
- package/dist/commands/setup.d.cts +0 -99
- package/dist/commands/shell-init.cjs +0 -75
- package/dist/commands/shell-init.d.cts +0 -7
- package/dist/commands/sleep.cjs +0 -6029
- package/dist/commands/sleep.d.cts +0 -36
- package/dist/commands/status.cjs +0 -2737
- package/dist/commands/status.d.cts +0 -52
- package/dist/commands/task.cjs +0 -1236
- package/dist/commands/task.d.cts +0 -97
- package/dist/commands/template.cjs +0 -457
- package/dist/commands/template.d.cts +0 -36
- package/dist/commands/wake.cjs +0 -2627
- package/dist/commands/wake.d.cts +0 -22
- package/dist/context-BUGaWpyL.d.cts +0 -46
- package/dist/index.cjs +0 -12373
- package/dist/index.d.cts +0 -854
- package/dist/inject-Bzi5E-By.d.cts +0 -137
- package/dist/lib/auto-linker.cjs +0 -176
- package/dist/lib/auto-linker.d.cts +0 -26
- package/dist/lib/config.cjs +0 -78
- package/dist/lib/config.d.cts +0 -11
- package/dist/lib/entity-index.cjs +0 -84
- package/dist/lib/entity-index.d.cts +0 -26
- package/dist/lib/project-utils.cjs +0 -864
- package/dist/lib/project-utils.d.cts +0 -97
- package/dist/lib/session-repair.cjs +0 -239
- package/dist/lib/session-repair.d.cts +0 -110
- package/dist/lib/session-utils.cjs +0 -209
- package/dist/lib/session-utils.d.cts +0 -63
- package/dist/lib/task-utils.cjs +0 -1137
- package/dist/lib/task-utils.d.cts +0 -208
- package/dist/lib/template-engine.cjs +0 -47
- package/dist/lib/template-engine.d.cts +0 -11
- package/dist/plugin/index.cjs +0 -1907
- package/dist/plugin/index.d.cts +0 -36
- package/dist/plugin/inject.cjs +0 -356
- package/dist/plugin/inject.d.cts +0 -54
- package/dist/plugin/inject.d.ts +0 -54
- package/dist/plugin/inject.js +0 -17
- package/dist/plugin/observe.cjs +0 -631
- package/dist/plugin/observe.d.cts +0 -39
- package/dist/plugin/observe.d.ts +0 -39
- package/dist/plugin/observe.js +0 -18
- package/dist/plugin/templates.cjs +0 -593
- package/dist/plugin/templates.d.cts +0 -52
- package/dist/plugin/templates.d.ts +0 -52
- package/dist/plugin/templates.js +0 -25
- package/dist/plugin/types.cjs +0 -18
- package/dist/plugin/types.d.cts +0 -209
- package/dist/plugin/types.d.ts +0 -209
- package/dist/plugin/types.js +0 -0
- package/dist/plugin/vault.cjs +0 -927
- package/dist/plugin/vault.d.cts +0 -68
- package/dist/plugin/vault.d.ts +0 -68
- package/dist/plugin/vault.js +0 -22
- package/dist/types-Y2_Um2Ls.d.cts +0 -205
- package/templates/memory-event.md +0 -67
- package/templates/party.md +0 -63
- package/templates/primitive-registry.yaml +0 -551
- package/templates/run.md +0 -68
- package/templates/trigger.md +0 -68
- package/templates/workspace.md +0 -50
|
@@ -7,8 +7,6 @@ var CHECKPOINT_FILE = "last-checkpoint.json";
|
|
|
7
7
|
var SESSION_STATE_FILE = "session-state.json";
|
|
8
8
|
var DIRTY_DEATH_FLAG = "dirty-death.flag";
|
|
9
9
|
var CHECKPOINT_HISTORY_DIR = "checkpoints";
|
|
10
|
-
var CHECKPOINT_RETENTION_MAX_COUNT = 50;
|
|
11
|
-
var CHECKPOINT_RETENTION_MAX_AGE_MS = 7 * 24 * 60 * 60 * 1e3;
|
|
12
10
|
var pendingCheckpoint = null;
|
|
13
11
|
var pendingData = null;
|
|
14
12
|
function ensureClawvaultDir(vaultPath) {
|
|
@@ -18,50 +16,6 @@ function ensureClawvaultDir(vaultPath) {
|
|
|
18
16
|
}
|
|
19
17
|
return dir;
|
|
20
18
|
}
|
|
21
|
-
function readCheckpointHistoryEntries(historyDir) {
|
|
22
|
-
const entries = [];
|
|
23
|
-
const files = fs.readdirSync(historyDir).filter((entry) => entry.endsWith(".json"));
|
|
24
|
-
for (const fileName of files) {
|
|
25
|
-
const filePath = path.join(historyDir, fileName);
|
|
26
|
-
try {
|
|
27
|
-
const parsed = JSON.parse(fs.readFileSync(filePath, "utf-8"));
|
|
28
|
-
if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
|
|
29
|
-
continue;
|
|
30
|
-
}
|
|
31
|
-
const timestamp = typeof parsed.timestamp === "string" ? parsed.timestamp : "";
|
|
32
|
-
const timestampMs = Date.parse(timestamp);
|
|
33
|
-
if (Number.isNaN(timestampMs)) {
|
|
34
|
-
continue;
|
|
35
|
-
}
|
|
36
|
-
entries.push({ filePath, timestampMs });
|
|
37
|
-
} catch {
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
return entries.sort((left, right) => {
|
|
41
|
-
if (right.timestampMs !== left.timestampMs) {
|
|
42
|
-
return right.timestampMs - left.timestampMs;
|
|
43
|
-
}
|
|
44
|
-
return right.filePath.localeCompare(left.filePath);
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
function pruneCheckpointHistory(historyDir, nowMs) {
|
|
48
|
-
if (!fs.existsSync(historyDir)) {
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
const entries = readCheckpointHistoryEntries(historyDir);
|
|
52
|
-
if (entries.length <= CHECKPOINT_RETENTION_MAX_COUNT) {
|
|
53
|
-
return;
|
|
54
|
-
}
|
|
55
|
-
for (let index = CHECKPOINT_RETENTION_MAX_COUNT; index < entries.length; index += 1) {
|
|
56
|
-
const ageMs = nowMs - entries[index].timestampMs;
|
|
57
|
-
if (ageMs > CHECKPOINT_RETENTION_MAX_AGE_MS) {
|
|
58
|
-
try {
|
|
59
|
-
fs.unlinkSync(entries[index].filePath);
|
|
60
|
-
} catch {
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
19
|
function writeCheckpointToDisk(dir, data) {
|
|
66
20
|
const checkpointPath = path.join(dir, CHECKPOINT_FILE);
|
|
67
21
|
fs.writeFileSync(checkpointPath, JSON.stringify(data, null, 2));
|
|
@@ -70,7 +24,6 @@ function writeCheckpointToDisk(dir, data) {
|
|
|
70
24
|
const historyFileName = `${data.timestamp.replace(/[:.]/g, "-")}.json`;
|
|
71
25
|
const historyPath = path.join(historyDir, historyFileName);
|
|
72
26
|
fs.writeFileSync(historyPath, JSON.stringify(data, null, 2));
|
|
73
|
-
pruneCheckpointHistory(historyDir, Date.now());
|
|
74
27
|
const flagPath = path.join(dir, DIRTY_DEATH_FLAG);
|
|
75
28
|
fs.writeFileSync(flagPath, data.timestamp);
|
|
76
29
|
}
|
|
@@ -3,7 +3,7 @@ var DATE_HEADING_RE = /^##\s+(\d{4}-\d{2}-\d{2})\s*$/;
|
|
|
3
3
|
var SCORED_LINE_RE = /^(?:-\s*)?\[(decision|preference|fact|commitment|task|todo|commitment-unresolved|milestone|lesson|relationship|project)\|c=(0(?:\.\d+)?|1(?:\.0+)?)\|i=(0(?:\.\d+)?|1(?:\.0+)?)\]\s+(.+)$/i;
|
|
4
4
|
var EMOJI_LINE_RE = /^(?:-\s*)?(🔴|🟡|🟢)\s+(\d{2}:\d{2})?\s*(.+)$/u;
|
|
5
5
|
var DECISION_RE = /\b(decis(?:ion|ions)?|decid(?:e|ed|ing)|chose|selected|opted|went with|picked)\b/i;
|
|
6
|
-
var PREFERENCE_RE = /\b(prefer(?:ence|s|red)?|likes?|dislikes?|default to|always use|never use
|
|
6
|
+
var PREFERENCE_RE = /\b(prefer(?:ence|s|red)?|likes?|dislikes?|default to|always use|never use)\b/i;
|
|
7
7
|
var COMMITMENT_RE = /\b(commit(?:ment|ted)?|promised|deadline|due|scheduled|will deliver|agreed to)\b/i;
|
|
8
8
|
var TODO_RE = /(?:\btodo:\s*|\bwe need to\b|\bdon't forget(?: to)?\b|\bremember to\b|\bmake sure to\b)/i;
|
|
9
9
|
var COMMITMENT_TASK_RE = /\b(?:i'?ll|i will|let me|(?:i'?m\s+)?going to|plan to|should)\b/i;
|
|
@@ -33,10 +33,10 @@ function inferObservationType(content) {
|
|
|
33
33
|
if (DECISION_RE.test(content)) return "decision";
|
|
34
34
|
if (UNRESOLVED_RE.test(content)) return "commitment-unresolved";
|
|
35
35
|
if (TODO_RE.test(content)) return "todo";
|
|
36
|
-
if (PREFERENCE_RE.test(content)) return "preference";
|
|
37
36
|
if (COMMITMENT_TASK_RE.test(content) || DEADLINE_RE.test(content)) return "task";
|
|
38
37
|
if (COMMITMENT_RE.test(content)) return "commitment";
|
|
39
38
|
if (MILESTONE_RE.test(content)) return "milestone";
|
|
39
|
+
if (PREFERENCE_RE.test(content)) return "preference";
|
|
40
40
|
if (LESSON_RE.test(content)) return "lesson";
|
|
41
41
|
if (RELATIONSHIP_RE.test(content)) return "relationship";
|
|
42
42
|
if (PROJECT_RE.test(content)) return "project";
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
// src/lib/config.ts
|
|
2
|
+
import * as fs from "fs";
|
|
3
|
+
import * as path from "path";
|
|
4
|
+
function getVaultPath() {
|
|
5
|
+
const vaultPath = process.env.CLAWVAULT_PATH;
|
|
6
|
+
if (!vaultPath) {
|
|
7
|
+
throw new Error("CLAWVAULT_PATH environment variable not set");
|
|
8
|
+
}
|
|
9
|
+
return path.resolve(vaultPath);
|
|
10
|
+
}
|
|
11
|
+
function findNearestVaultPath(startPath = process.cwd()) {
|
|
12
|
+
let current = path.resolve(startPath);
|
|
13
|
+
while (true) {
|
|
14
|
+
if (fs.existsSync(path.join(current, ".clawvault.json"))) {
|
|
15
|
+
return current;
|
|
16
|
+
}
|
|
17
|
+
const parent = path.dirname(current);
|
|
18
|
+
if (parent === current) {
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
current = parent;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
function validateVaultPath(vaultPath) {
|
|
25
|
+
if (!vaultPath || typeof vaultPath !== "string") return null;
|
|
26
|
+
const resolved = path.resolve(vaultPath);
|
|
27
|
+
if (!path.isAbsolute(resolved)) return null;
|
|
28
|
+
try {
|
|
29
|
+
const stat = fs.statSync(resolved);
|
|
30
|
+
if (!stat.isDirectory()) return null;
|
|
31
|
+
} catch {
|
|
32
|
+
return null;
|
|
33
|
+
}
|
|
34
|
+
const configPath = path.join(resolved, ".clawvault.json");
|
|
35
|
+
if (!fs.existsSync(configPath)) return null;
|
|
36
|
+
return resolved;
|
|
37
|
+
}
|
|
38
|
+
function resolveAgentVaultPath(agentVaults, agentId) {
|
|
39
|
+
if (!agentId || typeof agentId !== "string") return null;
|
|
40
|
+
if (!agentVaults || typeof agentVaults !== "object" || Array.isArray(agentVaults)) {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
const agentPath = agentVaults[agentId];
|
|
44
|
+
if (!agentPath || typeof agentPath !== "string") return null;
|
|
45
|
+
return validateVaultPath(agentPath);
|
|
46
|
+
}
|
|
47
|
+
function resolveVaultPath(options = {}) {
|
|
48
|
+
if (options.explicitPath) {
|
|
49
|
+
return path.resolve(options.explicitPath);
|
|
50
|
+
}
|
|
51
|
+
if (options.agentId && options.pluginConfig?.agentVaults) {
|
|
52
|
+
const agentVaultPath = resolveAgentVaultPath(
|
|
53
|
+
options.pluginConfig.agentVaults,
|
|
54
|
+
options.agentId
|
|
55
|
+
);
|
|
56
|
+
if (agentVaultPath) {
|
|
57
|
+
return agentVaultPath;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (options.pluginConfig?.vaultPath) {
|
|
61
|
+
const validated = validateVaultPath(options.pluginConfig.vaultPath);
|
|
62
|
+
if (validated) return validated;
|
|
63
|
+
}
|
|
64
|
+
if (process.env.CLAWVAULT_PATH) {
|
|
65
|
+
return path.resolve(process.env.CLAWVAULT_PATH);
|
|
66
|
+
}
|
|
67
|
+
const discovered = findNearestVaultPath(options.cwd ?? process.cwd());
|
|
68
|
+
if (discovered) {
|
|
69
|
+
return discovered;
|
|
70
|
+
}
|
|
71
|
+
throw new Error("No vault path found. Set CLAWVAULT_PATH, use --vault, or run inside a vault.");
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export {
|
|
75
|
+
getVaultPath,
|
|
76
|
+
findNearestVaultPath,
|
|
77
|
+
resolveAgentVaultPath,
|
|
78
|
+
resolveVaultPath
|
|
79
|
+
};
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import {
|
|
2
|
+
append
|
|
3
|
+
} from "./chunk-K7PNYS45.js";
|
|
4
|
+
import {
|
|
5
|
+
getType,
|
|
6
|
+
loadRegistry
|
|
7
|
+
} from "./chunk-NTOPJI7W.js";
|
|
8
|
+
import {
|
|
9
|
+
__export
|
|
10
|
+
} from "./chunk-U67V476Y.js";
|
|
11
|
+
|
|
12
|
+
// src/workgraph/store.ts
|
|
13
|
+
var store_exports = {};
|
|
14
|
+
__export(store_exports, {
|
|
15
|
+
activeThreads: () => activeThreads,
|
|
16
|
+
blockedThreads: () => blockedThreads,
|
|
17
|
+
create: () => create,
|
|
18
|
+
findByField: () => findByField,
|
|
19
|
+
list: () => list,
|
|
20
|
+
openThreads: () => openThreads,
|
|
21
|
+
read: () => read,
|
|
22
|
+
remove: () => remove,
|
|
23
|
+
update: () => update
|
|
24
|
+
});
|
|
25
|
+
import fs from "fs";
|
|
26
|
+
import path from "path";
|
|
27
|
+
import matter from "gray-matter";
|
|
28
|
+
function create(vaultPath, typeName, fields, body, actor) {
|
|
29
|
+
const typeDef = getType(vaultPath, typeName);
|
|
30
|
+
if (!typeDef) {
|
|
31
|
+
throw new Error(`Unknown primitive type "${typeName}". Run \`clawvault primitive list\` to see available types, or \`clawvault primitive define\` to create one.`);
|
|
32
|
+
}
|
|
33
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
34
|
+
const merged = applyDefaults(typeDef, {
|
|
35
|
+
...fields,
|
|
36
|
+
created: fields.created ?? now,
|
|
37
|
+
updated: now
|
|
38
|
+
});
|
|
39
|
+
const slug = slugify(String(merged.title ?? merged.name ?? typeName));
|
|
40
|
+
const relDir = typeDef.directory;
|
|
41
|
+
const relPath = `${relDir}/${slug}.md`;
|
|
42
|
+
const absDir = path.join(vaultPath, relDir);
|
|
43
|
+
const absPath = path.join(vaultPath, relPath);
|
|
44
|
+
if (!fs.existsSync(absDir)) fs.mkdirSync(absDir, { recursive: true });
|
|
45
|
+
if (fs.existsSync(absPath)) {
|
|
46
|
+
throw new Error(`File already exists: ${relPath}. Use update instead.`);
|
|
47
|
+
}
|
|
48
|
+
const content = matter.stringify(body, stripUndefined(merged));
|
|
49
|
+
fs.writeFileSync(absPath, content, "utf-8");
|
|
50
|
+
append(vaultPath, actor, "create", relPath, typeName, {
|
|
51
|
+
title: merged.title ?? slug
|
|
52
|
+
});
|
|
53
|
+
return { path: relPath, type: typeName, fields: merged, body };
|
|
54
|
+
}
|
|
55
|
+
function read(vaultPath, relPath) {
|
|
56
|
+
const absPath = path.join(vaultPath, relPath);
|
|
57
|
+
if (!fs.existsSync(absPath)) return null;
|
|
58
|
+
const raw = fs.readFileSync(absPath, "utf-8");
|
|
59
|
+
const { data, content } = matter(raw);
|
|
60
|
+
const typeName = inferType(vaultPath, relPath);
|
|
61
|
+
return { path: relPath, type: typeName, fields: data, body: content.trim() };
|
|
62
|
+
}
|
|
63
|
+
function list(vaultPath, typeName) {
|
|
64
|
+
const typeDef = getType(vaultPath, typeName);
|
|
65
|
+
if (!typeDef) return [];
|
|
66
|
+
const dir = path.join(vaultPath, typeDef.directory);
|
|
67
|
+
if (!fs.existsSync(dir)) return [];
|
|
68
|
+
const files = fs.readdirSync(dir).filter((f) => f.endsWith(".md"));
|
|
69
|
+
const instances = [];
|
|
70
|
+
for (const file of files) {
|
|
71
|
+
const relPath = `${typeDef.directory}/${file}`;
|
|
72
|
+
const inst = read(vaultPath, relPath);
|
|
73
|
+
if (inst) instances.push(inst);
|
|
74
|
+
}
|
|
75
|
+
return instances;
|
|
76
|
+
}
|
|
77
|
+
function update(vaultPath, relPath, fieldUpdates, bodyUpdate, actor) {
|
|
78
|
+
const existing = read(vaultPath, relPath);
|
|
79
|
+
if (!existing) throw new Error(`Not found: ${relPath}`);
|
|
80
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
81
|
+
const newFields = { ...existing.fields, ...fieldUpdates, updated: now };
|
|
82
|
+
const newBody = bodyUpdate ?? existing.body;
|
|
83
|
+
const absPath = path.join(vaultPath, relPath);
|
|
84
|
+
const content = matter.stringify(newBody, stripUndefined(newFields));
|
|
85
|
+
fs.writeFileSync(absPath, content, "utf-8");
|
|
86
|
+
append(vaultPath, actor, "update", relPath, existing.type, {
|
|
87
|
+
changed: Object.keys(fieldUpdates)
|
|
88
|
+
});
|
|
89
|
+
return { path: relPath, type: existing.type, fields: newFields, body: newBody };
|
|
90
|
+
}
|
|
91
|
+
function remove(vaultPath, relPath, actor) {
|
|
92
|
+
const absPath = path.join(vaultPath, relPath);
|
|
93
|
+
if (!fs.existsSync(absPath)) throw new Error(`Not found: ${relPath}`);
|
|
94
|
+
const archiveDir = path.join(vaultPath, ".clawvault", "archive");
|
|
95
|
+
if (!fs.existsSync(archiveDir)) fs.mkdirSync(archiveDir, { recursive: true });
|
|
96
|
+
const archivePath = path.join(archiveDir, path.basename(relPath));
|
|
97
|
+
fs.renameSync(absPath, archivePath);
|
|
98
|
+
const typeName = inferType(vaultPath, relPath);
|
|
99
|
+
append(vaultPath, actor, "delete", relPath, typeName);
|
|
100
|
+
}
|
|
101
|
+
function findByField(vaultPath, typeName, field, value) {
|
|
102
|
+
return list(vaultPath, typeName).filter((inst) => inst.fields[field] === value);
|
|
103
|
+
}
|
|
104
|
+
function openThreads(vaultPath) {
|
|
105
|
+
return findByField(vaultPath, "thread", "status", "open");
|
|
106
|
+
}
|
|
107
|
+
function activeThreads(vaultPath) {
|
|
108
|
+
return findByField(vaultPath, "thread", "status", "active");
|
|
109
|
+
}
|
|
110
|
+
function blockedThreads(vaultPath) {
|
|
111
|
+
return findByField(vaultPath, "thread", "status", "blocked");
|
|
112
|
+
}
|
|
113
|
+
function slugify(text) {
|
|
114
|
+
return text.toLowerCase().replace(/[^a-z0-9]+/g, "-").replace(/^-|-$/g, "").slice(0, 80);
|
|
115
|
+
}
|
|
116
|
+
function applyDefaults(typeDef, fields) {
|
|
117
|
+
const result = { ...fields };
|
|
118
|
+
for (const [key, def] of Object.entries(typeDef.fields)) {
|
|
119
|
+
if (result[key] === void 0 && def.default !== void 0) {
|
|
120
|
+
result[key] = def.default;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return result;
|
|
124
|
+
}
|
|
125
|
+
function stripUndefined(obj) {
|
|
126
|
+
const result = {};
|
|
127
|
+
for (const [k, v] of Object.entries(obj)) {
|
|
128
|
+
if (v !== void 0) result[k] = v;
|
|
129
|
+
}
|
|
130
|
+
return result;
|
|
131
|
+
}
|
|
132
|
+
function inferType(vaultPath, relPath) {
|
|
133
|
+
const registry = loadRegistry(vaultPath);
|
|
134
|
+
const dir = relPath.split("/")[0];
|
|
135
|
+
for (const typeDef of Object.values(registry.types)) {
|
|
136
|
+
if (typeDef.directory === dir) return typeDef.name;
|
|
137
|
+
}
|
|
138
|
+
return "unknown";
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
export {
|
|
142
|
+
create,
|
|
143
|
+
read,
|
|
144
|
+
list,
|
|
145
|
+
update,
|
|
146
|
+
remove,
|
|
147
|
+
findByField,
|
|
148
|
+
openThreads,
|
|
149
|
+
activeThreads,
|
|
150
|
+
blockedThreads,
|
|
151
|
+
store_exports
|
|
152
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import {
|
|
2
|
+
registerTailscaleCommands
|
|
3
|
+
} from "./chunk-Y6VJKXGL.js";
|
|
4
|
+
import {
|
|
5
|
+
registerObserveCommand
|
|
6
|
+
} from "./chunk-4ITRXIVT.js";
|
|
7
|
+
import {
|
|
8
|
+
registerReflectCommand
|
|
9
|
+
} from "./chunk-S5OJEGFG.js";
|
|
10
|
+
import {
|
|
11
|
+
registerContextCommand
|
|
12
|
+
} from "./chunk-WJVWINEM.js";
|
|
13
|
+
import {
|
|
14
|
+
registerEmbedCommand
|
|
15
|
+
} from "./chunk-ECRZL5XR.js";
|
|
16
|
+
import {
|
|
17
|
+
registerInjectCommand
|
|
18
|
+
} from "./chunk-YNIPYN4F.js";
|
|
19
|
+
|
|
20
|
+
// src/cli/index.ts
|
|
21
|
+
function registerCliCommands(program) {
|
|
22
|
+
registerContextCommand(program);
|
|
23
|
+
registerInjectCommand(program);
|
|
24
|
+
registerObserveCommand(program);
|
|
25
|
+
registerReflectCommand(program);
|
|
26
|
+
registerEmbedCommand(program);
|
|
27
|
+
registerTailscaleCommands(program);
|
|
28
|
+
return program;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
export {
|
|
32
|
+
registerCliCommands
|
|
33
|
+
};
|