claudecode-omc 4.5.7 → 4.7.4

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 (1085) hide show
  1. package/.claude-plugin/marketplace.json +18 -4
  2. package/.claude-plugin/plugin.json +14 -1
  3. package/.mcp.json +0 -4
  4. package/README.de.md +260 -0
  5. package/README.es.md +27 -41
  6. package/README.fr.md +260 -0
  7. package/README.it.md +260 -0
  8. package/README.ja.md +27 -41
  9. package/README.ko.md +45 -54
  10. package/README.md +247 -14
  11. package/README.pt.md +23 -6
  12. package/README.ru.md +260 -0
  13. package/README.tr.md +260 -0
  14. package/README.vi.md +23 -6
  15. package/README.zh.md +27 -41
  16. package/agents/harsh-critic.md +254 -0
  17. package/bridge/cli.cjs +67181 -0
  18. package/bridge/gyoshu_bridge.py +69 -19
  19. package/bridge/mcp-server.cjs +846 -526
  20. package/bridge/runtime-cli.cjs +2861 -367
  21. package/bridge/team-bridge.cjs +216 -60
  22. package/bridge/team-mcp.cjs +493 -255
  23. package/bridge/team.js +1460 -0
  24. package/dist/__tests__/agent-registry.test.js +13 -3
  25. package/dist/__tests__/agent-registry.test.js.map +1 -1
  26. package/dist/__tests__/auto-slash-aliases.test.js +12 -20
  27. package/dist/__tests__/auto-slash-aliases.test.js.map +1 -1
  28. package/dist/__tests__/auto-update.test.js +1 -1
  29. package/dist/__tests__/auto-update.test.js.map +1 -1
  30. package/dist/__tests__/bash-history.test.js.map +1 -1
  31. package/dist/__tests__/cleanup-validation.test.d.ts +2 -0
  32. package/dist/__tests__/cleanup-validation.test.d.ts.map +1 -0
  33. package/dist/__tests__/cleanup-validation.test.js +44 -0
  34. package/dist/__tests__/cleanup-validation.test.js.map +1 -0
  35. package/dist/__tests__/config-force-inherit-env.test.d.ts +5 -0
  36. package/dist/__tests__/config-force-inherit-env.test.d.ts.map +1 -0
  37. package/dist/__tests__/config-force-inherit-env.test.js +35 -0
  38. package/dist/__tests__/config-force-inherit-env.test.js.map +1 -0
  39. package/dist/__tests__/consolidation-contracts.test.js +4 -7
  40. package/dist/__tests__/consolidation-contracts.test.js.map +1 -1
  41. package/dist/__tests__/daemon-module-path.test.d.ts +2 -0
  42. package/dist/__tests__/daemon-module-path.test.d.ts.map +1 -0
  43. package/dist/__tests__/daemon-module-path.test.js +29 -0
  44. package/dist/__tests__/daemon-module-path.test.js.map +1 -0
  45. package/dist/__tests__/delegation-enforcement-levels.test.js.map +1 -1
  46. package/dist/__tests__/delegation-enforcer.test.js +172 -0
  47. package/dist/__tests__/delegation-enforcer.test.js.map +1 -1
  48. package/dist/__tests__/doctor-conflicts.test.js +144 -1
  49. package/dist/__tests__/doctor-conflicts.test.js.map +1 -1
  50. package/dist/__tests__/file-lock.test.d.ts +2 -0
  51. package/dist/__tests__/file-lock.test.d.ts.map +1 -0
  52. package/dist/__tests__/file-lock.test.js +209 -0
  53. package/dist/__tests__/file-lock.test.js.map +1 -0
  54. package/dist/__tests__/hooks.test.js +27 -56
  55. package/dist/__tests__/hooks.test.js.map +1 -1
  56. package/dist/__tests__/hud/defaults.test.js +3 -0
  57. package/dist/__tests__/hud/defaults.test.js.map +1 -1
  58. package/dist/__tests__/hud/limits-error.test.d.ts +5 -0
  59. package/dist/__tests__/hud/limits-error.test.d.ts.map +1 -0
  60. package/dist/__tests__/hud/limits-error.test.js +43 -0
  61. package/dist/__tests__/hud/limits-error.test.js.map +1 -0
  62. package/dist/__tests__/hud/max-width.test.d.ts +2 -0
  63. package/dist/__tests__/hud/max-width.test.d.ts.map +1 -0
  64. package/dist/__tests__/hud/max-width.test.js +149 -0
  65. package/dist/__tests__/hud/max-width.test.js.map +1 -0
  66. package/dist/__tests__/hud/rate-limits-error.test.d.ts +5 -0
  67. package/dist/__tests__/hud/rate-limits-error.test.d.ts.map +1 -0
  68. package/dist/__tests__/hud/rate-limits-error.test.js +76 -0
  69. package/dist/__tests__/hud/rate-limits-error.test.js.map +1 -0
  70. package/dist/__tests__/hud/render.test.js +245 -1
  71. package/dist/__tests__/hud/render.test.js.map +1 -1
  72. package/dist/__tests__/hud/state.test.js +15 -0
  73. package/dist/__tests__/hud/state.test.js.map +1 -1
  74. package/dist/__tests__/hud/usage-api.test.js +19 -5
  75. package/dist/__tests__/hud/usage-api.test.js.map +1 -1
  76. package/dist/__tests__/hud/version-display.test.js +3 -1
  77. package/dist/__tests__/hud/version-display.test.js.map +1 -1
  78. package/dist/__tests__/hud-agents.test.js.map +1 -1
  79. package/dist/__tests__/hud-api-key-source.test.d.ts +7 -0
  80. package/dist/__tests__/hud-api-key-source.test.d.ts.map +1 -0
  81. package/dist/__tests__/hud-api-key-source.test.js +112 -0
  82. package/dist/__tests__/hud-api-key-source.test.js.map +1 -0
  83. package/dist/__tests__/hud-build-guidance.test.d.ts +2 -0
  84. package/dist/__tests__/hud-build-guidance.test.d.ts.map +1 -0
  85. package/dist/__tests__/hud-build-guidance.test.js +26 -0
  86. package/dist/__tests__/hud-build-guidance.test.js.map +1 -0
  87. package/dist/__tests__/installer-hooks-merge.test.js +1 -1
  88. package/dist/__tests__/installer-hooks-merge.test.js.map +1 -1
  89. package/dist/__tests__/installer.test.js +4 -0
  90. package/dist/__tests__/installer.test.js.map +1 -1
  91. package/dist/__tests__/job-management.test.js +1 -1
  92. package/dist/__tests__/job-management.test.js.map +1 -1
  93. package/dist/__tests__/live-data.test.js +11 -5
  94. package/dist/__tests__/live-data.test.js.map +1 -1
  95. package/dist/__tests__/mcp-default-config.test.d.ts +2 -0
  96. package/dist/__tests__/mcp-default-config.test.d.ts.map +1 -0
  97. package/dist/__tests__/mcp-default-config.test.js +13 -0
  98. package/dist/__tests__/mcp-default-config.test.js.map +1 -0
  99. package/dist/__tests__/model-routing.test.js.map +1 -1
  100. package/dist/__tests__/non-claude-provider-detection.test.d.ts +11 -0
  101. package/dist/__tests__/non-claude-provider-detection.test.d.ts.map +1 -0
  102. package/dist/__tests__/non-claude-provider-detection.test.js +303 -0
  103. package/dist/__tests__/non-claude-provider-detection.test.js.map +1 -0
  104. package/dist/__tests__/omc-tools-server.test.js +5 -5
  105. package/dist/__tests__/package-dir-resolution-regression.test.d.ts +2 -0
  106. package/dist/__tests__/package-dir-resolution-regression.test.d.ts.map +1 -0
  107. package/dist/__tests__/package-dir-resolution-regression.test.js +63 -0
  108. package/dist/__tests__/package-dir-resolution-regression.test.js.map +1 -0
  109. package/dist/__tests__/pipeline-orchestrator.test.d.ts +5 -0
  110. package/dist/__tests__/pipeline-orchestrator.test.d.ts.map +1 -0
  111. package/dist/__tests__/pipeline-orchestrator.test.js +244 -0
  112. package/dist/__tests__/pipeline-orchestrator.test.js.map +1 -0
  113. package/dist/__tests__/plugin-setup-deps.test.d.ts +2 -0
  114. package/dist/__tests__/plugin-setup-deps.test.d.ts.map +1 -0
  115. package/dist/__tests__/plugin-setup-deps.test.js +64 -0
  116. package/dist/__tests__/plugin-setup-deps.test.js.map +1 -0
  117. package/dist/__tests__/project-memory-merge.test.d.ts +2 -0
  118. package/dist/__tests__/project-memory-merge.test.d.ts.map +1 -0
  119. package/dist/__tests__/project-memory-merge.test.js +342 -0
  120. package/dist/__tests__/project-memory-merge.test.js.map +1 -0
  121. package/dist/__tests__/ralph-prd-mandatory.test.d.ts +2 -0
  122. package/dist/__tests__/ralph-prd-mandatory.test.d.ts.map +1 -0
  123. package/dist/__tests__/ralph-prd-mandatory.test.js +316 -0
  124. package/dist/__tests__/ralph-prd-mandatory.test.js.map +1 -0
  125. package/dist/__tests__/rate-limit-wait/daemon-bootstrap.test.d.ts +2 -0
  126. package/dist/__tests__/rate-limit-wait/daemon-bootstrap.test.d.ts.map +1 -0
  127. package/dist/__tests__/rate-limit-wait/daemon-bootstrap.test.js +94 -0
  128. package/dist/__tests__/rate-limit-wait/daemon-bootstrap.test.js.map +1 -0
  129. package/dist/__tests__/rate-limit-wait/daemon.test.js.map +1 -1
  130. package/dist/__tests__/rate-limit-wait/integration.test.js +33 -25
  131. package/dist/__tests__/rate-limit-wait/integration.test.js.map +1 -1
  132. package/dist/__tests__/rate-limit-wait/rate-limit-monitor.test.js +34 -26
  133. package/dist/__tests__/rate-limit-wait/rate-limit-monitor.test.js.map +1 -1
  134. package/dist/__tests__/rate-limit-wait/tmux-detector.test.js.map +1 -1
  135. package/dist/__tests__/resolve-node.test.js.map +1 -1
  136. package/dist/__tests__/resolve-transcript-path.test.d.ts +12 -0
  137. package/dist/__tests__/resolve-transcript-path.test.d.ts.map +1 -0
  138. package/dist/__tests__/resolve-transcript-path.test.js +167 -0
  139. package/dist/__tests__/resolve-transcript-path.test.js.map +1 -0
  140. package/dist/__tests__/routing-force-inherit.test.d.ts +8 -0
  141. package/dist/__tests__/routing-force-inherit.test.d.ts.map +1 -0
  142. package/dist/__tests__/routing-force-inherit.test.js +180 -0
  143. package/dist/__tests__/routing-force-inherit.test.js.map +1 -0
  144. package/dist/__tests__/run-cjs-graceful-fallback.test.js +2 -2
  145. package/dist/__tests__/run-cjs-graceful-fallback.test.js.map +1 -1
  146. package/dist/__tests__/shared-memory-concurrency.test.d.ts +8 -0
  147. package/dist/__tests__/shared-memory-concurrency.test.d.ts.map +1 -0
  148. package/dist/__tests__/shared-memory-concurrency.test.js +132 -0
  149. package/dist/__tests__/shared-memory-concurrency.test.js.map +1 -0
  150. package/dist/__tests__/shared-memory.test.d.ts +2 -0
  151. package/dist/__tests__/shared-memory.test.d.ts.map +1 -0
  152. package/dist/__tests__/shared-memory.test.js +345 -0
  153. package/dist/__tests__/shared-memory.test.js.map +1 -0
  154. package/dist/__tests__/shell-path.test.d.ts +5 -0
  155. package/dist/__tests__/shell-path.test.d.ts.map +1 -0
  156. package/dist/__tests__/shell-path.test.js +70 -0
  157. package/dist/__tests__/shell-path.test.js.map +1 -0
  158. package/dist/__tests__/skills.test.js +13 -10
  159. package/dist/__tests__/skills.test.js.map +1 -1
  160. package/dist/__tests__/slack-socket.test.d.ts +5 -0
  161. package/dist/__tests__/slack-socket.test.d.ts.map +1 -0
  162. package/dist/__tests__/slack-socket.test.js +252 -0
  163. package/dist/__tests__/slack-socket.test.js.map +1 -0
  164. package/dist/__tests__/smoke-functional.test.d.ts +8 -0
  165. package/dist/__tests__/smoke-functional.test.d.ts.map +1 -0
  166. package/dist/__tests__/smoke-functional.test.js +450 -0
  167. package/dist/__tests__/smoke-functional.test.js.map +1 -0
  168. package/dist/__tests__/smoke-pipeline-edge.test.d.ts +8 -0
  169. package/dist/__tests__/smoke-pipeline-edge.test.d.ts.map +1 -0
  170. package/dist/__tests__/smoke-pipeline-edge.test.js +435 -0
  171. package/dist/__tests__/smoke-pipeline-edge.test.js.map +1 -0
  172. package/dist/__tests__/smoke-slack-and-state.test.d.ts +13 -0
  173. package/dist/__tests__/smoke-slack-and-state.test.d.ts.map +1 -0
  174. package/dist/__tests__/smoke-slack-and-state.test.js +632 -0
  175. package/dist/__tests__/smoke-slack-and-state.test.js.map +1 -0
  176. package/dist/__tests__/smoke-team-worker.test.d.ts +15 -0
  177. package/dist/__tests__/smoke-team-worker.test.d.ts.map +1 -0
  178. package/dist/__tests__/smoke-team-worker.test.js +483 -0
  179. package/dist/__tests__/smoke-team-worker.test.js.map +1 -0
  180. package/dist/__tests__/ssrf-guard.test.d.ts +2 -0
  181. package/dist/__tests__/ssrf-guard.test.d.ts.map +1 -0
  182. package/dist/__tests__/ssrf-guard.test.js +96 -0
  183. package/dist/__tests__/ssrf-guard.test.js.map +1 -0
  184. package/dist/__tests__/task-continuation.test.js +1 -1
  185. package/dist/__tests__/task-continuation.test.js.map +1 -1
  186. package/dist/__tests__/tier0-contracts.test.js +5 -1
  187. package/dist/__tests__/tier0-contracts.test.js.map +1 -1
  188. package/dist/__tests__/tier0-docs-consistency.test.js +3 -4
  189. package/dist/__tests__/tier0-docs-consistency.test.js.map +1 -1
  190. package/dist/__tests__/tools/trace-tools.test.js +7 -3
  191. package/dist/__tests__/tools/trace-tools.test.js.map +1 -1
  192. package/dist/__tests__/types.test.js +4 -4
  193. package/dist/__tests__/types.test.js.map +1 -1
  194. package/dist/__tests__/worker-adapter.test.d.ts +5 -0
  195. package/dist/__tests__/worker-adapter.test.d.ts.map +1 -0
  196. package/dist/__tests__/worker-adapter.test.js +211 -0
  197. package/dist/__tests__/worker-adapter.test.js.map +1 -0
  198. package/dist/agents/definitions.d.ts +6 -5
  199. package/dist/agents/definitions.d.ts.map +1 -1
  200. package/dist/agents/definitions.js +11 -6
  201. package/dist/agents/definitions.js.map +1 -1
  202. package/dist/agents/harsh-critic.d.ts +14 -0
  203. package/dist/agents/harsh-critic.d.ts.map +1 -0
  204. package/dist/agents/harsh-critic.js +42 -0
  205. package/dist/agents/harsh-critic.js.map +1 -0
  206. package/dist/agents/index.d.ts +1 -3
  207. package/dist/agents/index.d.ts.map +1 -1
  208. package/dist/agents/index.js +1 -4
  209. package/dist/agents/index.js.map +1 -1
  210. package/dist/agents/prompt-helpers.d.ts.map +1 -1
  211. package/dist/agents/prompt-helpers.js +21 -16
  212. package/dist/agents/prompt-helpers.js.map +1 -1
  213. package/dist/agents/prompt-sections/index.d.ts.map +1 -1
  214. package/dist/agents/prompt-sections/index.js +7 -3
  215. package/dist/agents/prompt-sections/index.js.map +1 -1
  216. package/dist/agents/utils.d.ts.map +1 -1
  217. package/dist/agents/utils.js +22 -13
  218. package/dist/agents/utils.js.map +1 -1
  219. package/dist/cli/__tests__/ask.test.d.ts +2 -0
  220. package/dist/cli/__tests__/ask.test.d.ts.map +1 -0
  221. package/dist/cli/__tests__/ask.test.js +282 -0
  222. package/dist/cli/__tests__/ask.test.js.map +1 -0
  223. package/dist/cli/__tests__/cli-boot.test.d.ts +8 -0
  224. package/dist/cli/__tests__/cli-boot.test.d.ts.map +1 -0
  225. package/dist/cli/__tests__/cli-boot.test.js +82 -0
  226. package/dist/cli/__tests__/cli-boot.test.js.map +1 -0
  227. package/dist/cli/__tests__/launch.test.js +11 -2
  228. package/dist/cli/__tests__/launch.test.js.map +1 -1
  229. package/dist/cli/__tests__/team-command-branding.test.d.ts +2 -0
  230. package/dist/cli/__tests__/team-command-branding.test.d.ts.map +1 -0
  231. package/dist/cli/__tests__/team-command-branding.test.js +14 -0
  232. package/dist/cli/__tests__/team-command-branding.test.js.map +1 -0
  233. package/dist/cli/__tests__/team-help.test.d.ts +2 -0
  234. package/dist/cli/__tests__/team-help.test.d.ts.map +1 -0
  235. package/dist/cli/__tests__/team-help.test.js +19 -0
  236. package/dist/cli/__tests__/team-help.test.js.map +1 -0
  237. package/dist/cli/__tests__/team-runtime-boundary.test.d.ts +2 -0
  238. package/dist/cli/__tests__/team-runtime-boundary.test.d.ts.map +1 -0
  239. package/dist/cli/__tests__/team-runtime-boundary.test.js +11 -0
  240. package/dist/cli/__tests__/team-runtime-boundary.test.js.map +1 -0
  241. package/dist/cli/__tests__/team.test.d.ts +2 -0
  242. package/dist/cli/__tests__/team.test.d.ts.map +1 -0
  243. package/dist/cli/__tests__/team.test.js +335 -0
  244. package/dist/cli/__tests__/team.test.js.map +1 -0
  245. package/dist/cli/__tests__/tmux-utils.test.d.ts +11 -0
  246. package/dist/cli/__tests__/tmux-utils.test.d.ts.map +1 -0
  247. package/dist/cli/__tests__/tmux-utils.test.js +145 -0
  248. package/dist/cli/__tests__/tmux-utils.test.js.map +1 -0
  249. package/dist/cli/ask.d.ts +13 -0
  250. package/dist/cli/ask.d.ts.map +1 -0
  251. package/dist/cli/ask.js +202 -0
  252. package/dist/cli/ask.js.map +1 -0
  253. package/dist/cli/commands/__tests__/team.test.d.ts +2 -0
  254. package/dist/cli/commands/__tests__/team.test.d.ts.map +1 -0
  255. package/dist/cli/commands/__tests__/team.test.js +177 -0
  256. package/dist/cli/commands/__tests__/team.test.js.map +1 -0
  257. package/dist/cli/commands/__tests__/teleport.test.js.map +1 -1
  258. package/dist/cli/commands/doctor-conflicts.d.ts +14 -1
  259. package/dist/cli/commands/doctor-conflicts.d.ts.map +1 -1
  260. package/dist/cli/commands/doctor-conflicts.js +126 -12
  261. package/dist/cli/commands/doctor-conflicts.js.map +1 -1
  262. package/dist/cli/commands/team.d.ts +19 -0
  263. package/dist/cli/commands/team.d.ts.map +1 -0
  264. package/dist/cli/commands/team.js +510 -0
  265. package/dist/cli/commands/team.js.map +1 -0
  266. package/dist/cli/commands/teleport.d.ts.map +1 -1
  267. package/dist/cli/commands/teleport.js +6 -4
  268. package/dist/cli/commands/teleport.js.map +1 -1
  269. package/dist/cli/index.js +58 -17
  270. package/dist/cli/index.js.map +1 -1
  271. package/dist/cli/launch.d.ts.map +1 -1
  272. package/dist/cli/launch.js +12 -6
  273. package/dist/cli/launch.js.map +1 -1
  274. package/dist/cli/team.d.ts +76 -0
  275. package/dist/cli/team.d.ts.map +1 -0
  276. package/dist/cli/team.js +1117 -0
  277. package/dist/cli/team.js.map +1 -0
  278. package/dist/cli/tmux-utils.d.ts +10 -0
  279. package/dist/cli/tmux-utils.d.ts.map +1 -1
  280. package/dist/cli/tmux-utils.js +20 -1
  281. package/dist/cli/tmux-utils.js.map +1 -1
  282. package/dist/config/loader.d.ts.map +1 -1
  283. package/dist/config/loader.js +134 -48
  284. package/dist/config/loader.js.map +1 -1
  285. package/dist/config/models.d.ts +36 -14
  286. package/dist/config/models.d.ts.map +1 -1
  287. package/dist/config/models.js +94 -0
  288. package/dist/config/models.js.map +1 -1
  289. package/dist/constants/names.d.ts +6 -3
  290. package/dist/constants/names.d.ts.map +1 -1
  291. package/dist/constants/names.js +7 -3
  292. package/dist/constants/names.js.map +1 -1
  293. package/dist/features/auto-update.js +5 -5
  294. package/dist/features/auto-update.js.map +1 -1
  295. package/dist/features/boulder-state/storage.d.ts +1 -1
  296. package/dist/features/boulder-state/storage.d.ts.map +1 -1
  297. package/dist/features/boulder-state/storage.js +20 -22
  298. package/dist/features/boulder-state/storage.js.map +1 -1
  299. package/dist/features/delegation-enforcer.d.ts +5 -0
  300. package/dist/features/delegation-enforcer.d.ts.map +1 -1
  301. package/dist/features/delegation-enforcer.js +58 -5
  302. package/dist/features/delegation-enforcer.js.map +1 -1
  303. package/dist/features/model-routing/router.d.ts.map +1 -1
  304. package/dist/features/model-routing/router.js +11 -0
  305. package/dist/features/model-routing/router.js.map +1 -1
  306. package/dist/features/model-routing/types.d.ts +6 -0
  307. package/dist/features/model-routing/types.d.ts.map +1 -1
  308. package/dist/features/model-routing/types.js.map +1 -1
  309. package/dist/features/rate-limit-wait/daemon.d.ts +5 -0
  310. package/dist/features/rate-limit-wait/daemon.d.ts.map +1 -1
  311. package/dist/features/rate-limit-wait/daemon.js +38 -9
  312. package/dist/features/rate-limit-wait/daemon.js.map +1 -1
  313. package/dist/features/rate-limit-wait/rate-limit-monitor.d.ts.map +1 -1
  314. package/dist/features/rate-limit-wait/rate-limit-monitor.js +3 -2
  315. package/dist/features/rate-limit-wait/rate-limit-monitor.js.map +1 -1
  316. package/dist/features/rate-limit-wait/tmux-detector.d.ts.map +1 -1
  317. package/dist/features/rate-limit-wait/tmux-detector.js +8 -2
  318. package/dist/features/rate-limit-wait/tmux-detector.js.map +1 -1
  319. package/dist/features/state-manager/__tests__/cache.test.js +161 -1
  320. package/dist/features/state-manager/__tests__/cache.test.js.map +1 -1
  321. package/dist/features/state-manager/index.d.ts +2 -0
  322. package/dist/features/state-manager/index.d.ts.map +1 -1
  323. package/dist/features/state-manager/index.js +167 -51
  324. package/dist/features/state-manager/index.js.map +1 -1
  325. package/dist/hooks/__tests__/bridge-routing.test.js +124 -1
  326. package/dist/hooks/__tests__/bridge-routing.test.js.map +1 -1
  327. package/dist/hooks/__tests__/bridge-security.test.js +1 -1
  328. package/dist/hooks/__tests__/bridge-security.test.js.map +1 -1
  329. package/dist/hooks/__tests__/bridge-team-worker-guard.test.d.ts +2 -0
  330. package/dist/hooks/__tests__/bridge-team-worker-guard.test.d.ts.map +1 -0
  331. package/dist/hooks/__tests__/bridge-team-worker-guard.test.js +52 -0
  332. package/dist/hooks/__tests__/bridge-team-worker-guard.test.js.map +1 -0
  333. package/dist/hooks/__tests__/bridge.test.js.map +1 -1
  334. package/dist/hooks/__tests__/codebase-map.test.js.map +1 -1
  335. package/dist/hooks/__tests__/compaction-concurrency.test.js.map +1 -1
  336. package/dist/hooks/__tests__/stop-hook-openclaw-cooldown.test.d.ts +2 -0
  337. package/dist/hooks/__tests__/stop-hook-openclaw-cooldown.test.d.ts.map +1 -0
  338. package/dist/hooks/__tests__/stop-hook-openclaw-cooldown.test.js +65 -0
  339. package/dist/hooks/__tests__/stop-hook-openclaw-cooldown.test.js.map +1 -0
  340. package/dist/hooks/auto-slash-command/live-data.d.ts.map +1 -1
  341. package/dist/hooks/auto-slash-command/live-data.js +54 -25
  342. package/dist/hooks/auto-slash-command/live-data.js.map +1 -1
  343. package/dist/hooks/autopilot/__tests__/cancel.test.js +1 -1
  344. package/dist/hooks/autopilot/__tests__/cancel.test.js.map +1 -1
  345. package/dist/hooks/autopilot/__tests__/pipeline.test.d.ts +2 -0
  346. package/dist/hooks/autopilot/__tests__/pipeline.test.d.ts.map +1 -0
  347. package/dist/hooks/autopilot/__tests__/pipeline.test.js +375 -0
  348. package/dist/hooks/autopilot/__tests__/pipeline.test.js.map +1 -0
  349. package/dist/hooks/autopilot/__tests__/state.test.js +2 -2
  350. package/dist/hooks/autopilot/__tests__/state.test.js.map +1 -1
  351. package/dist/hooks/autopilot/__tests__/summary.test.js.map +1 -1
  352. package/dist/hooks/autopilot/__tests__/transition.test.js.map +1 -1
  353. package/dist/hooks/autopilot/__tests__/validation.test.js +3 -3
  354. package/dist/hooks/autopilot/__tests__/validation.test.js.map +1 -1
  355. package/dist/hooks/autopilot/adapters/execution-adapter.d.ts +12 -0
  356. package/dist/hooks/autopilot/adapters/execution-adapter.d.ts.map +1 -0
  357. package/dist/hooks/autopilot/adapters/execution-adapter.js +110 -0
  358. package/dist/hooks/autopilot/adapters/execution-adapter.js.map +1 -0
  359. package/dist/hooks/autopilot/adapters/index.d.ts +22 -0
  360. package/dist/hooks/autopilot/adapters/index.d.ts.map +1 -0
  361. package/dist/hooks/autopilot/adapters/index.js +32 -0
  362. package/dist/hooks/autopilot/adapters/index.js.map +1 -0
  363. package/dist/hooks/autopilot/adapters/qa-adapter.d.ts +12 -0
  364. package/dist/hooks/autopilot/adapters/qa-adapter.d.ts.map +1 -0
  365. package/dist/hooks/autopilot/adapters/qa-adapter.js +33 -0
  366. package/dist/hooks/autopilot/adapters/qa-adapter.js.map +1 -0
  367. package/dist/hooks/autopilot/adapters/ralph-adapter.d.ts +15 -0
  368. package/dist/hooks/autopilot/adapters/ralph-adapter.d.ts.map +1 -0
  369. package/dist/hooks/autopilot/adapters/ralph-adapter.js +102 -0
  370. package/dist/hooks/autopilot/adapters/ralph-adapter.js.map +1 -0
  371. package/dist/hooks/autopilot/adapters/ralplan-adapter.d.ts +14 -0
  372. package/dist/hooks/autopilot/adapters/ralplan-adapter.d.ts.map +1 -0
  373. package/dist/hooks/autopilot/adapters/ralplan-adapter.js +81 -0
  374. package/dist/hooks/autopilot/adapters/ralplan-adapter.js.map +1 -0
  375. package/dist/hooks/autopilot/enforcement.d.ts.map +1 -1
  376. package/dist/hooks/autopilot/enforcement.js +162 -0
  377. package/dist/hooks/autopilot/enforcement.js.map +1 -1
  378. package/dist/hooks/autopilot/index.d.ts +4 -0
  379. package/dist/hooks/autopilot/index.d.ts.map +1 -1
  380. package/dist/hooks/autopilot/index.js +5 -0
  381. package/dist/hooks/autopilot/index.js.map +1 -1
  382. package/dist/hooks/autopilot/pipeline-types.d.ts +133 -0
  383. package/dist/hooks/autopilot/pipeline-types.d.ts.map +1 -0
  384. package/dist/hooks/autopilot/pipeline-types.js +44 -0
  385. package/dist/hooks/autopilot/pipeline-types.js.map +1 -0
  386. package/dist/hooks/autopilot/pipeline.d.ts +124 -0
  387. package/dist/hooks/autopilot/pipeline.d.ts.map +1 -0
  388. package/dist/hooks/autopilot/pipeline.js +407 -0
  389. package/dist/hooks/autopilot/pipeline.js.map +1 -0
  390. package/dist/hooks/autopilot/state.d.ts +6 -6
  391. package/dist/hooks/autopilot/state.d.ts.map +1 -1
  392. package/dist/hooks/autopilot/state.js +71 -129
  393. package/dist/hooks/autopilot/state.js.map +1 -1
  394. package/dist/hooks/autopilot/types.d.ts +21 -0
  395. package/dist/hooks/autopilot/types.d.ts.map +1 -1
  396. package/dist/hooks/autopilot/types.js.map +1 -1
  397. package/dist/hooks/bridge-normalize.d.ts.map +1 -1
  398. package/dist/hooks/bridge-normalize.js +13 -2
  399. package/dist/hooks/bridge-normalize.js.map +1 -1
  400. package/dist/hooks/bridge.d.ts.map +1 -1
  401. package/dist/hooks/bridge.js +151 -27
  402. package/dist/hooks/bridge.js.map +1 -1
  403. package/dist/hooks/comment-checker/index.js +1 -1
  404. package/dist/hooks/comment-checker/index.js.map +1 -1
  405. package/dist/hooks/empty-message-sanitizer/__tests__/index.test.js +2 -2
  406. package/dist/hooks/empty-message-sanitizer/__tests__/index.test.js.map +1 -1
  407. package/dist/hooks/factcheck/__tests__/factcheck.test.d.ts +7 -0
  408. package/dist/hooks/factcheck/__tests__/factcheck.test.d.ts.map +1 -0
  409. package/dist/hooks/factcheck/__tests__/factcheck.test.js +153 -0
  410. package/dist/hooks/factcheck/__tests__/factcheck.test.js.map +1 -0
  411. package/dist/hooks/factcheck/__tests__/sentinel-gate.test.d.ts +5 -0
  412. package/dist/hooks/factcheck/__tests__/sentinel-gate.test.d.ts.map +1 -0
  413. package/dist/hooks/factcheck/__tests__/sentinel-gate.test.js +159 -0
  414. package/dist/hooks/factcheck/__tests__/sentinel-gate.test.js.map +1 -0
  415. package/dist/hooks/factcheck/__tests__/sentinel.test.d.ts +7 -0
  416. package/dist/hooks/factcheck/__tests__/sentinel.test.d.ts.map +1 -0
  417. package/dist/hooks/factcheck/__tests__/sentinel.test.js +117 -0
  418. package/dist/hooks/factcheck/__tests__/sentinel.test.js.map +1 -0
  419. package/dist/hooks/factcheck/checks.d.ts +36 -0
  420. package/dist/hooks/factcheck/checks.d.ts.map +1 -0
  421. package/dist/hooks/factcheck/checks.js +144 -0
  422. package/dist/hooks/factcheck/checks.js.map +1 -0
  423. package/dist/hooks/factcheck/config.d.ts +25 -0
  424. package/dist/hooks/factcheck/config.d.ts.map +1 -0
  425. package/dist/hooks/factcheck/config.js +125 -0
  426. package/dist/hooks/factcheck/config.js.map +1 -0
  427. package/dist/hooks/factcheck/index.d.ts +34 -0
  428. package/dist/hooks/factcheck/index.d.ts.map +1 -0
  429. package/dist/hooks/factcheck/index.js +120 -0
  430. package/dist/hooks/factcheck/index.js.map +1 -0
  431. package/dist/hooks/factcheck/sentinel.d.ts +32 -0
  432. package/dist/hooks/factcheck/sentinel.d.ts.map +1 -0
  433. package/dist/hooks/factcheck/sentinel.js +153 -0
  434. package/dist/hooks/factcheck/sentinel.js.map +1 -0
  435. package/dist/hooks/factcheck/types.d.ts +99 -0
  436. package/dist/hooks/factcheck/types.d.ts.map +1 -0
  437. package/dist/hooks/factcheck/types.js +27 -0
  438. package/dist/hooks/factcheck/types.js.map +1 -0
  439. package/dist/hooks/keyword-detector/__tests__/index.test.js +29 -80
  440. package/dist/hooks/keyword-detector/__tests__/index.test.js.map +1 -1
  441. package/dist/hooks/keyword-detector/index.d.ts +1 -1
  442. package/dist/hooks/keyword-detector/index.d.ts.map +1 -1
  443. package/dist/hooks/keyword-detector/index.js +11 -21
  444. package/dist/hooks/keyword-detector/index.js.map +1 -1
  445. package/dist/hooks/learner/bridge.d.ts.map +1 -1
  446. package/dist/hooks/learner/bridge.js +8 -0
  447. package/dist/hooks/learner/bridge.js.map +1 -1
  448. package/dist/hooks/learner/index.d.ts +15 -15
  449. package/dist/hooks/learner/index.d.ts.map +1 -1
  450. package/dist/hooks/learner/index.js +44 -38
  451. package/dist/hooks/learner/index.js.map +1 -1
  452. package/dist/hooks/mode-registry/__tests__/session-isolation.test.js +4 -2
  453. package/dist/hooks/mode-registry/__tests__/session-isolation.test.js.map +1 -1
  454. package/dist/hooks/mode-registry/index.d.ts +2 -13
  455. package/dist/hooks/mode-registry/index.d.ts.map +1 -1
  456. package/dist/hooks/mode-registry/index.js +77 -174
  457. package/dist/hooks/mode-registry/index.js.map +1 -1
  458. package/dist/hooks/mode-registry/types.d.ts +1 -1
  459. package/dist/hooks/mode-registry/types.d.ts.map +1 -1
  460. package/dist/hooks/notepad/index.d.ts.map +1 -1
  461. package/dist/hooks/notepad/index.js +83 -73
  462. package/dist/hooks/notepad/index.js.map +1 -1
  463. package/dist/hooks/omc-orchestrator/index.d.ts.map +1 -1
  464. package/dist/hooks/omc-orchestrator/index.js +2 -1
  465. package/dist/hooks/omc-orchestrator/index.js.map +1 -1
  466. package/dist/hooks/permission-handler/__tests__/index.test.js +2 -2
  467. package/dist/hooks/permission-handler/__tests__/index.test.js.map +1 -1
  468. package/dist/hooks/permission-handler/index.d.ts +1 -1
  469. package/dist/hooks/permission-handler/index.d.ts.map +1 -1
  470. package/dist/hooks/permission-handler/index.js +4 -8
  471. package/dist/hooks/permission-handler/index.js.map +1 -1
  472. package/dist/hooks/persistent-mode/__tests__/rate-limit-stop.test.js +23 -0
  473. package/dist/hooks/persistent-mode/__tests__/rate-limit-stop.test.js.map +1 -1
  474. package/dist/hooks/persistent-mode/__tests__/skill-state-stop.test.js.map +1 -1
  475. package/dist/hooks/persistent-mode/__tests__/tool-error.test.js +1 -1
  476. package/dist/hooks/persistent-mode/__tests__/tool-error.test.js.map +1 -1
  477. package/dist/hooks/persistent-mode/index.d.ts +3 -3
  478. package/dist/hooks/persistent-mode/index.d.ts.map +1 -1
  479. package/dist/hooks/persistent-mode/index.js +25 -12
  480. package/dist/hooks/persistent-mode/index.js.map +1 -1
  481. package/dist/hooks/persistent-mode/session-isolation.test.js +20 -4
  482. package/dist/hooks/persistent-mode/session-isolation.test.js.map +1 -1
  483. package/dist/hooks/persistent-mode/stop-hook-blocking.test.d.ts +2 -0
  484. package/dist/hooks/persistent-mode/stop-hook-blocking.test.d.ts.map +1 -0
  485. package/dist/hooks/persistent-mode/stop-hook-blocking.test.js +367 -0
  486. package/dist/hooks/persistent-mode/stop-hook-blocking.test.js.map +1 -0
  487. package/dist/hooks/pre-compact/index.d.ts +2 -14
  488. package/dist/hooks/pre-compact/index.d.ts.map +1 -1
  489. package/dist/hooks/pre-compact/index.js +8 -49
  490. package/dist/hooks/pre-compact/index.js.map +1 -1
  491. package/dist/hooks/preemptive-compaction/index.js +1 -1
  492. package/dist/hooks/preemptive-compaction/index.js.map +1 -1
  493. package/dist/hooks/project-memory/__tests__/integration.test.js +4 -2
  494. package/dist/hooks/project-memory/__tests__/integration.test.js.map +1 -1
  495. package/dist/hooks/project-memory/index.d.ts +9 -9
  496. package/dist/hooks/project-memory/index.d.ts.map +1 -1
  497. package/dist/hooks/project-memory/index.js +25 -25
  498. package/dist/hooks/project-memory/index.js.map +1 -1
  499. package/dist/hooks/project-memory/learner.d.ts.map +1 -1
  500. package/dist/hooks/project-memory/learner.js +92 -86
  501. package/dist/hooks/project-memory/learner.js.map +1 -1
  502. package/dist/hooks/project-memory/storage.d.ts +9 -0
  503. package/dist/hooks/project-memory/storage.d.ts.map +1 -1
  504. package/dist/hooks/project-memory/storage.js +15 -0
  505. package/dist/hooks/project-memory/storage.js.map +1 -1
  506. package/dist/hooks/ralph/index.d.ts +1 -1
  507. package/dist/hooks/ralph/index.d.ts.map +1 -1
  508. package/dist/hooks/ralph/index.js +2 -0
  509. package/dist/hooks/ralph/index.js.map +1 -1
  510. package/dist/hooks/ralph/loop.d.ts +10 -2
  511. package/dist/hooks/ralph/loop.d.ts.map +1 -1
  512. package/dist/hooks/ralph/loop.js +64 -113
  513. package/dist/hooks/ralph/loop.js.map +1 -1
  514. package/dist/hooks/ralph/prd.d.ts.map +1 -1
  515. package/dist/hooks/ralph/prd.js +3 -2
  516. package/dist/hooks/ralph/prd.js.map +1 -1
  517. package/dist/hooks/ralph/progress.d.ts.map +1 -1
  518. package/dist/hooks/ralph/progress.js +6 -5
  519. package/dist/hooks/ralph/progress.js.map +1 -1
  520. package/dist/hooks/ralph/verifier.d.ts +3 -1
  521. package/dist/hooks/ralph/verifier.d.ts.map +1 -1
  522. package/dist/hooks/ralph/verifier.js +19 -7
  523. package/dist/hooks/ralph/verifier.js.map +1 -1
  524. package/dist/hooks/session-end/__tests__/openclaw-session-end.test.d.ts +2 -0
  525. package/dist/hooks/session-end/__tests__/openclaw-session-end.test.d.ts.map +1 -0
  526. package/dist/hooks/session-end/__tests__/openclaw-session-end.test.js +86 -0
  527. package/dist/hooks/session-end/__tests__/openclaw-session-end.test.js.map +1 -0
  528. package/dist/hooks/session-end/index.d.ts.map +1 -1
  529. package/dist/hooks/session-end/index.js +17 -17
  530. package/dist/hooks/session-end/index.js.map +1 -1
  531. package/dist/hooks/setup/index.d.ts.map +1 -1
  532. package/dist/hooks/setup/index.js +0 -2
  533. package/dist/hooks/setup/index.js.map +1 -1
  534. package/dist/hooks/skill-bridge.cjs +13 -4
  535. package/dist/hooks/skill-state/__tests__/skill-state.test.js.map +1 -1
  536. package/dist/hooks/skill-state/index.d.ts +0 -5
  537. package/dist/hooks/skill-state/index.d.ts.map +1 -1
  538. package/dist/hooks/skill-state/index.js +9 -55
  539. package/dist/hooks/skill-state/index.js.map +1 -1
  540. package/dist/hooks/subagent-tracker/__tests__/flush-race.test.js.map +1 -1
  541. package/dist/hooks/subagent-tracker/__tests__/index.test.js.map +1 -1
  542. package/dist/hooks/subagent-tracker/__tests__/session-replay.test.js +1 -1
  543. package/dist/hooks/subagent-tracker/__tests__/session-replay.test.js.map +1 -1
  544. package/dist/hooks/subagent-tracker/index.d.ts.map +1 -1
  545. package/dist/hooks/subagent-tracker/index.js +10 -22
  546. package/dist/hooks/subagent-tracker/index.js.map +1 -1
  547. package/dist/hooks/subagent-tracker/session-replay.d.ts.map +1 -1
  548. package/dist/hooks/subagent-tracker/session-replay.js +3 -2
  549. package/dist/hooks/subagent-tracker/session-replay.js.map +1 -1
  550. package/dist/hooks/task-size-detector/__tests__/index.test.js +7 -7
  551. package/dist/hooks/task-size-detector/__tests__/index.test.js.map +1 -1
  552. package/dist/hooks/task-size-detector/index.d.ts.map +1 -1
  553. package/dist/hooks/task-size-detector/index.js +0 -3
  554. package/dist/hooks/task-size-detector/index.js.map +1 -1
  555. package/dist/hooks/team-dispatch-hook.d.ts +65 -0
  556. package/dist/hooks/team-dispatch-hook.d.ts.map +1 -0
  557. package/dist/hooks/team-dispatch-hook.js +663 -0
  558. package/dist/hooks/team-dispatch-hook.js.map +1 -0
  559. package/dist/hooks/team-leader-nudge-hook.d.ts +36 -0
  560. package/dist/hooks/team-leader-nudge-hook.d.ts.map +1 -0
  561. package/dist/hooks/team-leader-nudge-hook.js +218 -0
  562. package/dist/hooks/team-leader-nudge-hook.js.map +1 -0
  563. package/dist/hooks/team-worker-hook.d.ts +45 -0
  564. package/dist/hooks/team-worker-hook.d.ts.map +1 -0
  565. package/dist/hooks/team-worker-hook.js +415 -0
  566. package/dist/hooks/team-worker-hook.js.map +1 -0
  567. package/dist/hooks/think-mode/__tests__/index.test.js.map +1 -1
  568. package/dist/hooks/todo-continuation/__tests__/isAuthenticationError.test.d.ts +2 -0
  569. package/dist/hooks/todo-continuation/__tests__/isAuthenticationError.test.d.ts.map +1 -0
  570. package/dist/hooks/todo-continuation/__tests__/isAuthenticationError.test.js +33 -0
  571. package/dist/hooks/todo-continuation/__tests__/isAuthenticationError.test.js.map +1 -0
  572. package/dist/hooks/todo-continuation/index.d.ts +12 -0
  573. package/dist/hooks/todo-continuation/index.d.ts.map +1 -1
  574. package/dist/hooks/todo-continuation/index.js +37 -1
  575. package/dist/hooks/todo-continuation/index.js.map +1 -1
  576. package/dist/hooks/ultrapilot/decomposer.d.ts.map +1 -1
  577. package/dist/hooks/ultrapilot/decomposer.js +3 -1
  578. package/dist/hooks/ultrapilot/decomposer.js.map +1 -1
  579. package/dist/hooks/ultrapilot/index.d.ts.map +1 -1
  580. package/dist/hooks/ultrapilot/index.js +3 -1
  581. package/dist/hooks/ultrapilot/index.js.map +1 -1
  582. package/dist/hooks/ultrapilot/state.d.ts +1 -1
  583. package/dist/hooks/ultrapilot/state.d.ts.map +1 -1
  584. package/dist/hooks/ultrapilot/state.js +45 -77
  585. package/dist/hooks/ultrapilot/state.js.map +1 -1
  586. package/dist/hooks/ultraqa/index.d.ts.map +1 -1
  587. package/dist/hooks/ultraqa/index.js +4 -77
  588. package/dist/hooks/ultraqa/index.js.map +1 -1
  589. package/dist/hooks/ultrawork/index.d.ts.map +1 -1
  590. package/dist/hooks/ultrawork/index.js +40 -82
  591. package/dist/hooks/ultrawork/index.js.map +1 -1
  592. package/dist/hooks/ultrawork/session-isolation.test.js +1 -1
  593. package/dist/hooks/ultrawork/session-isolation.test.js.map +1 -1
  594. package/dist/hud/elements/api-key-source.d.ts +30 -0
  595. package/dist/hud/elements/api-key-source.d.ts.map +1 -0
  596. package/dist/hud/elements/api-key-source.js +70 -0
  597. package/dist/hud/elements/api-key-source.js.map +1 -0
  598. package/dist/hud/elements/index.d.ts +1 -0
  599. package/dist/hud/elements/index.d.ts.map +1 -1
  600. package/dist/hud/elements/index.js +1 -0
  601. package/dist/hud/elements/index.js.map +1 -1
  602. package/dist/hud/elements/limits.d.ts +9 -1
  603. package/dist/hud/elements/limits.d.ts.map +1 -1
  604. package/dist/hud/elements/limits.js +18 -0
  605. package/dist/hud/elements/limits.js.map +1 -1
  606. package/dist/hud/index.d.ts.map +1 -1
  607. package/dist/hud/index.js +40 -25
  608. package/dist/hud/index.js.map +1 -1
  609. package/dist/hud/omc-state.d.ts.map +1 -1
  610. package/dist/hud/omc-state.js +6 -4
  611. package/dist/hud/omc-state.js.map +1 -1
  612. package/dist/hud/render.d.ts +9 -0
  613. package/dist/hud/render.d.ts.map +1 -1
  614. package/dist/hud/render.js +166 -15
  615. package/dist/hud/render.js.map +1 -1
  616. package/dist/hud/state.d.ts.map +1 -1
  617. package/dist/hud/state.js +23 -14
  618. package/dist/hud/state.js.map +1 -1
  619. package/dist/hud/stdin.d.ts.map +1 -1
  620. package/dist/hud/stdin.js +5 -2
  621. package/dist/hud/stdin.js.map +1 -1
  622. package/dist/hud/types.d.ts +34 -3
  623. package/dist/hud/types.d.ts.map +1 -1
  624. package/dist/hud/types.js +19 -0
  625. package/dist/hud/types.js.map +1 -1
  626. package/dist/hud/usage-api.d.ts +9 -6
  627. package/dist/hud/usage-api.d.ts.map +1 -1
  628. package/dist/hud/usage-api.js +115 -46
  629. package/dist/hud/usage-api.js.map +1 -1
  630. package/dist/index.d.ts +3 -1
  631. package/dist/index.d.ts.map +1 -1
  632. package/dist/index.js +6 -2
  633. package/dist/index.js.map +1 -1
  634. package/dist/installer/__tests__/claude-md-merge.test.js +29 -0
  635. package/dist/installer/__tests__/claude-md-merge.test.js.map +1 -1
  636. package/dist/installer/__tests__/safe-installer.test.js +1 -1
  637. package/dist/installer/__tests__/safe-installer.test.js.map +1 -1
  638. package/dist/installer/hooks.d.ts.map +1 -1
  639. package/dist/installer/hooks.js +11 -12
  640. package/dist/installer/hooks.js.map +1 -1
  641. package/dist/installer/index.d.ts.map +1 -1
  642. package/dist/installer/index.js +20 -16
  643. package/dist/installer/index.js.map +1 -1
  644. package/dist/interop/__tests__/worker-adapter-integration.test.d.ts +2 -0
  645. package/dist/interop/__tests__/worker-adapter-integration.test.d.ts.map +1 -0
  646. package/dist/interop/__tests__/worker-adapter-integration.test.js +219 -0
  647. package/dist/interop/__tests__/worker-adapter-integration.test.js.map +1 -0
  648. package/dist/interop/__tests__/worker-adapter.test.d.ts +2 -0
  649. package/dist/interop/__tests__/worker-adapter.test.d.ts.map +1 -0
  650. package/dist/interop/__tests__/worker-adapter.test.js +408 -0
  651. package/dist/interop/__tests__/worker-adapter.test.js.map +1 -0
  652. package/dist/interop/adapter-types.d.ts +39 -0
  653. package/dist/interop/adapter-types.d.ts.map +1 -0
  654. package/dist/interop/adapter-types.js +9 -0
  655. package/dist/interop/adapter-types.js.map +1 -0
  656. package/dist/interop/worker-adapter.d.ts +116 -0
  657. package/dist/interop/worker-adapter.d.ts.map +1 -0
  658. package/dist/interop/worker-adapter.js +324 -0
  659. package/dist/interop/worker-adapter.js.map +1 -0
  660. package/dist/lib/__tests__/mode-state-io.test.d.ts +2 -0
  661. package/dist/lib/__tests__/mode-state-io.test.d.ts.map +1 -0
  662. package/dist/lib/__tests__/mode-state-io.test.js +194 -0
  663. package/dist/lib/__tests__/mode-state-io.test.js.map +1 -0
  664. package/dist/lib/__tests__/payload-limits.test.d.ts +2 -0
  665. package/dist/lib/__tests__/payload-limits.test.d.ts.map +1 -0
  666. package/dist/lib/__tests__/payload-limits.test.js +124 -0
  667. package/dist/lib/__tests__/payload-limits.test.js.map +1 -0
  668. package/dist/lib/__tests__/worktree-paths.test.js +5 -4
  669. package/dist/lib/__tests__/worktree-paths.test.js.map +1 -1
  670. package/dist/lib/file-lock.d.ts +75 -0
  671. package/dist/lib/file-lock.d.ts.map +1 -0
  672. package/dist/lib/file-lock.js +246 -0
  673. package/dist/lib/file-lock.js.map +1 -0
  674. package/dist/lib/mode-names.d.ts +10 -3
  675. package/dist/lib/mode-names.d.ts.map +1 -1
  676. package/dist/lib/mode-names.js +12 -17
  677. package/dist/lib/mode-names.js.map +1 -1
  678. package/dist/lib/mode-state-io.d.ts +41 -0
  679. package/dist/lib/mode-state-io.d.ts.map +1 -0
  680. package/dist/lib/mode-state-io.js +127 -0
  681. package/dist/lib/mode-state-io.js.map +1 -0
  682. package/dist/lib/payload-limits.d.ts +31 -0
  683. package/dist/lib/payload-limits.d.ts.map +1 -0
  684. package/dist/lib/payload-limits.js +82 -0
  685. package/dist/lib/payload-limits.js.map +1 -0
  686. package/dist/lib/project-memory-merge.d.ts +36 -0
  687. package/dist/lib/project-memory-merge.d.ts.map +1 -0
  688. package/dist/lib/project-memory-merge.js +154 -0
  689. package/dist/lib/project-memory-merge.js.map +1 -0
  690. package/dist/lib/shared-memory.d.ts +82 -0
  691. package/dist/lib/shared-memory.d.ts.map +1 -0
  692. package/dist/lib/shared-memory.js +305 -0
  693. package/dist/lib/shared-memory.js.map +1 -0
  694. package/dist/lib/worktree-paths.d.ts +31 -3
  695. package/dist/lib/worktree-paths.d.ts.map +1 -1
  696. package/dist/lib/worktree-paths.js +147 -12
  697. package/dist/lib/worktree-paths.js.map +1 -1
  698. package/dist/mcp/__tests__/team-server-artifact-convergence.test.d.ts +2 -0
  699. package/dist/mcp/__tests__/team-server-artifact-convergence.test.d.ts.map +1 -0
  700. package/dist/mcp/__tests__/team-server-artifact-convergence.test.js +84 -0
  701. package/dist/mcp/__tests__/team-server-artifact-convergence.test.js.map +1 -0
  702. package/dist/mcp/__tests__/team-server-deprecation.test.d.ts +2 -0
  703. package/dist/mcp/__tests__/team-server-deprecation.test.d.ts.map +1 -0
  704. package/dist/mcp/__tests__/team-server-deprecation.test.js +54 -0
  705. package/dist/mcp/__tests__/team-server-deprecation.test.js.map +1 -0
  706. package/dist/mcp/omc-tools-server.d.ts +2 -0
  707. package/dist/mcp/omc-tools-server.d.ts.map +1 -1
  708. package/dist/mcp/omc-tools-server.js +9 -2
  709. package/dist/mcp/omc-tools-server.js.map +1 -1
  710. package/dist/mcp/team-job-convergence.d.ts +20 -0
  711. package/dist/mcp/team-job-convergence.d.ts.map +1 -0
  712. package/dist/mcp/team-job-convergence.js +101 -0
  713. package/dist/mcp/team-job-convergence.js.map +1 -0
  714. package/dist/mcp/team-server.d.ts +33 -10
  715. package/dist/mcp/team-server.d.ts.map +1 -1
  716. package/dist/mcp/team-server.js +219 -109
  717. package/dist/mcp/team-server.js.map +1 -1
  718. package/dist/notifications/__tests__/config.test.js +100 -6
  719. package/dist/notifications/__tests__/config.test.js.map +1 -1
  720. package/dist/notifications/__tests__/custom-integration.test.d.ts +8 -0
  721. package/dist/notifications/__tests__/custom-integration.test.d.ts.map +1 -0
  722. package/dist/notifications/__tests__/custom-integration.test.js +297 -0
  723. package/dist/notifications/__tests__/custom-integration.test.js.map +1 -0
  724. package/dist/notifications/__tests__/dispatcher.test.js +195 -0
  725. package/dist/notifications/__tests__/dispatcher.test.js.map +1 -1
  726. package/dist/notifications/__tests__/redact.test.d.ts +2 -0
  727. package/dist/notifications/__tests__/redact.test.d.ts.map +1 -0
  728. package/dist/notifications/__tests__/redact.test.js +111 -0
  729. package/dist/notifications/__tests__/redact.test.js.map +1 -0
  730. package/dist/notifications/__tests__/reply-listener.test.js +8 -1
  731. package/dist/notifications/__tests__/reply-listener.test.js.map +1 -1
  732. package/dist/notifications/__tests__/slack-socket.test.d.ts +2 -0
  733. package/dist/notifications/__tests__/slack-socket.test.d.ts.map +1 -0
  734. package/dist/notifications/__tests__/slack-socket.test.js +293 -0
  735. package/dist/notifications/__tests__/slack-socket.test.js.map +1 -0
  736. package/dist/notifications/__tests__/template-engine.test.js +32 -0
  737. package/dist/notifications/__tests__/template-engine.test.js.map +1 -1
  738. package/dist/notifications/config.d.ts +40 -0
  739. package/dist/notifications/config.d.ts.map +1 -1
  740. package/dist/notifications/config.js +201 -4
  741. package/dist/notifications/config.js.map +1 -1
  742. package/dist/notifications/dispatcher.d.ts +20 -1
  743. package/dist/notifications/dispatcher.d.ts.map +1 -1
  744. package/dist/notifications/dispatcher.js +183 -7
  745. package/dist/notifications/dispatcher.js.map +1 -1
  746. package/dist/notifications/hook-config-types.d.ts +1 -1
  747. package/dist/notifications/hook-config-types.d.ts.map +1 -1
  748. package/dist/notifications/index.d.ts +11 -2
  749. package/dist/notifications/index.d.ts.map +1 -1
  750. package/dist/notifications/index.js +13 -3
  751. package/dist/notifications/index.js.map +1 -1
  752. package/dist/notifications/presets.d.ts +43 -0
  753. package/dist/notifications/presets.d.ts.map +1 -0
  754. package/dist/notifications/presets.js +122 -0
  755. package/dist/notifications/presets.js.map +1 -0
  756. package/dist/notifications/redact.d.ts +21 -0
  757. package/dist/notifications/redact.d.ts.map +1 -0
  758. package/dist/notifications/redact.js +33 -0
  759. package/dist/notifications/redact.js.map +1 -0
  760. package/dist/notifications/reply-listener.d.ts +54 -2
  761. package/dist/notifications/reply-listener.d.ts.map +1 -1
  762. package/dist/notifications/reply-listener.js +178 -15
  763. package/dist/notifications/reply-listener.js.map +1 -1
  764. package/dist/notifications/session-registry.d.ts +1 -1
  765. package/dist/notifications/session-registry.d.ts.map +1 -1
  766. package/dist/notifications/slack-socket.d.ts +242 -0
  767. package/dist/notifications/slack-socket.d.ts.map +1 -0
  768. package/dist/notifications/slack-socket.js +603 -0
  769. package/dist/notifications/slack-socket.js.map +1 -0
  770. package/dist/notifications/template-engine.d.ts.map +1 -1
  771. package/dist/notifications/template-engine.js +4 -0
  772. package/dist/notifications/template-engine.js.map +1 -1
  773. package/dist/notifications/template-variables.d.ts +26 -0
  774. package/dist/notifications/template-variables.d.ts.map +1 -0
  775. package/dist/notifications/template-variables.js +139 -0
  776. package/dist/notifications/template-variables.js.map +1 -0
  777. package/dist/notifications/types.d.ts +75 -2
  778. package/dist/notifications/types.d.ts.map +1 -1
  779. package/dist/notifications/validation.d.ts +24 -0
  780. package/dist/notifications/validation.d.ts.map +1 -0
  781. package/dist/notifications/validation.js +167 -0
  782. package/dist/notifications/validation.js.map +1 -0
  783. package/dist/openclaw/__tests__/dispatcher.test.js +0 -1
  784. package/dist/openclaw/__tests__/dispatcher.test.js.map +1 -1
  785. package/dist/openclaw/__tests__/index.test.js +82 -0
  786. package/dist/openclaw/__tests__/index.test.js.map +1 -1
  787. package/dist/openclaw/index.d.ts.map +1 -1
  788. package/dist/openclaw/index.js +24 -1
  789. package/dist/openclaw/index.js.map +1 -1
  790. package/dist/openclaw/types.d.ts +12 -0
  791. package/dist/openclaw/types.d.ts.map +1 -1
  792. package/dist/shared/types.d.ts +84 -20
  793. package/dist/shared/types.d.ts.map +1 -1
  794. package/dist/team/__tests__/api-interop.command-dialect.test.d.ts +2 -0
  795. package/dist/team/__tests__/api-interop.command-dialect.test.d.ts.map +1 -0
  796. package/dist/team/__tests__/api-interop.command-dialect.test.js +26 -0
  797. package/dist/team/__tests__/api-interop.command-dialect.test.js.map +1 -0
  798. package/dist/team/__tests__/api-interop.compatibility.test.d.ts +2 -0
  799. package/dist/team/__tests__/api-interop.compatibility.test.d.ts.map +1 -0
  800. package/dist/team/__tests__/api-interop.compatibility.test.js +93 -0
  801. package/dist/team/__tests__/api-interop.compatibility.test.js.map +1 -0
  802. package/dist/team/__tests__/cli-path-resolution.test.d.ts +2 -0
  803. package/dist/team/__tests__/cli-path-resolution.test.d.ts.map +1 -0
  804. package/dist/team/__tests__/cli-path-resolution.test.js +281 -0
  805. package/dist/team/__tests__/cli-path-resolution.test.js.map +1 -0
  806. package/dist/team/__tests__/index.compat-exports.test.d.ts +2 -0
  807. package/dist/team/__tests__/index.compat-exports.test.d.ts.map +1 -0
  808. package/dist/team/__tests__/index.compat-exports.test.js +20 -0
  809. package/dist/team/__tests__/index.compat-exports.test.js.map +1 -0
  810. package/dist/team/__tests__/layout-stabilizer.test.d.ts +2 -0
  811. package/dist/team/__tests__/layout-stabilizer.test.d.ts.map +1 -0
  812. package/dist/team/__tests__/layout-stabilizer.test.js +217 -0
  813. package/dist/team/__tests__/layout-stabilizer.test.js.map +1 -0
  814. package/dist/team/__tests__/mcp-team-bridge.spawn-args.test.js +8 -4
  815. package/dist/team/__tests__/mcp-team-bridge.spawn-args.test.js.map +1 -1
  816. package/dist/team/__tests__/mcp-team-bridge.usage.test.js +4 -2
  817. package/dist/team/__tests__/mcp-team-bridge.usage.test.js.map +1 -1
  818. package/dist/team/__tests__/model-contract.test.js +84 -8
  819. package/dist/team/__tests__/model-contract.test.js.map +1 -1
  820. package/dist/team/__tests__/pane-readiness.test.d.ts +2 -0
  821. package/dist/team/__tests__/pane-readiness.test.d.ts.map +1 -0
  822. package/dist/team/__tests__/pane-readiness.test.js +185 -0
  823. package/dist/team/__tests__/pane-readiness.test.js.map +1 -0
  824. package/dist/team/__tests__/prompt-sanitization.test.js +1 -1
  825. package/dist/team/__tests__/prompt-sanitization.test.js.map +1 -1
  826. package/dist/team/__tests__/runtime-cli.test.d.ts +2 -0
  827. package/dist/team/__tests__/runtime-cli.test.d.ts.map +1 -0
  828. package/dist/team/__tests__/runtime-cli.test.js +159 -0
  829. package/dist/team/__tests__/runtime-cli.test.js.map +1 -0
  830. package/dist/team/__tests__/runtime-done-recovery.test.d.ts +2 -0
  831. package/dist/team/__tests__/runtime-done-recovery.test.d.ts.map +1 -0
  832. package/dist/team/__tests__/runtime-done-recovery.test.js +77 -0
  833. package/dist/team/__tests__/runtime-done-recovery.test.js.map +1 -0
  834. package/dist/team/__tests__/runtime-interop-spawn-regression.test.d.ts +2 -0
  835. package/dist/team/__tests__/runtime-interop-spawn-regression.test.d.ts.map +1 -0
  836. package/dist/team/__tests__/runtime-interop-spawn-regression.test.js +139 -0
  837. package/dist/team/__tests__/runtime-interop-spawn-regression.test.js.map +1 -0
  838. package/dist/team/__tests__/runtime-prompt-mode.test.js +167 -14
  839. package/dist/team/__tests__/runtime-prompt-mode.test.js.map +1 -1
  840. package/dist/team/__tests__/runtime-v2.feature-flag.test.d.ts +2 -0
  841. package/dist/team/__tests__/runtime-v2.feature-flag.test.d.ts.map +1 -0
  842. package/dist/team/__tests__/runtime-v2.feature-flag.test.js +20 -0
  843. package/dist/team/__tests__/runtime-v2.feature-flag.test.js.map +1 -0
  844. package/dist/team/__tests__/runtime-watchdog-retry.test.d.ts +2 -0
  845. package/dist/team/__tests__/runtime-watchdog-retry.test.d.ts.map +1 -0
  846. package/dist/team/__tests__/runtime-watchdog-retry.test.js +408 -0
  847. package/dist/team/__tests__/runtime-watchdog-retry.test.js.map +1 -0
  848. package/dist/team/__tests__/shell-path.test.d.ts +2 -0
  849. package/dist/team/__tests__/shell-path.test.d.ts.map +1 -0
  850. package/dist/team/__tests__/shell-path.test.js +193 -0
  851. package/dist/team/__tests__/shell-path.test.js.map +1 -0
  852. package/dist/team/__tests__/state-paths.test.d.ts +2 -0
  853. package/dist/team/__tests__/state-paths.test.d.ts.map +1 -0
  854. package/dist/team/__tests__/state-paths.test.js +16 -0
  855. package/dist/team/__tests__/state-paths.test.js.map +1 -0
  856. package/dist/team/__tests__/task-file-ops.test.js +8 -2
  857. package/dist/team/__tests__/task-file-ops.test.js.map +1 -1
  858. package/dist/team/__tests__/tmux-session.create-team.test.js +15 -17
  859. package/dist/team/__tests__/tmux-session.create-team.test.js.map +1 -1
  860. package/dist/team/__tests__/tmux-session.kill-team-session.test.d.ts +2 -0
  861. package/dist/team/__tests__/tmux-session.kill-team-session.test.d.ts.map +1 -0
  862. package/dist/team/__tests__/tmux-session.kill-team-session.test.js +56 -0
  863. package/dist/team/__tests__/tmux-session.kill-team-session.test.js.map +1 -0
  864. package/dist/team/__tests__/tmux-session.spawn.test.js +9 -0
  865. package/dist/team/__tests__/tmux-session.spawn.test.js.map +1 -1
  866. package/dist/team/__tests__/tmux-session.test.js +83 -5
  867. package/dist/team/__tests__/tmux-session.test.js.map +1 -1
  868. package/dist/team/__tests__/wait-for-shell-ready.test.d.ts +2 -0
  869. package/dist/team/__tests__/wait-for-shell-ready.test.d.ts.map +1 -0
  870. package/dist/team/__tests__/wait-for-shell-ready.test.js +242 -0
  871. package/dist/team/__tests__/wait-for-shell-ready.test.js.map +1 -0
  872. package/dist/team/__tests__/worker-bootstrap.test.js +11 -0
  873. package/dist/team/__tests__/worker-bootstrap.test.js.map +1 -1
  874. package/dist/team/api-interop.d.ts +20 -0
  875. package/dist/team/api-interop.d.ts.map +1 -0
  876. package/dist/team/api-interop.js +601 -0
  877. package/dist/team/api-interop.js.map +1 -0
  878. package/dist/team/contracts.d.ts +14 -0
  879. package/dist/team/contracts.d.ts.map +1 -0
  880. package/dist/team/contracts.js +32 -0
  881. package/dist/team/contracts.js.map +1 -0
  882. package/dist/team/dispatch-queue.d.ts +64 -0
  883. package/dist/team/dispatch-queue.d.ts.map +1 -0
  884. package/dist/team/dispatch-queue.js +288 -0
  885. package/dist/team/dispatch-queue.js.map +1 -0
  886. package/dist/team/events.d.ts +49 -0
  887. package/dist/team/events.d.ts.map +1 -0
  888. package/dist/team/events.js +113 -0
  889. package/dist/team/events.js.map +1 -0
  890. package/dist/team/index.d.ts +15 -2
  891. package/dist/team/index.d.ts.map +1 -1
  892. package/dist/team/index.js +14 -1
  893. package/dist/team/index.js.map +1 -1
  894. package/dist/team/layout-stabilizer.d.ts +23 -0
  895. package/dist/team/layout-stabilizer.d.ts.map +1 -0
  896. package/dist/team/layout-stabilizer.js +117 -0
  897. package/dist/team/layout-stabilizer.js.map +1 -0
  898. package/dist/team/mcp-comm.d.ts +99 -0
  899. package/dist/team/mcp-comm.d.ts.map +1 -0
  900. package/dist/team/mcp-comm.js +235 -0
  901. package/dist/team/mcp-comm.js.map +1 -0
  902. package/dist/team/mcp-team-bridge.d.ts +2 -2
  903. package/dist/team/mcp-team-bridge.d.ts.map +1 -1
  904. package/dist/team/mcp-team-bridge.js +263 -144
  905. package/dist/team/mcp-team-bridge.js.map +1 -1
  906. package/dist/team/model-contract.d.ts +28 -1
  907. package/dist/team/model-contract.d.ts.map +1 -1
  908. package/dist/team/model-contract.js +143 -5
  909. package/dist/team/model-contract.js.map +1 -1
  910. package/dist/team/monitor.d.ts +45 -0
  911. package/dist/team/monitor.d.ts.map +1 -0
  912. package/dist/team/monitor.js +339 -0
  913. package/dist/team/monitor.js.map +1 -0
  914. package/dist/team/runtime-cli.d.ts +24 -0
  915. package/dist/team/runtime-cli.d.ts.map +1 -1
  916. package/dist/team/runtime-cli.js +230 -12
  917. package/dist/team/runtime-cli.js.map +1 -1
  918. package/dist/team/runtime-v2.d.ts +122 -0
  919. package/dist/team/runtime-v2.d.ts.map +1 -0
  920. package/dist/team/runtime-v2.js +766 -0
  921. package/dist/team/runtime-v2.js.map +1 -0
  922. package/dist/team/runtime.d.ts +2 -0
  923. package/dist/team/runtime.d.ts.map +1 -1
  924. package/dist/team/runtime.js +145 -52
  925. package/dist/team/runtime.js.map +1 -1
  926. package/dist/team/scaling.d.ts +59 -0
  927. package/dist/team/scaling.d.ts.map +1 -0
  928. package/dist/team/scaling.js +311 -0
  929. package/dist/team/scaling.js.map +1 -0
  930. package/dist/team/sentinel-gate.d.ts +23 -0
  931. package/dist/team/sentinel-gate.d.ts.map +1 -0
  932. package/dist/team/sentinel-gate.js +127 -0
  933. package/dist/team/sentinel-gate.js.map +1 -0
  934. package/dist/team/shell-path.d.ts +21 -0
  935. package/dist/team/shell-path.d.ts.map +1 -0
  936. package/dist/team/shell-path.js +73 -0
  937. package/dist/team/shell-path.js.map +1 -0
  938. package/dist/team/state/tasks.d.ts +48 -0
  939. package/dist/team/state/tasks.d.ts.map +1 -0
  940. package/dist/team/state/tasks.js +184 -0
  941. package/dist/team/state/tasks.js.map +1 -0
  942. package/dist/team/state-paths.d.ts +20 -4
  943. package/dist/team/state-paths.d.ts.map +1 -1
  944. package/dist/team/state-paths.js +29 -6
  945. package/dist/team/state-paths.js.map +1 -1
  946. package/dist/team/task-file-ops.d.ts +2 -1
  947. package/dist/team/task-file-ops.d.ts.map +1 -1
  948. package/dist/team/task-file-ops.js +19 -0
  949. package/dist/team/task-file-ops.js.map +1 -1
  950. package/dist/team/team-ops.d.ts +44 -0
  951. package/dist/team/team-ops.d.ts.map +1 -0
  952. package/dist/team/team-ops.js +547 -0
  953. package/dist/team/team-ops.js.map +1 -0
  954. package/dist/team/tmux-comm.d.ts.map +1 -1
  955. package/dist/team/tmux-comm.js +107 -44
  956. package/dist/team/tmux-comm.js.map +1 -1
  957. package/dist/team/tmux-session.d.ts +5 -0
  958. package/dist/team/tmux-session.d.ts.map +1 -1
  959. package/dist/team/tmux-session.js +81 -10
  960. package/dist/team/tmux-session.js.map +1 -1
  961. package/dist/team/types.d.ts +303 -8
  962. package/dist/team/types.d.ts.map +1 -1
  963. package/dist/team/types.js +2 -1
  964. package/dist/team/types.js.map +1 -1
  965. package/dist/team/worker-bootstrap.d.ts.map +1 -1
  966. package/dist/team/worker-bootstrap.js +73 -21
  967. package/dist/team/worker-bootstrap.js.map +1 -1
  968. package/dist/tools/__tests__/cancel-integration.test.d.ts +2 -0
  969. package/dist/tools/__tests__/cancel-integration.test.d.ts.map +1 -0
  970. package/dist/tools/__tests__/cancel-integration.test.js +248 -0
  971. package/dist/tools/__tests__/cancel-integration.test.js.map +1 -0
  972. package/dist/tools/__tests__/memory-tools.test.d.ts +2 -0
  973. package/dist/tools/__tests__/memory-tools.test.d.ts.map +1 -0
  974. package/dist/tools/__tests__/memory-tools.test.js +66 -0
  975. package/dist/tools/__tests__/memory-tools.test.js.map +1 -0
  976. package/dist/tools/__tests__/state-tools.test.js +73 -5
  977. package/dist/tools/__tests__/state-tools.test.js.map +1 -1
  978. package/dist/tools/lsp/__tests__/client-eviction.test.js +6 -6
  979. package/dist/tools/lsp/__tests__/client-eviction.test.js.map +1 -1
  980. package/dist/tools/lsp/__tests__/client-timeout-env.test.d.ts +2 -0
  981. package/dist/tools/lsp/__tests__/client-timeout-env.test.d.ts.map +1 -0
  982. package/dist/tools/lsp/__tests__/client-timeout-env.test.js +39 -0
  983. package/dist/tools/lsp/__tests__/client-timeout-env.test.js.map +1 -0
  984. package/dist/tools/lsp/client.d.ts +2 -0
  985. package/dist/tools/lsp/client.d.ts.map +1 -1
  986. package/dist/tools/lsp/client.js +11 -1
  987. package/dist/tools/lsp/client.js.map +1 -1
  988. package/dist/tools/lsp/index.d.ts +1 -1
  989. package/dist/tools/lsp/index.d.ts.map +1 -1
  990. package/dist/tools/lsp/index.js +1 -1
  991. package/dist/tools/lsp/index.js.map +1 -1
  992. package/dist/tools/memory-tools.d.ts.map +1 -1
  993. package/dist/tools/memory-tools.js +2 -1
  994. package/dist/tools/memory-tools.js.map +1 -1
  995. package/dist/tools/python-repl/__tests__/tcp-fallback.test.d.ts +2 -0
  996. package/dist/tools/python-repl/__tests__/tcp-fallback.test.d.ts.map +1 -0
  997. package/dist/tools/python-repl/__tests__/tcp-fallback.test.js +138 -0
  998. package/dist/tools/python-repl/__tests__/tcp-fallback.test.js.map +1 -0
  999. package/dist/tools/python-repl/bridge-manager.d.ts.map +1 -1
  1000. package/dist/tools/python-repl/bridge-manager.js +104 -24
  1001. package/dist/tools/python-repl/bridge-manager.js.map +1 -1
  1002. package/dist/tools/python-repl/paths.d.ts +8 -0
  1003. package/dist/tools/python-repl/paths.d.ts.map +1 -1
  1004. package/dist/tools/python-repl/paths.js +10 -0
  1005. package/dist/tools/python-repl/paths.js.map +1 -1
  1006. package/dist/tools/python-repl/socket-client.d.ts.map +1 -1
  1007. package/dist/tools/python-repl/socket-client.js +9 -2
  1008. package/dist/tools/python-repl/socket-client.js.map +1 -1
  1009. package/dist/tools/shared-memory-tools.d.ts +55 -0
  1010. package/dist/tools/shared-memory-tools.d.ts.map +1 -0
  1011. package/dist/tools/shared-memory-tools.js +250 -0
  1012. package/dist/tools/shared-memory-tools.js.map +1 -0
  1013. package/dist/tools/state-tools.d.ts.map +1 -1
  1014. package/dist/tools/state-tools.js +126 -101
  1015. package/dist/tools/state-tools.js.map +1 -1
  1016. package/dist/utils/daemon-module-path.d.ts +9 -0
  1017. package/dist/utils/daemon-module-path.d.ts.map +1 -0
  1018. package/dist/utils/daemon-module-path.js +23 -0
  1019. package/dist/utils/daemon-module-path.js.map +1 -0
  1020. package/dist/utils/jsonc.d.ts +16 -0
  1021. package/dist/utils/jsonc.d.ts.map +1 -0
  1022. package/dist/utils/jsonc.js +64 -0
  1023. package/dist/utils/jsonc.js.map +1 -0
  1024. package/dist/utils/paths.js +1 -1
  1025. package/dist/utils/paths.js.map +1 -1
  1026. package/dist/utils/ssrf-guard.d.ts +26 -0
  1027. package/dist/utils/ssrf-guard.d.ts.map +1 -0
  1028. package/dist/utils/ssrf-guard.js +103 -0
  1029. package/dist/utils/ssrf-guard.js.map +1 -0
  1030. package/dist/verification/tier-selector.d.ts +1 -1
  1031. package/dist/verification/tier-selector.js +1 -1
  1032. package/docs/ANALYTICS-SYSTEM.md +2 -5
  1033. package/docs/CLAUDE.md +88 -212
  1034. package/docs/MIGRATION.md +138 -161
  1035. package/docs/PERFORMANCE-MONITORING.md +5 -5
  1036. package/docs/REFERENCE.md +351 -286
  1037. package/docs/ko/ARCHITECTURE.md +152 -0
  1038. package/docs/ko/FEATURES.md +582 -0
  1039. package/docs/ko/MIGRATION.md +1027 -0
  1040. package/docs/ko/REFERENCE.md +745 -0
  1041. package/docs/partials/mode-selection-guide.md +22 -12
  1042. package/docs/shared/mode-selection-guide.md +22 -12
  1043. package/package.json +11 -6
  1044. package/scripts/ask-codex.sh +24 -0
  1045. package/scripts/ask-gemini.sh +24 -0
  1046. package/scripts/build-cli.mjs +47 -0
  1047. package/scripts/build-runtime-cli.mjs +2 -0
  1048. package/scripts/context-guard-stop.mjs +66 -3
  1049. package/scripts/context-safety.mjs +67 -2
  1050. package/scripts/keyword-detector.mjs +14 -36
  1051. package/scripts/persistent-mode.cjs +106 -1
  1052. package/scripts/persistent-mode.mjs +88 -2
  1053. package/scripts/plugin-setup.mjs +46 -4
  1054. package/scripts/pre-tool-enforcer.mjs +1 -0
  1055. package/scripts/qa-tests/test-custom-integration.mjs +144 -0
  1056. package/scripts/run-provider-advisor.js +220 -0
  1057. package/scripts/session-start.mjs +42 -2
  1058. package/skills/AGENTS.md +15 -20
  1059. package/skills/ask-codex/SKILL.md +47 -0
  1060. package/skills/ask-gemini/SKILL.md +47 -0
  1061. package/skills/autopilot/SKILL.md +39 -5
  1062. package/skills/cancel/SKILL.md +23 -105
  1063. package/skills/ccg/SKILL.md +58 -75
  1064. package/skills/configure-notifications/SKILL.md +276 -0
  1065. package/skills/configure-openclaw/SKILL.md +63 -0
  1066. package/skills/deep-interview/SKILL.md +551 -0
  1067. package/skills/deepinit/SKILL.md +1 -1
  1068. package/skills/hud/SKILL.md +35 -3
  1069. package/skills/omc-doctor/SKILL.md +30 -13
  1070. package/skills/omc-help/SKILL.md +1 -1
  1071. package/skills/omc-setup/SKILL.md +20 -20
  1072. package/skills/omc-teams/SKILL.md +60 -112
  1073. package/skills/plan/SKILL.md +5 -5
  1074. package/skills/ralph/SKILL.md +96 -70
  1075. package/skills/ralplan/SKILL.md +7 -7
  1076. package/skills/security-review/SKILL.md +2 -2
  1077. package/skills/team/SKILL.md +36 -2
  1078. package/skills/ultrawork/SKILL.md +7 -7
  1079. package/templates/hooks/keyword-detector.mjs +20 -28
  1080. package/templates/hooks/persistent-mode.mjs +89 -2
  1081. package/templates/hooks/pre-tool-use.mjs +53 -0
  1082. package/templates/hooks/session-start.mjs +3 -3
  1083. package/skills/pipeline/SKILL.md +0 -434
  1084. package/skills/review/SKILL.md +0 -30
  1085. package/skills/ultrapilot/SKILL.md +0 -632
