zero-workspace 0.0.2

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 (507) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/README.md +187 -0
  3. package/config/component-versions.json +16 -0
  4. package/config/scenarioCapabilities.json +29 -0
  5. package/config/version-notes.yaml +244 -0
  6. package/dist/adapters/OutputAdapter.d.ts +79 -0
  7. package/dist/adapters/OutputAdapter.d.ts.map +1 -0
  8. package/dist/adapters/OutputAdapter.js +124 -0
  9. package/dist/adapters/OutputAdapter.js.map +1 -0
  10. package/dist/cli/check-node-version.d.ts +3 -0
  11. package/dist/cli/check-node-version.d.ts.map +1 -0
  12. package/dist/cli/check-node-version.js +153 -0
  13. package/dist/cli/check-node-version.js.map +1 -0
  14. package/dist/cli/plugins.d.ts +41 -0
  15. package/dist/cli/plugins.d.ts.map +1 -0
  16. package/dist/cli/plugins.js +742 -0
  17. package/dist/cli/plugins.js.map +1 -0
  18. package/dist/cli/rebuild.d.ts +63 -0
  19. package/dist/cli/rebuild.d.ts.map +1 -0
  20. package/dist/cli/rebuild.js +989 -0
  21. package/dist/cli/rebuild.js.map +1 -0
  22. package/dist/cli/repair.d.ts +7 -0
  23. package/dist/cli/repair.d.ts.map +1 -0
  24. package/dist/cli/repair.js +925 -0
  25. package/dist/cli/repair.js.map +1 -0
  26. package/dist/cli/setup.d.ts +7 -0
  27. package/dist/cli/setup.d.ts.map +1 -0
  28. package/dist/cli/setup.js +452 -0
  29. package/dist/cli/setup.js.map +1 -0
  30. package/dist/cli/update.d.ts +10 -0
  31. package/dist/cli/update.d.ts.map +1 -0
  32. package/dist/cli/update.js +426 -0
  33. package/dist/cli/update.js.map +1 -0
  34. package/dist/cli/webui.d.ts +6 -0
  35. package/dist/cli/webui.d.ts.map +1 -0
  36. package/dist/cli/webui.js +210 -0
  37. package/dist/cli/webui.js.map +1 -0
  38. package/dist/http/index.d.ts +3 -0
  39. package/dist/http/index.d.ts.map +1 -0
  40. package/dist/http/index.js +15 -0
  41. package/dist/http/index.js.map +1 -0
  42. package/dist/http/middleware/errorHandler.d.ts +16 -0
  43. package/dist/http/middleware/errorHandler.d.ts.map +1 -0
  44. package/dist/http/middleware/errorHandler.js +79 -0
  45. package/dist/http/middleware/errorHandler.js.map +1 -0
  46. package/dist/http/routes/admin.d.ts +3 -0
  47. package/dist/http/routes/admin.d.ts.map +1 -0
  48. package/dist/http/routes/admin.js +730 -0
  49. package/dist/http/routes/admin.js.map +1 -0
  50. package/dist/http/routes/backup.d.ts +3 -0
  51. package/dist/http/routes/backup.d.ts.map +1 -0
  52. package/dist/http/routes/backup.js +172 -0
  53. package/dist/http/routes/backup.js.map +1 -0
  54. package/dist/http/routes/config.d.ts +3 -0
  55. package/dist/http/routes/config.d.ts.map +1 -0
  56. package/dist/http/routes/config.js +157 -0
  57. package/dist/http/routes/config.js.map +1 -0
  58. package/dist/http/routes/context.d.ts +3 -0
  59. package/dist/http/routes/context.d.ts.map +1 -0
  60. package/dist/http/routes/context.js +82 -0
  61. package/dist/http/routes/context.js.map +1 -0
  62. package/dist/http/routes/log.d.ts +3 -0
  63. package/dist/http/routes/log.d.ts.map +1 -0
  64. package/dist/http/routes/log.js +105 -0
  65. package/dist/http/routes/log.js.map +1 -0
  66. package/dist/http/routes/memo.d.ts +6 -0
  67. package/dist/http/routes/memo.d.ts.map +1 -0
  68. package/dist/http/routes/memo.js +29 -0
  69. package/dist/http/routes/memo.js.map +1 -0
  70. package/dist/http/routes/node.d.ts +3 -0
  71. package/dist/http/routes/node.d.ts.map +1 -0
  72. package/dist/http/routes/node.js +251 -0
  73. package/dist/http/routes/node.js.map +1 -0
  74. package/dist/http/routes/state.d.ts +3 -0
  75. package/dist/http/routes/state.d.ts.map +1 -0
  76. package/dist/http/routes/state.js +48 -0
  77. package/dist/http/routes/state.js.map +1 -0
  78. package/dist/http/routes/workspace.d.ts +3 -0
  79. package/dist/http/routes/workspace.d.ts.map +1 -0
  80. package/dist/http/routes/workspace.js +249 -0
  81. package/dist/http/routes/workspace.js.map +1 -0
  82. package/dist/http/server.d.ts +10 -0
  83. package/dist/http/server.d.ts.map +1 -0
  84. package/dist/http/server.js +284 -0
  85. package/dist/http/server.js.map +1 -0
  86. package/dist/http/services.d.ts +93 -0
  87. package/dist/http/services.d.ts.map +1 -0
  88. package/dist/http/services.js +297 -0
  89. package/dist/http/services.js.map +1 -0
  90. package/dist/index.d.ts +3 -0
  91. package/dist/index.d.ts.map +1 -0
  92. package/dist/index.js +1073 -0
  93. package/dist/index.js.map +1 -0
  94. package/dist/prompts/guidanceContent.d.ts +18 -0
  95. package/dist/prompts/guidanceContent.d.ts.map +1 -0
  96. package/dist/prompts/guidanceContent.js +814 -0
  97. package/dist/prompts/guidanceContent.js.map +1 -0
  98. package/dist/prompts/index.d.ts +2 -0
  99. package/dist/prompts/index.d.ts.map +1 -0
  100. package/dist/prompts/index.js +4 -0
  101. package/dist/prompts/index.js.map +1 -0
  102. package/dist/prompts/instructions.d.ts +56 -0
  103. package/dist/prompts/instructions.d.ts.map +1 -0
  104. package/dist/prompts/instructions.js +1343 -0
  105. package/dist/prompts/instructions.js.map +1 -0
  106. package/dist/services/BackupService.d.ts +104 -0
  107. package/dist/services/BackupService.d.ts.map +1 -0
  108. package/dist/services/BackupService.js +549 -0
  109. package/dist/services/BackupService.js.map +1 -0
  110. package/dist/services/CapabilityService.d.ts +38 -0
  111. package/dist/services/CapabilityService.d.ts.map +1 -0
  112. package/dist/services/CapabilityService.js +256 -0
  113. package/dist/services/CapabilityService.js.map +1 -0
  114. package/dist/services/ConfigService.d.ts +35 -0
  115. package/dist/services/ConfigService.d.ts.map +1 -0
  116. package/dist/services/ConfigService.js +105 -0
  117. package/dist/services/ConfigService.js.map +1 -0
  118. package/dist/services/ContextService.d.ts +65 -0
  119. package/dist/services/ContextService.d.ts.map +1 -0
  120. package/dist/services/ContextService.js +503 -0
  121. package/dist/services/ContextService.js.map +1 -0
  122. package/dist/services/DetectionService.d.ts +76 -0
  123. package/dist/services/DetectionService.d.ts.map +1 -0
  124. package/dist/services/DetectionService.js +262 -0
  125. package/dist/services/DetectionService.js.map +1 -0
  126. package/dist/services/DispatchService.d.ts +267 -0
  127. package/dist/services/DispatchService.d.ts.map +1 -0
  128. package/dist/services/DispatchService.js +1357 -0
  129. package/dist/services/DispatchService.js.map +1 -0
  130. package/dist/services/EventService.d.ts +81 -0
  131. package/dist/services/EventService.d.ts.map +1 -0
  132. package/dist/services/EventService.js +187 -0
  133. package/dist/services/EventService.js.map +1 -0
  134. package/dist/services/GuidanceService.d.ts +64 -0
  135. package/dist/services/GuidanceService.d.ts.map +1 -0
  136. package/dist/services/GuidanceService.js +259 -0
  137. package/dist/services/GuidanceService.js.map +1 -0
  138. package/dist/services/HealthService.d.ts +43 -0
  139. package/dist/services/HealthService.d.ts.map +1 -0
  140. package/dist/services/HealthService.js +276 -0
  141. package/dist/services/HealthService.js.map +1 -0
  142. package/dist/services/InstallationService.d.ts +62 -0
  143. package/dist/services/InstallationService.d.ts.map +1 -0
  144. package/dist/services/InstallationService.js +204 -0
  145. package/dist/services/InstallationService.js.map +1 -0
  146. package/dist/services/LogService.d.ts +35 -0
  147. package/dist/services/LogService.d.ts.map +1 -0
  148. package/dist/services/LogService.js +189 -0
  149. package/dist/services/LogService.js.map +1 -0
  150. package/dist/services/MemoService.d.ts +39 -0
  151. package/dist/services/MemoService.d.ts.map +1 -0
  152. package/dist/services/MemoService.js +288 -0
  153. package/dist/services/MemoService.js.map +1 -0
  154. package/dist/services/NodeService.d.ts +90 -0
  155. package/dist/services/NodeService.d.ts.map +1 -0
  156. package/dist/services/NodeService.js +958 -0
  157. package/dist/services/NodeService.js.map +1 -0
  158. package/dist/services/OpenSpecParser.d.ts +43 -0
  159. package/dist/services/OpenSpecParser.d.ts.map +1 -0
  160. package/dist/services/OpenSpecParser.js +191 -0
  161. package/dist/services/OpenSpecParser.js.map +1 -0
  162. package/dist/services/ReferenceService.d.ts +35 -0
  163. package/dist/services/ReferenceService.d.ts.map +1 -0
  164. package/dist/services/ReferenceService.js +195 -0
  165. package/dist/services/ReferenceService.js.map +1 -0
  166. package/dist/services/RepairService.d.ts +36 -0
  167. package/dist/services/RepairService.d.ts.map +1 -0
  168. package/dist/services/RepairService.js +429 -0
  169. package/dist/services/RepairService.js.map +1 -0
  170. package/dist/services/SearchService.d.ts +34 -0
  171. package/dist/services/SearchService.d.ts.map +1 -0
  172. package/dist/services/SearchService.js +293 -0
  173. package/dist/services/SearchService.js.map +1 -0
  174. package/dist/services/SessionService.d.ts +136 -0
  175. package/dist/services/SessionService.d.ts.map +1 -0
  176. package/dist/services/SessionService.js +297 -0
  177. package/dist/services/SessionService.js.map +1 -0
  178. package/dist/services/StateService.d.ts +97 -0
  179. package/dist/services/StateService.d.ts.map +1 -0
  180. package/dist/services/StateService.js +846 -0
  181. package/dist/services/StateService.js.map +1 -0
  182. package/dist/services/TutorialService.d.ts +114 -0
  183. package/dist/services/TutorialService.d.ts.map +1 -0
  184. package/dist/services/TutorialService.js +1262 -0
  185. package/dist/services/TutorialService.js.map +1 -0
  186. package/dist/services/WorkspaceService.d.ts +273 -0
  187. package/dist/services/WorkspaceService.d.ts.map +1 -0
  188. package/dist/services/WorkspaceService.js +1764 -0
  189. package/dist/services/WorkspaceService.js.map +1 -0
  190. package/dist/services/index.d.ts +15 -0
  191. package/dist/services/index.d.ts.map +1 -0
  192. package/dist/services/index.js +14 -0
  193. package/dist/services/index.js.map +1 -0
  194. package/dist/storage/FileSystemAdapter.d.ts +223 -0
  195. package/dist/storage/FileSystemAdapter.d.ts.map +1 -0
  196. package/dist/storage/FileSystemAdapter.js +384 -0
  197. package/dist/storage/FileSystemAdapter.js.map +1 -0
  198. package/dist/storage/JsonStorage.d.ts +158 -0
  199. package/dist/storage/JsonStorage.d.ts.map +1 -0
  200. package/dist/storage/JsonStorage.js +613 -0
  201. package/dist/storage/JsonStorage.js.map +1 -0
  202. package/dist/storage/MarkdownStorage.d.ts +178 -0
  203. package/dist/storage/MarkdownStorage.d.ts.map +1 -0
  204. package/dist/storage/MarkdownStorage.js +918 -0
  205. package/dist/storage/MarkdownStorage.js.map +1 -0
  206. package/dist/storage/SessionBindingStorage.d.ts +69 -0
  207. package/dist/storage/SessionBindingStorage.d.ts.map +1 -0
  208. package/dist/storage/SessionBindingStorage.js +131 -0
  209. package/dist/storage/SessionBindingStorage.js.map +1 -0
  210. package/dist/storage/index.d.ts +6 -0
  211. package/dist/storage/index.d.ts.map +1 -0
  212. package/dist/storage/index.js +6 -0
  213. package/dist/storage/index.js.map +1 -0
  214. package/dist/tools/capability.d.ts +18 -0
  215. package/dist/tools/capability.d.ts.map +1 -0
  216. package/dist/tools/capability.js +73 -0
  217. package/dist/tools/capability.js.map +1 -0
  218. package/dist/tools/config.d.ts +14 -0
  219. package/dist/tools/config.d.ts.map +1 -0
  220. package/dist/tools/config.js +61 -0
  221. package/dist/tools/config.js.map +1 -0
  222. package/dist/tools/context.d.ts +22 -0
  223. package/dist/tools/context.d.ts.map +1 -0
  224. package/dist/tools/context.js +139 -0
  225. package/dist/tools/context.js.map +1 -0
  226. package/dist/tools/dispatch.d.ts +41 -0
  227. package/dist/tools/dispatch.d.ts.map +1 -0
  228. package/dist/tools/dispatch.js +380 -0
  229. package/dist/tools/dispatch.js.map +1 -0
  230. package/dist/tools/help.d.ts +44 -0
  231. package/dist/tools/help.d.ts.map +1 -0
  232. package/dist/tools/help.js +227 -0
  233. package/dist/tools/help.js.map +1 -0
  234. package/dist/tools/import.d.ts +17 -0
  235. package/dist/tools/import.d.ts.map +1 -0
  236. package/dist/tools/import.js +96 -0
  237. package/dist/tools/import.js.map +1 -0
  238. package/dist/tools/index.d.ts +12 -0
  239. package/dist/tools/index.d.ts.map +1 -0
  240. package/dist/tools/index.js +13 -0
  241. package/dist/tools/index.js.map +1 -0
  242. package/dist/tools/log.d.ts +21 -0
  243. package/dist/tools/log.d.ts.map +1 -0
  244. package/dist/tools/log.js +93 -0
  245. package/dist/tools/log.js.map +1 -0
  246. package/dist/tools/memo.d.ts +26 -0
  247. package/dist/tools/memo.d.ts.map +1 -0
  248. package/dist/tools/memo.js +188 -0
  249. package/dist/tools/memo.js.map +1 -0
  250. package/dist/tools/node.d.ts +34 -0
  251. package/dist/tools/node.d.ts.map +1 -0
  252. package/dist/tools/node.js +328 -0
  253. package/dist/tools/node.js.map +1 -0
  254. package/dist/tools/search.d.ts +14 -0
  255. package/dist/tools/search.d.ts.map +1 -0
  256. package/dist/tools/search.js +95 -0
  257. package/dist/tools/search.js.map +1 -0
  258. package/dist/tools/session.d.ts +22 -0
  259. package/dist/tools/session.d.ts.map +1 -0
  260. package/dist/tools/session.js +127 -0
  261. package/dist/tools/session.js.map +1 -0
  262. package/dist/tools/state.d.ts +10 -0
  263. package/dist/tools/state.d.ts.map +1 -0
  264. package/dist/tools/state.js +79 -0
  265. package/dist/tools/state.js.map +1 -0
  266. package/dist/tools/workspace.d.ts +38 -0
  267. package/dist/tools/workspace.d.ts.map +1 -0
  268. package/dist/tools/workspace.js +240 -0
  269. package/dist/tools/workspace.js.map +1 -0
  270. package/dist/types/capability.d.ts +36 -0
  271. package/dist/types/capability.d.ts.map +1 -0
  272. package/dist/types/capability.js +3 -0
  273. package/dist/types/capability.js.map +1 -0
  274. package/dist/types/confirmation.d.ts +35 -0
  275. package/dist/types/confirmation.d.ts.map +1 -0
  276. package/dist/types/confirmation.js +3 -0
  277. package/dist/types/confirmation.js.map +1 -0
  278. package/dist/types/context.d.ts +174 -0
  279. package/dist/types/context.d.ts.map +1 -0
  280. package/dist/types/context.js +3 -0
  281. package/dist/types/context.js.map +1 -0
  282. package/dist/types/errors.d.ts +81 -0
  283. package/dist/types/errors.d.ts.map +1 -0
  284. package/dist/types/errors.js +154 -0
  285. package/dist/types/errors.js.map +1 -0
  286. package/dist/types/guidance.d.ts +162 -0
  287. package/dist/types/guidance.d.ts.map +1 -0
  288. package/dist/types/guidance.js +4 -0
  289. package/dist/types/guidance.js.map +1 -0
  290. package/dist/types/health.d.ts +61 -0
  291. package/dist/types/health.d.ts.map +1 -0
  292. package/dist/types/health.js +3 -0
  293. package/dist/types/health.js.map +1 -0
  294. package/dist/types/index.d.ts +10 -0
  295. package/dist/types/index.d.ts.map +1 -0
  296. package/dist/types/index.js +11 -0
  297. package/dist/types/index.js.map +1 -0
  298. package/dist/types/memo.d.ts +132 -0
  299. package/dist/types/memo.d.ts.map +1 -0
  300. package/dist/types/memo.js +3 -0
  301. package/dist/types/memo.js.map +1 -0
  302. package/dist/types/node.d.ts +316 -0
  303. package/dist/types/node.d.ts.map +1 -0
  304. package/dist/types/node.js +3 -0
  305. package/dist/types/node.js.map +1 -0
  306. package/dist/types/repair.d.ts +62 -0
  307. package/dist/types/repair.d.ts.map +1 -0
  308. package/dist/types/repair.js +4 -0
  309. package/dist/types/repair.js.map +1 -0
  310. package/dist/types/search.d.ts +58 -0
  311. package/dist/types/search.d.ts.map +1 -0
  312. package/dist/types/search.js +3 -0
  313. package/dist/types/search.js.map +1 -0
  314. package/dist/types/settings.d.ts +109 -0
  315. package/dist/types/settings.d.ts.map +1 -0
  316. package/dist/types/settings.js +30 -0
  317. package/dist/types/settings.js.map +1 -0
  318. package/dist/types/workspace.d.ts +357 -0
  319. package/dist/types/workspace.d.ts.map +1 -0
  320. package/dist/types/workspace.js +3 -0
  321. package/dist/types/workspace.js.map +1 -0
  322. package/dist/utils/contentValidation.d.ts +47 -0
  323. package/dist/utils/contentValidation.d.ts.map +1 -0
  324. package/dist/utils/contentValidation.js +93 -0
  325. package/dist/utils/contentValidation.js.map +1 -0
  326. package/dist/utils/devLog.d.ts +43 -0
  327. package/dist/utils/devLog.d.ts.map +1 -0
  328. package/dist/utils/devLog.js +94 -0
  329. package/dist/utils/devLog.js.map +1 -0
  330. package/dist/utils/errorLogger.d.ts +27 -0
  331. package/dist/utils/errorLogger.d.ts.map +1 -0
  332. package/dist/utils/errorLogger.js +105 -0
  333. package/dist/utils/errorLogger.js.map +1 -0
  334. package/dist/utils/git.d.ts +123 -0
  335. package/dist/utils/git.d.ts.map +1 -0
  336. package/dist/utils/git.js +400 -0
  337. package/dist/utils/git.js.map +1 -0
  338. package/dist/utils/hash.d.ts +32 -0
  339. package/dist/utils/hash.d.ts.map +1 -0
  340. package/dist/utils/hash.js +37 -0
  341. package/dist/utils/hash.js.map +1 -0
  342. package/dist/utils/id.d.ts +54 -0
  343. package/dist/utils/id.d.ts.map +1 -0
  344. package/dist/utils/id.js +96 -0
  345. package/dist/utils/id.js.map +1 -0
  346. package/dist/utils/index.d.ts +8 -0
  347. package/dist/utils/index.d.ts.map +1 -0
  348. package/dist/utils/index.js +9 -0
  349. package/dist/utils/index.js.map +1 -0
  350. package/dist/utils/logger.d.ts +42 -0
  351. package/dist/utils/logger.d.ts.map +1 -0
  352. package/dist/utils/logger.js +228 -0
  353. package/dist/utils/logger.js.map +1 -0
  354. package/dist/utils/manualChangeFormatter.d.ts +8 -0
  355. package/dist/utils/manualChangeFormatter.d.ts.map +1 -0
  356. package/dist/utils/manualChangeFormatter.js +21 -0
  357. package/dist/utils/manualChangeFormatter.js.map +1 -0
  358. package/dist/utils/paramValidator.d.ts +35 -0
  359. package/dist/utils/paramValidator.d.ts.map +1 -0
  360. package/dist/utils/paramValidator.js +214 -0
  361. package/dist/utils/paramValidator.js.map +1 -0
  362. package/dist/utils/port.d.ts +7 -0
  363. package/dist/utils/port.d.ts.map +1 -0
  364. package/dist/utils/port.js +28 -0
  365. package/dist/utils/port.js.map +1 -0
  366. package/dist/utils/processManager.d.ts +53 -0
  367. package/dist/utils/processManager.d.ts.map +1 -0
  368. package/dist/utils/processManager.js +267 -0
  369. package/dist/utils/processManager.js.map +1 -0
  370. package/dist/utils/sessionLogger.d.ts +28 -0
  371. package/dist/utils/sessionLogger.d.ts.map +1 -0
  372. package/dist/utils/sessionLogger.js +142 -0
  373. package/dist/utils/sessionLogger.js.map +1 -0
  374. package/dist/utils/time.d.ts +15 -0
  375. package/dist/utils/time.d.ts.map +1 -0
  376. package/dist/utils/time.js +32 -0
  377. package/dist/utils/time.js.map +1 -0
  378. package/dist/utils/validation.d.ts +23 -0
  379. package/dist/utils/validation.d.ts.map +1 -0
  380. package/dist/utils/validation.js +88 -0
  381. package/dist/utils/validation.js.map +1 -0
  382. package/docs//346/227/245/345/277/227/347/263/273/347/273/237.md +389 -0
  383. package/docs//347/224/250/346/210/267/346/211/213/345/206/214.md +1446 -0
  384. package/docs//347/224/250/346/210/267/346/211/213/345/206/214/344/270/216/346/212/200/346/234/257/346/214/207/345/215/227.md +873 -0
  385. package/package.json +94 -0
  386. package/plugin/README.md +141 -0
  387. package/plugin/agents/zero-executor.md +114 -0
  388. package/plugin/agents/zero-reviewer.md +133 -0
  389. package/plugin/docs/diagnostic-guide.md +128 -0
  390. package/plugin/hooks/hooks.json.deprecated +70 -0
  391. package/plugin/scripts/cursor-hook-entry.cjs +217 -0
  392. package/plugin/scripts/hook-entry.cjs +663 -0
  393. package/plugin/scripts/openspec-import.cjs +714 -0
  394. package/plugin/scripts/shared/binding.cjs +98 -0
  395. package/plugin/scripts/shared/config.cjs +65 -0
  396. package/plugin/scripts/shared/context.cjs +120 -0
  397. package/plugin/scripts/shared/index.cjs +34 -0
  398. package/plugin/scripts/shared/logger.cjs +196 -0
  399. package/plugin/scripts/shared/reminder.cjs +261 -0
  400. package/plugin/scripts/shared/utils.cjs +62 -0
  401. package/plugin/scripts/shared/workspace.cjs +322 -0
  402. package/plugin/skills/aligning-intent/SKILL.md +275 -0
  403. package/plugin/skills/analyzing-measurements/SKILL.md +223 -0
  404. package/plugin/skills/bootstrapping-workspace/SKILL.md +260 -0
  405. package/plugin/skills/designing-solutions/SKILL.md +363 -0
  406. package/plugin/skills/diagnosing-issues/SKILL.md +219 -0
  407. package/plugin/skills/discovering-context/SKILL.md +283 -0
  408. package/plugin/skills/dispatching-parent/SKILL.md +399 -0
  409. package/plugin/skills/executing-task/SKILL.md +340 -0
  410. package/plugin/skills/memo-create/SKILL.md +222 -0
  411. package/plugin/skills/planning-verification/SKILL.md +245 -0
  412. package/plugin/skills/preparing-dispatch/SKILL.md +299 -0
  413. package/plugin/skills/researching-tech/SKILL.md +223 -0
  414. package/plugin/skills/reviewing-quality/SKILL.md +354 -0
  415. package/plugin/skills/reviewing-spec/SKILL.md +333 -0
  416. package/plugin/skills/starting-info-flow/SKILL.md +196 -0
  417. package/web/README.md +5 -0
  418. package/web/dist/assets/DocsView-Bls_Vjsr.css +1 -0
  419. package/web/dist/assets/DocsView-Cxc0B63r.js +1447 -0
  420. package/web/dist/assets/HomeView-C7df9thb.js +9 -0
  421. package/web/dist/assets/HomeView-ufUdnfHk.css +1 -0
  422. package/web/dist/assets/MarkdownContent-DXp6CtSP.js +308 -0
  423. package/web/dist/assets/MarkdownContent-NFqiOBLH.css +1 -0
  424. package/web/dist/assets/NotFoundView-BYX1oZAn.css +1 -0
  425. package/web/dist/assets/NotFoundView-zrc0lT9q.js +1 -0
  426. package/web/dist/assets/WorkspaceView-BckqgNcX.js +27 -0
  427. package/web/dist/assets/WorkspaceView-J1dgpYMx.css +1 -0
  428. package/web/dist/assets/WsConfirmDialog-C1CvL4my.css +1 -0
  429. package/web/dist/assets/WsConfirmDialog-gLEP7uBD.js +4 -0
  430. package/web/dist/assets/arc-DPkKTkUT.js +1 -0
  431. package/web/dist/assets/architectureDiagram-VXUJARFQ-CEGpqUlZ.js +36 -0
  432. package/web/dist/assets/blockDiagram-VD42YOAC-Bv-mqdQH.js +122 -0
  433. package/web/dist/assets/c4Diagram-YG6GDRKO-DRyPatZ_.js +10 -0
  434. package/web/dist/assets/channel-B84mKLDZ.js +1 -0
  435. package/web/dist/assets/chunk-4BX2VUAB-c7DivX0u.js +1 -0
  436. package/web/dist/assets/chunk-55IACEB6-CGKTaLlo.js +1 -0
  437. package/web/dist/assets/chunk-B4BG7PRW-Czhx5Q_P.js +165 -0
  438. package/web/dist/assets/chunk-DI55MBZ5-CQVA7hcZ.js +220 -0
  439. package/web/dist/assets/chunk-FMBD7UC4-hEiPmi7V.js +15 -0
  440. package/web/dist/assets/chunk-QN33PNHL-rL6yYI-E.js +1 -0
  441. package/web/dist/assets/chunk-QZHKN3VN-BRyHBBzq.js +1 -0
  442. package/web/dist/assets/chunk-TZMSLE5B-D4PXmTz9.js +1 -0
  443. package/web/dist/assets/classDiagram-2ON5EDUG-CNn53ohi.js +1 -0
  444. package/web/dist/assets/classDiagram-v2-WZHVMYZB-CNn53ohi.js +1 -0
  445. package/web/dist/assets/cose-bilkent-S5V4N54A-BAREnRga.js +1 -0
  446. package/web/dist/assets/cytoscape.esm-BnkdMOzK.js +321 -0
  447. package/web/dist/assets/dagre-6UL2VRFP-DaYzb3MT.js +4 -0
  448. package/web/dist/assets/defaultLocale-C4B-KCzX.js +1 -0
  449. package/web/dist/assets/diagram-PSM6KHXK-BFltDqvd.js +24 -0
  450. package/web/dist/assets/diagram-QEK2KX5R-CR4VU2La.js +43 -0
  451. package/web/dist/assets/diagram-S2PKOQOG-0UfIeT-1.js +24 -0
  452. package/web/dist/assets/erDiagram-Q2GNP2WA-Bo17Xmng.js +60 -0
  453. package/web/dist/assets/flowDiagram-NV44I4VS-CzqhQp8s.js +162 -0
  454. package/web/dist/assets/ganttDiagram-JELNMOA3-TXwXtUcq.js +267 -0
  455. package/web/dist/assets/gitGraphDiagram-NY62KEGX-CoFQTy9O.js +65 -0
  456. package/web/dist/assets/graph-CIQcRIVd.js +1 -0
  457. package/web/dist/assets/index-BgLd_o_M.css +1 -0
  458. package/web/dist/assets/index-Cd_J3fZn.js +30 -0
  459. package/web/dist/assets/infoDiagram-WHAUD3N6-Dq0xXfVu.js +2 -0
  460. package/web/dist/assets/init-Gi6I4Gst.js +1 -0
  461. package/web/dist/assets/journeyDiagram-XKPGCS4Q-jIg5BOfC.js +139 -0
  462. package/web/dist/assets/kanban-definition-3W4ZIXB7-D2giu6aZ.js +89 -0
  463. package/web/dist/assets/katex-XbL3y5x-.js +261 -0
  464. package/web/dist/assets/layout-Bm-XCM-8.js +1 -0
  465. package/web/dist/assets/linear-FbekP9OZ.js +1 -0
  466. package/web/dist/assets/min-BrRCpYmF.js +1 -0
  467. package/web/dist/assets/mindmap-definition-VGOIOE7T-o-4ubbY9.js +68 -0
  468. package/web/dist/assets/noto-emoji-0-400-normal-BTQbhB77.woff +0 -0
  469. package/web/dist/assets/noto-emoji-0-400-normal-DHdy6Uhy.woff2 +0 -0
  470. package/web/dist/assets/noto-emoji-1-400-normal-0IvkdXBB.woff +0 -0
  471. package/web/dist/assets/noto-emoji-1-400-normal-BY9OovbM.woff2 +0 -0
  472. package/web/dist/assets/noto-emoji-10-400-normal-D9w4QCof.woff2 +0 -0
  473. package/web/dist/assets/noto-emoji-10-400-normal-DtCumcZR.woff +0 -0
  474. package/web/dist/assets/noto-emoji-11-400-normal-BboTlyvx.woff +0 -0
  475. package/web/dist/assets/noto-emoji-12-400-normal-BB5pgBKj.woff2 +0 -0
  476. package/web/dist/assets/noto-emoji-12-400-normal-g186qhiA.woff +0 -0
  477. package/web/dist/assets/noto-emoji-2-400-normal-BKCR1azW.woff2 +0 -0
  478. package/web/dist/assets/noto-emoji-2-400-normal-BYH0KhDr.woff +0 -0
  479. package/web/dist/assets/noto-emoji-3-400-normal-CnPTUeEK.woff +0 -0
  480. package/web/dist/assets/noto-emoji-3-400-normal-TrTb2VQM.woff2 +0 -0
  481. package/web/dist/assets/noto-emoji-4-400-normal-BxD0KVdj.woff +0 -0
  482. package/web/dist/assets/noto-emoji-4-400-normal-s_n9EyG1.woff2 +0 -0
  483. package/web/dist/assets/noto-emoji-5-400-normal-C190AIxR.woff +0 -0
  484. package/web/dist/assets/noto-emoji-5-400-normal-Ctfx4xc6.woff2 +0 -0
  485. package/web/dist/assets/noto-emoji-6-400-normal-DlXlXWt7.woff +0 -0
  486. package/web/dist/assets/noto-emoji-6-400-normal-NzsjD754.woff2 +0 -0
  487. package/web/dist/assets/noto-emoji-7-400-normal-BHP8KeA6.woff2 +0 -0
  488. package/web/dist/assets/noto-emoji-7-400-normal-CtuKhtAZ.woff +0 -0
  489. package/web/dist/assets/noto-emoji-8-400-normal-DR49ZFe7.woff +0 -0
  490. package/web/dist/assets/noto-emoji-8-400-normal-Dvmkf6b2.woff2 +0 -0
  491. package/web/dist/assets/noto-emoji-9-400-normal-BeHJQ2iK.woff2 +0 -0
  492. package/web/dist/assets/noto-emoji-9-400-normal-BlXmCgeQ.woff +0 -0
  493. package/web/dist/assets/ordinal-Cboi1Yqb.js +1 -0
  494. package/web/dist/assets/pieDiagram-ADFJNKIX-C45wSpld.js +30 -0
  495. package/web/dist/assets/quadrantDiagram-AYHSOK5B-tv-_fe-W.js +7 -0
  496. package/web/dist/assets/reduce-CoLNNlNb.js +1 -0
  497. package/web/dist/assets/requirementDiagram-UZGBJVZJ-Dn6PDfkL.js +64 -0
  498. package/web/dist/assets/sankeyDiagram-TZEHDZUN-CbXTZAsG.js +10 -0
  499. package/web/dist/assets/sequenceDiagram-WL72ISMW-B-o1CUJ5.js +145 -0
  500. package/web/dist/assets/stateDiagram-FKZM4ZOC-hzrupXQi.js +1 -0
  501. package/web/dist/assets/stateDiagram-v2-4FDKWEC3-DN-c2M96.js +1 -0
  502. package/web/dist/assets/timeline-definition-IT6M3QCI-R5SP9GDo.js +61 -0
  503. package/web/dist/assets/treemap-KMMF4GRG-Pg9KlUOt.js +128 -0
  504. package/web/dist/assets/xychartDiagram-PRI3JC2R-C3vbJhd1.js +7 -0
  505. package/web/dist/favicon.svg +13 -0
  506. package/web/dist/index.html +17 -0
  507. package//351/205/215/347/275/256/346/226/271/345/274/217.md +330 -0
