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
package/dist/plugin/index.d.cts
DELETED
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import { TemplateRegistry } from './templates.cjs';
|
|
2
|
-
export { classifyText, getAllSchemas, getSchema, getSchemaNames, initializeTemplateRegistry } from './templates.cjs';
|
|
3
|
-
export { detectCategory, extractObservations, extractSearchTerms, isObservable, processMessageForObservations } from './observe.cjs';
|
|
4
|
-
export { buildFullContext, buildPreferenceContext, buildSessionRecap, formatMemoriesForContext, formatSearchResults, scanVaultFiles } from './inject.cjs';
|
|
5
|
-
export { appendToLedger, batchWriteObservations, ensureVaultStructure, writeObservation, writeVaultFile } from './vault.cjs';
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* ClawVault OpenClaw Plugin v2.2.0
|
|
9
|
-
*
|
|
10
|
-
* Memory slot provider for OpenClaw. Template-driven observational memory architecture:
|
|
11
|
-
* memories are captured automatically from conversations, classified against template
|
|
12
|
-
* schemas, and stored with proper frontmatter validation.
|
|
13
|
-
*
|
|
14
|
-
* Architecture:
|
|
15
|
-
* ClawVault (engine) ←→ Plugin (integration) ←→ OpenClaw (agent platform)
|
|
16
|
-
* - ClawVault = vault, observations, search index, knowledge graph
|
|
17
|
-
* - Plugin = auto-recall, auto-capture, search tools, lifecycle hooks
|
|
18
|
-
* - OpenClaw = agent runtime, sessions, tools, channels
|
|
19
|
-
* - Templates = schema definitions for primitive types
|
|
20
|
-
*
|
|
21
|
-
* The plugin does NOT give the agent a "store memory" tool. Memory is
|
|
22
|
-
* observational: the system watches conversations and captures automatically.
|
|
23
|
-
* The agent searches memory; it doesn't manage it.
|
|
24
|
-
*/
|
|
25
|
-
|
|
26
|
-
declare function getTemplateRegistry(): TemplateRegistry | null;
|
|
27
|
-
declare const clawvaultPlugin: {
|
|
28
|
-
id: string;
|
|
29
|
-
name: string;
|
|
30
|
-
description: string;
|
|
31
|
-
version: string;
|
|
32
|
-
kind: "memory";
|
|
33
|
-
register(api: any): void;
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
export { clawvaultPlugin as default, getTemplateRegistry };
|
package/dist/plugin/inject.cjs
DELETED
|
@@ -1,356 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/plugin/inject.ts
|
|
21
|
-
var inject_exports = {};
|
|
22
|
-
__export(inject_exports, {
|
|
23
|
-
buildFullContext: () => buildFullContext,
|
|
24
|
-
buildPreferenceContext: () => buildPreferenceContext,
|
|
25
|
-
buildSessionRecap: () => buildSessionRecap,
|
|
26
|
-
formatMemoriesForContext: () => formatMemoriesForContext,
|
|
27
|
-
formatSearchResults: () => formatSearchResults,
|
|
28
|
-
scanVaultFiles: () => scanVaultFiles
|
|
29
|
-
});
|
|
30
|
-
module.exports = __toCommonJS(inject_exports);
|
|
31
|
-
var import_node_fs = require("fs");
|
|
32
|
-
var import_node_path = require("path");
|
|
33
|
-
function parseYamlFrontmatter(content) {
|
|
34
|
-
const match = content.match(/^---\n([\s\S]*?)\n---\n?([\s\S]*)$/);
|
|
35
|
-
if (!match) return null;
|
|
36
|
-
const yamlContent = match[1];
|
|
37
|
-
const body = match[2];
|
|
38
|
-
try {
|
|
39
|
-
const frontmatter = parseSimpleYaml(yamlContent);
|
|
40
|
-
return { frontmatter, body };
|
|
41
|
-
} catch {
|
|
42
|
-
return null;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
function parseSimpleYaml(yaml) {
|
|
46
|
-
const result = {};
|
|
47
|
-
const lines = yaml.split("\n");
|
|
48
|
-
for (const line of lines) {
|
|
49
|
-
if (!line.trim() || line.trim().startsWith("#")) continue;
|
|
50
|
-
const colonIndex = line.indexOf(":");
|
|
51
|
-
if (colonIndex === -1) continue;
|
|
52
|
-
const key = line.slice(0, colonIndex).trim();
|
|
53
|
-
const valueStr = line.slice(colonIndex + 1).trim();
|
|
54
|
-
if (valueStr === "" || valueStr.startsWith("|") || valueStr.startsWith(">")) continue;
|
|
55
|
-
result[key] = parseYamlValue(valueStr);
|
|
56
|
-
}
|
|
57
|
-
return result;
|
|
58
|
-
}
|
|
59
|
-
function parseYamlValue(value) {
|
|
60
|
-
if (value === "" || value === "null" || value === "~") return null;
|
|
61
|
-
if (value === "true") return true;
|
|
62
|
-
if (value === "false") return false;
|
|
63
|
-
if (/^-?\d+$/.test(value)) return parseInt(value, 10);
|
|
64
|
-
if (/^-?\d+\.\d+$/.test(value)) return parseFloat(value);
|
|
65
|
-
if (value.startsWith('"') && value.endsWith('"') || value.startsWith("'") && value.endsWith("'")) {
|
|
66
|
-
return value.slice(1, -1);
|
|
67
|
-
}
|
|
68
|
-
return value;
|
|
69
|
-
}
|
|
70
|
-
function scanVaultFiles(vaultPath, options = {}) {
|
|
71
|
-
const files = [];
|
|
72
|
-
const maxAge = options.maxAge ?? 7 * 24 * 60 * 60 * 1e3;
|
|
73
|
-
const limit = options.limit ?? 100;
|
|
74
|
-
const now = Date.now();
|
|
75
|
-
const cutoff = now - maxAge;
|
|
76
|
-
const dirsToScan = findVaultDirectories(vaultPath);
|
|
77
|
-
for (const dir of dirsToScan) {
|
|
78
|
-
if (!(0, import_node_fs.existsSync)(dir)) continue;
|
|
79
|
-
try {
|
|
80
|
-
scanDirectory(dir, vaultPath, files, cutoff, options.primitiveTypes);
|
|
81
|
-
} catch {
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
files.sort((a, b) => b.modifiedAt.getTime() - a.modifiedAt.getTime());
|
|
85
|
-
return files.slice(0, limit);
|
|
86
|
-
}
|
|
87
|
-
function findVaultDirectories(vaultPath) {
|
|
88
|
-
const dirs = [];
|
|
89
|
-
dirs.push(vaultPath);
|
|
90
|
-
const commonDirs = [
|
|
91
|
-
"tasks",
|
|
92
|
-
"projects",
|
|
93
|
-
"decisions",
|
|
94
|
-
"people",
|
|
95
|
-
"persons",
|
|
96
|
-
"notes",
|
|
97
|
-
"daily",
|
|
98
|
-
"journal",
|
|
99
|
-
"ledger",
|
|
100
|
-
"memory",
|
|
101
|
-
"memories",
|
|
102
|
-
"observations",
|
|
103
|
-
"lessons",
|
|
104
|
-
"triggers",
|
|
105
|
-
"runs",
|
|
106
|
-
"checkpoints",
|
|
107
|
-
"handoffs",
|
|
108
|
-
"workspaces",
|
|
109
|
-
"parties"
|
|
110
|
-
];
|
|
111
|
-
for (const subdir of commonDirs) {
|
|
112
|
-
const fullPath = (0, import_node_path.join)(vaultPath, subdir);
|
|
113
|
-
if ((0, import_node_fs.existsSync)(fullPath)) {
|
|
114
|
-
dirs.push(fullPath);
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
try {
|
|
118
|
-
const entries = (0, import_node_fs.readdirSync)(vaultPath, { withFileTypes: true });
|
|
119
|
-
for (const entry of entries) {
|
|
120
|
-
if (entry.isDirectory() && !entry.name.startsWith(".") && !entry.name.startsWith("_")) {
|
|
121
|
-
const fullPath = (0, import_node_path.join)(vaultPath, entry.name);
|
|
122
|
-
if (!dirs.includes(fullPath)) {
|
|
123
|
-
dirs.push(fullPath);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
} catch {
|
|
128
|
-
}
|
|
129
|
-
return dirs;
|
|
130
|
-
}
|
|
131
|
-
function scanDirectory(dir, vaultPath, files, cutoff, primitiveTypes) {
|
|
132
|
-
const entries = (0, import_node_fs.readdirSync)(dir, { withFileTypes: true });
|
|
133
|
-
for (const entry of entries) {
|
|
134
|
-
if (entry.name.startsWith(".") || entry.name.startsWith("_")) continue;
|
|
135
|
-
const fullPath = (0, import_node_path.join)(dir, entry.name);
|
|
136
|
-
if (entry.isDirectory()) {
|
|
137
|
-
const depth = fullPath.replace(vaultPath, "").split("/").length;
|
|
138
|
-
if (depth <= 3) {
|
|
139
|
-
scanDirectory(fullPath, vaultPath, files, cutoff, primitiveTypes);
|
|
140
|
-
}
|
|
141
|
-
} else if (entry.name.endsWith(".md")) {
|
|
142
|
-
try {
|
|
143
|
-
const stat = (0, import_node_fs.statSync)(fullPath);
|
|
144
|
-
if (stat.mtimeMs < cutoff) continue;
|
|
145
|
-
const content = (0, import_node_fs.readFileSync)(fullPath, "utf-8");
|
|
146
|
-
const parsed = parseYamlFrontmatter(content);
|
|
147
|
-
if (!parsed) continue;
|
|
148
|
-
const primitiveType = detectPrimitiveType(parsed.frontmatter, fullPath);
|
|
149
|
-
if (primitiveTypes && !primitiveTypes.includes(primitiveType)) continue;
|
|
150
|
-
files.push({
|
|
151
|
-
path: fullPath,
|
|
152
|
-
relativePath: (0, import_node_path.relative)(vaultPath, fullPath),
|
|
153
|
-
primitiveType,
|
|
154
|
-
frontmatter: parsed.frontmatter,
|
|
155
|
-
content: parsed.body,
|
|
156
|
-
modifiedAt: stat.mtime,
|
|
157
|
-
createdAt: stat.birthtime
|
|
158
|
-
});
|
|
159
|
-
} catch {
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
function detectPrimitiveType(frontmatter, filePath) {
|
|
165
|
-
if (frontmatter.primitive) return String(frontmatter.primitive);
|
|
166
|
-
if (frontmatter.type) return String(frontmatter.type);
|
|
167
|
-
const pathLower = filePath.toLowerCase();
|
|
168
|
-
if (pathLower.includes("/tasks/")) return "task";
|
|
169
|
-
if (pathLower.includes("/projects/")) return "project";
|
|
170
|
-
if (pathLower.includes("/decisions/")) return "decision";
|
|
171
|
-
if (pathLower.includes("/people/") || pathLower.includes("/persons/")) return "person";
|
|
172
|
-
if (pathLower.includes("/daily/") || pathLower.includes("/journal/")) return "daily-note";
|
|
173
|
-
if (pathLower.includes("/lessons/")) return "lesson";
|
|
174
|
-
if (pathLower.includes("/triggers/")) return "trigger";
|
|
175
|
-
if (pathLower.includes("/runs/")) return "run";
|
|
176
|
-
if (pathLower.includes("/checkpoints/")) return "checkpoint";
|
|
177
|
-
if (pathLower.includes("/handoffs/")) return "handoff";
|
|
178
|
-
if (pathLower.includes("/ledger/")) return "memory_event";
|
|
179
|
-
if (pathLower.includes("/memory/") || pathLower.includes("/memories/")) return "memory_event";
|
|
180
|
-
return "unknown";
|
|
181
|
-
}
|
|
182
|
-
function buildSessionRecap(vaultPath, options = {}) {
|
|
183
|
-
const maxAge = options.maxAge ?? 24 * 60 * 60 * 1e3;
|
|
184
|
-
const limit = options.limit ?? 20;
|
|
185
|
-
const includeContent = options.includeContent ?? false;
|
|
186
|
-
const files = scanVaultFiles(vaultPath, { maxAge, limit });
|
|
187
|
-
if (files.length === 0) {
|
|
188
|
-
return {
|
|
189
|
-
xml: "",
|
|
190
|
-
fileCount: 0,
|
|
191
|
-
primitiveGroups: {},
|
|
192
|
-
timeRange: null
|
|
193
|
-
};
|
|
194
|
-
}
|
|
195
|
-
const groups = {};
|
|
196
|
-
for (const file of files) {
|
|
197
|
-
const type = file.primitiveType;
|
|
198
|
-
if (!groups[type]) groups[type] = [];
|
|
199
|
-
groups[type].push(file);
|
|
200
|
-
}
|
|
201
|
-
const lines = ["<session-recap>"];
|
|
202
|
-
lines.push(`<summary>Found ${files.length} recent items across ${Object.keys(groups).length} categories</summary>`);
|
|
203
|
-
for (const [primitiveType, groupFiles] of Object.entries(groups)) {
|
|
204
|
-
lines.push(`<${primitiveType}-items count="${groupFiles.length}">`);
|
|
205
|
-
for (const file of groupFiles.slice(0, 5)) {
|
|
206
|
-
const title = file.frontmatter.title || file.frontmatter.summary || file.relativePath;
|
|
207
|
-
const status = file.frontmatter.status || "";
|
|
208
|
-
const modified = file.modifiedAt.toISOString().slice(0, 16).replace("T", " ");
|
|
209
|
-
lines.push(` <item path="${file.relativePath}" modified="${modified}"${status ? ` status="${status}"` : ""}>`);
|
|
210
|
-
lines.push(` <title>${escapeXml(String(title))}</title>`);
|
|
211
|
-
if (includeContent && file.content) {
|
|
212
|
-
const snippet = file.content.slice(0, 200).replace(/\n/g, " ").trim();
|
|
213
|
-
if (snippet) {
|
|
214
|
-
lines.push(` <snippet>${escapeXml(snippet)}</snippet>`);
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
lines.push(" </item>");
|
|
218
|
-
}
|
|
219
|
-
if (groupFiles.length > 5) {
|
|
220
|
-
lines.push(` <more count="${groupFiles.length - 5}" />`);
|
|
221
|
-
}
|
|
222
|
-
lines.push(`</${primitiveType}-items>`);
|
|
223
|
-
}
|
|
224
|
-
lines.push("</session-recap>");
|
|
225
|
-
const sortedByTime = [...files].sort((a, b) => a.modifiedAt.getTime() - b.modifiedAt.getTime());
|
|
226
|
-
const timeRange = {
|
|
227
|
-
oldest: sortedByTime[0].modifiedAt,
|
|
228
|
-
newest: sortedByTime[sortedByTime.length - 1].modifiedAt
|
|
229
|
-
};
|
|
230
|
-
const primitiveGroups = {};
|
|
231
|
-
for (const [type, groupFiles] of Object.entries(groups)) {
|
|
232
|
-
primitiveGroups[type] = groupFiles.length;
|
|
233
|
-
}
|
|
234
|
-
return {
|
|
235
|
-
xml: lines.join("\n"),
|
|
236
|
-
fileCount: files.length,
|
|
237
|
-
primitiveGroups,
|
|
238
|
-
timeRange
|
|
239
|
-
};
|
|
240
|
-
}
|
|
241
|
-
function buildPreferenceContext(vaultPath, options = {}) {
|
|
242
|
-
const maxAge = options.maxAge ?? 30 * 24 * 60 * 60 * 1e3;
|
|
243
|
-
const limit = options.limit ?? 50;
|
|
244
|
-
const files = scanVaultFiles(vaultPath, { maxAge, limit: limit * 2 });
|
|
245
|
-
const preferenceFiles = files.filter((file) => {
|
|
246
|
-
if (file.frontmatter.type === "preference") return true;
|
|
247
|
-
if (file.primitiveType === "memory_event" && file.frontmatter.type === "preference") return true;
|
|
248
|
-
const content = (file.content || "").toLowerCase();
|
|
249
|
-
if (/\b(prefer|like|love|hate|dislike|want|need|always|never)\b/.test(content)) {
|
|
250
|
-
return true;
|
|
251
|
-
}
|
|
252
|
-
return false;
|
|
253
|
-
}).slice(0, limit);
|
|
254
|
-
if (preferenceFiles.length === 0) {
|
|
255
|
-
return {
|
|
256
|
-
xml: "",
|
|
257
|
-
preferenceCount: 0,
|
|
258
|
-
categories: []
|
|
259
|
-
};
|
|
260
|
-
}
|
|
261
|
-
const categories = /* @__PURE__ */ new Set();
|
|
262
|
-
for (const file of preferenceFiles) {
|
|
263
|
-
if (file.frontmatter.category) {
|
|
264
|
-
categories.add(String(file.frontmatter.category));
|
|
265
|
-
}
|
|
266
|
-
}
|
|
267
|
-
const lines = ["<user-preferences>"];
|
|
268
|
-
for (const file of preferenceFiles) {
|
|
269
|
-
const summary = file.frontmatter.summary || file.frontmatter.title || extractPreferenceSummary(file.content);
|
|
270
|
-
if (!summary) continue;
|
|
271
|
-
const category = file.frontmatter.category || "general";
|
|
272
|
-
const sentiment = file.frontmatter.sentiment || inferSentiment(file.content);
|
|
273
|
-
lines.push(` <preference category="${escapeXml(String(category))}" sentiment="${sentiment}">`);
|
|
274
|
-
lines.push(` ${escapeXml(String(summary))}`);
|
|
275
|
-
lines.push(" </preference>");
|
|
276
|
-
}
|
|
277
|
-
lines.push("</user-preferences>");
|
|
278
|
-
return {
|
|
279
|
-
xml: lines.join("\n"),
|
|
280
|
-
preferenceCount: preferenceFiles.length,
|
|
281
|
-
categories: Array.from(categories)
|
|
282
|
-
};
|
|
283
|
-
}
|
|
284
|
-
function extractPreferenceSummary(content) {
|
|
285
|
-
if (!content) return "";
|
|
286
|
-
const sentences = content.split(/[.!?\n]+/).map((s) => s.trim()).filter((s) => s.length > 10);
|
|
287
|
-
for (const sentence of sentences) {
|
|
288
|
-
if (/\b(prefer|like|love|hate|dislike|want|need|always|never)\b/i.test(sentence)) {
|
|
289
|
-
return sentence.slice(0, 150);
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
return sentences[0]?.slice(0, 150) || "";
|
|
293
|
-
}
|
|
294
|
-
function inferSentiment(content) {
|
|
295
|
-
if (!content) return "neutral";
|
|
296
|
-
const lower = content.toLowerCase();
|
|
297
|
-
if (/\b(love|like|prefer|enjoy|want|need|always)\b/.test(lower)) return "positive";
|
|
298
|
-
if (/\b(hate|dislike|don't like|never|avoid)\b/.test(lower)) return "negative";
|
|
299
|
-
return "neutral";
|
|
300
|
-
}
|
|
301
|
-
function formatMemoriesForContext(results, collection) {
|
|
302
|
-
if (results.length === 0) return "";
|
|
303
|
-
const lines = results.map((r, i) => {
|
|
304
|
-
const file = (r.file || "").replace(`qmd://${collection}/`, "");
|
|
305
|
-
const snippet = (r.snippet || "").replace(/@@ .+? @@\s*\(.+?\)\n?/g, "").trim() || r.title || "";
|
|
306
|
-
return `${i + 1}. [${file}] ${snippet}`;
|
|
307
|
-
});
|
|
308
|
-
return `<relevant-memories>
|
|
309
|
-
These are recalled from long-term vault memory. Treat as historical context.
|
|
310
|
-
${lines.join("\n")}
|
|
311
|
-
</relevant-memories>`;
|
|
312
|
-
}
|
|
313
|
-
function formatSearchResults(results, collection) {
|
|
314
|
-
if (results.length === 0) return "No relevant memories found.";
|
|
315
|
-
return results.map((r, i) => {
|
|
316
|
-
const file = (r.file || "").replace(`qmd://${collection}/`, "");
|
|
317
|
-
const snippet = (r.snippet || "").replace(/@@ .+? @@\s*\(.+?\)\n?/g, "").trim() || r.title || "(no content)";
|
|
318
|
-
const score = ((r.score ?? 0) * 100).toFixed(0);
|
|
319
|
-
return `${i + 1}. [${file}] ${snippet} (${score}%)`;
|
|
320
|
-
}).join("\n");
|
|
321
|
-
}
|
|
322
|
-
function escapeXml(str) {
|
|
323
|
-
return str.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'");
|
|
324
|
-
}
|
|
325
|
-
function buildFullContext(vaultPath, options = {}) {
|
|
326
|
-
const parts = [];
|
|
327
|
-
if (options.includeRecap !== false) {
|
|
328
|
-
const recap = buildSessionRecap(vaultPath, {
|
|
329
|
-
maxAge: options.recapMaxAge ?? 24 * 60 * 60 * 1e3,
|
|
330
|
-
limit: 15,
|
|
331
|
-
includeContent: true
|
|
332
|
-
});
|
|
333
|
-
if (recap.xml) {
|
|
334
|
-
parts.push(recap.xml);
|
|
335
|
-
}
|
|
336
|
-
}
|
|
337
|
-
if (options.includePreferences !== false) {
|
|
338
|
-
const prefs = buildPreferenceContext(vaultPath, {
|
|
339
|
-
maxAge: options.preferenceMaxAge ?? 30 * 24 * 60 * 60 * 1e3,
|
|
340
|
-
limit: 20
|
|
341
|
-
});
|
|
342
|
-
if (prefs.xml) {
|
|
343
|
-
parts.push(prefs.xml);
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
return parts.join("\n\n");
|
|
347
|
-
}
|
|
348
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
349
|
-
0 && (module.exports = {
|
|
350
|
-
buildFullContext,
|
|
351
|
-
buildPreferenceContext,
|
|
352
|
-
buildSessionRecap,
|
|
353
|
-
formatMemoriesForContext,
|
|
354
|
-
formatSearchResults,
|
|
355
|
-
scanVaultFiles
|
|
356
|
-
});
|
package/dist/plugin/inject.d.cts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Dynamic Context Injection for ClawVault
|
|
3
|
-
*
|
|
4
|
-
* Builds session recaps and preference context by dynamically scanning
|
|
5
|
-
* the vault instead of using hardcoded paths. Groups files by primitive
|
|
6
|
-
* type and builds context XML for injection.
|
|
7
|
-
*/
|
|
8
|
-
interface VaultFile {
|
|
9
|
-
path: string;
|
|
10
|
-
relativePath: string;
|
|
11
|
-
primitiveType: string;
|
|
12
|
-
frontmatter: Record<string, unknown>;
|
|
13
|
-
content: string;
|
|
14
|
-
modifiedAt: Date;
|
|
15
|
-
createdAt: Date;
|
|
16
|
-
}
|
|
17
|
-
interface SessionRecap {
|
|
18
|
-
xml: string;
|
|
19
|
-
fileCount: number;
|
|
20
|
-
primitiveGroups: Record<string, number>;
|
|
21
|
-
timeRange: {
|
|
22
|
-
oldest: Date;
|
|
23
|
-
newest: Date;
|
|
24
|
-
} | null;
|
|
25
|
-
}
|
|
26
|
-
interface PreferenceContext {
|
|
27
|
-
xml: string;
|
|
28
|
-
preferenceCount: number;
|
|
29
|
-
categories: string[];
|
|
30
|
-
}
|
|
31
|
-
declare function scanVaultFiles(vaultPath: string, options?: {
|
|
32
|
-
maxAge?: number;
|
|
33
|
-
limit?: number;
|
|
34
|
-
primitiveTypes?: string[];
|
|
35
|
-
}): VaultFile[];
|
|
36
|
-
declare function buildSessionRecap(vaultPath: string, options?: {
|
|
37
|
-
maxAge?: number;
|
|
38
|
-
limit?: number;
|
|
39
|
-
includeContent?: boolean;
|
|
40
|
-
}): SessionRecap;
|
|
41
|
-
declare function buildPreferenceContext(vaultPath: string, options?: {
|
|
42
|
-
maxAge?: number;
|
|
43
|
-
limit?: number;
|
|
44
|
-
}): PreferenceContext;
|
|
45
|
-
declare function formatMemoriesForContext(results: any[], collection: string): string;
|
|
46
|
-
declare function formatSearchResults(results: any[], collection: string): string;
|
|
47
|
-
declare function buildFullContext(vaultPath: string, options?: {
|
|
48
|
-
includeRecap?: boolean;
|
|
49
|
-
includePreferences?: boolean;
|
|
50
|
-
recapMaxAge?: number;
|
|
51
|
-
preferenceMaxAge?: number;
|
|
52
|
-
}): string;
|
|
53
|
-
|
|
54
|
-
export { type PreferenceContext, type SessionRecap, type VaultFile, buildFullContext, buildPreferenceContext, buildSessionRecap, formatMemoriesForContext, formatSearchResults, scanVaultFiles };
|
package/dist/plugin/inject.d.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Dynamic Context Injection for ClawVault
|
|
3
|
-
*
|
|
4
|
-
* Builds session recaps and preference context by dynamically scanning
|
|
5
|
-
* the vault instead of using hardcoded paths. Groups files by primitive
|
|
6
|
-
* type and builds context XML for injection.
|
|
7
|
-
*/
|
|
8
|
-
interface VaultFile {
|
|
9
|
-
path: string;
|
|
10
|
-
relativePath: string;
|
|
11
|
-
primitiveType: string;
|
|
12
|
-
frontmatter: Record<string, unknown>;
|
|
13
|
-
content: string;
|
|
14
|
-
modifiedAt: Date;
|
|
15
|
-
createdAt: Date;
|
|
16
|
-
}
|
|
17
|
-
interface SessionRecap {
|
|
18
|
-
xml: string;
|
|
19
|
-
fileCount: number;
|
|
20
|
-
primitiveGroups: Record<string, number>;
|
|
21
|
-
timeRange: {
|
|
22
|
-
oldest: Date;
|
|
23
|
-
newest: Date;
|
|
24
|
-
} | null;
|
|
25
|
-
}
|
|
26
|
-
interface PreferenceContext {
|
|
27
|
-
xml: string;
|
|
28
|
-
preferenceCount: number;
|
|
29
|
-
categories: string[];
|
|
30
|
-
}
|
|
31
|
-
declare function scanVaultFiles(vaultPath: string, options?: {
|
|
32
|
-
maxAge?: number;
|
|
33
|
-
limit?: number;
|
|
34
|
-
primitiveTypes?: string[];
|
|
35
|
-
}): VaultFile[];
|
|
36
|
-
declare function buildSessionRecap(vaultPath: string, options?: {
|
|
37
|
-
maxAge?: number;
|
|
38
|
-
limit?: number;
|
|
39
|
-
includeContent?: boolean;
|
|
40
|
-
}): SessionRecap;
|
|
41
|
-
declare function buildPreferenceContext(vaultPath: string, options?: {
|
|
42
|
-
maxAge?: number;
|
|
43
|
-
limit?: number;
|
|
44
|
-
}): PreferenceContext;
|
|
45
|
-
declare function formatMemoriesForContext(results: any[], collection: string): string;
|
|
46
|
-
declare function formatSearchResults(results: any[], collection: string): string;
|
|
47
|
-
declare function buildFullContext(vaultPath: string, options?: {
|
|
48
|
-
includeRecap?: boolean;
|
|
49
|
-
includePreferences?: boolean;
|
|
50
|
-
recapMaxAge?: number;
|
|
51
|
-
preferenceMaxAge?: number;
|
|
52
|
-
}): string;
|
|
53
|
-
|
|
54
|
-
export { type PreferenceContext, type SessionRecap, type VaultFile, buildFullContext, buildPreferenceContext, buildSessionRecap, formatMemoriesForContext, formatSearchResults, scanVaultFiles };
|
package/dist/plugin/inject.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
buildFullContext,
|
|
3
|
-
buildPreferenceContext,
|
|
4
|
-
buildSessionRecap,
|
|
5
|
-
formatMemoriesForContext,
|
|
6
|
-
formatSearchResults,
|
|
7
|
-
scanVaultFiles
|
|
8
|
-
} from "../chunk-CMB7UL7C.js";
|
|
9
|
-
import "../chunk-3RG5ZIWI.js";
|
|
10
|
-
export {
|
|
11
|
-
buildFullContext,
|
|
12
|
-
buildPreferenceContext,
|
|
13
|
-
buildSessionRecap,
|
|
14
|
-
formatMemoriesForContext,
|
|
15
|
-
formatSearchResults,
|
|
16
|
-
scanVaultFiles
|
|
17
|
-
};
|