clawvault 2.6.0 → 3.0.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 (232) hide show
  1. package/bin/command-registration.test.js +1 -3
  2. package/bin/register-core-commands.js +10 -23
  3. package/bin/register-maintenance-commands.js +3 -20
  4. package/bin/register-query-commands.js +23 -0
  5. package/bin/register-task-commands.js +1 -18
  6. package/bin/register-task-commands.test.js +0 -16
  7. package/bin/register-vault-operations-commands.js +1 -29
  8. package/dist/{chunk-QVMXF7FY.js → chunk-3D6BCTP6.js} +39 -1
  9. package/dist/{chunk-R2MIW5G7.js → chunk-3DHXQHYG.js} +1 -1
  10. package/dist/{chunk-Q2J5YTUF.js → chunk-3NSBOUT3.js} +73 -36
  11. package/dist/chunk-3RG5ZIWI.js +10 -0
  12. package/dist/{chunk-AZYOKJYC.js → chunk-62YTUT6J.js} +2 -2
  13. package/dist/chunk-6U6MK36V.js +205 -0
  14. package/dist/{chunk-4QYGFWRM.js → chunk-7R7O6STJ.js} +4 -4
  15. package/dist/{chunk-VXEOHTSL.js → chunk-C7OK5WKP.js} +4 -4
  16. package/dist/chunk-CMB7UL7C.js +327 -0
  17. package/dist/chunk-DEFFDRVP.js +938 -0
  18. package/dist/{chunk-K3CDT7IH.js → chunk-E7MFQB6D.js} +61 -20
  19. package/dist/{chunk-ME37YNW3.js → chunk-F2JEUD4J.js} +6 -4
  20. package/dist/chunk-GAJV4IGR.js +82 -0
  21. package/dist/chunk-GQSLDZTS.js +560 -0
  22. package/dist/{chunk-4OXMU5S2.js → chunk-GUKMRGM7.js} +1 -1
  23. package/dist/{chunk-YOSEUUNB.js → chunk-H34S76MB.js} +6 -6
  24. package/dist/{chunk-4TE4JMLA.js → chunk-JY6FYXIT.js} +10 -5
  25. package/dist/chunk-K234IDRJ.js +1073 -0
  26. package/dist/{chunk-IEVLHNLU.js → chunk-LNJA2UGL.js} +86 -9
  27. package/dist/{chunk-MFAWT5O5.js → chunk-LYHGEHXG.js} +1 -0
  28. package/dist/chunk-MFM6K7PU.js +374 -0
  29. package/dist/{chunk-QWQ3TIKS.js → chunk-N2AXRYLC.js} +1 -1
  30. package/dist/chunk-PAH27GSN.js +108 -0
  31. package/dist/{chunk-OIWVQYQF.js → chunk-QBLMXKF2.js} +1 -1
  32. package/dist/{chunk-FHFUXL6G.js → chunk-QK3UCXWL.js} +2 -2
  33. package/dist/{chunk-2YDBJS7M.js → chunk-SJSFRIYS.js} +1 -1
  34. package/dist/{chunk-GSD4ALSI.js → chunk-U55BGUAU.js} +2 -2
  35. package/dist/{chunk-PBEE567J.js → chunk-VGLOTGAS.js} +1 -1
  36. package/dist/{chunk-F55HGNU4.js → chunk-WAZ3NLWL.js} +47 -0
  37. package/dist/{chunk-KL4NAOMO.js → chunk-WGRQ6HDV.js} +1 -1
  38. package/dist/{chunk-UEOUADMO.js → chunk-YKTA5JOJ.js} +13 -10
  39. package/dist/{chunk-XAVB4GB4.js → chunk-ZVVFWOLW.js} +4 -4
  40. package/dist/cli/index.cjs +10033 -0
  41. package/dist/cli/index.d.cts +5 -0
  42. package/dist/cli/index.js +20 -18
  43. package/dist/commands/archive.cjs +287 -0
  44. package/dist/commands/archive.d.cts +11 -0
  45. package/dist/commands/archive.js +1 -0
  46. package/dist/commands/backlog.cjs +721 -0
  47. package/dist/commands/backlog.d.cts +53 -0
  48. package/dist/commands/backlog.js +3 -2
  49. package/dist/commands/blocked.cjs +204 -0
  50. package/dist/commands/blocked.d.cts +26 -0
  51. package/dist/commands/blocked.js +3 -2
  52. package/dist/commands/checkpoint.cjs +244 -0
  53. package/dist/commands/checkpoint.d.cts +41 -0
  54. package/dist/commands/checkpoint.js +2 -1
  55. package/dist/commands/compat.cjs +369 -0
  56. package/dist/commands/compat.d.cts +28 -0
  57. package/dist/commands/compat.js +2 -1
  58. package/dist/commands/context.cjs +2989 -0
  59. package/dist/commands/context.d.cts +2 -0
  60. package/dist/commands/context.js +5 -4
  61. package/dist/commands/doctor.cjs +3062 -0
  62. package/dist/commands/doctor.d.cts +21 -0
  63. package/dist/commands/doctor.d.ts +6 -1
  64. package/dist/commands/doctor.js +13 -11
  65. package/dist/commands/embed.cjs +232 -0
  66. package/dist/commands/embed.d.cts +17 -0
  67. package/dist/commands/embed.js +5 -2
  68. package/dist/commands/entities.cjs +141 -0
  69. package/dist/commands/entities.d.cts +7 -0
  70. package/dist/commands/entities.js +1 -0
  71. package/dist/commands/graph.cjs +501 -0
  72. package/dist/commands/graph.d.cts +21 -0
  73. package/dist/commands/graph.js +1 -0
  74. package/dist/commands/inject.cjs +1636 -0
  75. package/dist/commands/inject.d.cts +2 -0
  76. package/dist/commands/inject.d.ts +1 -1
  77. package/dist/commands/inject.js +4 -2
  78. package/dist/commands/kanban.cjs +884 -0
  79. package/dist/commands/kanban.d.cts +63 -0
  80. package/dist/commands/kanban.js +4 -3
  81. package/dist/commands/link.cjs +965 -0
  82. package/dist/commands/link.d.cts +11 -0
  83. package/dist/commands/link.js +1 -0
  84. package/dist/commands/migrate-observations.cjs +362 -0
  85. package/dist/commands/migrate-observations.d.cts +19 -0
  86. package/dist/commands/migrate-observations.js +3 -2
  87. package/dist/commands/observe.cjs +4099 -0
  88. package/dist/commands/observe.d.cts +23 -0
  89. package/dist/commands/observe.d.ts +1 -0
  90. package/dist/commands/observe.js +11 -9
  91. package/dist/commands/project.cjs +1341 -0
  92. package/dist/commands/project.d.cts +85 -0
  93. package/dist/commands/project.js +5 -4
  94. package/dist/commands/rebuild.cjs +3136 -0
  95. package/dist/commands/rebuild.d.cts +11 -0
  96. package/dist/commands/rebuild.js +10 -8
  97. package/dist/commands/recover.cjs +361 -0
  98. package/dist/commands/recover.d.cts +38 -0
  99. package/dist/commands/recover.js +3 -2
  100. package/dist/commands/reflect.cjs +1008 -0
  101. package/dist/commands/reflect.d.cts +11 -0
  102. package/dist/commands/reflect.js +6 -4
  103. package/dist/commands/repair-session.cjs +457 -0
  104. package/dist/commands/repair-session.d.cts +38 -0
  105. package/dist/commands/repair-session.js +1 -0
  106. package/dist/commands/replay.cjs +4103 -0
  107. package/dist/commands/replay.d.cts +16 -0
  108. package/dist/commands/replay.js +12 -10
  109. package/dist/commands/session-recap.cjs +353 -0
  110. package/dist/commands/session-recap.d.cts +27 -0
  111. package/dist/commands/session-recap.js +1 -0
  112. package/dist/commands/setup.cjs +1345 -0
  113. package/dist/commands/setup.d.cts +100 -0
  114. package/dist/commands/setup.d.ts +90 -2
  115. package/dist/commands/setup.js +21 -2
  116. package/dist/commands/shell-init.cjs +75 -0
  117. package/dist/commands/shell-init.d.cts +7 -0
  118. package/dist/commands/shell-init.js +2 -0
  119. package/dist/commands/sleep.cjs +6028 -0
  120. package/dist/commands/sleep.d.cts +36 -0
  121. package/dist/commands/sleep.d.ts +1 -1
  122. package/dist/commands/sleep.js +17 -15
  123. package/dist/commands/status.cjs +2736 -0
  124. package/dist/commands/status.d.cts +52 -0
  125. package/dist/commands/status.js +12 -10
  126. package/dist/commands/tailscale.cjs +1532 -0
  127. package/dist/commands/tailscale.d.cts +52 -0
  128. package/dist/commands/tailscale.js +1 -0
  129. package/dist/commands/task.cjs +1236 -0
  130. package/dist/commands/task.d.cts +97 -0
  131. package/dist/commands/task.js +4 -3
  132. package/dist/commands/template.cjs +457 -0
  133. package/dist/commands/template.d.cts +36 -0
  134. package/dist/commands/template.js +2 -1
  135. package/dist/commands/wake.cjs +2626 -0
  136. package/dist/commands/wake.d.cts +22 -0
  137. package/dist/commands/wake.d.ts +1 -1
  138. package/dist/commands/wake.js +12 -11
  139. package/dist/context-BUGaWpyL.d.cts +46 -0
  140. package/dist/index.cjs +14526 -0
  141. package/dist/index.d.cts +858 -0
  142. package/dist/index.d.ts +192 -7
  143. package/dist/index.js +101 -75
  144. package/dist/{inject-x65KXWPk.d.ts → inject-Bzi5E-By.d.cts} +1 -1
  145. package/dist/inject-Bzi5E-By.d.ts +137 -0
  146. package/dist/lib/auto-linker.cjs +176 -0
  147. package/dist/lib/auto-linker.d.cts +26 -0
  148. package/dist/lib/auto-linker.js +1 -0
  149. package/dist/lib/canvas-layout.cjs +136 -0
  150. package/dist/lib/canvas-layout.d.cts +31 -0
  151. package/dist/lib/canvas-layout.d.ts +16 -100
  152. package/dist/lib/canvas-layout.js +78 -20
  153. package/dist/lib/config.cjs +78 -0
  154. package/dist/lib/config.d.cts +11 -0
  155. package/dist/lib/config.js +1 -0
  156. package/dist/lib/entity-index.cjs +84 -0
  157. package/dist/lib/entity-index.d.cts +26 -0
  158. package/dist/lib/entity-index.js +1 -0
  159. package/dist/lib/project-utils.cjs +864 -0
  160. package/dist/lib/project-utils.d.cts +97 -0
  161. package/dist/lib/project-utils.js +4 -3
  162. package/dist/lib/session-repair.cjs +239 -0
  163. package/dist/lib/session-repair.d.cts +110 -0
  164. package/dist/lib/session-repair.js +1 -0
  165. package/dist/lib/session-utils.cjs +209 -0
  166. package/dist/lib/session-utils.d.cts +63 -0
  167. package/dist/lib/session-utils.js +1 -0
  168. package/dist/lib/tailscale.cjs +1183 -0
  169. package/dist/lib/tailscale.d.cts +225 -0
  170. package/dist/lib/tailscale.js +1 -0
  171. package/dist/lib/task-utils.cjs +1137 -0
  172. package/dist/lib/task-utils.d.cts +208 -0
  173. package/dist/lib/task-utils.js +3 -2
  174. package/dist/lib/template-engine.cjs +47 -0
  175. package/dist/lib/template-engine.d.cts +11 -0
  176. package/dist/lib/template-engine.js +1 -0
  177. package/dist/lib/webdav.cjs +568 -0
  178. package/dist/lib/webdav.d.cts +109 -0
  179. package/dist/lib/webdav.js +1 -0
  180. package/dist/plugin/index.cjs +1907 -0
  181. package/dist/plugin/index.d.cts +36 -0
  182. package/dist/plugin/index.d.ts +36 -0
  183. package/dist/plugin/index.js +572 -0
  184. package/dist/plugin/inject.cjs +356 -0
  185. package/dist/plugin/inject.d.cts +54 -0
  186. package/dist/plugin/inject.d.ts +54 -0
  187. package/dist/plugin/inject.js +17 -0
  188. package/dist/plugin/observe.cjs +631 -0
  189. package/dist/plugin/observe.d.cts +39 -0
  190. package/dist/plugin/observe.d.ts +39 -0
  191. package/dist/plugin/observe.js +18 -0
  192. package/dist/plugin/templates.cjs +593 -0
  193. package/dist/plugin/templates.d.cts +52 -0
  194. package/dist/plugin/templates.d.ts +52 -0
  195. package/dist/plugin/templates.js +25 -0
  196. package/dist/plugin/types.cjs +18 -0
  197. package/dist/plugin/types.d.cts +209 -0
  198. package/dist/plugin/types.d.ts +209 -0
  199. package/dist/plugin/types.js +0 -0
  200. package/dist/plugin/vault.cjs +927 -0
  201. package/dist/plugin/vault.d.cts +68 -0
  202. package/dist/plugin/vault.d.ts +68 -0
  203. package/dist/plugin/vault.js +22 -0
  204. package/dist/{types-C74wgGL1.d.ts → types-Y2_Um2Ls.d.cts} +44 -1
  205. package/dist/types-Y2_Um2Ls.d.ts +205 -0
  206. package/hooks/clawvault/handler.js +70 -7
  207. package/hooks/clawvault/handler.test.js +91 -0
  208. package/openclaw.plugin.json +56 -0
  209. package/package.json +17 -7
  210. package/templates/memory-event.md +67 -0
  211. package/templates/party.md +63 -0
  212. package/templates/primitive-registry.yaml +551 -0
  213. package/templates/run.md +68 -0
  214. package/templates/trigger.md +68 -0
  215. package/templates/workspace.md +50 -0
  216. package/dashboard/lib/graph-diff.js +0 -104
  217. package/dashboard/lib/graph-diff.test.js +0 -75
  218. package/dashboard/lib/vault-parser.js +0 -556
  219. package/dashboard/lib/vault-parser.test.js +0 -254
  220. package/dashboard/public/app.js +0 -796
  221. package/dashboard/public/index.html +0 -52
  222. package/dashboard/public/styles.css +0 -221
  223. package/dashboard/server.js +0 -374
  224. package/dist/chunk-HA5M6KJB.js +0 -33
  225. package/dist/chunk-MAKNAHAW.js +0 -375
  226. package/dist/chunk-MDIH26GC.js +0 -183
  227. package/dist/chunk-MGDEINGP.js +0 -99
  228. package/dist/chunk-RVYA52PY.js +0 -363
  229. package/dist/commands/canvas.d.ts +0 -15
  230. package/dist/commands/canvas.js +0 -199
  231. package/dist/commands/sync-bd.d.ts +0 -10
  232. package/dist/commands/sync-bd.js +0 -9
