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.
Files changed (289) hide show
  1. package/README.md +422 -141
  2. package/bin/clawvault.js +10 -2
  3. package/bin/command-registration.test.js +3 -1
  4. package/bin/command-runtime.js +9 -1
  5. package/bin/register-core-commands.js +23 -28
  6. package/bin/register-maintenance-commands.js +39 -3
  7. package/bin/register-query-commands.js +58 -29
  8. package/bin/register-tailscale-commands.js +106 -0
  9. package/bin/register-task-commands.js +18 -1
  10. package/bin/register-task-commands.test.js +16 -0
  11. package/bin/register-vault-operations-commands.js +29 -1
  12. package/bin/register-workgraph-commands.js +1368 -0
  13. package/dashboard/lib/graph-diff.js +104 -0
  14. package/dashboard/lib/graph-diff.test.js +75 -0
  15. package/dashboard/lib/vault-parser.js +556 -0
  16. package/dashboard/lib/vault-parser.test.js +254 -0
  17. package/dashboard/public/app.js +796 -0
  18. package/dashboard/public/index.html +52 -0
  19. package/dashboard/public/styles.css +221 -0
  20. package/dashboard/server.js +374 -0
  21. package/dist/{chunk-F2JEUD4J.js → chunk-23YDQ3QU.js} +6 -8
  22. package/dist/{chunk-C7OK5WKP.js → chunk-2JQ3O2YL.js} +4 -4
  23. package/dist/{chunk-VR5NE7PZ.js → chunk-2RAZ4ZFE.js} +1 -1
  24. package/dist/chunk-2ZDO52B4.js +52 -0
  25. package/dist/{chunk-ZZA73MFY.js → chunk-33DOSHTA.js} +176 -36
  26. package/dist/chunk-33VSQP4J.js +37 -0
  27. package/dist/chunk-4BQTQMJP.js +93 -0
  28. package/dist/{chunk-GUKMRGM7.js → chunk-4OXMU5S2.js} +1 -1
  29. package/dist/{chunk-62YTUT6J.js → chunk-4PY655YM.js} +15 -3
  30. package/dist/chunk-6FH3IULF.js +352 -0
  31. package/dist/{chunk-3NSBOUT3.js → chunk-77Q5CSPJ.js} +404 -80
  32. package/dist/{chunk-4VQTUVH7.js → chunk-7YZWHM36.js} +52 -26
  33. package/dist/chunk-BSJ6RIT7.js +447 -0
  34. package/dist/chunk-BUEW6IIK.js +364 -0
  35. package/dist/{chunk-LI4O6NVK.js → chunk-CLJTREDS.js} +74 -14
  36. package/dist/chunk-EK6S23ZB.js +469 -0
  37. package/dist/{chunk-LNJA2UGL.js → chunk-ESFLMDRB.js} +9 -86
  38. package/dist/{chunk-H34S76MB.js → chunk-ESVS6K2B.js} +6 -6
  39. package/dist/{chunk-WAZ3NLWL.js → chunk-F55HGNU4.js} +0 -47
  40. package/dist/{chunk-QK3UCXWL.js → chunk-FHFUXL6G.js} +2 -2
  41. package/dist/{chunk-H62BP7RI.js → chunk-GAOWA7GR.js} +212 -46
  42. package/dist/chunk-GGA32J2R.js +784 -0
  43. package/dist/chunk-GNJL4YGR.js +79 -0
  44. package/dist/chunk-IVRIKYFE.js +520 -0
  45. package/dist/chunk-MDIH26GC.js +183 -0
  46. package/dist/{chunk-LYHGEHXG.js → chunk-MFAWT5O5.js} +0 -1
  47. package/dist/chunk-MM6QGW3P.js +207 -0
  48. package/dist/{chunk-P5EPF6MB.js → chunk-MW5C6ZQA.js} +110 -13
  49. package/dist/chunk-NCKFNBHJ.js +257 -0
  50. package/dist/{chunk-QBLMXKF2.js → chunk-OIWVQYQF.js} +1 -1
  51. package/dist/{chunk-42MXU7A6.js → chunk-P62WHA27.js} +58 -47
  52. package/dist/chunk-PBACDKKP.js +66 -0
  53. package/dist/{chunk-VGLOTGAS.js → chunk-QSHD36LH.js} +2 -2
  54. package/dist/{chunk-OZ7RIXTO.js → chunk-QSRRMEYM.js} +2 -2
  55. package/dist/chunk-QVEERJSP.js +152 -0
  56. package/dist/{chunk-N2AXRYLC.js → chunk-QWQ3TIKS.js} +1 -1
  57. package/dist/{chunk-3DHXQHYG.js → chunk-R2MIW5G7.js} +1 -1
  58. package/dist/{chunk-SJSFRIYS.js → chunk-SLXOR3CC.js} +2 -2
  59. package/dist/chunk-SS4B7P7V.js +99 -0
  60. package/dist/{chunk-JY6FYXIT.js → chunk-STCQGCEQ.js} +6 -11
  61. package/dist/chunk-TIGW564L.js +628 -0
  62. package/dist/chunk-U4O6C46S.js +154 -0
  63. package/dist/{chunk-ITPEXLHA.js → chunk-URXDAUVH.js} +24 -5
  64. package/dist/chunk-VSL7KY3M.js +189 -0
  65. package/dist/{chunk-U55BGUAU.js → chunk-W4SPAEE7.js} +6 -6
  66. package/dist/chunk-WMGIIABP.js +15 -0
  67. package/dist/{chunk-33UGEQRT.js → chunk-X3SPPUFG.js} +151 -64
  68. package/dist/chunk-Y6VJKXGL.js +373 -0
  69. package/dist/{chunk-3WRJEKN4.js → chunk-ZN54U2OZ.js} +123 -10
  70. package/dist/cli/index.js +34 -24
  71. package/dist/commands/archive.js +3 -3
  72. package/dist/commands/backlog.js +3 -3
  73. package/dist/commands/blocked.js +3 -3
  74. package/dist/commands/canvas.d.ts +15 -0
  75. package/dist/commands/canvas.js +200 -0
  76. package/dist/commands/checkpoint.js +2 -2
  77. package/dist/commands/compat.js +2 -2
  78. package/dist/commands/context.js +8 -6
  79. package/dist/commands/doctor.d.ts +11 -7
  80. package/dist/commands/doctor.js +18 -16
  81. package/dist/commands/embed.js +5 -6
  82. package/dist/commands/entities.js +2 -2
  83. package/dist/commands/graph.js +4 -4
  84. package/dist/commands/inject.d.ts +1 -1
  85. package/dist/commands/inject.js +5 -6
  86. package/dist/commands/kanban.js +4 -4
  87. package/dist/commands/link.js +5 -5
  88. package/dist/commands/migrate-observations.js +4 -4
  89. package/dist/commands/observe.d.ts +0 -1
  90. package/dist/commands/observe.js +14 -13
  91. package/dist/commands/project.js +5 -5
  92. package/dist/commands/rebuild-embeddings.d.ts +21 -0
  93. package/dist/commands/rebuild-embeddings.js +91 -0
  94. package/dist/commands/rebuild.js +12 -11
  95. package/dist/commands/recover.js +3 -3
  96. package/dist/commands/reflect.js +6 -7
  97. package/dist/commands/repair-session.js +1 -1
  98. package/dist/commands/replay.js +14 -14
  99. package/dist/commands/session-recap.js +1 -1
  100. package/dist/commands/setup.d.ts +2 -89
  101. package/dist/commands/setup.js +3 -21
  102. package/dist/commands/shell-init.js +1 -1
  103. package/dist/commands/sleep.d.ts +1 -1
  104. package/dist/commands/sleep.js +20 -19
  105. package/dist/commands/status.d.ts +2 -0
  106. package/dist/commands/status.js +57 -35
  107. package/dist/commands/sync-bd.d.ts +10 -0
  108. package/dist/commands/sync-bd.js +10 -0
  109. package/dist/commands/tailscale.d.ts +52 -0
  110. package/dist/commands/tailscale.js +26 -0
  111. package/dist/commands/task.js +4 -4
  112. package/dist/commands/template.js +2 -2
  113. package/dist/commands/wake.d.ts +1 -1
  114. package/dist/commands/wake.js +11 -10
  115. package/dist/commands/workgraph.d.ts +124 -0
  116. package/dist/commands/workgraph.js +38 -0
  117. package/dist/index.d.ts +341 -191
  118. package/dist/index.js +446 -116
  119. package/dist/{inject-Bzi5E-By.d.ts → inject-DYUrDqQO.d.ts} +3 -3
  120. package/dist/ledger-B7g7jhqG.d.ts +44 -0
  121. package/dist/lib/auto-linker.js +2 -2
  122. package/dist/lib/canvas-layout.d.ts +115 -0
  123. package/dist/lib/canvas-layout.js +35 -0
  124. package/dist/lib/config.d.ts +27 -3
  125. package/dist/lib/config.js +4 -2
  126. package/dist/lib/entity-index.js +1 -1
  127. package/dist/lib/project-utils.js +4 -4
  128. package/dist/lib/session-repair.js +1 -1
  129. package/dist/lib/session-utils.js +1 -1
  130. package/dist/lib/tailscale.d.ts +225 -0
  131. package/dist/lib/tailscale.js +50 -0
  132. package/dist/lib/task-utils.js +3 -3
  133. package/dist/lib/template-engine.js +1 -1
  134. package/dist/lib/webdav.d.ts +109 -0
  135. package/dist/lib/webdav.js +35 -0
  136. package/dist/onnxruntime_binding-5QEF3SUC.node +0 -0
  137. package/dist/onnxruntime_binding-BKPKNEGC.node +0 -0
  138. package/dist/onnxruntime_binding-FMOXGIUT.node +0 -0
  139. package/dist/onnxruntime_binding-OI2KMXC5.node +0 -0
  140. package/dist/onnxruntime_binding-UX44MLAZ.node +0 -0
  141. package/dist/onnxruntime_binding-Y2W7N7WY.node +0 -0
  142. package/dist/openclaw-plugin.d.ts +8 -0
  143. package/dist/openclaw-plugin.js +14 -0
  144. package/dist/registry-BR4326o0.d.ts +30 -0
  145. package/dist/store-CA-6sKCJ.d.ts +34 -0
  146. package/dist/thread-B9LhXNU0.d.ts +41 -0
  147. package/dist/transformers.node-A2ZRORSQ.js +46775 -0
  148. package/dist/{types-Y2_Um2Ls.d.ts → types-BbWJoC1c.d.ts} +1 -44
  149. package/dist/workgraph/index.d.ts +5 -0
  150. package/dist/workgraph/index.js +23 -0
  151. package/dist/workgraph/ledger.d.ts +2 -0
  152. package/dist/workgraph/ledger.js +25 -0
  153. package/dist/workgraph/registry.d.ts +2 -0
  154. package/dist/workgraph/registry.js +19 -0
  155. package/dist/workgraph/store.d.ts +2 -0
  156. package/dist/workgraph/store.js +25 -0
  157. package/dist/workgraph/thread.d.ts +2 -0
  158. package/dist/workgraph/thread.js +25 -0
  159. package/dist/workgraph/types.d.ts +54 -0
  160. package/dist/workgraph/types.js +7 -0
  161. package/hooks/clawvault/HOOK.md +113 -0
  162. package/hooks/clawvault/handler.js +1561 -0
  163. package/hooks/clawvault/handler.test.js +510 -0
  164. package/hooks/clawvault/openclaw.plugin.json +72 -0
  165. package/openclaw.plugin.json +65 -38
  166. package/package.json +25 -22
  167. package/dist/chunk-3RG5ZIWI.js +0 -10
  168. package/dist/chunk-3ZIH425O.js +0 -871
  169. package/dist/chunk-6U6MK36V.js +0 -205
  170. package/dist/chunk-CMB7UL7C.js +0 -327
  171. package/dist/chunk-D2H45LON.js +0 -1074
  172. package/dist/chunk-E7MFQB6D.js +0 -163
  173. package/dist/chunk-GQSLDZTS.js +0 -560
  174. package/dist/chunk-MFM6K7PU.js +0 -374
  175. package/dist/chunk-MXSSG3QU.js +0 -42
  176. package/dist/chunk-OCGVIN3L.js +0 -88
  177. package/dist/chunk-PAH27GSN.js +0 -108
  178. package/dist/chunk-YCUNCH2I.js +0 -78
  179. package/dist/cli/index.cjs +0 -8584
  180. package/dist/cli/index.d.cts +0 -5
  181. package/dist/commands/archive.cjs +0 -287
  182. package/dist/commands/archive.d.cts +0 -11
  183. package/dist/commands/backlog.cjs +0 -721
  184. package/dist/commands/backlog.d.cts +0 -53
  185. package/dist/commands/blocked.cjs +0 -204
  186. package/dist/commands/blocked.d.cts +0 -26
  187. package/dist/commands/checkpoint.cjs +0 -244
  188. package/dist/commands/checkpoint.d.cts +0 -41
  189. package/dist/commands/compat.cjs +0 -294
  190. package/dist/commands/compat.d.cts +0 -28
  191. package/dist/commands/context.cjs +0 -2990
  192. package/dist/commands/context.d.cts +0 -2
  193. package/dist/commands/doctor.cjs +0 -2986
  194. package/dist/commands/doctor.d.cts +0 -21
  195. package/dist/commands/embed.cjs +0 -232
  196. package/dist/commands/embed.d.cts +0 -17
  197. package/dist/commands/entities.cjs +0 -141
  198. package/dist/commands/entities.d.cts +0 -7
  199. package/dist/commands/graph.cjs +0 -501
  200. package/dist/commands/graph.d.cts +0 -21
  201. package/dist/commands/inject.cjs +0 -1636
  202. package/dist/commands/inject.d.cts +0 -2
  203. package/dist/commands/kanban.cjs +0 -884
  204. package/dist/commands/kanban.d.cts +0 -63
  205. package/dist/commands/link.cjs +0 -965
  206. package/dist/commands/link.d.cts +0 -11
  207. package/dist/commands/migrate-observations.cjs +0 -362
  208. package/dist/commands/migrate-observations.d.cts +0 -19
  209. package/dist/commands/observe.cjs +0 -4099
  210. package/dist/commands/observe.d.cts +0 -23
  211. package/dist/commands/project.cjs +0 -1341
  212. package/dist/commands/project.d.cts +0 -85
  213. package/dist/commands/rebuild.cjs +0 -3136
  214. package/dist/commands/rebuild.d.cts +0 -11
  215. package/dist/commands/recover.cjs +0 -361
  216. package/dist/commands/recover.d.cts +0 -38
  217. package/dist/commands/reflect.cjs +0 -1008
  218. package/dist/commands/reflect.d.cts +0 -11
  219. package/dist/commands/repair-session.cjs +0 -457
  220. package/dist/commands/repair-session.d.cts +0 -38
  221. package/dist/commands/replay.cjs +0 -4103
  222. package/dist/commands/replay.d.cts +0 -16
  223. package/dist/commands/session-recap.cjs +0 -353
  224. package/dist/commands/session-recap.d.cts +0 -27
  225. package/dist/commands/setup.cjs +0 -1278
  226. package/dist/commands/setup.d.cts +0 -99
  227. package/dist/commands/shell-init.cjs +0 -75
  228. package/dist/commands/shell-init.d.cts +0 -7
  229. package/dist/commands/sleep.cjs +0 -6029
  230. package/dist/commands/sleep.d.cts +0 -36
  231. package/dist/commands/status.cjs +0 -2737
  232. package/dist/commands/status.d.cts +0 -52
  233. package/dist/commands/task.cjs +0 -1236
  234. package/dist/commands/task.d.cts +0 -97
  235. package/dist/commands/template.cjs +0 -457
  236. package/dist/commands/template.d.cts +0 -36
  237. package/dist/commands/wake.cjs +0 -2627
  238. package/dist/commands/wake.d.cts +0 -22
  239. package/dist/context-BUGaWpyL.d.cts +0 -46
  240. package/dist/index.cjs +0 -12373
  241. package/dist/index.d.cts +0 -854
  242. package/dist/inject-Bzi5E-By.d.cts +0 -137
  243. package/dist/lib/auto-linker.cjs +0 -176
  244. package/dist/lib/auto-linker.d.cts +0 -26
  245. package/dist/lib/config.cjs +0 -78
  246. package/dist/lib/config.d.cts +0 -11
  247. package/dist/lib/entity-index.cjs +0 -84
  248. package/dist/lib/entity-index.d.cts +0 -26
  249. package/dist/lib/project-utils.cjs +0 -864
  250. package/dist/lib/project-utils.d.cts +0 -97
  251. package/dist/lib/session-repair.cjs +0 -239
  252. package/dist/lib/session-repair.d.cts +0 -110
  253. package/dist/lib/session-utils.cjs +0 -209
  254. package/dist/lib/session-utils.d.cts +0 -63
  255. package/dist/lib/task-utils.cjs +0 -1137
  256. package/dist/lib/task-utils.d.cts +0 -208
  257. package/dist/lib/template-engine.cjs +0 -47
  258. package/dist/lib/template-engine.d.cts +0 -11
  259. package/dist/plugin/index.cjs +0 -1907
  260. package/dist/plugin/index.d.cts +0 -36
  261. package/dist/plugin/index.d.ts +0 -36
  262. package/dist/plugin/index.js +0 -572
  263. package/dist/plugin/inject.cjs +0 -356
  264. package/dist/plugin/inject.d.cts +0 -54
  265. package/dist/plugin/inject.d.ts +0 -54
  266. package/dist/plugin/inject.js +0 -17
  267. package/dist/plugin/observe.cjs +0 -631
  268. package/dist/plugin/observe.d.cts +0 -39
  269. package/dist/plugin/observe.d.ts +0 -39
  270. package/dist/plugin/observe.js +0 -18
  271. package/dist/plugin/templates.cjs +0 -593
  272. package/dist/plugin/templates.d.cts +0 -52
  273. package/dist/plugin/templates.d.ts +0 -52
  274. package/dist/plugin/templates.js +0 -25
  275. package/dist/plugin/types.cjs +0 -18
  276. package/dist/plugin/types.d.cts +0 -209
  277. package/dist/plugin/types.d.ts +0 -209
  278. package/dist/plugin/types.js +0 -0
  279. package/dist/plugin/vault.cjs +0 -927
  280. package/dist/plugin/vault.d.cts +0 -68
  281. package/dist/plugin/vault.d.ts +0 -68
  282. package/dist/plugin/vault.js +0 -22
  283. package/dist/types-Y2_Um2Ls.d.cts +0 -205
  284. package/templates/memory-event.md +0 -67
  285. package/templates/party.md +0 -63
  286. package/templates/primitive-registry.yaml +0 -551
  287. package/templates/run.md +0 -68
  288. package/templates/trigger.md +0 -68
  289. package/templates/workspace.md +0 -50
