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,97 @@
1
+ import { Task } from './task-utils.cjs';
2
+
3
+ /**
4
+ * Project utilities for ClawVault project tracking
5
+ * Handles project definition and activity file read/write/query operations
6
+ */
7
+
8
+ type ProjectStatus = 'active' | 'paused' | 'completed' | 'archived';
9
+ interface ProjectFrontmatter {
10
+ type: 'project';
11
+ status: ProjectStatus;
12
+ created: string;
13
+ updated: string;
14
+ owner?: string;
15
+ team?: string[];
16
+ client?: string;
17
+ tags?: string[];
18
+ description?: string;
19
+ started?: string;
20
+ deadline?: string;
21
+ repo?: string;
22
+ url?: string;
23
+ completed?: string;
24
+ reason?: string;
25
+ }
26
+ interface Project {
27
+ slug: string;
28
+ title: string;
29
+ content: string;
30
+ frontmatter: ProjectFrontmatter;
31
+ }
32
+ interface ProjectFilterOptions {
33
+ status?: ProjectStatus;
34
+ owner?: string;
35
+ client?: string;
36
+ tag?: string;
37
+ }
38
+ interface CreateProjectOptions {
39
+ status?: ProjectStatus;
40
+ owner?: string;
41
+ team?: string[];
42
+ client?: string;
43
+ tags?: string[];
44
+ description?: string;
45
+ started?: string;
46
+ deadline?: string;
47
+ repo?: string;
48
+ url?: string;
49
+ completed?: string;
50
+ reason?: string;
51
+ content?: string;
52
+ }
53
+ interface UpdateProjectOptions {
54
+ status?: ProjectStatus;
55
+ owner?: string | null;
56
+ team?: string[] | null;
57
+ client?: string | null;
58
+ tags?: string[] | null;
59
+ description?: string | null;
60
+ started?: string | null;
61
+ deadline?: string | null;
62
+ repo?: string | null;
63
+ url?: string | null;
64
+ completed?: string | null;
65
+ reason?: string | null;
66
+ }
67
+ /**
68
+ * List all project definition files in the vault.
69
+ * Includes only root-level projects/*.md files with type: project frontmatter.
70
+ */
71
+ declare function listProjects(vaultPath: string, filters?: ProjectFilterOptions): Project[];
72
+ /**
73
+ * Read a project definition file from projects/{slug}.md
74
+ */
75
+ declare function readProject(vaultPath: string, slug: string): Project | null;
76
+ /**
77
+ * Create a new project definition at projects/{slug}.md
78
+ */
79
+ declare function createProject(vaultPath: string, title: string, options?: CreateProjectOptions): Project;
80
+ /**
81
+ * Update an existing project's frontmatter
82
+ */
83
+ declare function updateProject(vaultPath: string, slug: string, updates: UpdateProjectOptions): Project;
84
+ /**
85
+ * Archive a project with optional reason and completion date
86
+ */
87
+ declare function archiveProject(vaultPath: string, slug: string, reason?: string): Project;
88
+ /**
89
+ * List tasks linked to a project by task.frontmatter.project === project slug
90
+ */
91
+ declare function getProjectTasks(vaultPath: string, slug: string): Task[];
92
+ /**
93
+ * List files in projects/{slug}/ sorted by date (newest first)
94
+ */
95
+ declare function getProjectActivity(vaultPath: string, slug: string): string[];
96
+
97
+ export { type CreateProjectOptions, type Project, type ProjectFilterOptions, type ProjectFrontmatter, type ProjectStatus, type UpdateProjectOptions, archiveProject, createProject, getProjectActivity, getProjectTasks, listProjects, readProject, updateProject };
@@ -6,10 +6,11 @@ import {
6
6
  listProjects,
7
7
  readProject,
8
8
  updateProject
9
- } from "../chunk-AZYOKJYC.js";
10
- import "../chunk-QWQ3TIKS.js";
11
- import "../chunk-MFAWT5O5.js";
9
+ } from "../chunk-62YTUT6J.js";
10
+ import "../chunk-N2AXRYLC.js";
11
+ import "../chunk-LYHGEHXG.js";
12
12
  import "../chunk-7766SIJP.js";