@@ -0,0 +1,766 @@
1
+ /**
2
+ * Event-driven team runtime v2 — replaces the polling watchdog from runtime.ts.
3
+ *
4
+ * Runtime selection:
5
+ * - Default: v2 enabled
6
+ * - Opt-out: set OMC_RUNTIME_V2=0|false|no|off to force legacy v1
7
+ * NO done.json polling. Completion is detected via:
8
+ * - CLI API lifecycle transitions (claim-task, transition-task-status)
9
+ * - Event-driven monitor snapshots
10
+ * - Worker heartbeat/status files
11
+ *
12
+ * Preserves: sentinel gate, circuit breaker, failure sidecars.
13
+ * Removes: done.json watchdog loop, sleep-based polling.
14
+ *
15
+ * Architecture mirrors runtime.ts: startTeam, monitorTeam, shutdownTeam,
16
+ * assignTask, resumeTeam as discrete operations driven by the caller.
17
+ */
18
+ import { join, resolve } from 'path';
19
+ import { existsSync } from 'fs';
20
+ import { mkdir, readdir, writeFile } from 'fs/promises';
21
+ import { performance } from 'perf_hooks';
22
+ import { TeamPaths, absPath, teamStateRoot } from './state-paths.js';
23
+ import { readTeamConfig, readWorkerStatus, readWorkerHeartbeat, readMonitorSnapshot, writeMonitorSnapshot, writeShutdownRequest, readShutdownAck, writeWorkerInbox, listTasksFromFiles, saveTeamConfig, cleanupTeamState, } from './monitor.js';
24
+ import { appendTeamEvent, emitMonitorDerivedEvents } from './events.js';
25
+ import { inferPhase } from './phase-controller.js';
26
+ import { validateTeamName } from './team-name.js';
27
+ import { buildWorkerArgv, resolveValidatedBinaryPath, getWorkerEnv as getModelWorkerEnv, isPromptModeAgent, getPromptModeArgs, } from './model-contract.js';
28
+ import { createTeamSession, spawnWorkerInPane, sendToWorker, waitForPaneReady, } from './tmux-session.js';
29
+ import { composeInitialInbox, ensureWorkerStateDir, writeWorkerOverlay, } from './worker-bootstrap.js';
30
+ // ---------------------------------------------------------------------------
31
+ // Feature flag
32
+ // ---------------------------------------------------------------------------
33
+ export function isRuntimeV2Enabled(env = process.env) {
34
+ const raw = env.OMC_RUNTIME_V2;
35
+ if (!raw)
36
+ return true;
37
+ const normalized = raw.trim().toLowerCase();
38
+ return !['0', 'false', 'no', 'off'].includes(normalized);
39
+ }
40
+ // ---------------------------------------------------------------------------
41
+ // Helper: sanitize team name
42
+ // ---------------------------------------------------------------------------
43
+ function sanitizeTeamName(name) {
44
+ return name.replace(/[^a-z0-9-]/g, '').slice(0, 30);
45
+ }
46
+ // ---------------------------------------------------------------------------
47
+ // Helper: check worker liveness via tmux pane
48
+ // ---------------------------------------------------------------------------
49
+ async function isWorkerPaneAlive(paneId) {
50
+ if (!paneId)
51
+ return false;
52
+ try {
53
+ const { isWorkerAlive } = await import('./tmux-session.js');
54
+ return await isWorkerAlive(paneId);
55
+ }
56
+ catch {
57
+ return false;
58
+ }
59
+ }
60
+ // ---------------------------------------------------------------------------
61
+ // V2 task instruction builder — CLI API lifecycle, NO done.json
62
+ // ---------------------------------------------------------------------------
63
+ /**
64
+ * Build the initial task instruction for v2 workers.
65
+ * Workers use `omc team api` CLI commands for all lifecycle transitions.
66
+ */
67
+ function buildV2TaskInstruction(teamName, workerName, task, taskId) {
68
+ return [
69
+ `## Initial Task Assignment`,
70
+ `Task ID: ${taskId}`,
71
+ `Worker: ${workerName}`,
72
+ `Subject: ${task.subject}`,
73
+ ``,
74
+ task.description,
75
+ ``,
76
+ `## Task Lifecycle (CLI API)`,
77
+ `1. Claim your task:`,
78
+ ` omc team api claim-task --input '{"team_name":"${teamName}","task_id":"${taskId}","worker":"${workerName}"}' --json`,
79
+ `2. Do the work described above`,
80
+ `3. On completion (use the claim_token from step 1):`,
81
+ ` omc team api transition-task-status --input '{"team_name":"${teamName}","task_id":"${taskId}","from":"in_progress","to":"completed","claim_token":"<claim_token>"}' --json`,
82
+ `4. On failure (use the claim_token from step 1):`,
83
+ ` omc team api transition-task-status --input '{"team_name":"${teamName}","task_id":"${taskId}","from":"in_progress","to":"failed","claim_token":"<claim_token>"}' --json`,
84
+ ``,
85
+ `IMPORTANT: Use the CLI API commands above for all task state transitions.`,
86
+ `Do NOT write done.json or edit task files directly.`,
87
+ `After completing or failing the task, exit immediately.`,
88
+ ].join('\n');
89
+ }
90
+ // ---------------------------------------------------------------------------
91
+ // V2 worker spawning — direct tmux pane creation, no v1 delegation
92
+ // ---------------------------------------------------------------------------
93
+ async function notifyPaneWithRetry(sessionName, paneId, message, maxAttempts = 6, retryDelayMs = 350) {
94
+ for (let attempt = 1; attempt <= maxAttempts; attempt++) {
95
+ if (await sendToWorker(sessionName, paneId, message)) {
96
+ return true;
97
+ }
98
+ if (attempt < maxAttempts) {
99
+ await new Promise(r => setTimeout(r, retryDelayMs));
100
+ }
101
+ }
102
+ return false;
103
+ }
104
+ /**
105
+ * Spawn a single v2 worker in a tmux pane.
106
+ * Writes CLI API inbox (no done.json), waits for ready, sends inbox path.
107
+ */
108
+ async function spawnV2Worker(opts) {
109
+ const { execFile } = await import('child_process');
110
+ const { promisify } = await import('util');
111
+ const execFileAsync = promisify(execFile);
112
+ // Split new pane off the last existing pane (or leader if first worker)
113
+ const splitTarget = opts.existingWorkerPaneIds.length === 0
114
+ ? opts.leaderPaneId
115
+ : opts.existingWorkerPaneIds[opts.existingWorkerPaneIds.length - 1];
116
+ const splitType = opts.existingWorkerPaneIds.length === 0 ? '-h' : '-v';
117
+ const splitResult = await execFileAsync('tmux', [
118
+ 'split-window', splitType, '-t', splitTarget,
119
+ '-d', '-P', '-F', '#{pane_id}',
120
+ '-c', opts.cwd,
121
+ ]);
122
+ const paneId = splitResult.stdout.split('\n')[0]?.trim();
123
+ if (!paneId)
124
+ return null;
125
+ const usePromptMode = isPromptModeAgent(opts.agentType);
126
+ // Build v2 task instruction (CLI API, NO done.json)
127
+ const instruction = buildV2TaskInstruction(opts.teamName, opts.workerName, opts.task, opts.taskId);
128
+ await composeInitialInbox(opts.teamName, opts.workerName, instruction, opts.cwd);
129
+ const relInboxPath = `.omc/state/team/${opts.teamName}/workers/${opts.workerName}/inbox.md`;
130
+ // Build env and launch command
131
+ const envVars = getModelWorkerEnv(opts.teamName, opts.workerName, opts.agentType);
132
+ const resolvedBinaryPath = opts.resolvedBinaryPaths[opts.agentType]
133
+ ?? resolveValidatedBinaryPath(opts.agentType);
134
+ // Resolve model from environment variables
135
+ const modelForAgent = (() => {
136
+ if (opts.agentType === 'codex') {
137
+ return process.env.OMC_EXTERNAL_MODELS_DEFAULT_CODEX_MODEL
138
+ || process.env.OMC_CODEX_DEFAULT_MODEL
139
+ || undefined;
140
+ }
141
+ if (opts.agentType === 'gemini') {
142
+ return process.env.OMC_EXTERNAL_MODELS_DEFAULT_GEMINI_MODEL
143
+ || process.env.OMC_GEMINI_DEFAULT_MODEL
144
+ || undefined;
145
+ }
146
+ return undefined;
147
+ })();
148
+ const [launchBinary, ...launchArgs] = buildWorkerArgv(opts.agentType, {
149
+ teamName: opts.teamName,
150
+ workerName: opts.workerName,
151
+ cwd: opts.cwd,
152
+ resolvedBinaryPath,
153
+ model: modelForAgent,
154
+ });
155
+ // For prompt-mode agents (codex, gemini), pass instruction via CLI flag
156
+ if (usePromptMode) {
157
+ const promptArgs = getPromptModeArgs(opts.agentType, `Read and execute your task from: ${relInboxPath}`);
158
+ launchArgs.push(...promptArgs);
159
+ }
160
+ const paneConfig = {
161
+ teamName: opts.teamName,
162
+ workerName: opts.workerName,
163
+ envVars,
164
+ launchBinary,
165
+ launchArgs,
166
+ cwd: opts.cwd,
167
+ };
168
+ await spawnWorkerInPane(opts.sessionName, paneId, paneConfig);
169
+ // Apply layout
170
+ try {
171
+ await execFileAsync('tmux', [
172
+ 'select-layout', '-t', opts.sessionName, 'main-vertical',
173
+ ]);
174
+ }
175
+ catch { /* layout is best-effort */ }
176
+ // For interactive agents, wait for pane readiness then send inbox path
177
+ if (!usePromptMode) {
178
+ const paneReady = await waitForPaneReady(paneId);
179
+ if (!paneReady) {
180
+ try {
181
+ await execFileAsync('tmux', ['kill-pane', '-t', paneId]);
182
+ }
183
+ catch { /* best-effort cleanup */ }
184
+ return null;
185
+ }
186
+ // Handle gemini trust-confirm
187
+ if (opts.agentType === 'gemini') {
188
+ const confirmed = await notifyPaneWithRetry(opts.sessionName, paneId, '1');
189
+ if (!confirmed) {
190
+ try {
191
+ await execFileAsync('tmux', ['kill-pane', '-t', paneId]);
192
+ }
193
+ catch { /* best-effort cleanup */ }
194
+ return null;
195
+ }
196
+ await new Promise(r => setTimeout(r, 800));
197
+ }
198
+ // Send inbox path to worker
199
+ const notified = await notifyPaneWithRetry(opts.sessionName, paneId, `Read and execute your task from: ${relInboxPath}`);
200
+ if (!notified) {
201
+ try {
202
+ await execFileAsync('tmux', ['kill-pane', '-t', paneId]);
203
+ }
204
+ catch { /* best-effort cleanup */ }
205
+ return null;
206
+ }
207
+ }
208
+ return paneId;
209
+ }
210
+ // ---------------------------------------------------------------------------
211
+ // startTeamV2 — direct tmux creation, CLI API inbox, NO watchdog
212
+ // ---------------------------------------------------------------------------
213
+ /**
214
+ * Start a team with the v2 event-driven runtime.
215
+ * Creates state directories, writes config + task files, spawns workers via
216
+ * tmux split-panes, and writes CLI API inbox instructions. NO done.json.
217
+ * NO watchdog polling — the leader drives monitoring via monitorTeamV2().
218
+ */
219
+ export async function startTeamV2(config) {
220
+ const sanitized = sanitizeTeamName(config.teamName);
221
+ const leaderCwd = resolve(config.cwd);
222
+ validateTeamName(sanitized);
223
+ // Validate CLIs and pin absolute binary paths
224
+ const agentTypes = config.agentTypes;
225
+ const resolvedBinaryPaths = {};
226
+ for (const agentType of [...new Set(agentTypes)]) {
227
+ resolvedBinaryPaths[agentType] = resolveValidatedBinaryPath(agentType);
228
+ }
229
+ // Create state directories
230
+ await mkdir(absPath(leaderCwd, TeamPaths.tasks(sanitized)), { recursive: true });
231
+ await mkdir(absPath(leaderCwd, TeamPaths.workers(sanitized)), { recursive: true });
232
+ await mkdir(join(leaderCwd, '.omc', 'state', 'team', sanitized, 'mailbox'), { recursive: true });
233
+ // Write task files
234
+ for (let i = 0; i < config.tasks.length; i++) {
235
+ const taskId = String(i + 1);
236
+ const taskFilePath = absPath(leaderCwd, TeamPaths.taskFile(sanitized, taskId));
237
+ await mkdir(join(taskFilePath, '..'), { recursive: true });
238
+ await writeFile(taskFilePath, JSON.stringify({
239
+ id: taskId,
240
+ subject: config.tasks[i].subject,
241
+ description: config.tasks[i].description,
242
+ status: 'pending',
243
+ owner: null,
244
+ result: null,
245
+ created_at: new Date().toISOString(),
246
+ }, null, 2), 'utf-8');
247
+ }
248
+ // Set up worker state dirs and overlays (with v2 CLI API instructions)
249
+ const workerNames = [];
250
+ for (let i = 0; i < config.tasks.length; i++) {
251
+ const wName = `worker-${i + 1}`;
252
+ workerNames.push(wName);
253
+ const agentType = (agentTypes[i % agentTypes.length] ?? agentTypes[0] ?? 'claude');
254
+ await ensureWorkerStateDir(sanitized, wName, leaderCwd);
255
+ await writeWorkerOverlay({
256
+ teamName: sanitized, workerName: wName, agentType,
257
+ tasks: config.tasks.map((t, idx) => ({
258
+ id: String(idx + 1), subject: t.subject, description: t.description,
259
+ })),
260
+ cwd: leaderCwd,
261
+ });
262
+ }
263
+ // Create tmux session (leader only — workers spawned below)
264
+ const session = await createTeamSession(sanitized, 0, leaderCwd);
265
+ const sessionName = session.sessionName;
266
+ const leaderPaneId = session.leaderPaneId;
267
+ const workerPaneIds = [];
268
+ // Build workers info for config
269
+ const workersInfo = workerNames.map((wName, i) => ({
270
+ name: wName,
271
+ index: i + 1,
272
+ role: (agentTypes[i % agentTypes.length] ?? agentTypes[0] ?? 'claude'),
273
+ assigned_tasks: [],
274
+ working_dir: leaderCwd,
275
+ }));
276
+ // Write initial v2 config
277
+ const teamConfig = {
278
+ name: sanitized,
279
+ task: config.tasks.map(t => t.subject).join('; '),
280
+ agent_type: agentTypes[0] || 'claude',
281
+ worker_launch_mode: 'interactive',
282
+ worker_count: config.workerCount,
283
+ max_workers: 20,
284
+ workers: workersInfo,
285
+ created_at: new Date().toISOString(),
286
+ tmux_session: sessionName,
287
+ next_task_id: config.tasks.length + 1,
288
+ leader_cwd: leaderCwd,
289
+ team_state_root: teamStateRoot(leaderCwd, sanitized),
290
+ leader_pane_id: leaderPaneId,
291
+ hud_pane_id: null,
292
+ resize_hook_name: null,
293
+ resize_hook_target: null,
294
+ };
295
+ await saveTeamConfig(teamConfig, leaderCwd);
296
+ // Spawn workers for initial tasks (up to workerCount concurrent)
297
+ const maxConcurrent = Math.min(agentTypes.length, config.tasks.length);
298
+ for (let i = 0; i < maxConcurrent; i++) {
299
+ const wName = workerNames[i];
300
+ const taskId = String(i + 1);
301
+ const task = config.tasks[i];
302
+ if (!task)
303
+ break;
304
+ const paneId = await spawnV2Worker({
305
+ sessionName,
306
+ leaderPaneId,
307
+ existingWorkerPaneIds: workerPaneIds,
308
+ teamName: sanitized,
309
+ workerName: wName,
310
+ workerIndex: i,
311
+ agentType: (agentTypes[i % agentTypes.length] ?? agentTypes[0] ?? 'claude'),
312
+ task,
313
+ taskId,
314
+ cwd: leaderCwd,
315
+ resolvedBinaryPaths,
316
+ });
317
+ if (paneId) {
318
+ workerPaneIds.push(paneId);
319
+ const workerInfo = workersInfo[i];
320
+ if (workerInfo) {
321
+ workerInfo.pane_id = paneId;
322
+ workerInfo.assigned_tasks = [taskId];
323
+ }
324
+ }
325
+ }
326
+ // Persist config with pane IDs
327
+ teamConfig.workers = workersInfo;
328
+ await saveTeamConfig(teamConfig, leaderCwd);
329
+ // Emit start event — NO watchdog, leader drives via monitorTeamV2()
330
+ await appendTeamEvent(sanitized, {
331
+ type: 'team_leader_nudge',
332
+ worker: 'leader-fixed',
333
+ reason: `start_team_v2: workers=${config.workerCount} tasks=${config.tasks.length} panes=${workerPaneIds.length}`,
334
+ }, leaderCwd);
335
+ return {
336
+ teamName: sanitized,
337
+ sanitizedName: sanitized,
338
+ sessionName,
339
+ config: teamConfig,
340
+ cwd: leaderCwd,
341
+ };
342
+ }
343
+ // ---------------------------------------------------------------------------
344
+ // Circuit breaker — 3 consecutive failures -> write watchdog-failed.json
345
+ // ---------------------------------------------------------------------------
346
+ const CIRCUIT_BREAKER_THRESHOLD = 3;
347
+ export async function writeWatchdogFailedMarker(teamName, cwd, reason) {
348
+ const { writeFile } = await import('fs/promises');
349
+ const marker = {
350
+ failedAt: Date.now(),
351
+ reason,
352
+ writtenBy: 'runtime-v2',
353
+ };
354
+ const root = absPath(cwd, TeamPaths.root(sanitizeTeamName(teamName)));
355
+ const markerPath = join(root, 'watchdog-failed.json');
356
+ await mkdir(root, { recursive: true });
357
+ await writeFile(markerPath, JSON.stringify(marker, null, 2), 'utf-8');
358
+ }
359
+ /**
360
+ * Circuit breaker context for tracking consecutive monitor failures.
361
+ * The caller (runtime-cli v2 loop) should call recordSuccess on each
362
+ * successful monitor cycle and recordFailure on each error. When the
363
+ * threshold is reached, the breaker trips and writes watchdog-failed.json.
364
+ */
365
+ export class CircuitBreakerV2 {
366
+ teamName;
367
+ cwd;
368
+ threshold;
369
+ consecutiveFailures = 0;
370
+ tripped = false;
371
+ constructor(teamName, cwd, threshold = CIRCUIT_BREAKER_THRESHOLD) {
372
+ this.teamName = teamName;
373
+ this.cwd = cwd;
374
+ this.threshold = threshold;
375
+ }
376
+ recordSuccess() {
377
+ this.consecutiveFailures = 0;
378
+ }
379
+ async recordFailure(reason) {
380
+ this.consecutiveFailures++;
381
+ if (this.consecutiveFailures >= this.threshold && !this.tripped) {
382
+ this.tripped = true;
383
+ await writeWatchdogFailedMarker(this.teamName, this.cwd, reason);
384
+ return true; // breaker tripped
385
+ }
386
+ return false;
387
+ }
388
+ isTripped() {
389
+ return this.tripped;
390
+ }
391
+ }
392
+ // ---------------------------------------------------------------------------
393
+ // Failure sidecars — requeue tasks from dead workers
394
+ // ---------------------------------------------------------------------------
395
+ /**
396
+ * Requeue tasks from dead workers by writing failure sidecars and resetting
397
+ * task status back to pending so they can be claimed by other workers.
398
+ */
399
+ export async function requeueDeadWorkerTasks(teamName, deadWorkerNames, cwd) {
400
+ const sanitized = sanitizeTeamName(teamName);
401
+ const tasks = await listTasksFromFiles(sanitized, cwd);
402
+ const requeued = [];
403
+ const deadSet = new Set(deadWorkerNames);
404
+ for (const task of tasks) {
405
+ if (task.status !== 'in_progress')
406
+ continue;
407
+ if (!task.owner || !deadSet.has(task.owner))
408
+ continue;
409
+ // Write failure sidecar
410
+ const sidecarPath = absPath(cwd, `${TeamPaths.tasks(sanitized)}/${task.id}.failure.json`);
411
+ const sidecar = {
412
+ taskId: task.id,
413
+ lastError: `worker_dead:${task.owner}`,
414
+ retryCount: 0,
415
+ lastFailedAt: new Date().toISOString(),
416
+ };
417
+ const { writeFile } = await import('fs/promises');
418
+ await mkdir(absPath(cwd, TeamPaths.tasks(sanitized)), { recursive: true });
419
+ await writeFile(sidecarPath, JSON.stringify(sidecar, null, 2), 'utf-8');
420
+ // Reset task to pending (clear owner and claim)
421
+ const taskPath = absPath(cwd, TeamPaths.taskFile(sanitized, task.id));
422
+ try {
423
+ const raw = await import('fs/promises').then(fs => fs.readFile(taskPath, 'utf-8'));
424
+ const taskData = JSON.parse(raw);
425
+ taskData.status = 'pending';
426
+ taskData.owner = undefined;
427
+ taskData.claim = undefined;
428
+ await writeFile(taskPath, JSON.stringify(taskData, null, 2), 'utf-8');
429
+ requeued.push(task.id);
430
+ }
431
+ catch {
432
+ // Task file may have been removed; skip
433
+ }
434
+ await appendTeamEvent(sanitized, {
435
+ type: 'team_leader_nudge',
436
+ worker: 'leader-fixed',
437
+ task_id: task.id,
438
+ reason: `requeue_dead_worker:${task.owner}`,
439
+ }, cwd).catch(() => { });
440
+ }
441
+ return requeued;
442
+ }
443
+ // ---------------------------------------------------------------------------
444
+ // monitorTeam — snapshot-based, event-driven (no watchdog)
445
+ // ---------------------------------------------------------------------------
446
+ /**
447
+ * Take a single monitor snapshot of team state.
448
+ * Caller drives the loop (e.g., runtime-cli poll interval or event trigger).
449
+ */
450
+ export async function monitorTeamV2(teamName, cwd) {
451
+ const monitorStartMs = performance.now();
452
+ const sanitized = sanitizeTeamName(teamName);
453
+ const config = await readTeamConfig(sanitized, cwd);
454
+ if (!config)
455
+ return null;
456
+ const previousSnapshot = await readMonitorSnapshot(sanitized, cwd);
457
+ // Load all tasks
458
+ const listTasksStartMs = performance.now();
459
+ const allTasks = await listTasksFromFiles(sanitized, cwd);
460
+ const listTasksMs = performance.now() - listTasksStartMs;
461
+ const taskById = new Map(allTasks.map((task) => [task.id, task]));
462
+ const inProgressByOwner = new Map();
463
+ for (const task of allTasks) {
464
+ if (task.status !== 'in_progress' || !task.owner)
465
+ continue;
466
+ const existing = inProgressByOwner.get(task.owner) || [];
467
+ existing.push(task);
468
+ inProgressByOwner.set(task.owner, existing);
469
+ }
470
+ // Scan workers
471
+ const workers = [];
472
+ const deadWorkers = [];
473
+ const nonReportingWorkers = [];
474
+ const recommendations = [];
475
+ const workerScanStartMs = performance.now();
476
+ const workerSignals = await Promise.all(config.workers.map(async (worker) => {
477
+ const alive = await isWorkerPaneAlive(worker.pane_id);
478
+ const [status, heartbeat] = await Promise.all([
479
+ readWorkerStatus(sanitized, worker.name, cwd),
480
+ readWorkerHeartbeat(sanitized, worker.name, cwd),
481
+ ]);
482
+ return { worker, alive, status, heartbeat };
483
+ }));
484
+ const workerScanMs = performance.now() - workerScanStartMs;
485
+ for (const { worker: w, alive, status, heartbeat } of workerSignals) {
486
+ const currentTask = status.current_task_id ? taskById.get(status.current_task_id) ?? null : null;
487
+ const previousTurns = previousSnapshot ? (previousSnapshot.workerTurnCountByName[w.name] ?? 0) : null;
488
+ const previousTaskId = previousSnapshot?.workerTaskIdByName[w.name] ?? '';
489
+ const currentTaskId = status.current_task_id ?? '';
490
+ const turnsWithoutProgress = heartbeat &&
491
+ previousTurns !== null &&
492
+ status.state === 'working' &&
493
+ currentTask &&
494
+ (currentTask.status === 'pending' || currentTask.status === 'in_progress') &&
495
+ currentTaskId !== '' &&
496
+ previousTaskId === currentTaskId
497
+ ? Math.max(0, heartbeat.turn_count - previousTurns)
498
+ : 0;
499
+ workers.push({
500
+ name: w.name,
501
+ alive,
502
+ status,
503
+ heartbeat,
504
+ assignedTasks: w.assigned_tasks,
505
+ turnsWithoutProgress,
506
+ });
507
+ if (!alive) {
508
+ deadWorkers.push(w.name);
509
+ const deadWorkerTasks = inProgressByOwner.get(w.name) || [];
510
+ for (const t of deadWorkerTasks) {
511
+ recommendations.push(`Reassign task-${t.id} from dead ${w.name}`);
512
+ }
513
+ }
514
+ if (alive && turnsWithoutProgress > 5) {
515
+ nonReportingWorkers.push(w.name);
516
+ recommendations.push(`Send reminder to non-reporting ${w.name}`);
517
+ }
518
+ }
519
+ // Count tasks
520
+ const taskCounts = {
521
+ total: allTasks.length,
522
+ pending: allTasks.filter((t) => t.status === 'pending').length,
523
+ blocked: allTasks.filter((t) => t.status === 'blocked').length,
524
+ in_progress: allTasks.filter((t) => t.status === 'in_progress').length,
525
+ completed: allTasks.filter((t) => t.status === 'completed').length,
526
+ failed: allTasks.filter((t) => t.status === 'failed').length,
527
+ };
528
+ const allTasksTerminal = taskCounts.pending === 0 && taskCounts.blocked === 0 && taskCounts.in_progress === 0;
529
+ // Infer phase from task distribution
530
+ const phase = inferPhase(allTasks.map((t) => ({
531
+ status: t.status,
532
+ metadata: undefined,
533
+ })));
534
+ // Emit monitor-derived events (task completions, worker state changes)
535
+ await emitMonitorDerivedEvents(sanitized, allTasks, workers.map((w) => ({ name: w.name, alive: w.alive, status: w.status })), previousSnapshot, cwd);
536
+ // Persist snapshot for next cycle
537
+ const updatedAt = new Date().toISOString();
538
+ const totalMs = performance.now() - monitorStartMs;
539
+ await writeMonitorSnapshot(sanitized, {
540
+ taskStatusById: Object.fromEntries(allTasks.map((t) => [t.id, t.status])),
541
+ workerAliveByName: Object.fromEntries(workers.map((w) => [w.name, w.alive])),
542
+ workerStateByName: Object.fromEntries(workers.map((w) => [w.name, w.status.state])),
543
+ workerTurnCountByName: Object.fromEntries(workers.map((w) => [w.name, w.heartbeat?.turn_count ?? 0])),
544
+ workerTaskIdByName: Object.fromEntries(workers.map((w) => [w.name, w.status.current_task_id ?? ''])),
545
+ mailboxNotifiedByMessageId: previousSnapshot?.mailboxNotifiedByMessageId ?? {},
546
+ completedEventTaskIds: previousSnapshot?.completedEventTaskIds ?? {},
547
+ monitorTimings: {
548
+ list_tasks_ms: Number(listTasksMs.toFixed(2)),
549
+ worker_scan_ms: Number(workerScanMs.toFixed(2)),
550
+ mailbox_delivery_ms: 0,
551
+ total_ms: Number(totalMs.toFixed(2)),
552
+ updated_at: updatedAt,
553
+ },
554
+ }, cwd);
555
+ return {
556
+ teamName: sanitized,
557
+ phase,
558
+ workers,
559
+ tasks: {
560
+ ...taskCounts,
561
+ items: allTasks,
562
+ },
563
+ allTasksTerminal,
564
+ deadWorkers,
565
+ nonReportingWorkers,
566
+ recommendations,
567
+ performance: {
568
+ list_tasks_ms: Number(listTasksMs.toFixed(2)),
569
+ worker_scan_ms: Number(workerScanMs.toFixed(2)),
570
+ total_ms: Number(totalMs.toFixed(2)),
571
+ updated_at: updatedAt,
572
+ },
573
+ };
574
+ }
575
+ // ---------------------------------------------------------------------------
576
+ // shutdownTeam — graceful shutdown with gate, ack, force kill
577
+ // ---------------------------------------------------------------------------
578
+ /**
579
+ * Graceful team shutdown:
580
+ * 1. Shutdown gate check (unless force)
581
+ * 2. Send shutdown request to all workers via inbox
582
+ * 3. Wait for ack or timeout
583
+ * 4. Force kill remaining tmux panes
584
+ * 5. Clean up state
585
+ */
586
+ export async function shutdownTeamV2(teamName, cwd, options = {}) {
587
+ const force = options.force === true;
588
+ const ralph = options.ralph === true;
589
+ const timeoutMs = options.timeoutMs ?? 15_000;
590
+ const sanitized = sanitizeTeamName(teamName);
591
+ const config = await readTeamConfig(sanitized, cwd);
592
+ if (!config) {
593
+ // No config available; only clean state. We intentionally avoid guessing
594
+ // a tmux session name here to prevent accidental self-session termination.
595
+ await cleanupTeamState(sanitized, cwd);
596
+ return;
597
+ }
598
+ // 1. Shutdown gate check
599
+ if (!force) {
600
+ const allTasks = await listTasksFromFiles(sanitized, cwd);
601
+ const gate = {
602
+ total: allTasks.length,
603
+ pending: allTasks.filter((t) => t.status === 'pending').length,
604
+ blocked: allTasks.filter((t) => t.status === 'blocked').length,
605
+ in_progress: allTasks.filter((t) => t.status === 'in_progress').length,
606
+ completed: allTasks.filter((t) => t.status === 'completed').length,
607
+ failed: allTasks.filter((t) => t.status === 'failed').length,
608
+ allowed: false,
609
+ };
610
+ gate.allowed = gate.pending === 0 && gate.blocked === 0 && gate.in_progress === 0 && gate.failed === 0;
611
+ await appendTeamEvent(sanitized, {
612
+ type: 'shutdown_gate',
613
+ worker: 'leader-fixed',
614
+ reason: `allowed=${gate.allowed} total=${gate.total} pending=${gate.pending} blocked=${gate.blocked} in_progress=${gate.in_progress} completed=${gate.completed} failed=${gate.failed}${ralph ? ' policy=ralph' : ''}`,
615
+ }, cwd).catch(() => { });
616
+ if (!gate.allowed) {
617
+ const hasActiveWork = gate.pending > 0 || gate.blocked > 0 || gate.in_progress > 0;
618
+ if (ralph && !hasActiveWork) {
619
+ // Ralph policy: bypass on failure-only scenarios
620
+ await appendTeamEvent(sanitized, {
621
+ type: 'team_leader_nudge',
622
+ worker: 'leader-fixed',
623
+ reason: `gate_bypassed:pending=${gate.pending},blocked=${gate.blocked},in_progress=${gate.in_progress},failed=${gate.failed}`,
624
+ }, cwd).catch(() => { });
625
+ }
626
+ else {
627
+ throw new Error(`shutdown_gate_blocked:pending=${gate.pending},blocked=${gate.blocked},in_progress=${gate.in_progress},failed=${gate.failed}`);
628
+ }
629
+ }
630
+ }
631
+ if (force) {
632
+ await appendTeamEvent(sanitized, {
633
+ type: 'shutdown_gate_forced',
634
+ worker: 'leader-fixed',
635
+ reason: 'force_bypass',
636
+ }, cwd).catch(() => { });
637
+ }
638
+ // 2. Send shutdown request to each worker
639
+ const shutdownRequestTimes = new Map();
640
+ for (const w of config.workers) {
641
+ try {
642
+ const requestedAt = new Date().toISOString();
643
+ await writeShutdownRequest(sanitized, w.name, 'leader-fixed', cwd);
644
+ shutdownRequestTimes.set(w.name, requestedAt);
645
+ // Write shutdown inbox
646
+ const shutdownInbox = `# Shutdown Request\n\nAll tasks are complete. Please wrap up and respond with a shutdown acknowledgement.\n\nWrite your ack to: ${TeamPaths.shutdownAck(sanitized, w.name)}\nFormat: {"status":"accept","reason":"ok","updated_at":"<iso>"}\n\nThen exit your session.\n`;
647
+ await writeWorkerInbox(sanitized, w.name, shutdownInbox, cwd);
648
+ }
649
+ catch (err) {
650
+ process.stderr.write(`[team/runtime-v2] shutdown request failed for ${w.name}: ${err}\n`);
651
+ }
652
+ }
653
+ // 3. Wait for ack or timeout
654
+ const deadline = Date.now() + timeoutMs;
655
+ const rejected = [];
656
+ const ackedWorkers = new Set();
657
+ while (Date.now() < deadline) {
658
+ for (const w of config.workers) {
659
+ if (ackedWorkers.has(w.name))
660
+ continue;
661
+ const ack = await readShutdownAck(sanitized, w.name, cwd, shutdownRequestTimes.get(w.name));
662
+ if (ack) {
663
+ ackedWorkers.add(w.name);
664
+ await appendTeamEvent(sanitized, {
665
+ type: 'shutdown_ack',
666
+ worker: w.name,
667
+ reason: ack.status === 'reject' ? `reject:${ack.reason || 'no_reason'}` : 'accept',
668
+ }, cwd).catch(() => { });
669
+ if (ack.status === 'reject') {
670
+ rejected.push({ worker: w.name, reason: ack.reason || 'no_reason' });
671
+ }
672
+ }
673
+ }
674
+ if (rejected.length > 0 && !force) {
675
+ const detail = rejected.map((r) => `${r.worker}:${r.reason}`).join(',');
676
+ throw new Error(`shutdown_rejected:${detail}`);
677
+ }
678
+ // Check if all workers have acked or exited
679
+ const allDone = config.workers.every((w) => ackedWorkers.has(w.name));
680
+ if (allDone)
681
+ break;
682
+ await new Promise((r) => setTimeout(r, 2_000));
683
+ }
684
+ // 4. Force kill remaining tmux panes
685
+ try {
686
+ const { killWorkerPanes, killTeamSession } = await import('./tmux-session.js');
687
+ const workerPaneIds = config.workers
688
+ .map((w) => w.pane_id)
689
+ .filter((p) => typeof p === 'string' && p.trim().length > 0);
690
+ await killWorkerPanes({
691
+ paneIds: workerPaneIds,
692
+ leaderPaneId: config.leader_pane_id ?? undefined,
693
+ teamName: sanitized,
694
+ cwd,
695
+ });
696
+ // Destroy tmux session if it's a standalone session
697
+ if (config.tmux_session && !config.tmux_session.includes(':')) {
698
+ await killTeamSession(config.tmux_session, [], undefined);
699
+ }
700
+ }
701
+ catch (err) {
702
+ process.stderr.write(`[team/runtime-v2] tmux cleanup: ${err}\n`);
703
+ }
704
+ // 5. Ralph completion logging
705
+ if (ralph) {
706
+ const finalTasks = await listTasksFromFiles(sanitized, cwd).catch(() => []);
707
+ const completed = finalTasks.filter((t) => t.status === 'completed').length;
708
+ const failed = finalTasks.filter((t) => t.status === 'failed').length;
709
+ const pending = finalTasks.filter((t) => t.status === 'pending').length;
710
+ await appendTeamEvent(sanitized, {
711
+ type: 'team_leader_nudge',
712
+ worker: 'leader-fixed',
713
+ reason: `ralph_cleanup_summary: total=${finalTasks.length} completed=${completed} failed=${failed} pending=${pending} force=${force}`,
714
+ }, cwd).catch(() => { });
715
+ }
716
+ // 6. Clean up state
717
+ await cleanupTeamState(sanitized, cwd);
718
+ }
719
+ // ---------------------------------------------------------------------------
720
+ // resumeTeam — reconstruct runtime from persisted state
721
+ // ---------------------------------------------------------------------------
722
+ export async function resumeTeamV2(teamName, cwd) {
723
+ const sanitized = sanitizeTeamName(teamName);
724
+ const config = await readTeamConfig(sanitized, cwd);
725
+ if (!config)
726
+ return null;
727
+ // Verify tmux session is alive
728
+ try {
729
+ const { execFile } = await import('child_process');
730
+ const { promisify } = await import('util');
731
+ const execFileAsync = promisify(execFile);
732
+ const sessionName = config.tmux_session || `omc-team-${sanitized}`;
733
+ await execFileAsync('tmux', ['has-session', '-t', sessionName.split(':')[0]]);
734
+ return {
735
+ teamName: sanitized,
736
+ sanitizedName: sanitized,
737
+ sessionName,
738
+ config,
739
+ cwd,
740
+ };
741
+ }
742
+ catch {
743
+ return null; // Session not alive
744
+ }
745
+ }
746
+ // ---------------------------------------------------------------------------
747
+ // findActiveTeams — discover running teams
748
+ // ---------------------------------------------------------------------------
749
+ export async function findActiveTeamsV2(cwd) {
750
+ const root = join(cwd, '.omc', 'state', 'team');
751
+ if (!existsSync(root))
752
+ return [];
753
+ const entries = await readdir(root, { withFileTypes: true });
754
+ const active = [];
755
+ for (const e of entries) {
756
+ if (!e.isDirectory())
757
+ continue;
758
+ const teamName = e.name;
759
+ const config = await readTeamConfig(teamName, cwd);
760
+ if (config) {
761
+ active.push(teamName);
762
+ }
763
+ }
764
+ return active;
765
+ }
766
+ //# sourceMappingURL=runtime-v2.js.map