@@ -1,39 +0,0 @@
1
- /**
2
- * Dynamic Observation Engine for ClawVault
3
- *
4
- * Replaces hardcoded categories with template-driven classification.
5
- * Extracts observations from text and classifies them against the
6
- * template registry using keyword/heuristic matching (no LLM calls).
7
- */
8
- interface Observation {
9
- text: string;
10
- primitiveType: string;
11
- confidence: number;
12
- matchedKeywords: string[];
13
- category: string;
14
- tags: string[];
15
- extractedAt: Date;
16
- }
17
- interface ObservationResult {
18
- observations: Observation[];
19
- skipped: number;
20
- reason?: string;
21
- }
22
- declare function isObservable(text: string): boolean;
23
- declare function extractObservations(text: string): Observation[];
24
- declare function processMessageForObservations(content: string, options?: {
25
- from?: string;
26
- sessionId?: string;
27
- }): ObservationResult;
28
- declare function detectCategory(text: string): string;
29
- interface ExtractedPreference {
30
- category: string;
31
- item: string;
32
- sentiment: 'positive' | 'negative' | 'neutral';
33
- confidence: number;
34
- source: string;
35
- }
36
- declare function extractPreferences(text: string): ExtractedPreference[];
37
- declare function extractSearchTerms(input: string): string;
38
-
39
- export { type ExtractedPreference, type Observation, type ObservationResult, detectCategory, extractObservations, extractPreferences, extractSearchTerms, isObservable, processMessageForObservations };
@@ -1,18 +0,0 @@
1
- import {
2
- detectCategory,
3
- extractObservations,
4
- extractPreferences,
5
- extractSearchTerms,
6
- isObservable,
7
- processMessageForObservations
8
- } from "../chunk-6U6MK36V.js";
9
- import "../chunk-GQSLDZTS.js";
10
- import "../chunk-3RG5ZIWI.js";
11
- export {
12
- detectCategory,
13
- extractObservations,
14
- extractPreferences,
15
- extractSearchTerms,
16
- isObservable,
17
- processMessageForObservations
18
- };
@@ -1,593 +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/templates.ts
21
- var templates_exports = {};
22
- __export(templates_exports, {
23
- classifyText: () => classifyText,
24
- generateFrontmatter: () => generateFrontmatter,
25
- getAllSchemas: () => getAllSchemas,
26
- getSchema: () => getSchema,
27
- getSchemaNames: () => getSchemaNames,
28
- getTemplateRegistry: () => getTemplateRegistry,
29
- initializeTemplateRegistry: () => initializeTemplateRegistry,
30
- resetTemplateRegistry: () => resetTemplateRegistry,
31
- serializeFrontmatter: () => serializeFrontmatter,
32
- validateFrontmatter: () => validateFrontmatter
33
- });
34
- module.exports = __toCommonJS(templates_exports);
35
- var import_node_fs = require("fs");
36
- var import_node_path = require("path");
37
- var DEFAULT_SCHEMAS = [
38
- {
39
- primitive: "memory_event",
40
- description: "General memory event for observations",
41
- fields: {
42
- type: { type: "string", required: true, default: "memory_event" },
43
- status: { type: "string", required: true, default: "recorded", enum: ["recorded", "superseded", "corrected"] },
44
- created: { type: "datetime", required: true, default: "{{datetime}}" },
45
- observed_at: { type: "datetime", required: true },
46
- source: { type: "string", required: true, enum: ["openclaw", "claude-code", "replay", "manual-correction"] },
47
- summary: { type: "string", required: true },
48
- confidence: { type: "number" },
49
- importance: { type: "number" }
50
- },
51
- keywords: ["preference", "like", "hate", "want", "need", "always", "never", "remember", "note"]
52
- },
53
- {
54
- primitive: "person",
55
- description: "People and relationship notes",
56
- fields: {
57
- title: { type: "string", required: true, default: "{{title}}" },
58
- date: { type: "date", required: true, default: "{{date}}" },
59
- type: { type: "string", required: true, default: "person" },
60
- relationship: { type: "string", default: "contact" }
61
- },
62
- keywords: ["person", "contact", "colleague", "friend", "works at", "lives in", "email", "phone", "name is"]
63
- },
64
- {
65
- primitive: "decision",
66
- description: "Decision records",
67
- fields: {
68
- title: { type: "string", required: true, default: "{{title}}" },
69
- date: { type: "date", required: true, default: "{{date}}" },
70
- type: { type: "string", required: true, default: "decision" },
71
- status: { type: "string", default: "decided", enum: ["proposed", "decided", "superseded"] }
72
- },
73
- keywords: ["decided", "decision", "chose", "will use", "go with", "ship", "approved", "rejected"]
74
- },
75
- {
76
- primitive: "task",
77
- description: "Task primitives",
78
- fields: {
79
- status: { type: "string", required: true, default: "open", enum: ["open", "in-progress", "blocked", "done"] },
80
- created: { type: "datetime", required: true, default: "{{datetime}}" },
81
- updated: { type: "datetime", required: true, default: "{{datetime}}" },
82
- priority: { type: "string", enum: ["critical", "high", "medium", "low"] },
83
- due: { type: "date" }
84
- },
85
- keywords: ["task", "todo", "need to", "should", "must", "deadline", "due", "by tomorrow", "by tonight"]
86
- },
87
- {
88
- primitive: "project",
89
- description: "Project definition documents",
90
- fields: {
91
- type: { type: "string", required: true, default: "project" },
92
- status: { type: "string", required: true, default: "active", enum: ["active", "paused", "completed", "archived"] },
93
- created: { type: "datetime", required: true, default: "{{datetime}}" },
94
- updated: { type: "datetime", required: true, default: "{{datetime}}" }
95
- },
96
- keywords: ["project", "initiative", "working on", "building", "developing"]
97
- },
98
- {
99
- primitive: "lesson",
100
- description: "Lessons learned",
101
- fields: {
102
- title: { type: "string", required: true, default: "{{title}}" },
103
- date: { type: "date", required: true, default: "{{date}}" },
104
- type: { type: "string", required: true, default: "lesson" }
105
- },
106
- keywords: ["learned", "lesson", "insight", "realized", "discovered", "found out"]
107
- }
108
- ];
109
- function parseYamlFrontmatter(content) {
110
- const match = content.match(/^---\n([\s\S]*?)\n---\n?([\s\S]*)$/);
111
- if (!match) return null;
112
- const yamlContent = match[1];
113
- const body = match[2];
114
- try {
115
- const frontmatter = parseSimpleYaml(yamlContent);
116
- return { frontmatter, body };
117
- } catch {
118
- return null;
119
- }
120
- }
121
- function parseSimpleYaml(yaml) {
122
- const result = {};
123
- const lines = yaml.split("\n");
124
- let currentKey = "";
125
- let currentIndent = 0;
126
- let nestedObject = null;
127
- let nestedKey = "";
128
- for (const line of lines) {
129
- if (!line.trim() || line.trim().startsWith("#")) continue;
130
- const indent = line.search(/\S/);
131
- const trimmed = line.trim();
132
- if (trimmed.startsWith("- ")) {
133
- const value = trimmed.slice(2).trim();
134
- if (nestedObject && nestedKey) {
135
- const arr = nestedObject[nestedKey];
136
- if (Array.isArray(arr)) {
137
- arr.push(parseYamlValue(value));
138
- }
139
- } else if (currentKey && result[currentKey]) {
140
- const arr = result[currentKey];
141
- if (Array.isArray(arr)) {
142
- arr.push(parseYamlValue(value));
143
- }
144
- }
145
- continue;
146
- }
147
- const colonIndex = trimmed.indexOf(":");
148
- if (colonIndex === -1) continue;
149
- const key = trimmed.slice(0, colonIndex).trim();
150
- const valueStr = trimmed.slice(colonIndex + 1).trim();
151
- if (indent === 0) {
152
- if (valueStr === "" || valueStr === "|" || valueStr === ">") {
153
- if (key === "fields") {
154
- result[key] = {};
155
- nestedObject = result[key];
156
- nestedKey = "";
157
- } else {
158
- result[key] = {};
159
- nestedObject = null;
160
- }
161
- } else {
162
- result[key] = parseYamlValue(valueStr);
163
- nestedObject = null;
164
- }
165
- currentKey = key;
166
- currentIndent = indent;
167
- } else if (nestedObject && indent > 0) {
168
- if (valueStr === "" || valueStr === "|" || valueStr === ">") {
169
- nestedObject[key] = {};
170
- nestedKey = key;
171
- } else if (nestedKey && indent > 2) {
172
- const fieldObj = nestedObject[nestedKey];
173
- if (fieldObj) {
174
- if (key === "enum") {
175
- fieldObj[key] = [];
176
- } else {
177
- fieldObj[key] = parseYamlValue(valueStr);
178
- }
179
- }
180
- } else {
181
- nestedObject[key] = parseYamlValue(valueStr);
182
- nestedKey = key;
183
- }
184
- }
185
- }
186
- return result;
187
- }
188
- function parseYamlValue(value) {
189
- if (value === "" || value === "null" || value === "~") return null;
190
- if (value === "true") return true;
191
- if (value === "false") return false;
192
- if (/^-?\d+$/.test(value)) return parseInt(value, 10);
193
- if (/^-?\d+\.\d+$/.test(value)) return parseFloat(value);
194
- if (value.startsWith('"') && value.endsWith('"') || value.startsWith("'") && value.endsWith("'")) {
195
- return value.slice(1, -1);
196
- }
197
- return value;
198
- }
199
- var registry = null;
200
- function getTemplateRegistry() {
201
- if (!registry) {
202
- registry = {
203
- schemas: /* @__PURE__ */ new Map(),
204
- keywordIndex: /* @__PURE__ */ new Map(),
205
- initialized: false
206
- };
207
- }
208
- return registry;
209
- }
210
- function initializeTemplateRegistry(templatesDir) {
211
- const reg = getTemplateRegistry();
212
- if (reg.initialized) {
213
- return reg;
214
- }
215
- const dirsToTry = templatesDir ? [templatesDir] : [
216
- (0, import_node_path.join)(process.cwd(), "templates"),
217
- (0, import_node_path.join)(process.cwd(), "..", "..", "templates"),
218
- (0, import_node_path.join)(process.env.HOME ?? ".", "clawvault", "templates"),
219
- (0, import_node_path.join)(process.env.HOME ?? ".", ".clawvault", "templates")
220
- ];
221
- let loaded = false;
222
- for (const dir of dirsToTry) {
223
- if ((0, import_node_fs.existsSync)(dir)) {
224
- try {
225
- loadTemplatesFromDirectory(dir, reg);
226
- loaded = true;
227
- break;
228
- } catch {
229
- }
230
- }
231
- }
232
- if (!loaded || reg.schemas.size === 0) {
233
- loadDefaultSchemas(reg);
234
- }
235
- buildKeywordIndex(reg);
236
- reg.initialized = true;
237
- return reg;
238
- }
239
- function loadTemplatesFromDirectory(dir, reg) {
240
- const files = (0, import_node_fs.readdirSync)(dir).filter((f) => f.endsWith(".md"));
241
- for (const file of files) {
242
- const filePath = (0, import_node_path.join)(dir, file);
243
- const content = (0, import_node_fs.readFileSync)(filePath, "utf-8");
244
- const parsed = parseYamlFrontmatter(content);
245
- if (!parsed?.frontmatter?.primitive) continue;
246
- const schema = convertFrontmatterToSchema(parsed.frontmatter, parsed.body);
247
- if (schema) {
248
- reg.schemas.set(schema.primitive, schema);
249
- }
250
- }
251
- }
252
- function convertFrontmatterToSchema(fm, body) {
253
- const primitive = fm.primitive;
254
- if (!primitive) return null;
255
- const fields = {};
256
- const fmFields = fm.fields;
257
- if (fmFields) {
258
- for (const [fieldName, fieldDef] of Object.entries(fmFields)) {
259
- if (typeof fieldDef === "object" && fieldDef !== null) {
260
- const def = fieldDef;
261
- fields[fieldName] = {
262
- type: def.type || "string",
263
- required: def.required,
264
- default: def.default,
265
- enum: def.enum,
266
- description: def.description
267
- };
268
- }
269
- }
270
- }
271
- const keywords = extractKeywordsFromSchema(primitive, fm.description, fields);
272
- return {
273
- primitive,
274
- description: fm.description,
275
- fields,
276
- bodyTemplate: body,
277
- keywords
278
- };
279
- }
280
- function extractKeywordsFromSchema(primitive, description, fields) {
281
- const keywords = [primitive];
282
- keywords.push(primitive.replace(/-/g, " "));
283
- keywords.push(primitive.replace(/_/g, " "));
284
- switch (primitive) {
285
- case "memory_event":
286
- keywords.push("preference", "like", "hate", "want", "need", "always", "never", "remember", "note");
287
- break;
288
- case "person":
289
- keywords.push("person", "contact", "colleague", "friend", "works at", "lives in", "email", "phone", "name is");
290
- break;
291
- case "decision":
292
- keywords.push("decided", "decision", "chose", "will use", "go with", "ship", "approved", "rejected");
293
- break;
294
- case "task":
295
- keywords.push("task", "todo", "need to", "should", "must", "deadline", "due", "by tomorrow", "by tonight");
296
- break;
297
- case "project":
298
- keywords.push("project", "initiative", "working on", "building", "developing");
299
- break;
300
- case "lesson":
301
- keywords.push("learned", "lesson", "insight", "realized", "discovered", "found out");
302
- break;
303
- case "trigger":
304
- keywords.push("trigger", "schedule", "cron", "automated", "recurring");
305
- break;
306
- case "run":
307
- keywords.push("run", "execution", "job", "started", "finished", "failed");
308
- break;
309
- case "checkpoint":
310
- keywords.push("checkpoint", "snapshot", "state", "progress");
311
- break;
312
- case "handoff":
313
- keywords.push("handoff", "transition", "context", "resume");
314
- break;
315
- case "daily-note":
316
- case "daily":
317
- keywords.push("daily", "today", "journal", "log");
318
- break;
319
- case "party":
320
- keywords.push("party", "agent", "human", "runtime", "service");
321
- break;
322
- case "workspace":
323
- keywords.push("workspace", "shared", "collaboration");
324
- break;
325
- }
326
- if (fields.status?.enum) {
327
- keywords.push(...fields.status.enum);
328
- }
329
- return [...new Set(keywords)];
330
- }
331
- function loadDefaultSchemas(reg) {
332
- for (const schema of DEFAULT_SCHEMAS) {
333
- reg.schemas.set(schema.primitive, schema);
334
- }
335
- }
336
- function buildKeywordIndex(reg) {
337
- reg.keywordIndex.clear();
338
- for (const [primitive, schema] of reg.schemas) {
339
- const keywords = schema.keywords ?? [primitive];
340
- for (const keyword of keywords) {
341
- const lower = keyword.toLowerCase();
342
- const existing = reg.keywordIndex.get(lower) ?? [];
343
- if (!existing.includes(primitive)) {
344
- existing.push(primitive);
345
- }
346
- reg.keywordIndex.set(lower, existing);
347
- }
348
- }
349
- }
350
- function classifyText(text) {
351
- const reg = getTemplateRegistry();
352
- if (!reg.initialized) {
353
- initializeTemplateRegistry();
354
- }
355
- const lower = text.toLowerCase();
356
- const scores = /* @__PURE__ */ new Map();
357
- for (const [keyword, primitives] of reg.keywordIndex) {
358
- if (lower.includes(keyword)) {
359
- for (const primitive of primitives) {
360
- const existing = scores.get(primitive) ?? { score: 0, keywords: [] };
361
- existing.score += getKeywordWeight(keyword, primitive);
362
- existing.keywords.push(keyword);
363
- scores.set(primitive, existing);
364
- }
365
- }
366
- }
367
- applyPatternScoring(lower, scores);
368
- let bestPrimitive = "memory_event";
369
- let bestScore = 0;
370
- let bestKeywords = [];
371
- for (const [primitive, data] of scores) {
372
- if (data.score > bestScore) {
373
- bestScore = data.score;
374
- bestPrimitive = primitive;
375
- bestKeywords = data.keywords;
376
- }
377
- }
378
- const confidence = Math.min(1, bestScore / 5);
379
- return {
380
- primitiveType: bestPrimitive,
381
- confidence,
382
- matchedKeywords: [...new Set(bestKeywords)]
383
- };
384
- }
385
- function getKeywordWeight(keyword, primitive) {
386
- if (keyword === primitive || keyword === primitive.replace(/-/g, " ")) {
387
- return 3;
388
- }
389
- const strongIndicators = {
390
- person: ["works at", "lives in", "email", "phone", "name is"],
391
- decision: ["decided", "chose", "will use", "go with"],
392
- task: ["deadline", "due", "by tomorrow", "by tonight"],
393
- memory_event: ["preference", "remember", "note"]
394
- };
395
- if (strongIndicators[primitive]?.includes(keyword)) {
396
- return 2;
397
- }
398
- return 1;
399
- }
400
- function applyPatternScoring(text, scores) {
401
- if (/\b(my .+ is|his .+ is|her .+ is|their .+ is)\b/i.test(text)) {
402
- const existing = scores.get("person") ?? { score: 0, keywords: [] };
403
- existing.score += 2;
404
- existing.keywords.push("possessive pattern");
405
- scores.set("person", existing);
406
- }
407
- if (/[\w.-]+@[\w.-]+\.\w+|\+\d{10,}/.test(text)) {
408
- const existing = scores.get("person") ?? { score: 0, keywords: [] };
409
- existing.score += 3;
410
- existing.keywords.push("contact info");
411
- scores.set("person", existing);
412
- }
413
- if (/\b(i prefer|i like|i hate|i love|i want|i need|i always|i never|don't like|dont like)\b/i.test(text)) {
414
- const existing = scores.get("memory_event") ?? { score: 0, keywords: [] };
415
- existing.score += 3;
416
- existing.keywords.push("preference pattern");
417
- scores.set("memory_event", existing);
418
- }
419
- if (/\b(we decided|let's go with|we're going|i chose|we'll use|ship it|do it)\b/i.test(text)) {
420
- const existing = scores.get("decision") ?? { score: 0, keywords: [] };
421
- existing.score += 3;
422
- existing.keywords.push("decision pattern");
423
- scores.set("decision", existing);
424
- }
425
- if (/\b(by tonight|by tomorrow|deadline|due date|by end of|ship by|ready by)\b/i.test(text)) {
426
- const existing = scores.get("task") ?? { score: 0, keywords: [] };
427
- existing.score += 2;
428
- existing.keywords.push("deadline pattern");
429
- scores.set("task", existing);
430
- }
431
- }
432
- function getSchema(primitiveType) {
433
- const reg = getTemplateRegistry();
434
- if (!reg.initialized) {
435
- initializeTemplateRegistry();
436
- }
437
- return reg.schemas.get(primitiveType);
438
- }
439
- function getAllSchemas() {
440
- const reg = getTemplateRegistry();
441
- if (!reg.initialized) {
442
- initializeTemplateRegistry();
443
- }
444
- return Array.from(reg.schemas.values());
445
- }
446
- function getSchemaNames() {
447
- const reg = getTemplateRegistry();
448
- if (!reg.initialized) {
449
- initializeTemplateRegistry();
450
- }
451
- return Array.from(reg.schemas.keys());
452
- }
453
- function generateFrontmatter(primitiveType, options = {}) {
454
- const schema = getSchema(primitiveType);
455
- if (!schema) {
456
- return {
457
- type: primitiveType,
458
- created: (/* @__PURE__ */ new Date()).toISOString(),
459
- updated: (/* @__PURE__ */ new Date()).toISOString()
460
- };
461
- }
462
- const frontmatter = {};
463
- const now = /* @__PURE__ */ new Date();
464
- const dateStr = now.toISOString().split("T")[0];
465
- const datetimeStr = now.toISOString();
466
- for (const [fieldName, fieldDef] of Object.entries(schema.fields)) {
467
- if (options.extraFields?.[fieldName] !== void 0) {
468
- const value = options.extraFields[fieldName];
469
- if (fieldDef.enum && !fieldDef.enum.includes(String(value))) {
470
- frontmatter[fieldName] = fieldDef.default ?? fieldDef.enum[0];
471
- } else {
472
- frontmatter[fieldName] = value;
473
- }
474
- continue;
475
- }
476
- if (fieldDef.default !== void 0) {
477
- let defaultValue = fieldDef.default;
478
- if (typeof defaultValue === "string") {
479
- defaultValue = defaultValue.replace("{{datetime}}", datetimeStr).replace("{{date}}", dateStr).replace("{{title}}", options.title ?? "Untitled");
480
- }
481
- frontmatter[fieldName] = defaultValue;
482
- } else if (fieldDef.required) {
483
- switch (fieldDef.type) {
484
- case "datetime":
485
- frontmatter[fieldName] = datetimeStr;
486
- break;
487
- case "date":
488
- frontmatter[fieldName] = dateStr;
489
- break;
490
- case "string":
491
- if (fieldDef.enum?.length) {
492
- frontmatter[fieldName] = fieldDef.enum[0];
493
- } else {
494
- frontmatter[fieldName] = "";
495
- }
496
- break;
497
- case "number":
498
- frontmatter[fieldName] = 0;
499
- break;
500
- case "boolean":
501
- frontmatter[fieldName] = false;
502
- break;
503
- }
504
- }
505
- }
506
- if (options.source && schema.fields.source) {
507
- frontmatter.source = options.source;
508
- }
509
- if (options.sessionId && schema.fields.session_id) {
510
- frontmatter.session_id = options.sessionId;
511
- }
512
- return frontmatter;
513
- }
514
- function validateFrontmatter(primitiveType, frontmatter) {
515
- const schema = getSchema(primitiveType);
516
- if (!schema) {
517
- return { valid: true, errors: [] };
518
- }
519
- const errors = [];
520
- for (const [fieldName, fieldDef] of Object.entries(schema.fields)) {
521
- const value = frontmatter[fieldName];
522
- if (fieldDef.required && (value === void 0 || value === null || value === "")) {
523
- errors.push(`Missing required field: ${fieldName}`);
524
- continue;
525
- }
526
- if (value === void 0 || value === null) continue;
527
- if (fieldDef.enum && !fieldDef.enum.includes(String(value))) {
528
- errors.push(`Invalid value for ${fieldName}: "${value}". Must be one of: ${fieldDef.enum.join(", ")}`);
529
- }
530
- switch (fieldDef.type) {
531
- case "number":
532
- if (typeof value !== "number" && isNaN(Number(value))) {
533
- errors.push(`Field ${fieldName} must be a number`);
534
- }
535
- break;
536
- case "boolean":
537
- if (typeof value !== "boolean" && value !== "true" && value !== "false") {
538
- errors.push(`Field ${fieldName} must be a boolean`);
539
- }
540
- break;
541
- case "datetime":
542
- if (typeof value === "string" && isNaN(Date.parse(value))) {
543
- errors.push(`Field ${fieldName} must be a valid datetime`);
544
- }
545
- break;
546
- case "date":
547
- if (typeof value === "string" && !/^\d{4}-\d{2}-\d{2}$/.test(value)) {
548
- errors.push(`Field ${fieldName} must be a valid date (YYYY-MM-DD)`);
549
- }
550
- break;
551
- }
552
- }
553
- return { valid: errors.length === 0, errors };
554
- }
555
- function serializeFrontmatter(frontmatter) {
556
- const lines = ["---"];
557
- for (const [key, value] of Object.entries(frontmatter)) {
558
- if (value === void 0 || value === null) continue;
559
- if (Array.isArray(value)) {
560
- lines.push(`${key}:`);
561
- for (const item of value) {
562
- lines.push(` - ${item}`);
563
- }
564
- } else if (typeof value === "object") {
565
- lines.push(`${key}: ${JSON.stringify(value)}`);
566
- } else if (typeof value === "string" && value.includes("\n")) {
567
- lines.push(`${key}: |`);
568
- for (const line of value.split("\n")) {
569
- lines.push(` ${line}`);
570
- }
571
- } else {
572
- lines.push(`${key}: ${value}`);
573
- }
574
- }
575
- lines.push("---");
576
- return lines.join("\n");
577
- }
578
- function resetTemplateRegistry() {
579
- registry = null;
580
- }
581
- // Annotate the CommonJS export names for ESM import in node:
582
- 0 && (module.exports = {
583
- classifyText,
584
- generateFrontmatter,
585
- getAllSchemas,
586
- getSchema,
587
- getSchemaNames,
588
- getTemplateRegistry,
589
- initializeTemplateRegistry,
590
- resetTemplateRegistry,
591
- serializeFrontmatter,
592
- validateFrontmatter
593
- });