@@ -0,0 +1,53 @@
1
+ import { TaskPriority, BacklogItem, Task } from '../lib/task-utils.cjs';
2
+
3
+ /**
4
+ * Backlog command for ClawVault
5
+ * Manages backlog add/list/promote operations
6
+ */
7
+
8
+ interface BacklogAddOptions {
9
+ source?: string;
10
+ project?: string;
11
+ content?: string;
12
+ tags?: string[];
13
+ }
14
+ interface BacklogListOptions {
15
+ project?: string;
16
+ json?: boolean;
17
+ }
18
+ interface BacklogPromoteOptions {
19
+ owner?: string;
20
+ priority?: TaskPriority;
21
+ due?: string;
22
+ }
23
+ /**
24
+ * Add a new backlog item
25
+ */
26
+ declare function backlogAdd(vaultPath: string, title: string, options?: BacklogAddOptions): BacklogItem;
27
+ /**
28
+ * List backlog items with optional filters
29
+ */
30
+ declare function backlogList(vaultPath: string, options?: BacklogListOptions): BacklogItem[];
31
+ /**
32
+ * Promote a backlog item to a task
33
+ */
34
+ declare function backlogPromote(vaultPath: string, slug: string, options?: BacklogPromoteOptions): Task;
35
+ /**
36
+ * Format backlog list for terminal display
37
+ */
38
+ declare function formatBacklogList(items: BacklogItem[]): string;
39
+ /**
40
+ * Format backlog item details for display
41
+ */
42
+ declare function formatBacklogDetails(item: BacklogItem): string;
43
+ /**
44
+ * Backlog command handler for CLI
45
+ * Note: The CLI uses "clawvault backlog <title>" as shorthand for add
46
+ */
47
+ declare function backlogCommand(vaultPath: string, action: 'add' | 'list' | 'promote', args: {
48
+ title?: string;
49
+ slug?: string;
50
+ options?: BacklogAddOptions & BacklogListOptions & BacklogPromoteOptions;
51
+ }): Promise<void>;
52
+
53
+ export { type BacklogAddOptions, type BacklogListOptions, type BacklogPromoteOptions, backlogAdd, backlogCommand, backlogList, backlogPromote, formatBacklogDetails, formatBacklogList };
@@ -2,9 +2,10 @@ import {
2
2
  createBacklogItem,
3
3
  listBacklogItems,
4
4
  promoteBacklogItem
5
- } from "../chunk-QWQ3TIKS.js";
6
- import "../chunk-MFAWT5O5.js";
5
+ } from "../chunk-N2AXRYLC.js";
6
+ import "../chunk-LYHGEHXG.js";
7
7
  import "../chunk-7766SIJP.js";