@@ -0,0 +1,88 @@
1
+ // src/utils/validation.ts
2
+ import * as path from "node:path";
3
+ import * as fs from "node:fs";
4
+ import { ZeroError } from "../types/errors.js";
5
+ /**
6
+ * 禁止在名称中使用的字符
7
+ */
8
+ const INVALID_CHARS = /[/\\:*?"<>|]/;
9
+ /**
10
+ * 验证工作区名称
11
+ * @throws ZeroError 如果名称不合法
12
+ */
13
+ export function validateWorkspaceName(name) {
14
+ if (!name || name.trim().length === 0) {
15
+ throw new ZeroError("INVALID_NAME", "工作区名称不能为空");
16
+ }
17
+ if (INVALID_CHARS.test(name)) {
18
+ throw new ZeroError("INVALID_NAME", "工作区名称不能包含特殊字符: / \\ : * ? \" < > |");
19
+ }
20
+ }
21
+ /**
22
+ * 验证节点标题
23
+ * @throws ZeroError 如果标题不合法
24
+ */
25
+ export function validateNodeTitle(title) {
26
+ if (!title || title.trim().length === 0) {
27
+ throw new ZeroError("INVALID_TITLE", "节点标题不能为空");
28
+ }
29
+ if (INVALID_CHARS.test(title)) {
30
+ throw new ZeroError("INVALID_TITLE", "节点标题不能包含特殊字符: / \\ : * ? \" < > |");
31
+ }
32
+ }
33
+ /**
34
+ * 验证 ID 是否为空
35
+ */
36
+ export function validateId(id, type) {
37
+ if (!id || id.trim().length === 0) {
38
+ if (type === "workspace") {
39
+ throw new ZeroError("WORKSPACE_NOT_FOUND", "工作区 ID 不能为空");
40
+ }
41
+ else {
42
+ throw new ZeroError("NODE_NOT_FOUND", "节点 ID 不能为空");
43
+ }
44
+ }
45
+ }
46
+ /**
47
+ * 验证并规范化项目根目录路径
48
+ * @param inputPath 用户输入的路径
49
+ * @param basePath 基准路径(默认为 cwd),用于解析相对路径
50
+ * @returns 规范化后的绝对路径
51
+ * @throws ZeroError 如果路径不安全或不存在
52
+ */
53
+ export function validateProjectRoot(inputPath, basePath = process.cwd()) {
54
+ // 1. 检查输入是否为空
55
+ if (!inputPath || inputPath.trim().length === 0) {
56
+ throw new ZeroError("INVALID_PATH", "项目路径不能为空");
57
+ }
58
+ // 2. 检查是否包含危险的路径穿越模式
59
+ // 注意:需要在 resolve 之前检查原始输入
60
+ const normalizedInput = inputPath.replace(/\\/g, "/");
61
+ if (normalizedInput.includes("/../") ||
62
+ normalizedInput.startsWith("../") ||
63
+ normalizedInput.endsWith("/..") ||
64
+ normalizedInput === "..") {
65
+ throw new ZeroError("INVALID_PATH", "项目路径不能包含目录穿越 (..)");
66
+ }
67
+ // 3. 解析为绝对路径
68
+ const resolvedPath = path.resolve(basePath, inputPath);
69
+ // 4. 再次验证解析后的路径不会逃逸到意外位置
70
+ // 确保解析后的路径在用户主目录或 basePath 下
71
+ const homeDir = process.env.HOME || process.env.USERPROFILE || "/";
72
+ const isUnderHome = resolvedPath.startsWith(homeDir);
73
+ const isUnderBase = resolvedPath.startsWith(basePath);
74
+ if (!isUnderHome && !isUnderBase) {
75
+ throw new ZeroError("INVALID_PATH", `项目路径必须在用户主目录或当前目录下: ${resolvedPath}`);
76
+ }
77
+ // 5. 验证目录存在
78
+ if (!fs.existsSync(resolvedPath)) {
79
+ throw new ZeroError("INVALID_PATH", `项目目录不存在: ${resolvedPath}`);
80
+ }
81
+ // 6. 验证是目录而非文件
82
+ const stat = fs.statSync(resolvedPath);
83
+ if (!stat.isDirectory()) {
84
+ throw new ZeroError("INVALID_PATH", `路径不是目录: ${resolvedPath}`);
85
+ }
86
+ return resolvedPath;
87
+ }
88
+ //# sourceMappingURL=validation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/utils/validation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,389 @@
1
+ # 日志系统
2
+
3
+ > ZeroWorkspace 统一日志记录方案
4
+
5
+ ---
6
+
7
+ ## 概述
8
+
9
+ ZeroWorkspace 日志系统提供统一的日志记录能力,支持:
10
+
11
+ - **后端系统日志**:记录 MCP 调用、系统事件等
12
+ - **前端错误上报**:捕获 Vue 错误、JS 异常、Promise rejection、API 错误
13
+ - **可配置日志级别**:支持 debug/info/warn/error 四级过滤
14
+
15
+ 所有日志统一写入 `~/.zero-workspace/logs/system.log`,采用 JSON Lines 格式便于解析。
16
+
17
+ ---
18
+
19
+ ## 架构
20
+
21
+ ```
22
+ ┌─────────────────────────────────────────────────────────────────┐
23
+ │ 前端 (Vue) │
24
+ ├─────────────────────────────────────────────────────────────────┤
25
+ │ Vue errorHandler │ window.onerror │ onunhandledrejection │
26
+ │ │ │ │
27
+ │ axios interceptor (API 错误) │
28
+ └───────────────────────────┬─────────────────────────────────────┘
29
+ │ POST /api/logs/client
30
+
31
+ ┌─────────────────────────────────────────────────────────────────┐
32
+ │ 后端 (Node.js) │
33
+ ├─────────────────────────────────────────────────────────────────┤
34
+ │ log.ts 路由 │ sessionLogger (MCP 调用) │
35
+ │ │ │ │ │
36
+ │ └────────────────┴─────────┘ │
37
+ │ │ │
38
+ │ ▼ │
39
+ │ ┌─────────────────┐ │
40
+ │ │ Logger 单例 │ ◄── 读取 config.json logLevel │
41
+ │ │ (级别过滤) │ │
42
+ │ └────────┬────────┘ │
43
+ │ │ │
44
+ │ ▼ │
45
+ │ ┌─────────────────┐ │
46
+ │ │ 异步写入队列 │ │
47
+ │ └────────┬────────┘ │
48
+ │ │ │
49
+ │ ▼ │
50
+ │ ~/.zero-workspace/logs/system.log │
51
+ │ (JSON Lines, 10MB 轮转, 最多 10 个文件) │
52
+ └─────────────────────────────────────────────────────────────────┘
53
+ ```
54
+
55
+ ---
56
+
57
+ ## 日志存储
58
+
59
+ ### 文件位置
60
+
61
+ | 环境 | 路径 |
62
+ |------|------|
63
+ | 生产 | `~/.zero-workspace/logs/system.log` |
64
+ | 开发 | `~/.zero-workspace-dev/logs/system.log` |
65
+
66
+ ### 日志格式 (JSON Lines)
67
+
68
+ 每行是一个独立的 JSON 对象:
69
+
70
+ ```json
71
+ {"ts":"2024-01-15T10:30:45.123Z","level":"info","source":"mcp","event":"start","tool":"node_create","sessionId":"abc123"}
72
+ {"ts":"2024-01-15T10:30:45.456Z","level":"error","source":"client","type":"vue","message":"Cannot read property 'x' of undefined","component":"NodeTree"}
73
+ ```
74
+
75
+ ### 日志字段
76
+
77
+ | 字段 | 类型 | 说明 |
78
+ |------|------|------|
79
+ | `ts` | string | ISO 8601 时间戳 |
80
+ | `level` | string | 日志级别:debug/info/warn/error |
81
+ | `source` | string | 来源标识:mcp/client/system |
82
+ | `...` | any | 其他动态字段,取决于日志类型 |
83
+
84
+ ### 日志轮转
85
+
86
+ - **触发条件**:单个日志文件达到 10MB
87
+ - **保留数量**:最多 10 个文件
88
+ - **文件命名**:
89
+ - `system.log` - 当前日志
90
+ - `system.1.log` - 上一个
91
+ - `system.2.log` ~ `system.9.log` - 更早的日志
92
+
93
+ 轮转时,最旧的 `system.9.log` 被删除,其余文件依次重命名。
94
+
95
+ ---
96
+
97
+ ## 日志级别
98
+
99
+ ### 级别优先级
100
+
101
+ | 级别 | 优先级 | 说明 |
102
+ |------|--------|------|
103
+ | `debug` | 0 | 调试信息,最详细 |
104
+ | `info` | 1 | 常规信息(默认级别) |
105
+ | `warn` | 2 | 警告信息 |
106
+ | `error` | 3 | 错误信息 |
107
+
108
+ ### 过滤规则
109
+
110
+ 配置的日志级别决定最低记录级别。例如:
111
+
112
+ - 配置 `logLevel: "info"`:记录 info、warn、error,忽略 debug
113
+ - 配置 `logLevel: "warn"`:记录 warn、error,忽略 debug、info
114
+ - 配置 `logLevel: "debug"`:记录所有级别
115
+
116
+ ### 配置方法
117
+
118
+ 编辑 `~/.zero-workspace/config.json`:
119
+
120
+ ```json
121
+ {
122
+ "version": "1.0",
123
+ "defaultDispatchMode": "none",
124
+ "logLevel": "debug"
125
+ }
126
+ ```
127
+
128
+ 或使用 MCP 工具:
129
+
130
+ ```typescript
131
+ config_set({ logLevel: "debug" })
132
+ ```
133
+
134
+ ---
135
+
136
+ ## 后端日志
137
+
138
+ ### Logger API
139
+
140
+ ```typescript
141
+ import { logger } from './utils/logger.js';
142
+
143
+ // 调试日志
144
+ logger.debug('source', { key: 'value' });
145
+
146
+ // 信息日志
147
+ logger.info('source', { key: 'value' });
148
+
149
+ // 警告日志
150
+ logger.warn('source', { key: 'value' });
151
+
152
+ // 错误日志
153
+ logger.error('source', { key: 'value' });
154
+ ```
155
+
156
+ ### MCP 调用日志
157
+
158
+ `sessionLogger` 自动记录所有 MCP 工具调用:
159
+
160
+ ```typescript
161
+ // 调用开始
162
+ logMcpStart('node_create', { workspaceId: 'ws-xxx', title: '新任务' });
163
+
164
+ // 调用结束
165
+ logMcpEnd('node_create', true, { nodeId: 'node-xxx' }, 123);
166
+
167
+ // 调用错误
168
+ logMcpError('node_create', new Error('创建失败'));
169
+ ```
170
+
171
+ 生成的日志:
172
+
173
+ ```json
174
+ {"ts":"...","level":"info","source":"mcp","event":"start","tool":"node_create","sessionId":"...","params":{...}}
175
+ {"ts":"...","level":"info","source":"mcp","event":"end","tool":"node_create","sessionId":"...","success":true,"result":"...","durationMs":123}
176
+ ```
177
+
178
+ ---
179
+
180
+ ## 前端错误上报
181
+
182
+ ### 错误类型
183
+
184
+ | 类型 | 说明 | 触发场景 |
185
+ |------|------|----------|
186
+ | `vue` | Vue 组件错误 | 组件渲染/生命周期异常 |
187
+ | `js` | JavaScript 错误 | 运行时异常 |
188
+ | `promise` | Promise rejection | 未处理的 Promise 拒绝 |
189
+ | `api` | API 请求错误 | HTTP 请求失败 |
190
+
191
+ ### 自动捕获
192
+
193
+ 前端已注册全局错误处理器,无需手动调用:
194
+
195
+ ```typescript
196
+ // main.ts 中已配置
197
+
198
+ // 1. Vue 组件错误
199
+ app.config.errorHandler = (err, vm, info) => {
200
+ reportError({ type: 'vue', message: err.message, ... });
201
+ }
202
+
203
+ // 2. 全局 JS 错误
204
+ window.onerror = (message, filename, lineno, colno, error) => {
205
+ reportError({ type: 'js', message, ... });
206
+ }
207
+
208
+ // 3. 未处理 Promise rejection
209
+ window.onunhandledrejection = (event) => {
210
+ reportError({ type: 'promise', message: event.reason, ... });
211
+ }
212
+
213
+ // 4. API 错误(axios 拦截器)
214
+ // client.ts 中已配置
215
+ ```
216
+
217
+ ### 手动上报
218
+
219
+ ```typescript
220
+ import { reportError } from '@/utils/errorReporter';
221
+
222
+ reportError({
223
+ type: 'js',
224
+ message: '自定义错误信息',
225
+ stack: error.stack,
226
+ extra: { userId: '123' }
227
+ });
228
+ ```
229
+
230
+ ### 上报数据结构
231
+
232
+ ```typescript
233
+ interface ErrorReport {
234
+ type: 'vue' | 'js' | 'promise' | 'api'; // 错误类型
235
+ message: string; // 错误消息
236
+ stack?: string; // 堆栈信息
237
+ component?: string; // Vue 组件名(仅 vue 类型)
238
+ url?: string; // 页面 URL(自动填充)
239
+ extra?: Record<string, unknown>; // 额外信息
240
+ }
241
+ ```
242
+
243
+ ### 后端接收端点
244
+
245
+ `POST /api/logs/client`
246
+
247
+ 请求体:
248
+
249
+ ```json
250
+ {
251
+ "type": "vue",
252
+ "message": "Cannot read property 'x' of undefined",
253
+ "stack": "Error: ...\n at ...",
254
+ "component": "NodeTree",
255
+ "url": "http://localhost:5173/workspace/ws-xxx"
256
+ }
257
+ ```
258
+
259
+ 响应:
260
+
261
+ ```json
262
+ { "success": true }
263
+ ```
264
+
265
+ ---
266
+
267
+ ## 查看日志
268
+
269
+ ### 命令行查看
270
+
271
+ ```bash
272
+ # 查看最新日志
273
+ tail -f ~/.zero-workspace/logs/system.log
274
+
275
+ # 格式化查看(需要 jq)
276
+ tail -f ~/.zero-workspace/logs/system.log | jq .
277
+
278
+ # 过滤错误日志
279
+ cat ~/.zero-workspace/logs/system.log | jq 'select(.level == "error")'
280
+
281
+ # 过滤前端错误
282
+ cat ~/.zero-workspace/logs/system.log | jq 'select(.source == "client")'
283
+
284
+ # 过滤特定 MCP 工具
285
+ cat ~/.zero-workspace/logs/system.log | jq 'select(.tool == "node_create")'
286
+ ```
287
+
288
+ ### 常用过滤
289
+
290
+ ```bash
291
+ # 最近 10 条错误
292
+ cat ~/.zero-workspace/logs/system.log | jq 'select(.level == "error")' | tail -10
293
+
294
+ # 统计各级别日志数量
295
+ cat ~/.zero-workspace/logs/system.log | jq -r '.level' | sort | uniq -c
296
+
297
+ # 统计各来源日志数量
298
+ cat ~/.zero-workspace/logs/system.log | jq -r '.source' | sort | uniq -c
299
+
300
+ # 查看某时间段的日志
301
+ cat ~/.zero-workspace/logs/system.log | jq 'select(.ts >= "2024-01-15T10:00:00" and .ts <= "2024-01-15T11:00:00")'
302
+ ```
303
+
304
+ ---
305
+
306
+ ## 故障排查
307
+
308
+ ### 常见问题
309
+
310
+ **Q: 日志文件不存在?**
311
+
312
+ A: 日志目录和文件在首次写入时自动创建。检查:
313
+ - 是否有写入权限:`ls -la ~/.zero-workspace/`
314
+ - 开发环境路径不同:`~/.zero-workspace-dev/logs/`
315
+
316
+ **Q: 日志级别配置不生效?**
317
+
318
+ A:
319
+ 1. 检查配置文件格式是否正确
320
+ 2. 日志级别在模块加载时读取,修改后需重启服务
321
+ 3. 无效的级别值会回退到默认值 `info`
322
+
323
+ **Q: 前端错误没有上报?**
324
+
325
+ A:
326
+ 1. 检查网络请求是否发出(DevTools Network)
327
+ 2. 上报失败时静默处理,不会影响用户体验
328
+ 3. 确认后端服务正常运行
329
+
330
+ ### 日志文件过大
331
+
332
+ 如果磁盘空间不足,可手动清理:
333
+
334
+ ```bash
335
+ # 删除所有轮转日志,保留当前日志
336
+ rm ~/.zero-workspace/logs/system.*.log
337
+
338
+ # 清空当前日志
339
+ > ~/.zero-workspace/logs/system.log
340
+ ```
341
+
342
+ ---
343
+
344
+ ## 最佳实践
345
+
346
+ ### 后端日志
347
+
348
+ 1. **选择合适的来源标识**
349
+ - `mcp`:MCP 工具调用
350
+ - `system`:系统内部事件
351
+ - `http`:HTTP 请求/响应
352
+
353
+ 2. **包含必要上下文**
354
+ ```typescript
355
+ logger.info('mcp', {
356
+ tool: 'node_create',
357
+ workspaceId: 'ws-xxx',
358
+ params: { title: '...' }
359
+ });
360
+ ```
361
+
362
+ 3. **错误日志包含堆栈**
363
+ ```typescript
364
+ logger.error('system', {
365
+ message: error.message,
366
+ stack: error.stack
367
+ });
368
+ ```
369
+
370
+ ### 前端错误
371
+
372
+ 1. **使用 extra 字段补充上下文**
373
+ ```typescript
374
+ reportError({
375
+ type: 'js',
376
+ message: '操作失败',
377
+ extra: {
378
+ userId: currentUser.id,
379
+ action: 'saveDocument'
380
+ }
381
+ });
382
+ ```
383
+
384
+ 2. **不要过度上报**
385
+ - 避免在循环中上报
386
+ - 考虑防抖/节流
387
+
388
+ 3. **敏感信息脱敏**
389
+ - 不要上报密码、token 等敏感数据