clawvault 3.1.0 → 3.2.0
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 +1368 -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-F2JEUD4J.js → chunk-23YDQ3QU.js} +6 -8
- package/dist/{chunk-C7OK5WKP.js → chunk-2JQ3O2YL.js} +4 -4
- package/dist/{chunk-VR5NE7PZ.js → chunk-2RAZ4ZFE.js} +1 -1
- package/dist/chunk-2ZDO52B4.js +52 -0
- package/dist/{chunk-ZZA73MFY.js → chunk-33DOSHTA.js} +176 -36
- package/dist/chunk-33VSQP4J.js +37 -0
- package/dist/chunk-4BQTQMJP.js +93 -0
- package/dist/{chunk-GUKMRGM7.js → chunk-4OXMU5S2.js} +1 -1
- package/dist/{chunk-62YTUT6J.js → chunk-4PY655YM.js} +15 -3
- package/dist/chunk-6FH3IULF.js +352 -0
- package/dist/{chunk-3NSBOUT3.js → chunk-77Q5CSPJ.js} +404 -80
- package/dist/{chunk-4VQTUVH7.js → chunk-7YZWHM36.js} +52 -26
- package/dist/chunk-BSJ6RIT7.js +447 -0
- package/dist/chunk-BUEW6IIK.js +364 -0
- package/dist/{chunk-LI4O6NVK.js → chunk-CLJTREDS.js} +74 -14
- package/dist/chunk-EK6S23ZB.js +469 -0
- package/dist/{chunk-LNJA2UGL.js → chunk-ESFLMDRB.js} +9 -86
- package/dist/{chunk-H34S76MB.js → chunk-ESVS6K2B.js} +6 -6
- package/dist/{chunk-WAZ3NLWL.js → chunk-F55HGNU4.js} +0 -47
- package/dist/{chunk-QK3UCXWL.js → chunk-FHFUXL6G.js} +2 -2
- package/dist/{chunk-H62BP7RI.js → chunk-GAOWA7GR.js} +212 -46
- package/dist/chunk-GGA32J2R.js +784 -0
- package/dist/chunk-GNJL4YGR.js +79 -0
- package/dist/chunk-IVRIKYFE.js +520 -0
- package/dist/chunk-MDIH26GC.js +183 -0
- package/dist/{chunk-LYHGEHXG.js → chunk-MFAWT5O5.js} +0 -1
- package/dist/chunk-MM6QGW3P.js +207 -0
- package/dist/{chunk-P5EPF6MB.js → chunk-MW5C6ZQA.js} +110 -13
- package/dist/chunk-NCKFNBHJ.js +257 -0
- package/dist/{chunk-QBLMXKF2.js → chunk-OIWVQYQF.js} +1 -1
- package/dist/{chunk-42MXU7A6.js → chunk-P62WHA27.js} +58 -47
- package/dist/chunk-PBACDKKP.js +66 -0
- package/dist/{chunk-VGLOTGAS.js → chunk-QSHD36LH.js} +2 -2
- package/dist/{chunk-OZ7RIXTO.js → chunk-QSRRMEYM.js} +2 -2
- package/dist/chunk-QVEERJSP.js +152 -0
- 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-SLXOR3CC.js} +2 -2
- package/dist/chunk-SS4B7P7V.js +99 -0
- package/dist/{chunk-JY6FYXIT.js → chunk-STCQGCEQ.js} +6 -11
- package/dist/chunk-TIGW564L.js +628 -0
- package/dist/chunk-U4O6C46S.js +154 -0
- package/dist/{chunk-ITPEXLHA.js → chunk-URXDAUVH.js} +24 -5
- package/dist/chunk-VSL7KY3M.js +189 -0
- package/dist/{chunk-U55BGUAU.js → chunk-W4SPAEE7.js} +6 -6
- package/dist/chunk-WMGIIABP.js +15 -0
- package/dist/{chunk-33UGEQRT.js → chunk-X3SPPUFG.js} +151 -64
- package/dist/chunk-Y6VJKXGL.js +373 -0
- package/dist/{chunk-3WRJEKN4.js → chunk-ZN54U2OZ.js} +123 -10
- package/dist/cli/index.js +34 -24
- 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 +8 -6
- package/dist/commands/doctor.d.ts +11 -7
- package/dist/commands/doctor.js +18 -16
- package/dist/commands/embed.js +5 -6
- package/dist/commands/entities.js +2 -2
- package/dist/commands/graph.js +4 -4
- package/dist/commands/inject.d.ts +1 -1
- package/dist/commands/inject.js +5 -6
- package/dist/commands/kanban.js +4 -4
- package/dist/commands/link.js +5 -5
- package/dist/commands/migrate-observations.js +4 -4
- package/dist/commands/observe.d.ts +0 -1
- package/dist/commands/observe.js +14 -13
- 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 +20 -19
- package/dist/commands/status.d.ts +2 -0
- package/dist/commands/status.js +57 -35
- 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/commands/workgraph.d.ts +124 -0
- package/dist/commands/workgraph.js +38 -0
- package/dist/index.d.ts +341 -191
- package/dist/index.js +446 -116
- 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 +2 -2
- 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/onnxruntime_binding-5QEF3SUC.node +0 -0
- package/dist/onnxruntime_binding-BKPKNEGC.node +0 -0
- package/dist/onnxruntime_binding-FMOXGIUT.node +0 -0
- package/dist/onnxruntime_binding-OI2KMXC5.node +0 -0
- package/dist/onnxruntime_binding-UX44MLAZ.node +0 -0
- package/dist/onnxruntime_binding-Y2W7N7WY.node +0 -0
- package/dist/openclaw-plugin.d.ts +8 -0
- package/dist/openclaw-plugin.js +14 -0
- 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/transformers.node-A2ZRORSQ.js +46775 -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 +1561 -0
- package/hooks/clawvault/handler.test.js +510 -0
- package/hooks/clawvault/openclaw.plugin.json +72 -0
- package/openclaw.plugin.json +65 -38
- package/package.json +25 -22
- 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/index.d.ts +0 -36
- package/dist/plugin/index.js +0 -572
- 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
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
type DoctorStatus = 'ok' | 'warn' | 'error';
|
|
2
|
-
interface DoctorCheck {
|
|
3
|
-
label: string;
|
|
4
|
-
status: DoctorStatus;
|
|
5
|
-
detail?: string;
|
|
6
|
-
hint?: string;
|
|
7
|
-
}
|
|
8
|
-
interface DoctorReport {
|
|
9
|
-
vaultPath?: string;
|
|
10
|
-
qmdCollection?: string;
|
|
11
|
-
qmdRoot?: string;
|
|
12
|
-
checks: DoctorCheck[];
|
|
13
|
-
warnings: number;
|
|
14
|
-
errors: number;
|
|
15
|
-
}
|
|
16
|
-
declare function doctor(options?: string | {
|
|
17
|
-
vaultPath?: string;
|
|
18
|
-
fix?: boolean;
|
|
19
|
-
}): Promise<DoctorReport>;
|
|
20
|
-
|
|
21
|
-
export { type DoctorCheck, type DoctorReport, type DoctorStatus, doctor };
|
package/dist/commands/embed.cjs
DELETED
|
@@ -1,232 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/commands/embed.ts
|
|
31
|
-
var embed_exports = {};
|
|
32
|
-
__export(embed_exports, {
|
|
33
|
-
embedCommand: () => embedCommand,
|
|
34
|
-
registerEmbedCommand: () => registerEmbedCommand
|
|
35
|
-
});
|
|
36
|
-
module.exports = __toCommonJS(embed_exports);
|
|
37
|
-
|
|
38
|
-
// src/lib/config.ts
|
|
39
|
-
var fs = __toESM(require("fs"), 1);
|
|
40
|
-
var path = __toESM(require("path"), 1);
|
|
41
|
-
function findNearestVaultPath(startPath = process.cwd()) {
|
|
42
|
-
let current = path.resolve(startPath);
|
|
43
|
-
while (true) {
|
|
44
|
-
if (fs.existsSync(path.join(current, ".clawvault.json"))) {
|
|
45
|
-
return current;
|
|
46
|
-
}
|
|
47
|
-
const parent = path.dirname(current);
|
|
48
|
-
if (parent === current) {
|
|
49
|
-
return null;
|
|
50
|
-
}
|
|
51
|
-
current = parent;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
function resolveVaultPath(options = {}) {
|
|
55
|
-
if (options.explicitPath) {
|
|
56
|
-
return path.resolve(options.explicitPath);
|
|
57
|
-
}
|
|
58
|
-
if (process.env.CLAWVAULT_PATH) {
|
|
59
|
-
return path.resolve(process.env.CLAWVAULT_PATH);
|
|
60
|
-
}
|
|
61
|
-
const discovered = findNearestVaultPath(options.cwd ?? process.cwd());
|
|
62
|
-
if (discovered) {
|
|
63
|
-
return discovered;
|
|
64
|
-
}
|
|
65
|
-
throw new Error("No vault path found. Set CLAWVAULT_PATH, use --vault, or run inside a vault.");
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
// src/lib/search.ts
|
|
69
|
-
var import_child_process = require("child_process");
|
|
70
|
-
var QMD_INSTALL_COMMAND = "bun install -g github:tobi/qmd";
|
|
71
|
-
var QMD_NOT_INSTALLED_MESSAGE = `ClawVault requires qmd. Install: ${QMD_INSTALL_COMMAND}`;
|
|
72
|
-
var QMD_INDEX_ENV_VAR = "CLAWVAULT_QMD_INDEX";
|
|
73
|
-
var QmdUnavailableError = class extends Error {
|
|
74
|
-
constructor(message = QMD_NOT_INSTALLED_MESSAGE) {
|
|
75
|
-
super(message);
|
|
76
|
-
this.name = "QmdUnavailableError";
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
function resolveQmdIndexName(indexName) {
|
|
80
|
-
const explicit = indexName?.trim();
|
|
81
|
-
if (explicit) {
|
|
82
|
-
return explicit;
|
|
83
|
-
}
|
|
84
|
-
const fromEnv = process.env[QMD_INDEX_ENV_VAR]?.trim();
|
|
85
|
-
return fromEnv || void 0;
|
|
86
|
-
}
|
|
87
|
-
function withQmdIndexArgs(args, indexName) {
|
|
88
|
-
if (args.includes("--index")) {
|
|
89
|
-
return [...args];
|
|
90
|
-
}
|
|
91
|
-
const resolvedIndexName = resolveQmdIndexName(indexName);
|
|
92
|
-
if (!resolvedIndexName) {
|
|
93
|
-
return [...args];
|
|
94
|
-
}
|
|
95
|
-
return ["--index", resolvedIndexName, ...args];
|
|
96
|
-
}
|
|
97
|
-
function ensureQmdAvailable() {
|
|
98
|
-
if (!hasQmd()) {
|
|
99
|
-
throw new QmdUnavailableError();
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
function hasQmd() {
|
|
103
|
-
const result = (0, import_child_process.spawnSync)("qmd", ["--version"], { stdio: "ignore" });
|
|
104
|
-
return !result.error;
|
|
105
|
-
}
|
|
106
|
-
function qmdEmbed(collection, indexName) {
|
|
107
|
-
ensureQmdAvailable();
|
|
108
|
-
const args = ["embed"];
|
|
109
|
-
if (collection) {
|
|
110
|
-
args.push("-c", collection);
|
|
111
|
-
}
|
|
112
|
-
(0, import_child_process.execFileSync)("qmd", withQmdIndexArgs(args, indexName), { stdio: "inherit" });
|
|
113
|
-
}
|
|
114
|
-
var MONTH_NAMES = {
|
|
115
|
-
january: 1,
|
|
116
|
-
february: 2,
|
|
117
|
-
march: 3,
|
|
118
|
-
april: 4,
|
|
119
|
-
may: 5,
|
|
120
|
-
june: 6,
|
|
121
|
-
july: 7,
|
|
122
|
-
august: 8,
|
|
123
|
-
september: 9,
|
|
124
|
-
october: 10,
|
|
125
|
-
november: 11,
|
|
126
|
-
december: 12,
|
|
127
|
-
jan: 1,
|
|
128
|
-
feb: 2,
|
|
129
|
-
mar: 3,
|
|
130
|
-
apr: 4,
|
|
131
|
-
jun: 6,
|
|
132
|
-
jul: 7,
|
|
133
|
-
aug: 8,
|
|
134
|
-
sep: 9,
|
|
135
|
-
sept: 9,
|
|
136
|
-
oct: 10,
|
|
137
|
-
nov: 11,
|
|
138
|
-
dec: 12
|
|
139
|
-
};
|
|
140
|
-
var MONTH_RE_PART = Object.keys(MONTH_NAMES).join("|");
|
|
141
|
-
var DATE_MONTH_DAY_YEAR_RE = new RegExp(
|
|
142
|
-
`\\b(${MONTH_RE_PART})\\s+(\\d{1,2})(?:st|nd|rd|th)?,?\\s*(\\d{4})\\b`,
|
|
143
|
-
"gi"
|
|
144
|
-
);
|
|
145
|
-
var DATE_DAY_MONTH_YEAR_RE = new RegExp(
|
|
146
|
-
`\\b(\\d{1,2})(?:st|nd|rd|th)?\\s+(${MONTH_RE_PART}),?\\s*(\\d{4})\\b`,
|
|
147
|
-
"gi"
|
|
148
|
-
);
|
|
149
|
-
var DATE_MONTH_DAY_RE = new RegExp(
|
|
150
|
-
`\\b(${MONTH_RE_PART})\\s+(\\d{1,2})(?:st|nd|rd|th)?\\b`,
|
|
151
|
-
"gi"
|
|
152
|
-
);
|
|
153
|
-
|
|
154
|
-
// src/lib/vault-qmd-config.ts
|
|
155
|
-
var fs2 = __toESM(require("fs"), 1);
|
|
156
|
-
var path2 = __toESM(require("path"), 1);
|
|
157
|
-
var CONFIG_FILE = ".clawvault.json";
|
|
158
|
-
function readTrimmedString(value) {
|
|
159
|
-
if (typeof value !== "string") return void 0;
|
|
160
|
-
const trimmed = value.trim();
|
|
161
|
-
return trimmed.length > 0 ? trimmed : void 0;
|
|
162
|
-
}
|
|
163
|
-
function loadVaultQmdConfig(vaultPath) {
|
|
164
|
-
const resolvedVaultPath = path2.resolve(vaultPath);
|
|
165
|
-
const fallbackName = path2.basename(resolvedVaultPath);
|
|
166
|
-
const fallbackRoot = resolvedVaultPath;
|
|
167
|
-
const configPath = path2.join(resolvedVaultPath, CONFIG_FILE);
|
|
168
|
-
if (!fs2.existsSync(configPath)) {
|
|
169
|
-
return {
|
|
170
|
-
vaultPath: resolvedVaultPath,
|
|
171
|
-
qmdCollection: fallbackName,
|
|
172
|
-
qmdRoot: fallbackRoot
|
|
173
|
-
};
|
|
174
|
-
}
|
|
175
|
-
try {
|
|
176
|
-
const raw = JSON.parse(fs2.readFileSync(configPath, "utf-8"));
|
|
177
|
-
const configuredName = readTrimmedString(raw.name) ?? fallbackName;
|
|
178
|
-
const qmdCollection = readTrimmedString(raw.qmdCollection) ?? configuredName;
|
|
179
|
-
const rawRoot = readTrimmedString(raw.qmdRoot) ?? fallbackRoot;
|
|
180
|
-
const qmdRoot = path2.isAbsolute(rawRoot) ? path2.resolve(rawRoot) : path2.resolve(resolvedVaultPath, rawRoot);
|
|
181
|
-
return {
|
|
182
|
-
vaultPath: resolvedVaultPath,
|
|
183
|
-
qmdCollection,
|
|
184
|
-
qmdRoot
|
|
185
|
-
};
|
|
186
|
-
} catch {
|
|
187
|
-
return {
|
|
188
|
-
vaultPath: resolvedVaultPath,
|
|
189
|
-
qmdCollection: fallbackName,
|
|
190
|
-
qmdRoot: fallbackRoot
|
|
191
|
-
};
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
// src/commands/embed.ts
|
|
196
|
-
async function embedCommand(options = {}) {
|
|
197
|
-
if (!hasQmd()) {
|
|
198
|
-
throw new QmdUnavailableError();
|
|
199
|
-
}
|
|
200
|
-
const vaultPath = resolveVaultPath({ explicitPath: options.vaultPath });
|
|
201
|
-
const qmdConfig = loadVaultQmdConfig(vaultPath);
|
|
202
|
-
const startedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
203
|
-
if (!options.quiet) {
|
|
204
|
-
console.log(
|
|
205
|
-
`Embedding pending documents for collection "${qmdConfig.qmdCollection}" (root: ${qmdConfig.qmdRoot})...`
|
|
206
|
-
);
|
|
207
|
-
}
|
|
208
|
-
qmdEmbed(qmdConfig.qmdCollection);
|
|
209
|
-
const finishedAt = (/* @__PURE__ */ new Date()).toISOString();
|
|
210
|
-
if (!options.quiet) {
|
|
211
|
-
console.log(`\u2713 Embedding complete for "${qmdConfig.qmdCollection}"`);
|
|
212
|
-
}
|
|
213
|
-
return {
|
|
214
|
-
vaultPath,
|
|
215
|
-
qmdCollection: qmdConfig.qmdCollection,
|
|
216
|
-
qmdRoot: qmdConfig.qmdRoot,
|
|
217
|
-
startedAt,
|
|
218
|
-
finishedAt
|
|
219
|
-
};
|
|
220
|
-
}
|
|
221
|
-
function registerEmbedCommand(program) {
|
|
222
|
-
program.command("embed").description("Run qmd embedding for pending vault documents").option("-v, --vault <path>", "Vault path").action(async (rawOptions) => {
|
|
223
|
-
await embedCommand({
|
|
224
|
-
vaultPath: rawOptions.vault
|
|
225
|
-
});
|
|
226
|
-
});
|
|
227
|
-
}
|
|
228
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
229
|
-
0 && (module.exports = {
|
|
230
|
-
embedCommand,
|
|
231
|
-
registerEmbedCommand
|
|
232
|
-
});
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { Command } from 'commander';
|
|
2
|
-
|
|
3
|
-
interface EmbedCommandOptions {
|
|
4
|
-
vaultPath?: string;
|
|
5
|
-
quiet?: boolean;
|
|
6
|
-
}
|
|
7
|
-
interface EmbedCommandResult {
|
|
8
|
-
vaultPath: string;
|
|
9
|
-
qmdCollection: string;
|
|
10
|
-
qmdRoot: string;
|
|
11
|
-
startedAt: string;
|
|
12
|
-
finishedAt: string;
|
|
13
|
-
}
|
|
14
|
-
declare function embedCommand(options?: EmbedCommandOptions): Promise<EmbedCommandResult>;
|
|
15
|
-
declare function registerEmbedCommand(program: Command): void;
|
|
16
|
-
|
|
17
|
-
export { type EmbedCommandOptions, type EmbedCommandResult, embedCommand, registerEmbedCommand };
|
|
@@ -1,141 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/commands/entities.ts
|
|
31
|
-
var entities_exports = {};
|
|
32
|
-
__export(entities_exports, {
|
|
33
|
-
entitiesCommand: () => entitiesCommand
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(entities_exports);
|
|
36
|
-
|
|
37
|
-
// src/lib/entity-index.ts
|
|
38
|
-
var fs = __toESM(require("fs"), 1);
|
|
39
|
-
var path = __toESM(require("path"), 1);
|
|
40
|
-
var import_gray_matter = __toESM(require("gray-matter"), 1);
|
|
41
|
-
function buildEntityIndex(vaultPath) {
|
|
42
|
-
const entries = /* @__PURE__ */ new Map();
|
|
43
|
-
const byPath = /* @__PURE__ */ new Map();
|
|
44
|
-
const entityFolders = ["people", "projects", "agents", "lessons", "decisions", "commitments"];
|
|
45
|
-
for (const folder of entityFolders) {
|
|
46
|
-
const folderPath = path.join(vaultPath, folder);
|
|
47
|
-
if (!fs.existsSync(folderPath)) continue;
|
|
48
|
-
const files = fs.readdirSync(folderPath).filter((f) => f.endsWith(".md"));
|
|
49
|
-
for (const file of files) {
|
|
50
|
-
const filePath = path.join(folderPath, file);
|
|
51
|
-
const content = fs.readFileSync(filePath, "utf-8");
|
|
52
|
-
const { data: frontmatter } = (0, import_gray_matter.default)(content);
|
|
53
|
-
const relativePath = `${folder}/${file.replace(".md", "")}`;
|
|
54
|
-
const baseName = file.replace(".md", "");
|
|
55
|
-
const aliases = [baseName];
|
|
56
|
-
if (frontmatter.title && frontmatter.title.toLowerCase() !== baseName.toLowerCase()) {
|
|
57
|
-
aliases.push(frontmatter.title);
|
|
58
|
-
}
|
|
59
|
-
if (Array.isArray(frontmatter.aliases)) {
|
|
60
|
-
aliases.push(...frontmatter.aliases);
|
|
61
|
-
}
|
|
62
|
-
for (const alias of aliases) {
|
|
63
|
-
const key = alias.toLowerCase();
|
|
64
|
-
if (!entries.has(key)) {
|
|
65
|
-
entries.set(key, relativePath);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
byPath.set(relativePath, { path: relativePath, aliases });
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
return { entries, byPath };
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
// src/lib/config.ts
|
|
75
|
-
var fs2 = __toESM(require("fs"), 1);
|
|
76
|
-
var path2 = __toESM(require("path"), 1);
|
|
77
|
-
function findNearestVaultPath(startPath = process.cwd()) {
|
|
78
|
-
let current = path2.resolve(startPath);
|
|
79
|
-
while (true) {
|
|
80
|
-
if (fs2.existsSync(path2.join(current, ".clawvault.json"))) {
|
|
81
|
-
return current;
|
|
82
|
-
}
|
|
83
|
-
const parent = path2.dirname(current);
|
|
84
|
-
if (parent === current) {
|
|
85
|
-
return null;
|
|
86
|
-
}
|
|
87
|
-
current = parent;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
function resolveVaultPath(options = {}) {
|
|
91
|
-
if (options.explicitPath) {
|
|
92
|
-
return path2.resolve(options.explicitPath);
|
|
93
|
-
}
|
|
94
|
-
if (process.env.CLAWVAULT_PATH) {
|
|
95
|
-
return path2.resolve(process.env.CLAWVAULT_PATH);
|
|
96
|
-
}
|
|
97
|
-
const discovered = findNearestVaultPath(options.cwd ?? process.cwd());
|
|
98
|
-
if (discovered) {
|
|
99
|
-
return discovered;
|
|
100
|
-
}
|
|
101
|
-
throw new Error("No vault path found. Set CLAWVAULT_PATH, use --vault, or run inside a vault.");
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
// src/commands/entities.ts
|
|
105
|
-
async function entitiesCommand(options) {
|
|
106
|
-
const vaultPath = resolveVaultPath({ explicitPath: options.vaultPath });
|
|
107
|
-
const index = buildEntityIndex(vaultPath);
|
|
108
|
-
if (options.json) {
|
|
109
|
-
const output = {};
|
|
110
|
-
for (const [path3, entry] of index.byPath) {
|
|
111
|
-
output[path3] = entry.aliases;
|
|
112
|
-
}
|
|
113
|
-
console.log(JSON.stringify(output, null, 2));
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
const byFolder = {};
|
|
117
|
-
for (const [path3, entry] of index.byPath) {
|
|
118
|
-
const folder = path3.split("/")[0];
|
|
119
|
-
if (!byFolder[folder]) byFolder[folder] = [];
|
|
120
|
-
byFolder[folder].push({ path: path3, aliases: entry.aliases });
|
|
121
|
-
}
|
|
122
|
-
console.log("\u{1F4DA} Linkable Entities\n");
|
|
123
|
-
for (const [folder, entities] of Object.entries(byFolder)) {
|
|
124
|
-
console.log(`## ${folder}/`);
|
|
125
|
-
for (const entity of entities) {
|
|
126
|
-
const name = entity.path.split("/")[1];
|
|
127
|
-
const otherAliases = entity.aliases.filter((a) => a.toLowerCase() !== name.toLowerCase());
|
|
128
|
-
if (otherAliases.length > 0) {
|
|
129
|
-
console.log(` - ${name} (${otherAliases.join(", ")})`);
|
|
130
|
-
} else {
|
|
131
|
-
console.log(` - ${name}`);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
console.log();
|
|
135
|
-
}
|
|
136
|
-
console.log(`Total: ${index.byPath.size} entities, ${index.entries.size} linkable aliases`);
|
|
137
|
-
}
|
|
138
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
139
|
-
0 && (module.exports = {
|
|
140
|
-
entitiesCommand
|
|
141
|
-
});
|