@jingyi0605/codingns 0.8.5 → 0.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (439) hide show
  1. package/bin/codingns.mjs +7 -156
  2. package/dist/public/assets/AdaptiveButlerPage-B17QiMyT.js +2 -0
  3. package/dist/public/assets/{App-BOHBGFOd.js → App-CFBwDUNA.js} +6 -6
  4. package/dist/public/assets/{BootstrapPage-BxHQT4nA.js → BootstrapPage-W5wU3BPh.js} +1 -1
  5. package/dist/public/assets/{ConversationPage-DWFsF6BB.js → ConversationPage-DQLX1bUh.js} +6 -6
  6. package/dist/public/assets/{DesktopDetachPreviewPage-DOgEjYEf.js → DesktopDetachPreviewPage-DTPeuAW-.js} +1 -1
  7. package/dist/public/assets/DesktopModal-6ii53_Y9.js +1 -0
  8. package/dist/public/assets/DesktopWindowPage-D0blSuKd.js +2 -0
  9. package/dist/public/assets/FileContextPanel-BrKO8Xt6.js +1 -0
  10. package/dist/public/assets/GitSidebar-BdwiDtOr.js +6 -0
  11. package/dist/public/assets/MobileCreateSessionSheet-Cx_dBiBb.js +1 -0
  12. package/dist/public/assets/MobileSheet-opTWyRe1.js +1 -0
  13. package/dist/public/assets/{MobileTopHeaderFrame-lcp2GscV.js → MobileTopHeaderFrame-BbNON3Y4.js} +1 -1
  14. package/dist/public/assets/MobileWorkspaceSwitcherHeader-BZEzPeMj.js +1 -0
  15. package/dist/public/assets/{PluginAccessOverview-DGcKAMQl.js → PluginAccessOverview-mQDmAljp.js} +1 -1
  16. package/dist/public/assets/PluginContainerPage-CcxUJpM4.js +1 -0
  17. package/dist/public/assets/{PluginDetailPage-CAJ7LFpD.js → PluginDetailPage-D5--ACIt.js} +1 -1
  18. package/dist/public/assets/{PluginsListPage-BxZG1NyT.js → PluginsListPage-D_oJxYXT.js} +1 -1
  19. package/dist/public/assets/{RelayConnectEntryPage-CfNO_TIl.js → RelayConnectEntryPage-DROxpnkv.js} +1 -1
  20. package/dist/public/assets/{ServerSettingsModal-by36Z_5k.js → ServerSettingsModal-CUUOPqSe.js} +1 -1
  21. package/dist/public/assets/SessionIndexPage-C2Jxh6Gp.js +1 -0
  22. package/dist/public/assets/SettingsPage-BlAZCHsy.js +2 -0
  23. package/dist/public/assets/{TerminalManagerPanel-NVZRxxmH.js → TerminalManagerPanel-CjzbiWjl.js} +1 -1
  24. package/dist/public/assets/{TerminalPage-C4LNoPBp.js → TerminalPage-CwWyFDj8.js} +2 -2
  25. package/dist/public/assets/TerminalRuntimeFallbackModal-CSVVbO8r.js +1 -0
  26. package/dist/public/assets/{ToolFilesPage-47zbdgTW.js → ToolFilesPage-QBEY8oCf.js} +1 -1
  27. package/dist/public/assets/{ToolGitPage-Fuk_b_jg.js → ToolGitPage-BKoZ2l9v.js} +1 -1
  28. package/dist/public/assets/{ToolProcessesPage-sWSMWD-9.js → ToolProcessesPage-BOH0ib4G.js} +1 -1
  29. package/dist/public/assets/{ToolsHomePage-R1mZlbZi.js → ToolsHomePage-BcMZ3BCQ.js} +1 -1
  30. package/dist/public/assets/{WorkbenchLandingPage-CqmiFH2u.js → WorkbenchLandingPage-B5zoppEl.js} +1 -1
  31. package/dist/public/assets/WorkbenchLayout-BksVkkFF.css +1 -0
  32. package/dist/public/assets/WorkbenchLayout-CikJBS62.js +1019 -0
  33. package/dist/public/assets/{WorkbenchModal-C7qoQElW.js → WorkbenchModal-NGmPgqaE.js} +1 -1
  34. package/dist/public/assets/WorkbenchShellRoute-BbbSOiZw.js +1 -0
  35. package/dist/public/assets/WorkbenchShellRoute-DT3VMjWD.css +1 -0
  36. package/dist/public/assets/WorkspaceDebugDetailPage-CVivdPx5.js +1 -0
  37. package/dist/public/assets/{WorkspaceDetailPage-BPsrFffw.js → WorkspaceDetailPage-DgOSjscR.js} +1 -1
  38. package/dist/public/assets/{WorkspaceHomePage-KAtqZOAb.js → WorkspaceHomePage-HPa7M_Vh.js} +1 -1
  39. package/dist/public/assets/{client-runtime-manager-wmCJZKYd.js → client-runtime-manager-DXbI9K1K.js} +1 -1
  40. package/dist/public/assets/index-BxJPQpFM.css +1 -0
  41. package/dist/public/assets/index-CeXGOT_T.js +50 -0
  42. package/dist/public/assets/{login-direct-candidate-resolver-BOAgTuUf.js → login-direct-candidate-resolver-DkKyFtQJ.js} +1 -1
  43. package/dist/public/assets/{plugin-permission-copy-Cq99cnzV.js → plugin-permission-copy-CzN269Bk.js} +1 -1
  44. package/dist/public/assets/{plugins-api-BQTV5DOp.js → plugins-api-Bv9DHpLF.js} +1 -1
  45. package/dist/public/assets/{preferences-service-DJxbEEeg.js → preferences-service-D2ISL2Zz.js} +1 -1
  46. package/dist/public/assets/{relay-entry-D-LfvdiX.js → relay-entry-Bg0OisQy.js} +1 -1
  47. package/dist/public/assets/{terminal-runtime-meta-BJmy8dyK.js → terminal-runtime-meta-C8t-CIDF.js} +1 -1
  48. package/dist/public/assets/{useRegisteredDebugTemplates-DQAWVdCo.js → useRegisteredDebugTemplates-Bol3NVfN.js} +1 -1
  49. package/dist/public/assets/{workbench-navigation-MEzCSmsK.js → workbench-navigation-B7IjRQd8.js} +1 -1
  50. package/dist/public/index.html +2 -2
  51. package/dist/server/middlewares/auth-guard.js +10 -5
  52. package/dist/server/middlewares/auth-guard.js.map +1 -1
  53. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.d.ts +11 -0
  54. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.js +22 -0
  55. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.js.map +1 -0
  56. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.d.ts +23 -0
  57. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.js +23 -0
  58. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.js.map +1 -0
  59. package/dist/server/modules/affairs-indexer/contracts/src/index.d.ts +4 -0
  60. package/dist/server/modules/affairs-indexer/contracts/src/index.js +5 -0
  61. package/dist/server/modules/affairs-indexer/contracts/src/index.js.map +1 -0
  62. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.d.ts +7 -0
  63. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.js +2 -0
  64. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.js.map +1 -0
  65. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.d.ts +16 -0
  66. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.js +2 -0
  67. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.js.map +1 -0
  68. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.d.ts +10 -0
  69. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.js +215 -0
  70. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.js.map +1 -0
  71. package/dist/server/modules/affairs-indexer/core/src/index.d.ts +31 -0
  72. package/dist/server/modules/affairs-indexer/core/src/index.js +32 -0
  73. package/dist/server/modules/affairs-indexer/core/src/index.js.map +1 -0
  74. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.d.ts +20 -0
  75. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.js +47 -0
  76. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.js.map +1 -0
  77. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.d.ts +17 -0
  78. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.js +63 -0
  79. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.js.map +1 -0
  80. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.d.ts +12 -0
  81. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.js +42 -0
  82. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.js.map +1 -0
  83. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.d.ts +7 -0
  84. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.js +107 -0
  85. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.js.map +1 -0
  86. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.d.ts +19 -0
  87. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.js +37 -0
  88. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.js.map +1 -0
  89. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.d.ts +7 -0
  90. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.js +123 -0
  91. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.js.map +1 -0
  92. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.d.ts +8 -0
  93. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.js +111 -0
  94. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.js.map +1 -0
  95. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.d.ts +42 -0
  96. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.js +2 -0
  97. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.js.map +1 -0
  98. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.d.ts +18 -0
  99. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.js +91 -0
  100. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.js.map +1 -0
  101. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.d.ts +18 -0
  102. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.js +59 -0
  103. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.js.map +1 -0
  104. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.d.ts +48 -0
  105. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.js +193 -0
  106. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.js.map +1 -0
  107. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.d.ts +7 -0
  108. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.js +371 -0
  109. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.js.map +1 -0
  110. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.d.ts +10 -0
  111. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.js +55 -0
  112. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.js.map +1 -0
  113. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.d.ts +9 -0
  114. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.js +2 -0
  115. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.js.map +1 -0
  116. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.d.ts +7 -0
  117. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.js +130 -0
  118. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.js.map +1 -0
  119. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.d.ts +7 -0
  120. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.js +228 -0
  121. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.js.map +1 -0
  122. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.d.ts +205 -0
  123. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.js +1471 -0
  124. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.js.map +1 -0
  125. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.d.ts +161 -0
  126. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.js +1350 -0
  127. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.js.map +1 -0
  128. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.d.ts +32 -0
  129. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.js +208 -0
  130. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.js.map +1 -0
  131. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.d.ts +30 -0
  132. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.js +66 -0
  133. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.js.map +1 -0
  134. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.d.ts +33 -0
  135. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.js +705 -0
  136. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.js.map +1 -0
  137. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.d.ts +80 -0
  138. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.js +193 -0
  139. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.js.map +1 -0
  140. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.d.ts +77 -0
  141. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.js +467 -0
  142. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.js.map +1 -0
  143. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.d.ts +17 -0
  144. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.js +264 -0
  145. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.js.map +1 -0
  146. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.d.ts +11 -0
  147. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.js +76 -0
  148. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.js.map +1 -0
  149. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.d.ts +26 -0
  150. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.js +305 -0
  151. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.js.map +1 -0
  152. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.d.ts +53 -0
  153. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.js +566 -0
  154. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.js.map +1 -0
  155. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.d.ts +47 -0
  156. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.js +227 -0
  157. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.js.map +1 -0
  158. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.d.ts +5 -0
  159. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.js +245 -0
  160. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.js.map +1 -0
  161. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.d.ts +14 -0
  162. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.js +87 -0
  163. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.js.map +1 -0
  164. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.d.ts +13 -0
  165. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.js +16 -0
  166. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.js.map +1 -0
  167. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.d.ts +22 -0
  168. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.js +430 -0
  169. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.js.map +1 -0
  170. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.d.ts +9 -0
  171. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.js +19 -0
  172. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.js.map +1 -0
  173. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.d.ts +21 -0
  174. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.js +94 -0
  175. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.js.map +1 -0
  176. package/dist/server/modules/affairs-indexer/core/src/utils/abort.d.ts +2 -0
  177. package/dist/server/modules/affairs-indexer/core/src/utils/abort.js +13 -0
  178. package/dist/server/modules/affairs-indexer/core/src/utils/abort.js.map +1 -0
  179. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.d.ts +9 -0
  180. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.js +64 -0
  181. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.js.map +1 -0
  182. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.d.ts +10 -0
  183. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.js +230 -0
  184. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.js.map +1 -0
  185. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.d.ts +2 -0
  186. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.js +19 -0
  187. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.js.map +1 -0
  188. package/dist/server/modules/affairs-indexer/internal-command-runner.d.ts +31 -0
  189. package/dist/server/modules/affairs-indexer/internal-command-runner.js +643 -0
  190. package/dist/server/modules/affairs-indexer/internal-command-runner.js.map +1 -0
  191. package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +0 -49
  192. package/dist/server/modules/assistant-capability/assistant-capability-controller.js +10 -56
  193. package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -1
  194. package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +2 -46
  195. package/dist/server/modules/assistant-capability/assistant-capability-service.js +15 -158
  196. package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -1
  197. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.d.ts +4 -2
  198. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js +62 -21
  199. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js.map +1 -1
  200. package/dist/server/modules/butler/butler-control-session-service.d.ts +3 -4
  201. package/dist/server/modules/butler/butler-control-session-service.js +39 -62
  202. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
  203. package/dist/server/modules/butler/butler-controller.d.ts +11 -3
  204. package/dist/server/modules/butler/butler-controller.js +19 -4
  205. package/dist/server/modules/butler/butler-controller.js.map +1 -1
  206. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
  207. package/dist/server/modules/butler/butler-profile-service.d.ts +1 -1
  208. package/dist/server/modules/butler/butler-profile-service.js +34 -63
  209. package/dist/server/modules/butler/butler-profile-service.js.map +1 -1
  210. package/dist/server/modules/butler/butler-project-service.d.ts +1 -3
  211. package/dist/server/modules/butler/butler-project-service.js +1 -7
  212. package/dist/server/modules/butler/butler-project-service.js.map +1 -1
  213. package/dist/server/modules/butler/butler-session-service.d.ts +1 -0
  214. package/dist/server/modules/butler/butler-session-service.js +109 -0
  215. package/dist/server/modules/butler/butler-session-service.js.map +1 -1
  216. package/dist/server/modules/butler/butler-session-summary-service.js +0 -2
  217. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
  218. package/dist/server/modules/butler/butler-workspace-context.d.ts +5 -1
  219. package/dist/server/modules/butler/butler-workspace-context.js +21 -12
  220. package/dist/server/modules/butler/butler-workspace-context.js.map +1 -1
  221. package/dist/server/modules/file/file-content-service.d.ts +11 -0
  222. package/dist/server/modules/file/file-content-service.js +55 -0
  223. package/dist/server/modules/file/file-content-service.js.map +1 -1
  224. package/dist/server/modules/file/file-controller.d.ts +26 -1
  225. package/dist/server/modules/file/file-controller.js +59 -4
  226. package/dist/server/modules/file/file-controller.js.map +1 -1
  227. package/dist/server/modules/file/file-preview-link-service.d.ts +1 -0
  228. package/dist/server/modules/file/file-preview-link-service.js +25 -0
  229. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  230. package/dist/server/modules/file/file-preview-service.js +15 -4
  231. package/dist/server/modules/file/file-preview-service.js.map +1 -1
  232. package/dist/server/modules/file/file-preview-types.d.ts +9 -1
  233. package/dist/server/modules/file/file-preview-types.js +8 -1
  234. package/dist/server/modules/file/file-preview-types.js.map +1 -1
  235. package/dist/server/modules/file/recent-modified-file-service.d.ts +15 -0
  236. package/dist/server/modules/file/recent-modified-file-service.js +102 -0
  237. package/dist/server/modules/file/recent-modified-file-service.js.map +1 -0
  238. package/dist/server/modules/file/runtime/codingns-workspace-bridge.js +6 -0
  239. package/dist/server/modules/file/workspace-file-bridge-service.d.ts +11 -0
  240. package/dist/server/modules/file/workspace-file-bridge-service.js +19 -0
  241. package/dist/server/modules/file/workspace-file-bridge-service.js.map +1 -1
  242. package/dist/server/modules/file/workspace-index-apply-service.d.ts +25 -0
  243. package/dist/server/modules/file/workspace-index-apply-service.js +42 -0
  244. package/dist/server/modules/file/workspace-index-apply-service.js.map +1 -0
  245. package/dist/server/modules/office/office-controller.d.ts +15 -1
  246. package/dist/server/modules/office/office-controller.js +26 -1
  247. package/dist/server/modules/office/office-controller.js.map +1 -1
  248. package/dist/server/modules/office/onlyoffice-integration-service.d.ts +78 -0
  249. package/dist/server/modules/office/onlyoffice-integration-service.js +610 -0
  250. package/dist/server/modules/office/onlyoffice-integration-service.js.map +1 -0
  251. package/dist/server/modules/plugins/plugin-file-gateway-service.d.ts +12 -0
  252. package/dist/server/modules/plugins/plugin-file-gateway-service.js +13 -0
  253. package/dist/server/modules/plugins/plugin-file-gateway-service.js.map +1 -1
  254. package/dist/server/modules/preferences/profile-service.d.ts +1 -0
  255. package/dist/server/modules/preferences/profile-service.js +27 -3
  256. package/dist/server/modules/preferences/profile-service.js.map +1 -1
  257. package/dist/server/modules/sessions/codex-app-server-helper-process.js +0 -8
  258. package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
  259. package/dist/server/modules/sessions/session-controller.d.ts +1 -0
  260. package/dist/server/modules/sessions/session-controller.js +3 -0
  261. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  262. package/dist/server/modules/sessions/session-history-service.d.ts +2 -0
  263. package/dist/server/modules/sessions/session-history-service.js +78 -3
  264. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  265. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +1 -0
  266. package/dist/server/modules/sessions/session-live-runtime-service.js +4 -0
  267. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  268. package/dist/server/modules/sessions/session-permission-request-service.js +0 -4
  269. package/dist/server/modules/sessions/session-permission-request-service.js.map +1 -1
  270. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.d.ts +23 -0
  271. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.js +122 -0
  272. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.js.map +1 -0
  273. package/dist/server/modules/sessions/workspace-session-runtime-context-service.d.ts +15 -0
  274. package/dist/server/modules/sessions/workspace-session-runtime-context-service.js +93 -10
  275. package/dist/server/modules/sessions/workspace-session-runtime-context-service.js.map +1 -1
  276. package/dist/server/modules/skills/builtin-skills/codingns-assistant/SKILL.md +6 -7
  277. package/dist/server/modules/skills/builtin-skills/codingns-assistant/references/cli-workflow.md +2 -3
  278. package/dist/server/modules/system/host-resource-controller.d.ts +7 -0
  279. package/dist/server/modules/system/host-resource-controller.js +12 -0
  280. package/dist/server/modules/system/host-resource-controller.js.map +1 -0
  281. package/dist/server/modules/system/host-resource-service.d.ts +54 -0
  282. package/dist/server/modules/system/host-resource-service.js +162 -0
  283. package/dist/server/modules/system/host-resource-service.js.map +1 -0
  284. package/dist/server/modules/tasks/observability-service.d.ts +12 -2
  285. package/dist/server/modules/tasks/observability-service.js +13 -1
  286. package/dist/server/modules/tasks/observability-service.js.map +1 -1
  287. package/dist/server/modules/tasks/task-helper-client.d.ts +36 -2
  288. package/dist/server/modules/tasks/task-helper-client.js +201 -19
  289. package/dist/server/modules/tasks/task-helper-client.js.map +1 -1
  290. package/dist/server/modules/tasks/task-helper-pool.d.ts +37 -0
  291. package/dist/server/modules/tasks/task-helper-pool.js +173 -0
  292. package/dist/server/modules/tasks/task-helper-pool.js.map +1 -0
  293. package/dist/server/modules/tasks/task-helper-process-handlers.d.ts +27 -0
  294. package/dist/server/modules/tasks/task-helper-process-handlers.js +25 -1
  295. package/dist/server/modules/tasks/task-helper-process-handlers.js.map +1 -1
  296. package/dist/server/modules/tasks/task-helper-process.js +75 -26
  297. package/dist/server/modules/tasks/task-helper-process.js.map +1 -1
  298. package/dist/server/modules/tasks/task-helper-scheduling.d.ts +11 -0
  299. package/dist/server/modules/tasks/task-helper-scheduling.js +43 -0
  300. package/dist/server/modules/tasks/task-helper-scheduling.js.map +1 -0
  301. package/dist/server/modules/tasks/task-lane-executors.js +19 -3
  302. package/dist/server/modules/tasks/task-lane-executors.js.map +1 -1
  303. package/dist/server/modules/tasks/task-manager.d.ts +1 -0
  304. package/dist/server/modules/tasks/task-manager.js +3 -0
  305. package/dist/server/modules/tasks/task-manager.js.map +1 -1
  306. package/dist/server/modules/tasks/task-registry.d.ts +1 -0
  307. package/dist/server/modules/tasks/task-registry.js +3 -0
  308. package/dist/server/modules/tasks/task-registry.js.map +1 -1
  309. package/dist/server/modules/tasks/task-scheduler.d.ts +6 -0
  310. package/dist/server/modules/tasks/task-scheduler.js +162 -7
  311. package/dist/server/modules/tasks/task-scheduler.js.map +1 -1
  312. package/dist/server/modules/tasks/task-types.d.ts +28 -3
  313. package/dist/server/modules/tasks/task-types.js +14 -2
  314. package/dist/server/modules/tasks/task-types.js.map +1 -1
  315. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.d.ts +68 -0
  316. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.js +286 -0
  317. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.js.map +1 -0
  318. package/dist/server/modules/workbench/workbench-controller.js +11 -1
  319. package/dist/server/modules/workbench/workbench-controller.js.map +1 -1
  320. package/dist/server/modules/workbench/workbench-service.d.ts +9 -2
  321. package/dist/server/modules/workbench/workbench-service.js +58 -18
  322. package/dist/server/modules/workbench/workbench-service.js.map +1 -1
  323. package/dist/server/modules/workspace/affairs-library-controller.d.ts +117 -0
  324. package/dist/server/modules/workspace/affairs-library-controller.js +164 -0
  325. package/dist/server/modules/workspace/affairs-library-controller.js.map +1 -0
  326. package/dist/server/modules/workspace/affairs-library-debug-log.d.ts +23 -0
  327. package/dist/server/modules/workspace/affairs-library-debug-log.js +107 -0
  328. package/dist/server/modules/workspace/affairs-library-debug-log.js.map +1 -0
  329. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.d.ts +52 -0
  330. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.js +555 -0
  331. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.js.map +1 -0
  332. package/dist/server/modules/workspace/affairs-library-preview-link-service.d.ts +24 -0
  333. package/dist/server/modules/workspace/affairs-library-preview-link-service.js +157 -0
  334. package/dist/server/modules/workspace/affairs-library-preview-link-service.js.map +1 -0
  335. package/dist/server/modules/workspace/affairs-library-refresh-contract.d.ts +56 -0
  336. package/dist/server/modules/workspace/affairs-library-refresh-contract.js +48 -0
  337. package/dist/server/modules/workspace/affairs-library-refresh-contract.js.map +1 -0
  338. package/dist/server/modules/workspace/affairs-library-service.d.ts +344 -0
  339. package/dist/server/modules/workspace/affairs-library-service.js +3755 -0
  340. package/dist/server/modules/workspace/affairs-library-service.js.map +1 -0
  341. package/dist/server/modules/workspace/affairs-lightweight-session-controller.d.ts +78 -0
  342. package/dist/server/modules/workspace/affairs-lightweight-session-controller.js +146 -0
  343. package/dist/server/modules/workspace/affairs-lightweight-session-controller.js.map +1 -0
  344. package/dist/server/modules/workspace/affairs-lightweight-session-service.d.ts +133 -0
  345. package/dist/server/modules/workspace/affairs-lightweight-session-service.js +1447 -0
  346. package/dist/server/modules/workspace/affairs-lightweight-session-service.js.map +1 -0
  347. package/dist/server/modules/workspace/affairs-tag-controller.d.ts +107 -0
  348. package/dist/server/modules/workspace/affairs-tag-controller.js +97 -0
  349. package/dist/server/modules/workspace/affairs-tag-controller.js.map +1 -0
  350. package/dist/server/modules/workspace/affairs-tag-service.d.ts +153 -0
  351. package/dist/server/modules/workspace/affairs-tag-service.js +680 -0
  352. package/dist/server/modules/workspace/affairs-tag-service.js.map +1 -0
  353. package/dist/server/modules/workspace/workspace-controller.d.ts +2 -1
  354. package/dist/server/modules/workspace/workspace-controller.js +8 -2
  355. package/dist/server/modules/workspace/workspace-controller.js.map +1 -1
  356. package/dist/server/modules/workspace/workspace-service.js +60 -9
  357. package/dist/server/modules/workspace/workspace-service.js.map +1 -1
  358. package/dist/server/routes/affairs.d.ts +3 -0
  359. package/dist/server/routes/affairs.js +7 -0
  360. package/dist/server/routes/affairs.js.map +1 -0
  361. package/dist/server/routes/assistant.js +0 -5
  362. package/dist/server/routes/assistant.js.map +1 -1
  363. package/dist/server/routes/files.js +5 -0
  364. package/dist/server/routes/files.js.map +1 -1
  365. package/dist/server/routes/office.js +4 -0
  366. package/dist/server/routes/office.js.map +1 -1
  367. package/dist/server/routes/system.d.ts +2 -1
  368. package/dist/server/routes/system.js +2 -1
  369. package/dist/server/routes/system.js.map +1 -1
  370. package/dist/server/routes/workspaces.d.ts +4 -1
  371. package/dist/server/routes/workspaces.js +46 -1
  372. package/dist/server/routes/workspaces.js.map +1 -1
  373. package/dist/server/server/create-server.d.ts +6 -2
  374. package/dist/server/server/create-server.js +113 -32
  375. package/dist/server/server/create-server.js.map +1 -1
  376. package/dist/server/shared/http/error-handler.js +10 -0
  377. package/dist/server/shared/http/error-handler.js.map +1 -1
  378. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.d.ts +10 -0
  379. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.js +47 -0
  380. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.js.map +1 -0
  381. package/dist/server/storage/repositories/butler-profile-repository.js +7 -3
  382. package/dist/server/storage/repositories/butler-profile-repository.js.map +1 -1
  383. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.d.ts +19 -0
  384. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.js +55 -0
  385. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.js.map +1 -0
  386. package/dist/server/storage/repositories/session-index-repository.js +9 -2
  387. package/dist/server/storage/repositories/session-index-repository.js.map +1 -1
  388. package/dist/server/storage/repositories/user-affairs-library-setting-repository.d.ts +10 -0
  389. package/dist/server/storage/repositories/user-affairs-library-setting-repository.js +69 -0
  390. package/dist/server/storage/repositories/user-affairs-library-setting-repository.js.map +1 -0
  391. package/dist/server/storage/repositories/user-preference-profile-repository.js +6 -3
  392. package/dist/server/storage/repositories/user-preference-profile-repository.js.map +1 -1
  393. package/dist/server/storage/repositories/workspace-navigation-state-repository.d.ts +3 -0
  394. package/dist/server/storage/repositories/workspace-navigation-state-repository.js +47 -4
  395. package/dist/server/storage/repositories/workspace-navigation-state-repository.js.map +1 -1
  396. package/dist/server/storage/sqlite/client.js +230 -123
  397. package/dist/server/storage/sqlite/client.js.map +1 -1
  398. package/dist/server/storage/sqlite/schema.sql +48 -25
  399. package/dist/server/types/domain.d.ts +27 -20
  400. package/dist/server/ws/workbench-ws-hub.js +2 -2
  401. package/dist/server/ws/workbench-ws-hub.js.map +1 -1
  402. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js +0 -2
  403. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js.map +1 -1
  404. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +0 -6
  405. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
  406. package/package.json +1 -1
  407. package/dist/public/assets/AdaptiveButlerPage-B153lk5H.css +0 -1
  408. package/dist/public/assets/AdaptiveButlerPage-CJw8Ae62.js +0 -3
  409. package/dist/public/assets/DesktopModal-D_A8sgQU.js +0 -1
  410. package/dist/public/assets/DesktopWindowPage-DK7L7osV.js +0 -2
  411. package/dist/public/assets/FileContextPanel-BdCoubcJ.js +0 -1
  412. package/dist/public/assets/GitSidebar-BeZ0hj7A.js +0 -6
  413. package/dist/public/assets/MobileCreateSessionSheet-DfLMVu8q.js +0 -1
  414. package/dist/public/assets/MobileSheet-5kZ-w-gU.js +0 -1
  415. package/dist/public/assets/MobileWorkspaceSwitcherHeader-C6JMiOq_.js +0 -1
  416. package/dist/public/assets/PluginContainerPage-BlY-xJDh.js +0 -1
  417. package/dist/public/assets/SessionIndexPage-DkBp9Mqz.js +0 -1
  418. package/dist/public/assets/SettingsPage-C-ASmJAG.js +0 -2
  419. package/dist/public/assets/TerminalRuntimeFallbackModal-Bzum5nZ0.js +0 -1
  420. package/dist/public/assets/WorkbenchLayout-OFi6CWgH.js +0 -244
  421. package/dist/public/assets/WorkbenchShellRoute-B4XB8SwG.css +0 -1
  422. package/dist/public/assets/WorkbenchShellRoute-BAQe_E0O.js +0 -1
  423. package/dist/public/assets/WorkspaceDebugDetailPage-DhKa6e9y.js +0 -1
  424. package/dist/public/assets/file-tree-icon-Mg1DiBRX.js +0 -590
  425. package/dist/public/assets/index-C4t-vvqk.css +0 -1
  426. package/dist/public/assets/index-CL97fwWB.js +0 -42
  427. package/dist/public/assets/realtime-client-CLafKzzJ.js +0 -1
  428. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.d.ts +0 -32
  429. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js +0 -93
  430. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js.map +0 -1
  431. package/dist/server/modules/butler/assistant-sandbox-service.d.ts +0 -69
  432. package/dist/server/modules/butler/assistant-sandbox-service.js +0 -399
  433. package/dist/server/modules/butler/assistant-sandbox-service.js.map +0 -1
  434. package/dist/server/modules/channels/wechat-claw-client.d.ts +0 -51
  435. package/dist/server/modules/channels/wechat-claw-client.js +0 -245
  436. package/dist/server/modules/channels/wechat-claw-client.js.map +0 -1
  437. package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.d.ts +0 -18
  438. package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js +0 -191
  439. package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js.map +0 -1