13
+ import "../chunk-3RG5ZIWI.js";
13
14
  export {
14
15
  archiveProject,
15
16
  createProject,
@@ -0,0 +1,239 @@
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/lib/session-repair.ts
31
+ var session_repair_exports = {};
32
+ __export(session_repair_exports, {
33
+ analyzeSession: () => analyzeSession,
34
+ computeParentRelinks: () => computeParentRelinks,
35
+ extractToolUses: () => extractToolUses,
36
+ findCorruptedEntries: () => findCorruptedEntries,
37
+ parseTranscript: () => parseTranscript,
38
+ repairSession: () => repairSession
39
+ });
40
+ module.exports = __toCommonJS(session_repair_exports);
41
+ var fs = __toESM(require("fs"), 1);
42
+ function parseTranscript(filePath) {
43
+ const content = fs.readFileSync(filePath, "utf-8");
44
+ const lines = content.split("\n").filter((line) => line.trim());
45
+ const entries = [];
46
+ for (let i = 0; i < lines.length; i++) {
47
+ const raw = lines[i];
48
+ try {
49
+ const entry = JSON.parse(raw);
50
+ entries.push({ line: i + 1, entry, raw });
51
+ } catch {
52
+ console.warn(`Warning: Could not parse line ${i + 1}`);
53
+ }
54
+ }
55
+ return entries;
56
+ }
57
+ function extractToolUses(entries) {
58
+ const toolUses = /* @__PURE__ */ new Map();
59
+ for (const { line, entry } of entries) {
60
+ if (entry.type !== "message") continue;
61
+ if (entry.message?.role !== "assistant") continue;
62
+ const isAborted = entry.message.stopReason === "aborted";
63
+ const content = entry.message.content || [];
64
+ for (const block of content) {
65
+ if (block.type === "toolCall" || block.type === "tool_use" || block.type === "functionCall") {
66
+ if (block.id) {
67
+ const isPartial = !!block.partialJson;
68
+ toolUses.set(block.id, {
69
+ id: block.id,
70
+ lineNumber: line,
71
+ entryId: entry.id,
72
+ isAborted: isAborted || isPartial,
73
+ isPartial,
74
+ name: block.name
75
+ });
76
+ }
77
+ }
78
+ }
79
+ }
80
+ return toolUses;
81
+ }
82
+ function findCorruptedEntries(entries, toolUses) {
83
+ const corrupted = [];
84
+ const entriesToRemove = /* @__PURE__ */ new Set();
85
+ for (const [toolId, info] of toolUses) {
86
+ if (info.isAborted) {
87
+ corrupted.push({
88
+ lineNumber: info.lineNumber,
89
+ entryId: info.entryId,
90
+ type: "aborted_tool_use",
91
+ toolUseId: toolId,
92
+ description: `Aborted tool_use${info.name ? ` (${info.name})` : ""} with id: ${toolId}`
93
+ });
94
+ entriesToRemove.add(info.entryId);
95
+ }
96
+ }
97
+ for (const { line, entry } of entries) {
98
+ if (entry.type !== "message") continue;
99
+ if (entry.message?.role !== "toolResult") continue;
100
+ const content = entry.message.content || [];
101
+ let toolCallId;
102
+ const msg = entry.message;
103
+ toolCallId = msg.toolCallId || msg.toolUseId;
104
+ if (!toolCallId) {
105
+ for (const block of content) {
106
+ if (block.toolCallId || block.toolUseId) {
107
+ toolCallId = block.toolCallId || block.toolUseId;
108
+ break;
109
+ }
110
+ }
111
+ }
112
+ if (!toolCallId) continue;
113
+ const toolUse = toolUses.get(toolCallId);
114
+ if (!toolUse || toolUse.isAborted) {
115
+ corrupted.push({
116
+ lineNumber: line,
117
+ entryId: entry.id,
118
+ type: "orphaned_tool_result",
119
+ toolUseId: toolCallId,
120
+ description: toolUse ? `Orphaned tool_result references aborted tool_use: ${toolCallId}` : `Orphaned tool_result references non-existent tool_use: ${toolCallId}`
121
+ });
122
+ entriesToRemove.add(entry.id);
123
+ }
124
+ }
125
+ return { corrupted, entriesToRemove };
126
+ }
127
+ function computeParentRelinks(entries, entriesToRemove) {
128
+ const relinks = [];
129
+ const entryParents = /* @__PURE__ */ new Map();
130
+ for (const { entry } of entries) {
131
+ entryParents.set(entry.id, entry.parentId);
132
+ }
133
+ for (const { line, entry } of entries) {
134
+ if (entriesToRemove.has(entry.id)) continue;
135
+ if (!entry.parentId) continue;
136
+ if (!entriesToRemove.has(entry.parentId)) continue;
137
+ let newParentId = entry.parentId;
138
+ while (newParentId && entriesToRemove.has(newParentId)) {
139
+ newParentId = entryParents.get(newParentId) || null;
140
+ }
141
+ if (newParentId !== entry.parentId) {
142
+ relinks.push({
143
+ lineNumber: line,
144
+ entryId: entry.id,
145
+ oldParentId: entry.parentId,
146
+ newParentId: newParentId || "null"
147
+ });
148
+ }
149
+ }
150
+ return relinks;
151
+ }
152
+ function analyzeSession(filePath) {
153
+ const entries = parseTranscript(filePath);
154
+ const sessionEntry = entries.find((e) => e.entry.type === "session");
155
+ const sessionId = sessionEntry?.entry.id || "unknown";
156
+ const toolUses = extractToolUses(entries);
157
+ const { corrupted, entriesToRemove } = findCorruptedEntries(entries, toolUses);
158
+ const parentRelinks = computeParentRelinks(entries, entriesToRemove);
159
+ return {
160
+ sessionId,
161
+ totalLines: entries.length,
162
+ corruptedEntries: corrupted,
163
+ parentRelinks,
164
+ removedCount: entriesToRemove.size,
165
+ relinkedCount: parentRelinks.length,
166
+ repaired: false
167
+ };
168
+ }
169
+ function repairSession(filePath, options = {}) {
170
+ const { backup = true, dryRun = false } = options;
171
+ const entries = parseTranscript(filePath);
172
+ const sessionEntry = entries.find((e) => e.entry.type === "session");
173
+ const sessionId = sessionEntry?.entry.id || "unknown";
174
+ const toolUses = extractToolUses(entries);
175
+ const { corrupted, entriesToRemove } = findCorruptedEntries(entries, toolUses);
176
+ const parentRelinks = computeParentRelinks(entries, entriesToRemove);
177
+ if (corrupted.length === 0) {
178
+ return {
179
+ sessionId,
180
+ totalLines: entries.length,
181
+ corruptedEntries: [],
182
+ parentRelinks: [],
183
+ removedCount: 0,
184
+ relinkedCount: 0,
185
+ repaired: false
186
+ };
187
+ }
188
+ if (dryRun) {
189
+ return {
190
+ sessionId,
191
+ totalLines: entries.length,
192
+ corruptedEntries: corrupted,
193
+ parentRelinks,
194
+ removedCount: entriesToRemove.size,
195
+ relinkedCount: parentRelinks.length,
196
+ repaired: false
197
+ };
198
+ }
199
+ let backupPath;
200
+ if (backup) {
201
+ const timestamp = (/* @__PURE__ */ new Date()).toISOString().replace(/[:.]/g, "").replace("T", "-").slice(0, 15);
202
+ backupPath = `${filePath}.backup-${timestamp}`;
203
+ fs.copyFileSync(filePath, backupPath);
204
+ }
205
+ const relinkMap = /* @__PURE__ */ new Map();
206
+ for (const relink of parentRelinks) {
207
+ relinkMap.set(relink.entryId, relink.newParentId === "null" ? null : relink.newParentId);
208
+ }
209
+ const repairedLines = [];
210
+ for (const { entry, raw } of entries) {
211
+ if (entriesToRemove.has(entry.id)) continue;
212
+ if (relinkMap.has(entry.id)) {
213
+ const newEntry = { ...entry, parentId: relinkMap.get(entry.id) };
214
+ repairedLines.push(JSON.stringify(newEntry));
215
+ } else {
216
+ repairedLines.push(raw);
217
+ }
218
+ }
219
+ fs.writeFileSync(filePath, repairedLines.join("\n") + "\n");
220
+ return {
221
+ sessionId,
222
+ totalLines: entries.length,
223
+ corruptedEntries: corrupted,
224
+ parentRelinks,
225
+ removedCount: entriesToRemove.size,
226
+ relinkedCount: parentRelinks.length,
227
+ backupPath,
228
+ repaired: true
229
+ };
230
+ }
231
+ // Annotate the CommonJS export names for ESM import in node:
232
+ 0 && (module.exports = {
233
+ analyzeSession,
234
+ computeParentRelinks,
235
+ extractToolUses,
236
+ findCorruptedEntries,
237
+ parseTranscript,
238
+ repairSession
239
+ });
@@ -0,0 +1,110 @@
1
+ /**
2
+ * Session transcript repair logic
3
+ *
4
+ * Repairs corrupted OpenClaw session transcripts by:
5
+ * 1. Finding aborted tool_use blocks (stopReason: "aborted", partialJson present)
6
+ * 2. Finding orphaned tool_result messages that reference non-existent tool_use IDs
7
+ * 3. Removing both the aborted entries and orphaned results
8
+ * 4. Relinking parent chain references
9
+ */
10
+ interface TranscriptEntry {
11
+ type: 'session' | 'message' | 'compaction' | 'custom' | 'thinking_level_change' | string;
12
+ id: string;
13
+ parentId: string | null;
14
+ timestamp: string;
15
+ message?: {
16
+ role: 'user' | 'assistant' | 'toolResult' | 'system';
17
+ content: Array<{
18
+ type: string;
19
+ id?: string;
20
+ name?: string;
21
+ arguments?: unknown;
22
+ toolCallId?: string;
23
+ toolUseId?: string;
24
+ partialJson?: string;
25
+ text?: string;
26
+ }>;
27
+ stopReason?: string;
28
+ errorMessage?: string;
29
+ };
30
+ summary?: string;
31
+ customType?: string;
32
+ data?: unknown;
33
+ thinkingLevel?: string;
34
+ }
35
+ interface ToolUseInfo {
36
+ id: string;
37
+ lineNumber: number;
38
+ entryId: string;
39
+ isAborted: boolean;
40
+ isPartial: boolean;
41
+ name?: string;
42
+ }
43
+ interface CorruptedEntry {
44
+ lineNumber: number;
45
+ entryId: string;
46
+ type: 'aborted_tool_use' | 'orphaned_tool_result';
47
+ toolUseId: string;
48
+ description: string;
49
+ }
50
+ interface ParentRelink {
51
+ lineNumber: number;
52
+ entryId: string;
53
+ oldParentId: string;
54
+ newParentId: string;
55
+ }
56
+ interface RepairResult {
57
+ sessionId: string;
58
+ totalLines: number;
59
+ corruptedEntries: CorruptedEntry[];
60
+ parentRelinks: ParentRelink[];
61
+ removedCount: number;
62
+ relinkedCount: number;
63
+ backupPath?: string;
64
+ repaired: boolean;
65
+ }
66
+ /**
67
+ * Parse a JSONL file into transcript entries with line numbers
68
+ */
69
+ declare function parseTranscript(filePath: string): Array<{
70
+ line: number;
71
+ entry: TranscriptEntry;
72
+ raw: string;
73
+ }>;
74
+ /**
75
+ * Extract all tool_use IDs from assistant messages
76
+ */
77
+ declare function extractToolUses(entries: Array<{
78
+ line: number;
79
+ entry: TranscriptEntry;
80
+ }>): Map<string, ToolUseInfo>;
81
+ /**
82
+ * Find orphaned tool_result messages that reference non-existent or aborted tool_use IDs
83
+ */
84
+ declare function findCorruptedEntries(entries: Array<{
85
+ line: number;
86
+ entry: TranscriptEntry;
87
+ }>, toolUses: Map<string, ToolUseInfo>): {
88
+ corrupted: CorruptedEntry[];
89
+ entriesToRemove: Set<string>;
90
+ };
91
+ /**
92
+ * Compute parent chain relinks after removing entries
93
+ */
94
+ declare function computeParentRelinks(entries: Array<{
95
+ line: number;
96
+ entry: TranscriptEntry;
97
+ }>, entriesToRemove: Set<string>): ParentRelink[];
98
+ /**
99
+ * Analyze a session transcript for corruption without modifying it
100
+ */
101
+ declare function analyzeSession(filePath: string): RepairResult;
102
+ /**
103
+ * Repair a session transcript
104
+ */
105
+ declare function repairSession(filePath: string, options?: {
106
+ backup?: boolean;
107
+ dryRun?: boolean;
108
+ }): RepairResult;
109
+
110
+ export { type CorruptedEntry, type ParentRelink, type RepairResult, type ToolUseInfo, type TranscriptEntry, analyzeSession, computeParentRelinks, extractToolUses, findCorruptedEntries, parseTranscript, repairSession };
@@ -6,6 +6,7 @@ import {
6
6
  parseTranscript,
7
7
  repairSession
8
8
  } from "../chunk-L53L5FCL.js";
9
+ import "../chunk-3RG5ZIWI.js";
9
10
  export {
10
11
  analyzeSession,
11
12
  computeParentRelinks,
@@ -0,0 +1,209 @@
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/lib/session-utils.ts
31
+ var session_utils_exports = {};
32
+ __export(session_utils_exports, {
33
+ backupSession: () => backupSession,
34
+ findMainSession: () => findMainSession,
35
+ findSessionById: () => findSessionById,
36
+ getOpenClawAgentsDir: () => getOpenClawAgentsDir,
37
+ getOpenClawDir: () => getOpenClawDir,
38
+ getSessionFilePath: () => getSessionFilePath,
39
+ getSessionsDir: () => getSessionsDir,
40
+ getSessionsJsonPath: () => getSessionsJsonPath,
41
+ listAgents: () => listAgents,
42
+ listSessions: () => listSessions,
43
+ loadSessionsStore: () => loadSessionsStore
44
+ });
45
+ module.exports = __toCommonJS(session_utils_exports);
46
+ var fs = __toESM(require("fs"), 1);
47
+ var path = __toESM(require("path"), 1);
48
+ var os = __toESM(require("os"), 1);
49
+ function validateEnvPath(envValue) {
50
+ if (!envValue) return null;
51
+ const trimmed = envValue.trim();
52
+ if (!trimmed) return null;
53
+ const resolved = path.resolve(trimmed);
54
+ if (!path.isAbsolute(resolved)) return null;
55
+ return resolved;
56
+ }
57
+ function getOpenClawDir() {
58
+ const customHome = validateEnvPath(process.env.OPENCLAW_HOME);
59
+ if (customHome) {
60
+ return customHome;
61
+ }
62
+ return path.join(os.homedir(), ".openclaw");
63
+ }
64
+ function getOpenClawAgentsDir() {
65
+ const stateDir = validateEnvPath(process.env.OPENCLAW_STATE_DIR);
66
+ if (stateDir) {
67
+ return path.join(stateDir, "agents");
68
+ }
69
+ return path.join(getOpenClawDir(), "agents");
70
+ }
71
+ function getSessionsDir(agentId) {
72
+ return path.join(getOpenClawAgentsDir(), agentId, "sessions");
73
+ }
74
+ function getSessionsJsonPath(agentId) {
75
+ return path.join(getSessionsDir(agentId), "sessions.json");
76
+ }
77
+ function getSessionFilePath(agentId, sessionId) {
78
+ return path.join(getSessionsDir(agentId), `${sessionId}.jsonl`);
79
+ }
80
+ function listAgents() {
81
+ const agentsDir = getOpenClawAgentsDir();
82
+ try {
83
+ if (!fs.existsSync(agentsDir)) {
84
+ return [];
85
+ }
86
+ const stat = fs.statSync(agentsDir);
87
+ if (!stat.isDirectory()) {
88
+ return [];
89
+ }
90
+ return fs.readdirSync(agentsDir).filter((name) => {
91
+ try {
92
+ const sessionsDir = getSessionsDir(name);
93
+ return fs.existsSync(sessionsDir) && fs.statSync(sessionsDir).isDirectory();
94
+ } catch {
95
+ return false;
96
+ }
97
+ });
98
+ } catch {
99
+ return [];
100
+ }
101
+ }
102
+ function loadSessionsStore(agentId) {
103
+ const sessionsJsonPath = getSessionsJsonPath(agentId);
104
+ if (!fs.existsSync(sessionsJsonPath)) {
105
+ return null;
106
+ }
107
+ try {
108
+ const content = fs.readFileSync(sessionsJsonPath, "utf-8");
109
+ return JSON.parse(content);
110
+ } catch {
111
+ return null;
112
+ }
113
+ }
114
+ function findMainSession(agentId) {
115
+ const store = loadSessionsStore(agentId);
116
+ if (!store) return null;
117
+ const mainKey = `agent:${agentId}:main`;
118
+ const entry = store[mainKey];
119
+ if (entry?.sessionId) {
120
+ const filePath = getSessionFilePath(agentId, entry.sessionId);
121
+ if (fs.existsSync(filePath)) {
122
+ return {
123
+ sessionId: entry.sessionId,
124
+ sessionKey: mainKey,
125
+ agentId,
126
+ filePath,
127
+ updatedAt: entry.updatedAt
128
+ };
129
+ }
130
+ }
131
+ return null;
132
+ }
133
+ function findSessionById(agentId, sessionId) {
134
+ const filePath = getSessionFilePath(agentId, sessionId);
135
+ if (!fs.existsSync(filePath)) {
136
+ return null;
137
+ }
138
+ const store = loadSessionsStore(agentId);
139
+ let sessionKey;
140
+ let updatedAt;
141
+ if (store) {
142
+ for (const [key, entry] of Object.entries(store)) {
143
+ if (entry.sessionId === sessionId) {
144
+ sessionKey = key;
145
+ updatedAt = entry.updatedAt;
146
+ break;
147
+ }
148
+ }
149
+ }
150
+ return {
151
+ sessionId,
152
+ sessionKey: sessionKey || `agent:${agentId}:unknown`,
153
+ agentId,
154
+ filePath,
155
+ updatedAt
156
+ };
157
+ }
158
+ function listSessions(agentId) {
159
+ const sessionsDir = getSessionsDir(agentId);
160
+ if (!fs.existsSync(sessionsDir)) {
161
+ return [];
162
+ }
163
+ const store = loadSessionsStore(agentId);
164
+ const sessions = [];
165
+ const files = fs.readdirSync(sessionsDir).filter((f) => f.endsWith(".jsonl") && !f.includes(".backup") && !f.includes(".deleted") && !f.includes(".corrupted"));
166
+ for (const file of files) {
167
+ const sessionId = file.replace(".jsonl", "");
168
+ const filePath = path.join(sessionsDir, file);
169
+ let sessionKey = `agent:${agentId}:unknown`;
170
+ let updatedAt;
171
+ if (store) {
172
+ for (const [key, entry] of Object.entries(store)) {
173
+ if (entry.sessionId === sessionId) {
174
+ sessionKey = key;
175
+ updatedAt = entry.updatedAt;
176
+ break;
177
+ }
178
+ }
179
+ }
180
+ sessions.push({
181
+ sessionId,
182
+ sessionKey,
183
+ agentId,
184
+ filePath,
185
+ updatedAt
186
+ });
187
+ }
188
+ return sessions.sort((a, b) => (b.updatedAt || 0) - (a.updatedAt || 0));
189
+ }
190
+ function backupSession(filePath) {
191
+ const timestamp = (/* @__PURE__ */ new Date()).toISOString().replace(/[:.]/g, "").replace("T", "-").slice(0, 15);
192
+ const backupPath = `${filePath}.backup-${timestamp}`;
193
+ fs.copyFileSync(filePath, backupPath);
194
+ return backupPath;
195
+ }
196
+ // Annotate the CommonJS export names for ESM import in node:
197
+ 0 && (module.exports = {
198
+ backupSession,
199
+ findMainSession,
200
+ findSessionById,
201
+ getOpenClawAgentsDir,
202
+ getOpenClawDir,
203
+ getSessionFilePath,
204
+ getSessionsDir,
205
+ getSessionsJsonPath,
206
+ listAgents,
207
+ listSessions,
208
+ loadSessionsStore
209
+ });