8
+ import "../chunk-3RG5ZIWI.js";
8
9
 
9
10
  // src/commands/backlog.ts
10
11
  function toDateStr(val) {
@@ -0,0 +1,204 @@
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/blocked.ts
31
+ var blocked_exports = {};
32
+ __export(blocked_exports, {
33
+ blockedCommand: () => blockedCommand,
34
+ blockedList: () => blockedList,
35
+ formatBlockedList: () => formatBlockedList
36
+ });
37
+ module.exports = __toCommonJS(blocked_exports);
38
+
39
+ // src/lib/task-utils.ts
40
+ var fs = __toESM(require("fs"), 1);
41
+ var path = __toESM(require("path"), 1);
42
+ var import_gray_matter2 = __toESM(require("gray-matter"), 1);
43
+
44
+ // src/lib/primitive-templates.ts
45
+ var import_gray_matter = __toESM(require("gray-matter"), 1);
46
+
47
+ // src/lib/task-utils.ts
48
+ function getTasksDir(vaultPath) {
49
+ return path.join(path.resolve(vaultPath), "tasks");
50
+ }
51
+ function getTaskPath(vaultPath, slug) {
52
+ return path.join(getTasksDir(vaultPath), `${slug}.md`);
53
+ }
54
+ function extractTitle(content) {
55
+ const match = content.match(/^#\s+(.+)$/m);
56
+ return match ? match[1].trim() : "";
57
+ }
58
+ function parseDueDate(value) {
59
+ if (!value) return null;
60
+ const timestamp = Date.parse(value);
61
+ if (Number.isNaN(timestamp)) return null;
62
+ return timestamp;
63
+ }
64
+ function startOfToday() {
65
+ const now = /* @__PURE__ */ new Date();
66
+ return new Date(now.getFullYear(), now.getMonth(), now.getDate()).getTime();
67
+ }
68
+ function readTask(vaultPath, slug) {
69
+ const taskPath = getTaskPath(vaultPath, slug);
70
+ if (!fs.existsSync(taskPath)) {
71
+ return null;
72
+ }
73
+ try {
74
+ const raw = fs.readFileSync(taskPath, "utf-8");
75
+ const { data, content } = (0, import_gray_matter2.default)(raw);
76
+ const title = extractTitle(content) || slug;
77
+ return {
78
+ slug,
79
+ title,
80
+ content,
81
+ frontmatter: data,
82
+ path: taskPath
83
+ };
84
+ } catch {
85
+ return null;
86
+ }
87
+ }
88
+ function listTasks(vaultPath, filters) {
89
+ const tasksDir = getTasksDir(vaultPath);
90
+ if (!fs.existsSync(tasksDir)) {
91
+ return [];
92
+ }
93
+ const tasks = [];
94
+ const entries = fs.readdirSync(tasksDir, { withFileTypes: true });
95
+ const today = startOfToday();
96
+ for (const entry of entries) {
97
+ if (!entry.isFile() || !entry.name.endsWith(".md")) {
98
+ continue;
99
+ }
100
+ const slug = entry.name.replace(/\.md$/, "");
101
+ const task = readTask(vaultPath, slug);
102
+ if (!task) continue;
103
+ if (filters) {
104
+ if (filters.status && task.frontmatter.status !== filters.status) continue;
105
+ if (filters.owner && task.frontmatter.owner !== filters.owner) continue;
106
+ if (filters.project && task.frontmatter.project !== filters.project) continue;
107
+ if (filters.priority && task.frontmatter.priority !== filters.priority) continue;
108
+ if (filters.due && !task.frontmatter.due) continue;
109
+ if (filters.tag) {
110
+ const tags = task.frontmatter.tags || [];
111
+ const hasTag = tags.some((tag) => tag.toLowerCase() === filters.tag?.toLowerCase());
112
+ if (!hasTag) continue;
113
+ }
114
+ if (filters.overdue) {
115
+ const dueTime = parseDueDate(task.frontmatter.due);
116
+ if (task.frontmatter.status === "done" || dueTime === null || dueTime >= today) continue;
117
+ }
118
+ }
119
+ tasks.push(task);
120
+ }
121
+ const priorityOrder = {
122
+ critical: 0,
123
+ high: 1,
124
+ medium: 2,
125
+ low: 3
126
+ };
127
+ if (filters?.due || filters?.overdue) {
128
+ return tasks.sort((a, b) => {
129
+ const aDue = parseDueDate(a.frontmatter.due);
130
+ const bDue = parseDueDate(b.frontmatter.due);
131
+ if (aDue !== null && bDue !== null && aDue !== bDue) {
132
+ return aDue - bDue;
133
+ }
134
+ if (aDue !== null && bDue === null) return -1;
135
+ if (aDue === null && bDue !== null) return 1;
136
+ return new Date(b.frontmatter.created).getTime() - new Date(a.frontmatter.created).getTime();
137
+ });
138
+ }
139
+ return tasks.sort((a, b) => {
140
+ const aPriority = priorityOrder[a.frontmatter.priority || "low"];
141
+ const bPriority = priorityOrder[b.frontmatter.priority || "low"];
142
+ if (aPriority !== bPriority) {
143
+ return aPriority - bPriority;
144
+ }
145
+ return new Date(b.frontmatter.created).getTime() - new Date(a.frontmatter.created).getTime();
146
+ });
147
+ }
148
+ function getBlockedTasks(vaultPath, project) {
149
+ const filters = { status: "blocked" };
150
+ if (project) filters.project = project;
151
+ return listTasks(vaultPath, filters);
152
+ }
153
+
154
+ // src/commands/blocked.ts
155
+ function toDateStr(val) {
156
+ if (!val) return "unknown";
157
+ if (val instanceof Date) return val.toISOString().split("T")[0];
158
+ const s = String(val);
159
+ if (s.includes("T")) return s.split("T")[0];
160
+ return s;
161
+ }
162
+ function blockedList(vaultPath, options = {}) {
163
+ let tasks = getBlockedTasks(vaultPath, options.project);
164
+ if (options.escalated) {
165
+ tasks = tasks.filter((t) => t.frontmatter.escalation === true);
166
+ }
167
+ return tasks;
168
+ }
169
+ function formatBlockedList(tasks) {
170
+ if (tasks.length === 0) {
171
+ return "No blocked tasks.\n";
172
+ }
173
+ let output = `BLOCKED TASKS (${tasks.length})
174
+
175
+ `;
176
+ for (const task of tasks) {
177
+ const owner = task.frontmatter.owner || "unassigned";
178
+ const project = task.frontmatter.project || "no project";
179
+ const blockedBy = task.frontmatter.blocked_by || "unknown";
180
+ const updatedDate = toDateStr(task.frontmatter.updated);
181
+ output += `\u25A0 ${task.title} (${owner}, ${project})
182
+ `;
183
+ output += ` Blocked by: ${blockedBy}
184
+ `;
185
+ output += ` Since: ${updatedDate}
186
+ `;
187
+ output += "\n";
188
+ }
189
+ return output;
190
+ }
191
+ async function blockedCommand(vaultPath, options = {}) {
192
+ const tasks = blockedList(vaultPath, options);
193
+ if (options.json) {
194
+ console.log(JSON.stringify(tasks, null, 2));
195
+ } else {
196
+ console.log(formatBlockedList(tasks));
197
+ }
198
+ }
199
+ // Annotate the CommonJS export names for ESM import in node:
200
+ 0 && (module.exports = {
201
+ blockedCommand,
202
+ blockedList,
203
+ formatBlockedList
204
+ });
@@ -0,0 +1,26 @@
1
+ import { Task } from '../lib/task-utils.cjs';
2
+
3
+ /**
4
+ * Blocked command for ClawVault
5
+ * Quick view of blocked tasks
6
+ */
7
+
8
+ interface BlockedOptions {
9
+ project?: string;
10
+ json?: boolean;
11
+ escalated?: boolean;
12
+ }
13
+ /**
14
+ * Get blocked tasks
15
+ */
16
+ declare function blockedList(vaultPath: string, options?: BlockedOptions): Task[];
17
+ /**
18
+ * Format blocked tasks for terminal display
19
+ */
20
+ declare function formatBlockedList(tasks: Task[]): string;
21
+ /**
22
+ * Blocked command handler for CLI
23
+ */
24
+ declare function blockedCommand(vaultPath: string, options?: BlockedOptions): Promise<void>;
25
+
26
+ export { type BlockedOptions, blockedCommand, blockedList, formatBlockedList };
@@ -1,8 +1,9 @@
1
1
  import {
2
2
  getBlockedTasks
3
- } from "../chunk-QWQ3TIKS.js";
4
- import "../chunk-MFAWT5O5.js";
3
+ } from "../chunk-N2AXRYLC.js";
4
+ import "../chunk-LYHGEHXG.js";
5
5
  import "../chunk-7766SIJP.js";
6
+ import "../chunk-3RG5ZIWI.js";
6
7
 
7
8
  // src/commands/blocked.ts
8
9
  function toDateStr(val) {
@@ -0,0 +1,244 @@
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/checkpoint.ts
31
+ var checkpoint_exports = {};
32
+ __export(checkpoint_exports, {
33
+ checkDirtyDeath: () => checkDirtyDeath,
34
+ checkpoint: () => checkpoint,
35
+ cleanExit: () => cleanExit,
36
+ clearDirtyFlag: () => clearDirtyFlag,
37
+ flush: () => flush,
38
+ setSessionState: () => setSessionState
39
+ });
40
+ module.exports = __toCommonJS(checkpoint_exports);
41
+ var fs = __toESM(require("fs"), 1);
42
+ var path = __toESM(require("path"), 1);
43
+ var import_child_process = require("child_process");
44
+ var CLAWVAULT_DIR = ".clawvault";
45
+ var CHECKPOINT_FILE = "last-checkpoint.json";
46
+ var SESSION_STATE_FILE = "session-state.json";
47
+ var DIRTY_DEATH_FLAG = "dirty-death.flag";
48
+ var CHECKPOINT_HISTORY_DIR = "checkpoints";
49
+ var CHECKPOINT_RETENTION_MAX_COUNT = 50;
50
+ var CHECKPOINT_RETENTION_MAX_AGE_MS = 7 * 24 * 60 * 60 * 1e3;
51
+ var pendingCheckpoint = null;
52
+ var pendingData = null;
53
+ function ensureClawvaultDir(vaultPath) {
54
+ const dir = path.join(vaultPath, CLAWVAULT_DIR);
55
+ if (!fs.existsSync(dir)) {
56
+ fs.mkdirSync(dir, { recursive: true });
57
+ }
58
+ return dir;
59
+ }
60
+ function readCheckpointHistoryEntries(historyDir) {
61
+ const entries = [];
62
+ const files = fs.readdirSync(historyDir).filter((entry) => entry.endsWith(".json"));
63
+ for (const fileName of files) {
64
+ const filePath = path.join(historyDir, fileName);
65
+ try {
66
+ const parsed = JSON.parse(fs.readFileSync(filePath, "utf-8"));
67
+ if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) {
68
+ continue;
69
+ }
70
+ const timestamp = typeof parsed.timestamp === "string" ? parsed.timestamp : "";
71
+ const timestampMs = Date.parse(timestamp);
72
+ if (Number.isNaN(timestampMs)) {
73
+ continue;
74
+ }
75
+ entries.push({ filePath, timestampMs });
76
+ } catch {
77
+ }
78
+ }
79
+ return entries.sort((left, right) => {
80
+ if (right.timestampMs !== left.timestampMs) {
81
+ return right.timestampMs - left.timestampMs;
82
+ }
83
+ return right.filePath.localeCompare(left.filePath);
84
+ });
85
+ }
86
+ function pruneCheckpointHistory(historyDir, nowMs) {
87
+ if (!fs.existsSync(historyDir)) {
88
+ return;
89
+ }
90
+ const entries = readCheckpointHistoryEntries(historyDir);
91
+ if (entries.length <= CHECKPOINT_RETENTION_MAX_COUNT) {
92
+ return;
93
+ }
94
+ for (let index = CHECKPOINT_RETENTION_MAX_COUNT; index < entries.length; index += 1) {
95
+ const ageMs = nowMs - entries[index].timestampMs;
96
+ if (ageMs > CHECKPOINT_RETENTION_MAX_AGE_MS) {
97
+ try {
98
+ fs.unlinkSync(entries[index].filePath);
99
+ } catch {
100
+ }
101
+ }
102
+ }
103
+ }
104
+ function writeCheckpointToDisk(dir, data) {
105
+ const checkpointPath = path.join(dir, CHECKPOINT_FILE);
106
+ fs.writeFileSync(checkpointPath, JSON.stringify(data, null, 2));
107
+ const historyDir = path.join(dir, CHECKPOINT_HISTORY_DIR);
108
+ fs.mkdirSync(historyDir, { recursive: true });
109
+ const historyFileName = `${data.timestamp.replace(/[:.]/g, "-")}.json`;
110
+ const historyPath = path.join(historyDir, historyFileName);
111
+ fs.writeFileSync(historyPath, JSON.stringify(data, null, 2));
112
+ pruneCheckpointHistory(historyDir, Date.now());
113
+ const flagPath = path.join(dir, DIRTY_DEATH_FLAG);
114
+ fs.writeFileSync(flagPath, data.timestamp);
115
+ }
116
+ function parseTokenEstimate(raw) {
117
+ if (!raw) return void 0;
118
+ const parsed = Number(raw);
119
+ return Number.isFinite(parsed) ? parsed : void 0;
120
+ }
121
+ function loadSessionState(dir) {
122
+ const sessionStatePath = path.join(dir, SESSION_STATE_FILE);
123
+ if (!fs.existsSync(sessionStatePath)) return null;
124
+ try {
125
+ return JSON.parse(fs.readFileSync(sessionStatePath, "utf-8"));
126
+ } catch {
127
+ return null;
128
+ }
129
+ }
130
+ function getEnvSessionState() {
131
+ return {
132
+ sessionKey: process.env.OPENCLAW_SESSION_KEY,
133
+ model: process.env.OPENCLAW_MODEL,
134
+ tokenEstimate: parseTokenEstimate(
135
+ process.env.OPENCLAW_TOKEN_ESTIMATE || process.env.OPENCLAW_CONTEXT_TOKENS
136
+ )
137
+ };
138
+ }
139
+ function triggerUrgentWake(data) {
140
+ const summary = [
141
+ data.workingOn ? `Working on: ${data.workingOn}` : null,
142
+ data.focus ? `Focus: ${data.focus}` : null,
143
+ data.blocked ? `Blocked: ${data.blocked}` : null
144
+ ].filter(Boolean).join(" | ");
145
+ const text = summary ? `Urgent checkpoint saved. ${summary}` : "Urgent checkpoint saved.";
146
+ try {
147
+ (0, import_child_process.execFileSync)("openclaw", ["gateway", "wake", "--text", text, "--mode", "now"], {
148
+ stdio: "inherit"
149
+ });
150
+ } catch (err) {
151
+ if (err?.code === "ENOENT") {
152
+ throw new Error("Urgent wake failed: openclaw CLI not found.");
153
+ }
154
+ throw new Error(`Urgent wake failed: ${err?.message || "unknown error"}`);
155
+ }
156
+ }
157
+ async function flush() {
158
+ if (pendingCheckpoint) {
159
+ clearTimeout(pendingCheckpoint);
160
+ pendingCheckpoint = null;
161
+ }
162
+ if (!pendingData) return null;
163
+ const { dir, data } = pendingData;
164
+ pendingData = null;
165
+ writeCheckpointToDisk(dir, data);
166
+ return data;
167
+ }
168
+ async function checkpoint(options) {
169
+ const dir = ensureClawvaultDir(options.vaultPath);
170
+ const data = {
171
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
172
+ workingOn: options.workingOn || null,
173
+ focus: options.focus || null,
174
+ blocked: options.blocked || null,
175
+ urgent: options.urgent || false
176
+ };
177
+ const sessionState = loadSessionState(dir);
178
+ const envState = getEnvSessionState();
179
+ data.sessionId = sessionState?.sessionId;
180
+ data.sessionKey = envState.sessionKey || sessionState?.sessionKey || sessionState?.sessionId;
181
+ data.model = envState.model || sessionState?.model;
182
+ data.tokenEstimate = envState.tokenEstimate ?? sessionState?.tokenEstimate;
183
+ data.sessionStartedAt = sessionState?.startedAt;
184
+ if (options.urgent) {
185
+ if (pendingCheckpoint) {
186
+ clearTimeout(pendingCheckpoint);
187
+ pendingCheckpoint = null;
188
+ }
189
+ pendingData = null;
190
+ writeCheckpointToDisk(dir, data);
191
+ triggerUrgentWake(data);
192
+ } else {
193
+ pendingData = { dir, data };
194
+ if (pendingCheckpoint) clearTimeout(pendingCheckpoint);
195
+ pendingCheckpoint = setTimeout(() => {
196
+ void flush();
197
+ }, 1e3);
198
+ }
199
+ return data;
200
+ }
201
+ async function clearDirtyFlag(vaultPath) {
202
+ const flagPath = path.join(vaultPath, CLAWVAULT_DIR, DIRTY_DEATH_FLAG);
203
+ if (fs.existsSync(flagPath)) {
204
+ fs.unlinkSync(flagPath);
205
+ }
206
+ }
207
+ async function cleanExit(vaultPath) {
208
+ await clearDirtyFlag(vaultPath);
209
+ }
210
+ async function checkDirtyDeath(vaultPath) {
211
+ const dir = path.join(vaultPath, CLAWVAULT_DIR);
212
+ const flagPath = path.join(dir, DIRTY_DEATH_FLAG);
213
+ const checkpointPath = path.join(dir, CHECKPOINT_FILE);
214
+ if (!fs.existsSync(flagPath)) {
215
+ return { died: false, checkpoint: null, deathTime: null };
216
+ }
217
+ const deathTime = fs.readFileSync(flagPath, "utf-8").trim();
218
+ let checkpoint2 = null;
219
+ if (fs.existsSync(checkpointPath)) {
220
+ try {
221
+ checkpoint2 = JSON.parse(fs.readFileSync(checkpointPath, "utf-8"));
222
+ } catch {
223
+ }
224
+ }
225
+ return { died: true, checkpoint: checkpoint2, deathTime };
226
+ }
227
+ async function setSessionState(vaultPath, session) {
228
+ const dir = ensureClawvaultDir(vaultPath);
229
+ const sessionStatePath = path.join(dir, SESSION_STATE_FILE);
230
+ const state = typeof session === "string" ? { sessionId: session } : { ...session };
231
+ if (!state.startedAt) {
232
+ state.startedAt = (/* @__PURE__ */ new Date()).toISOString();
233
+ }
234
+ fs.writeFileSync(sessionStatePath, JSON.stringify(state, null, 2));
235
+ }
236
+ // Annotate the CommonJS export names for ESM import in node:
237
+ 0 && (module.exports = {
238
+ checkDirtyDeath,
239
+ checkpoint,
240
+ cleanExit,
241
+ clearDirtyFlag,
242
+ flush,
243
+ setSessionState
244
+ });
@@ -0,0 +1,41 @@
1
+ /**
2
+ * Quick checkpoint command - fast state save for context death resilience
3
+ */
4
+ interface CheckpointOptions {
5
+ workingOn?: string;
6
+ focus?: string;
7
+ blocked?: string;
8
+ vaultPath: string;
9
+ urgent?: boolean;
10
+ }
11
+ interface CheckpointData {
12
+ timestamp: string;
13
+ workingOn: string | null;
14
+ focus: string | null;
15
+ blocked: string | null;
16
+ sessionId?: string;
17
+ sessionKey?: string;
18
+ model?: string;
19
+ tokenEstimate?: number;
20
+ sessionStartedAt?: string;
21
+ urgent?: boolean;
22
+ }
23
+ interface SessionState {
24
+ sessionId?: string;
25
+ sessionKey?: string;
26
+ model?: string;
27
+ tokenEstimate?: number;
28
+ startedAt?: string;
29
+ }
30
+ declare function flush(): Promise<CheckpointData | null>;
31
+ declare function checkpoint(options: CheckpointOptions): Promise<CheckpointData>;
32
+ declare function clearDirtyFlag(vaultPath: string): Promise<void>;
33
+ declare function cleanExit(vaultPath: string): Promise<void>;
34
+ declare function checkDirtyDeath(vaultPath: string): Promise<{
35
+ died: boolean;
36
+ checkpoint: CheckpointData | null;
37
+ deathTime: string | null;
38
+ }>;
39
+ declare function setSessionState(vaultPath: string, session: string | SessionState): Promise<void>;
40
+
41
+ export { type CheckpointData, type CheckpointOptions, type SessionState, checkDirtyDeath, checkpoint, cleanExit, clearDirtyFlag, flush, setSessionState };
@@ -5,7 +5,8 @@ import {
5
5
  clearDirtyFlag,
6
6
  flush,
7
7
  setSessionState
8
- } from "../chunk-F55HGNU4.js";
8
+ } from "../chunk-WAZ3NLWL.js";
9
+ import "../chunk-3RG5ZIWI.js";
9
10
  export {
10
11
  checkDirtyDeath,
11
12
  checkpoint,