@@ -0,0 +1,680 @@
1
+ import fs from "node:fs";
2
+ import path from "node:path";
3
+ import { AppError } from "../../shared/errors/app-error.js";
4
+ import { HOST_TASK_TYPES } from "../tasks/task-types.js";
5
+ import { CatalogRepository, } from "../affairs-indexer/core/src/repositories/catalog-repository.js";
6
+ import { CatalogWriteRepository, } from "../affairs-indexer/core/src/repositories/catalog-write-repository.js";
7
+ import { createAffairsIndexerRuntimeConfig } from "../affairs-indexer/internal-command-runner.js";
8
+ import { TagRecomputeService } from "../affairs-indexer/core/src/services/tagging/tag-recompute-service.js";
9
+ import { ExportBuilder } from "../affairs-indexer/core/src/services/export/export-builder.js";
10
+ import { initCatalog } from "../affairs-indexer/core/src/sqlite/init-catalog.js";
11
+ const TAG_EXPORT_REFRESH_TASK_TIMEOUT_MS = 30 * 60 * 1000;
12
+ const TAG_RECOMPUTE_TASK_TIMEOUT_MS = 30 * 60 * 1000;
13
+ export class AffairsTagService {
14
+ workspaceService;
15
+ affairsLibraryService;
16
+ taskManager;
17
+ constructor(workspaceService, affairsLibraryService, taskManager) {
18
+ this.workspaceService = workspaceService;
19
+ this.affairsLibraryService = affairsLibraryService;
20
+ this.taskManager = taskManager;
21
+ this.registerBackgroundTasks();
22
+ }
23
+ listTags(workspaceId, userId, input = {}) {
24
+ const { dbPath } = this.requireBinding(workspaceId, userId);
25
+ const repository = new CatalogRepository(dbPath);
26
+ const definitions = repository.listTagDefinitions(input.includeDisabled === true);
27
+ const enabledRules = repository.listAllEnabledTagRules();
28
+ const countByPath = this.buildTagDocumentCountMap(repository);
29
+ const resolvedRows = repository.listExportDocuments().flatMap(doc => [
30
+ ...doc.tags.map(tagPath => ({ tagPath, derived: false })),
31
+ ...doc.derivedTags.map(tagPath => ({ tagPath, derived: true })),
32
+ ]);
33
+ const parentPathById = new Map(definitions.map(item => [item.id, item.path]));
34
+ const items = definitions.map((tag) => this.toTagNodeDto(tag, parentPathById, countByPath.get(tag.path) ?? 0));
35
+ return {
36
+ items,
37
+ summary: {
38
+ totalActiveTags: items.filter(item => item.status === "active").length,
39
+ totalDisabledTags: items.filter(item => item.status === "disabled").length,
40
+ totalRuleEnabledTags: new Set(enabledRules.map(item => item.tagId)).size,
41
+ totalBoundDocuments: new Set(resolvedRows.map(item => item.tagPath)).size,
42
+ },
43
+ status: {
44
+ recomputeState: "idle",
45
+ lastRecomputedAt: null,
46
+ lastError: null,
47
+ },
48
+ };
49
+ }
50
+ getTagDetail(workspaceId, userId, tagId) {
51
+ const { dbPath } = this.requireBinding(workspaceId, userId);
52
+ const repository = new CatalogRepository(dbPath);
53
+ const definition = repository.getTagDefinitionById(tagId);
54
+ if (!definition) {
55
+ throw new AppError({
56
+ statusCode: 404,
57
+ errorCode: "AFFAIRS_TAG_NOT_FOUND",
58
+ detail: "标签不存在",
59
+ });
60
+ }
61
+ const definitions = repository.listTagDefinitions(true);
62
+ const parentPathById = new Map(definitions.map(item => [item.id, item.path]));
63
+ const countByPath = this.buildTagDocumentCountMap(repository);
64
+ const rules = repository.listTagRulesByTagIds([tagId]);
65
+ return {
66
+ ...this.toTagNodeDto(definition, parentPathById, countByPath.get(definition.path) ?? 0),
67
+ smartRules: rules.map(mapTagRuleDto),
68
+ smartRuleEnabled: rules.some(rule => rule.enabled),
69
+ };
70
+ }
71
+ ensureTagDefinition(workspaceId, userId, input) {
72
+ const normalizedPath = normalizeTagPath(input.path);
73
+ if (!normalizedPath) {
74
+ throw new AppError({
75
+ statusCode: 400,
76
+ errorCode: "AFFAIRS_TAG_PATH_REQUIRED",
77
+ detail: "标签路径不能为空",
78
+ field: "path",
79
+ });
80
+ }
81
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
82
+ const repository = new CatalogRepository(dbPath);
83
+ const writer = new CatalogWriteRepository(dbPath);
84
+ const definitions = repository.listTagDefinitions(true);
85
+ const definitionByPath = new Map(definitions.map(item => [item.path, item]));
86
+ const segments = normalizedPath.split("/").filter(Boolean);
87
+ let currentPath = "";
88
+ let parentId = null;
89
+ let lastTagId = null;
90
+ let rootType = segments[0] ?? normalizedPath;
91
+ for (const segment of segments) {
92
+ currentPath = currentPath ? `${currentPath}/${segment}` : segment;
93
+ const existing = definitionByPath.get(currentPath);
94
+ if (existing) {
95
+ if (existing.status === "disabled") {
96
+ writer.saveTagDefinition({
97
+ id: existing.id,
98
+ path: existing.path,
99
+ name: existing.name,
100
+ rootType: existing.rootType,
101
+ parentId: existing.parentId,
102
+ canonicalName: existing.canonicalName,
103
+ description: existing.description,
104
+ status: "active",
105
+ createdBy: existing.createdBy,
106
+ });
107
+ definitionByPath.set(currentPath, { ...existing, status: "active", disabledAt: null });
108
+ }
109
+ parentId = existing.id;
110
+ lastTagId = existing.id;
111
+ rootType = existing.rootType;
112
+ continue;
113
+ }
114
+ const nextParentId = parentId;
115
+ const result = writer.saveTagDefinition({
116
+ path: currentPath,
117
+ name: segment,
118
+ rootType,
119
+ parentId: nextParentId,
120
+ canonicalName: segment,
121
+ description: null,
122
+ status: "active",
123
+ createdBy: userId || "user",
124
+ });
125
+ parentId = result.id;
126
+ lastTagId = result.id;
127
+ definitionByPath.set(currentPath, {
128
+ id: result.id,
129
+ path: currentPath,
130
+ name: segment,
131
+ rootType,
132
+ parentId: nextParentId,
133
+ canonicalName: segment,
134
+ description: null,
135
+ status: "active",
136
+ createdBy: userId || "user",
137
+ createdAt: new Date().toISOString(),
138
+ updatedAt: new Date().toISOString(),
139
+ disabledAt: null,
140
+ });
141
+ }
142
+ if (!lastTagId) {
143
+ throw new AppError({
144
+ statusCode: 500,
145
+ errorCode: "AFFAIRS_TAG_ENSURE_FAILED",
146
+ detail: "标签创建失败",
147
+ });
148
+ }
149
+ this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagExportRefresh, {
150
+ key: `${workspaceId}:full`,
151
+ source: "affairs_tag.ensure_tag_definition",
152
+ input: {
153
+ workspaceId,
154
+ rootDir,
155
+ reason: `tag_definition_ensured:${lastTagId}`,
156
+ },
157
+ });
158
+ return this.getTagDetail(workspaceId, userId, lastTagId);
159
+ }
160
+ saveTagDefinition(workspaceId, userId, input) {
161
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
162
+ const repository = new CatalogRepository(dbPath);
163
+ const writer = new CatalogWriteRepository(dbPath);
164
+ const existingDefinitions = repository.listTagDefinitions(true);
165
+ const current = input.tagId
166
+ ? existingDefinitions.find(item => item.id === input.tagId) ?? null
167
+ : null;
168
+ const parent = input.parentId ? existingDefinitions.find(item => item.id === input.parentId) ?? null : null;
169
+ if (input.parentId && !parent) {
170
+ throw new AppError({
171
+ statusCode: 400,
172
+ errorCode: "AFFAIRS_TAG_PARENT_NOT_FOUND",
173
+ detail: "父标签不存在",
174
+ field: "parentId",
175
+ });
176
+ }
177
+ if (current && parent && isDescendantTag(existingDefinitions, parent.id, current.id)) {
178
+ throw new AppError({
179
+ statusCode: 400,
180
+ errorCode: "AFFAIRS_TAG_PARENT_CYCLE",
181
+ detail: "不能把标签移动到自己的下级标签下面",
182
+ field: "parentId",
183
+ });
184
+ }
185
+ const normalizedName = input.name.trim();
186
+ if (!normalizedName) {
187
+ throw new AppError({
188
+ statusCode: 400,
189
+ errorCode: "AFFAIRS_TAG_NAME_REQUIRED",
190
+ detail: "标签名称不能为空",
191
+ field: "name",
192
+ });
193
+ }
194
+ const nextPath = [parent?.path, normalizedName].filter(Boolean).join("/") || normalizedName;
195
+ const conflict = existingDefinitions.find(item => item.path === nextPath && item.id !== input.tagId);
196
+ if (conflict) {
197
+ throw new AppError({
198
+ statusCode: 409,
199
+ errorCode: "AFFAIRS_TAG_PATH_CONFLICT",
200
+ detail: "标签路径已存在,请换一个名称或层级",
201
+ field: "name",
202
+ });
203
+ }
204
+ const rootType = parent?.rootType ?? normalizedName;
205
+ if (current) {
206
+ const descendantUpdates = buildDescendantTagPathUpdates(existingDefinitions, current, nextPath, rootType);
207
+ const conflictPaths = new Set([nextPath, ...descendantUpdates.map(item => item.nextPath)]);
208
+ const conflict = existingDefinitions.find(item => item.id !== current.id
209
+ && !descendantUpdates.some(update => update.tag.id === item.id)
210
+ && conflictPaths.has(item.path));
211
+ if (conflict) {
212
+ throw new AppError({
213
+ statusCode: 409,
214
+ errorCode: "AFFAIRS_TAG_PATH_CONFLICT",
215
+ detail: "标签移动后会和现有标签路径冲突",
216
+ field: "parentId",
217
+ });
218
+ }
219
+ }
220
+ const result = writer.saveTagDefinition({
221
+ id: input.tagId,
222
+ path: nextPath,
223
+ name: normalizedName,
224
+ rootType,
225
+ parentId: parent?.id ?? null,
226
+ canonicalName: normalizedName,
227
+ description: input.description ?? null,
228
+ status: input.status ?? "active",
229
+ createdBy: userId || "user",
230
+ });
231
+ if (Array.isArray(input.smartRules)) {
232
+ writer.replaceTagRules(result.id, normalizeTagRulesInput(input.smartRules));
233
+ }
234
+ if (current) {
235
+ buildDescendantTagPathUpdates(existingDefinitions, current, nextPath, rootType)
236
+ .forEach(({ tag, nextPath: childPath }) => {
237
+ writer.saveTagDefinition({
238
+ id: tag.id,
239
+ path: childPath,
240
+ name: tag.name,
241
+ rootType,
242
+ parentId: tag.parentId,
243
+ canonicalName: tag.canonicalName,
244
+ description: tag.description,
245
+ status: tag.status === "disabled" ? "disabled" : "active",
246
+ createdBy: tag.createdBy,
247
+ });
248
+ });
249
+ }
250
+ const detail = this.getTagDetail(workspaceId, userId, result.id);
251
+ if (Array.isArray(input.smartRules)) {
252
+ this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagApplyBindings, {
253
+ key: `${workspaceId}:full`,
254
+ source: "affairs_tag.save_tag_definition",
255
+ input: {
256
+ workspaceId,
257
+ rootDir,
258
+ reason: `tag_definition_saved:${result.id}`,
259
+ scope: { kind: "full" },
260
+ },
261
+ });
262
+ }
263
+ else {
264
+ this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagExportRefresh, {
265
+ key: `${workspaceId}:full`,
266
+ source: "affairs_tag.save_tag_definition",
267
+ input: {
268
+ workspaceId,
269
+ rootDir,
270
+ reason: `tag_definition_saved:${result.id}`,
271
+ },
272
+ });
273
+ }
274
+ return detail;
275
+ }
276
+ deleteTagDefinition(workspaceId, userId, tagId) {
277
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
278
+ const repository = new CatalogRepository(dbPath);
279
+ const writer = new CatalogWriteRepository(dbPath);
280
+ const definitions = repository.listTagDefinitions(true);
281
+ const current = definitions.find(item => item.id === tagId) ?? null;
282
+ if (!current) {
283
+ throw new AppError({
284
+ statusCode: 404,
285
+ errorCode: "AFFAIRS_TAG_NOT_FOUND",
286
+ detail: "标签不存在",
287
+ });
288
+ }
289
+ const descendants = collectDescendantTags(definitions, current.id);
290
+ const deleteRows = [current, ...descendants];
291
+ const deletedTagIds = deleteRows.map(item => item.id);
292
+ const deletedPaths = deleteRows.map(item => item.path);
293
+ writer.deleteTagDefinitions([...descendants].reverse().map(item => item.id).concat(current.id));
294
+ const handle = this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagExportRefresh, {
295
+ key: `${workspaceId}:full`,
296
+ source: "affairs_tag.delete_tag_definition",
297
+ input: {
298
+ workspaceId,
299
+ rootDir,
300
+ reason: `tag_definition_deleted:${tagId}`,
301
+ },
302
+ });
303
+ return {
304
+ deletedTagIds,
305
+ deletedPaths,
306
+ exportRefreshTask: {
307
+ taskId: handle.taskId,
308
+ deduped: handle.deduped,
309
+ status: "queued",
310
+ },
311
+ };
312
+ }
313
+ getDocumentTagDetails(workspaceId, userId, documentId) {
314
+ const { dbPath } = this.requireBinding(workspaceId, userId);
315
+ const repository = new CatalogRepository(dbPath);
316
+ const context = repository.getDocumentContext(documentId);
317
+ if (!context) {
318
+ throw new AppError({
319
+ statusCode: 404,
320
+ errorCode: "AFFAIRS_DOCUMENT_NOT_FOUND",
321
+ detail: "文档不存在",
322
+ });
323
+ }
324
+ const manualBindings = repository.listManualDocumentTagBindingsByDocumentIds([documentId]);
325
+ const folderBindings = repository.listEffectiveFolderTagBindingsForDocumentPaths([context.path]);
326
+ const resolved = repository.listResolvedDocumentTagsByDocumentIds([documentId]);
327
+ return {
328
+ documentId,
329
+ path: context.path,
330
+ title: context.title,
331
+ manualTagIds: manualBindings.map(item => item.tagId),
332
+ effectiveFolderBindings: folderBindings.map(item => ({
333
+ id: item.id,
334
+ folderPath: item.folderPath,
335
+ tagId: item.tagId,
336
+ tagPath: item.tagPath,
337
+ })),
338
+ resolvedTags: resolved.map(item => ({
339
+ path: item.path,
340
+ sourceType: item.sourceType,
341
+ sourceRef: item.sourceRef,
342
+ evidence: item.evidence,
343
+ confidence: item.confidence,
344
+ priority: resolvePriority(item.sourceType),
345
+ })),
346
+ };
347
+ }
348
+ saveDocumentTagBindings(workspaceId, userId, documentId, tagIds) {
349
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
350
+ const repository = new CatalogRepository(dbPath);
351
+ const context = repository.getDocumentContext(documentId);
352
+ if (!context) {
353
+ throw new AppError({
354
+ statusCode: 404,
355
+ errorCode: "AFFAIRS_DOCUMENT_NOT_FOUND",
356
+ detail: "文档不存在",
357
+ });
358
+ }
359
+ const writer = new CatalogWriteRepository(dbPath);
360
+ writer.replaceManualDocumentTagBindings({
361
+ documentId,
362
+ inodeKey: context.inodeKey,
363
+ contentHash: context.contentHash,
364
+ size: context.size,
365
+ extension: context.extension,
366
+ }, tagIds);
367
+ const handle = this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagApplyBindings, {
368
+ key: `${workspaceId}:doc:${documentId}`,
369
+ source: "affairs_tag.save_document_bindings",
370
+ input: {
371
+ workspaceId,
372
+ rootDir,
373
+ reason: `manual_document_binding_saved:${documentId}`,
374
+ scope: { kind: "document", documentId },
375
+ },
376
+ });
377
+ return {
378
+ target: {
379
+ type: "document",
380
+ documentId,
381
+ },
382
+ items: this.getDocumentTagDetails(workspaceId, userId, documentId).resolvedTags,
383
+ refreshTask: {
384
+ taskId: handle.taskId,
385
+ deduped: handle.deduped,
386
+ affectedPaths: [context.path],
387
+ },
388
+ };
389
+ }
390
+ getFolderTagDetails(workspaceId, userId, folderPath) {
391
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
392
+ const normalizedFolderPath = normalizeFolderPath(folderPath);
393
+ const exists = normalizedFolderPath === "."
394
+ ? fs.existsSync(rootDir) && fs.statSync(rootDir).isDirectory()
395
+ : this.affairsLibraryService.resolvePreviewFile(workspaceId, userId, normalizedFolderPath, {
396
+ mustExist: false,
397
+ kind: "directory",
398
+ }).exists;
399
+ const repository = new CatalogRepository(dbPath);
400
+ const bindings = repository.listFolderTagBindingsByPaths([normalizedFolderPath]);
401
+ return {
402
+ folderPath: normalizedFolderPath,
403
+ exists,
404
+ bindingTagIds: bindings.map(item => item.tagId),
405
+ bindings: bindings.map(item => ({
406
+ id: item.id,
407
+ tagId: item.tagId,
408
+ tagPath: item.tagPath,
409
+ applyMode: item.applyMode,
410
+ })),
411
+ };
412
+ }
413
+ getFolderTagApplyTaskSnapshot(workspaceId, userId, folderPath) {
414
+ this.requireBinding(workspaceId, userId);
415
+ const normalizedFolderPath = normalizeFolderPath(folderPath);
416
+ return this.taskManager.peek(HOST_TASK_TYPES.affairsLibraryTagApplyBindings, `${workspaceId}:folder:${normalizedFolderPath}`);
417
+ }
418
+ getDocumentTagApplyTaskSnapshot(workspaceId, userId, documentId) {
419
+ this.requireBinding(workspaceId, userId);
420
+ return this.taskManager.peek(HOST_TASK_TYPES.affairsLibraryTagApplyBindings, `${workspaceId}:doc:${documentId}`);
421
+ }
422
+ getFullTagRecomputeTaskSnapshot(workspaceId, userId) {
423
+ this.requireBinding(workspaceId, userId);
424
+ return this.taskManager.peek(HOST_TASK_TYPES.affairsLibraryTagRecompute, `${workspaceId}:full`);
425
+ }
426
+ getTagRecoveryStatus(workspaceId, userId) {
427
+ const { dbPath } = this.requireBinding(workspaceId, userId);
428
+ const repository = new CatalogRepository(dbPath);
429
+ return {
430
+ task: this.taskManager.peek(HOST_TASK_TYPES.affairsLibraryTagRecompute, `${workspaceId}:full`),
431
+ bindingStats: repository.getManualTagBindingStats(),
432
+ };
433
+ }
434
+ requestFullTagRecompute(workspaceId, userId) {
435
+ const { rootDir } = this.requireBinding(workspaceId, userId);
436
+ const handle = this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagRecompute, {
437
+ key: `${workspaceId}:full`,
438
+ source: "affairs_tag.request_full_recompute",
439
+ input: {
440
+ workspaceId,
441
+ rootDir,
442
+ reason: "manual_full_recompute_requested",
443
+ scope: { kind: "full", mode: "full" },
444
+ },
445
+ });
446
+ return {
447
+ taskId: handle.taskId,
448
+ deduped: handle.deduped,
449
+ status: "queued",
450
+ scope: "full",
451
+ };
452
+ }
453
+ saveFolderTagBindings(workspaceId, userId, folderPath, tagIds) {
454
+ const { dbPath, rootDir } = this.requireBinding(workspaceId, userId);
455
+ const normalizedFolderPath = normalizeFolderPath(folderPath);
456
+ const writer = new CatalogWriteRepository(dbPath);
457
+ writer.replaceFolderTagBindings(normalizedFolderPath, tagIds);
458
+ const handle = this.taskManager.enqueue(HOST_TASK_TYPES.affairsLibraryTagApplyBindings, {
459
+ key: `${workspaceId}:folder:${normalizedFolderPath}`,
460
+ source: "affairs_tag.save_folder_bindings",
461
+ input: {
462
+ workspaceId,
463
+ rootDir,
464
+ reason: `folder_binding_saved:${normalizedFolderPath}`,
465
+ // 文件夹分配标签只重跑目标文件夹子树,但要走完整标签推理,
466
+ // 这样它和“位于某文件夹及其子文件夹”的智能规则语义保持一致。
467
+ scope: { kind: "folder", folderPath: normalizedFolderPath },
468
+ },
469
+ });
470
+ return {
471
+ target: {
472
+ type: "folder",
473
+ folderPath: normalizedFolderPath,
474
+ },
475
+ items: [],
476
+ refreshTask: {
477
+ taskId: handle.taskId,
478
+ deduped: handle.deduped,
479
+ affectedPaths: [normalizedFolderPath],
480
+ },
481
+ };
482
+ }
483
+ requireBinding(workspaceId, userId) {
484
+ this.workspaceService.getWorkspaceOrThrow(workspaceId);
485
+ const binding = this.affairsLibraryService.getBinding(workspaceId, userId);
486
+ const rootDir = binding?.rootDir?.trim() ?? "";
487
+ if (!rootDir || binding?.enabled !== true) {
488
+ throw new AppError({
489
+ statusCode: 409,
490
+ errorCode: "AFFAIRS_LIBRARY_BINDING_REQUIRED",
491
+ detail: "当前工作区还没有启用事务文档库",
492
+ });
493
+ }
494
+ // 这里不能假设 catalog.db 一定已经被 helper 跑到最新版本。
495
+ // 事务文档库标签接口会直接打开 SQLite;如果用户库还是旧 schema,
496
+ // prepareStatements 阶段就会因为缺表直接炸掉。
497
+ // 所以每次进入标签链路前先补一次幂等迁移,保证旧库也能安全读写。
498
+ initCatalog(createAffairsIndexerRuntimeConfig(rootDir));
499
+ return {
500
+ rootDir,
501
+ dbPath: resolveCatalogDbPath(rootDir),
502
+ };
503
+ }
504
+ registerBackgroundTasks() {
505
+ if (!this.taskManager.has(HOST_TASK_TYPES.affairsLibraryTagRecompute)) {
506
+ this.taskManager.register({
507
+ taskType: HOST_TASK_TYPES.affairsLibraryTagRecompute,
508
+ executionLane: "helper_process",
509
+ // 事务文档库全量标签恢复可能要扫几千到上万文档,30s 很容易误杀。
510
+ timeoutMs: TAG_RECOMPUTE_TASK_TIMEOUT_MS,
511
+ run: async (input, context) => {
512
+ await new TagRecomputeService(createAffairsIndexerRuntimeConfig(input.rootDir)).run({
513
+ scope: input.scope,
514
+ signal: context.signal,
515
+ onProgress: context.reportProgress,
516
+ });
517
+ return { ok: true };
518
+ },
519
+ });
520
+ }
521
+ if (!this.taskManager.has(HOST_TASK_TYPES.affairsLibraryTagApplyBindings)) {
522
+ this.taskManager.register({
523
+ taskType: HOST_TASK_TYPES.affairsLibraryTagApplyBindings,
524
+ executionLane: "helper_process",
525
+ timeoutMs: TAG_RECOMPUTE_TASK_TIMEOUT_MS,
526
+ run: async (input, context) => {
527
+ await new TagRecomputeService(createAffairsIndexerRuntimeConfig(input.rootDir)).run({
528
+ scope: input.scope,
529
+ signal: context.signal,
530
+ onProgress: context.reportProgress,
531
+ });
532
+ return { ok: true };
533
+ },
534
+ });
535
+ }
536
+ if (!this.taskManager.has(HOST_TASK_TYPES.affairsLibraryTagExportRefresh)) {
537
+ this.taskManager.register({
538
+ taskType: HOST_TASK_TYPES.affairsLibraryTagExportRefresh,
539
+ executionLane: "helper_process",
540
+ helperProcessHandler: "affairs.library_export",
541
+ // 这里跑的不是轻量标签刷新,而是整套静态导出。
542
+ // 大库下 20s 很容易误判超时,直接对齐文档库索引任务的分钟级超时。
543
+ timeoutMs: TAG_EXPORT_REFRESH_TASK_TIMEOUT_MS,
544
+ run: async (input, context) => {
545
+ await new ExportBuilder(createAffairsIndexerRuntimeConfig(input.rootDir)).build({
546
+ signal: context.signal,
547
+ });
548
+ return { ok: true };
549
+ },
550
+ });
551
+ }
552
+ }
553
+ toTagNodeDto(row, parentPathById, documentCount) {
554
+ return {
555
+ id: row.id,
556
+ path: row.path,
557
+ name: row.name,
558
+ rootType: row.rootType,
559
+ parentId: row.parentId,
560
+ parentPath: row.parentId ? parentPathById.get(row.parentId) ?? null : null,
561
+ description: row.description,
562
+ status: row.status === "disabled" ? "disabled" : "active",
563
+ documentCount,
564
+ createdAt: row.createdAt,
565
+ updatedAt: row.updatedAt,
566
+ disabledAt: row.disabledAt,
567
+ };
568
+ }
569
+ buildTagDocumentCountMap(repository) {
570
+ const countByPath = new Map();
571
+ repository.listExportDocuments().forEach((document) => {
572
+ document.tags.forEach((tagPath) => {
573
+ countByPath.set(tagPath, (countByPath.get(tagPath) ?? 0) + 1);
574
+ });
575
+ document.derivedTags.forEach((tagPath) => {
576
+ countByPath.set(tagPath, (countByPath.get(tagPath) ?? 0) + 1);
577
+ });
578
+ });
579
+ return countByPath;
580
+ }
581
+ }
582
+ function isDescendantTag(definitions, candidateId, ancestorId) {
583
+ let current = definitions.find(item => item.id === candidateId) ?? null;
584
+ const visited = new Set();
585
+ while (current?.parentId) {
586
+ if (current.parentId === ancestorId) {
587
+ return true;
588
+ }
589
+ if (visited.has(current.parentId)) {
590
+ return false;
591
+ }
592
+ visited.add(current.parentId);
593
+ current = definitions.find(item => item.id === current?.parentId) ?? null;
594
+ }
595
+ return false;
596
+ }
597
+ function collectDescendantTags(definitions, ancestorId) {
598
+ const childrenByParentId = new Map();
599
+ definitions.forEach((item) => {
600
+ if (!item.parentId) {
601
+ return;
602
+ }
603
+ const items = childrenByParentId.get(item.parentId) ?? [];
604
+ items.push(item);
605
+ childrenByParentId.set(item.parentId, items);
606
+ });
607
+ const result = [];
608
+ const queue = [...(childrenByParentId.get(ancestorId) ?? [])];
609
+ while (queue.length > 0) {
610
+ const current = queue.shift();
611
+ result.push(current);
612
+ const children = childrenByParentId.get(current.id);
613
+ if (children?.length) {
614
+ queue.push(...children);
615
+ }
616
+ }
617
+ return result;
618
+ }
619
+ function buildDescendantTagPathUpdates(definitions, current, nextPath, nextRootType) {
620
+ const oldPrefix = `${current.path}/`;
621
+ const nextPrefix = `${nextPath}/`;
622
+ return definitions
623
+ .filter(item => item.path.startsWith(oldPrefix))
624
+ .sort((left, right) => left.path.localeCompare(right.path, "zh-Hans-CN"))
625
+ .map(tag => ({
626
+ tag,
627
+ nextPath: `${nextPrefix}${tag.path.slice(oldPrefix.length)}`,
628
+ nextRootType,
629
+ }));
630
+ }
631
+ function normalizeFolderPath(value) {
632
+ return value.trim().replace(/^\.\/+/, "").replace(/\/+$/g, "") || ".";
633
+ }
634
+ function normalizeTagPath(value) {
635
+ return value
636
+ .trim()
637
+ .replace(/^\/+/, "")
638
+ .replace(/\/+$/g, "")
639
+ .split("/")
640
+ .map(item => item.trim())
641
+ .filter(Boolean)
642
+ .join("/");
643
+ }
644
+ function resolveCatalogDbPath(rootDir) {
645
+ return path.join(rootDir, ".ai-index", "catalog.db");
646
+ }
647
+ function resolvePriority(sourceType) {
648
+ switch (sourceType) {
649
+ case "manual_document":
650
+ return 1;
651
+ case "folder_binding":
652
+ return 2;
653
+ case "smart_rule":
654
+ return 3;
655
+ case "system_derived":
656
+ return 4;
657
+ }
658
+ }
659
+ function mapTagRuleDto(rule) {
660
+ return {
661
+ id: rule.id,
662
+ relation: rule.relation,
663
+ ruleType: rule.ruleType,
664
+ matcher: rule.matcher,
665
+ enabled: rule.enabled,
666
+ priority: rule.priority,
667
+ };
668
+ }
669
+ function normalizeTagRulesInput(rules) {
670
+ return rules
671
+ .map((rule, index) => ({
672
+ relation: (rule.relation === "or" || rule.relation === "not" ? rule.relation : "and"),
673
+ ruleType: rule.ruleType,
674
+ matcher: rule.matcher,
675
+ enabled: rule.enabled !== false,
676
+ priority: Number.isFinite(rule.priority) ? rule.priority : index,
677
+ }))
678
+ .sort((left, right) => left.priority - right.priority);
679
+ }
680
+ //# sourceMappingURL=affairs-tag-service.js.map