@jingyi0605/codingns 0.8.1 → 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 (587) hide show
  1. package/bin/codingns.mjs +187 -156
  2. package/dist/public/assets/AdaptiveButlerPage-B17QiMyT.js +2 -0
  3. package/dist/public/assets/App-CFBwDUNA.js +30 -0
  4. package/dist/public/assets/{BootstrapPage-jFfl7KNK.js → BootstrapPage-W5wU3BPh.js} +1 -1
  5. package/dist/public/assets/{ConversationPage-sj_rn4q0.js → ConversationPage-DQLX1bUh.js} +6 -6
  6. package/dist/public/assets/{DesktopDetachPreviewPage-C5c88SOX.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-_I0t7cC_.js → MobileTopHeaderFrame-BbNON3Y4.js} +1 -1
  14. package/dist/public/assets/MobileWorkspaceSwitcherHeader-BZEzPeMj.js +1 -0
  15. package/dist/public/assets/PluginAccessOverview-mQDmAljp.js +1 -0
  16. package/dist/public/assets/PluginContainerPage-CcxUJpM4.js +1 -0
  17. package/dist/public/assets/PluginDetailPage-D5--ACIt.js +1 -0
  18. package/dist/public/assets/PluginsListPage-D_oJxYXT.js +1 -0
  19. package/dist/public/assets/{RelayConnectEntryPage-CMtDWyGS.js → RelayConnectEntryPage-DROxpnkv.js} +1 -1
  20. package/dist/public/assets/ServerSettingsModal-CUUOPqSe.js +1 -0
  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-CjzbiWjl.js +1 -0
  24. package/dist/public/assets/{TerminalPage-CBIKHI33.js → TerminalPage-CwWyFDj8.js} +3 -3
  25. package/dist/public/assets/TerminalRuntimeFallbackModal-CSVVbO8r.js +1 -0
  26. package/dist/public/assets/ToolFilesPage-QBEY8oCf.js +1 -0
  27. package/dist/public/assets/ToolGitPage-BKoZ2l9v.js +1 -0
  28. package/dist/public/assets/ToolProcessesPage-BOH0ib4G.js +1 -0
  29. package/dist/public/assets/ToolsHomePage-BcMZ3BCQ.js +1 -0
  30. package/dist/public/assets/WorkbenchLandingPage-B5zoppEl.js +1 -0
  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-NGmPgqaE.js +1 -0
  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-DgOSjscR.js +1 -0
  38. package/dist/public/assets/WorkspaceHomePage-HPa7M_Vh.js +1 -0
  39. package/dist/public/assets/{client-runtime-manager-CdJP7nUp.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-C-mo698r.js → login-direct-candidate-resolver-DkKyFtQJ.js} +1 -1
  43. package/dist/public/assets/plugin-permission-copy-CzN269Bk.js +1 -0
  44. package/dist/public/assets/plugins-api-Bv9DHpLF.js +1 -0
  45. package/dist/public/assets/{preferences-service-CnaTvZq2.js → preferences-service-D2ISL2Zz.js} +1 -1
  46. package/dist/public/assets/{relay-entry-D7OgZZN-.js → relay-entry-Bg0OisQy.js} +1 -1
  47. package/dist/public/assets/{terminal-runtime-meta-BCtAYB0E.js → terminal-runtime-meta-C8t-CIDF.js} +1 -1
  48. package/dist/public/assets/useRegisteredDebugTemplates-Bol3NVfN.js +1 -0
  49. package/dist/public/assets/workbench-navigation-B7IjRQd8.js +1 -0
  50. package/dist/public/index.html +2 -2
  51. package/dist/server/config/env.d.ts +1 -0
  52. package/dist/server/config/env.js +4 -0
  53. package/dist/server/config/env.js.map +1 -1
  54. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js +1 -1
  55. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js.map +1 -1
  56. package/dist/server/middlewares/auth-guard.js +10 -5
  57. package/dist/server/middlewares/auth-guard.js.map +1 -1
  58. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.d.ts +11 -0
  59. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.js +22 -0
  60. package/dist/server/modules/affairs-indexer/contracts/src/errors/app-error.js.map +1 -0
  61. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.d.ts +23 -0
  62. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.js +23 -0
  63. package/dist/server/modules/affairs-indexer/contracts/src/errors/error-codes.js.map +1 -0
  64. package/dist/server/modules/affairs-indexer/contracts/src/index.d.ts +4 -0
  65. package/dist/server/modules/affairs-indexer/contracts/src/index.js +5 -0
  66. package/dist/server/modules/affairs-indexer/contracts/src/index.js.map +1 -0
  67. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.d.ts +7 -0
  68. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.js +2 -0
  69. package/dist/server/modules/affairs-indexer/contracts/src/types/cli-command-context.js.map +1 -0
  70. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.d.ts +16 -0
  71. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.js +2 -0
  72. package/dist/server/modules/affairs-indexer/contracts/src/types/runtime-config.js.map +1 -0
  73. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.d.ts +10 -0
  74. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.js +215 -0
  75. package/dist/server/modules/affairs-indexer/core/src/config/load-runtime-config.js.map +1 -0
  76. package/dist/server/modules/affairs-indexer/core/src/index.d.ts +31 -0
  77. package/dist/server/modules/affairs-indexer/core/src/index.js +32 -0
  78. package/dist/server/modules/affairs-indexer/core/src/index.js.map +1 -0
  79. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.d.ts +20 -0
  80. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.js +47 -0
  81. package/dist/server/modules/affairs-indexer/core/src/logging/structured-logger.js.map +1 -0
  82. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.d.ts +17 -0
  83. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.js +63 -0
  84. package/dist/server/modules/affairs-indexer/core/src/parser/base-complex-parser-adapter.js.map +1 -0
  85. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.d.ts +12 -0
  86. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.js +42 -0
  87. package/dist/server/modules/affairs-indexer/core/src/parser/complex-document-skip-adapter.js.map +1 -0
  88. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.d.ts +7 -0
  89. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.js +107 -0
  90. package/dist/server/modules/affairs-indexer/core/src/parser/csv-parser-adapter.js.map +1 -0
  91. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.d.ts +19 -0
  92. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.js +37 -0
  93. package/dist/server/modules/affairs-indexer/core/src/parser/document-parser.js.map +1 -0
  94. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.d.ts +7 -0
  95. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.js +123 -0
  96. package/dist/server/modules/affairs-indexer/core/src/parser/docx-parser-adapter.js.map +1 -0
  97. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.d.ts +8 -0
  98. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.js +111 -0
  99. package/dist/server/modules/affairs-indexer/core/src/parser/openxml-utils.js.map +1 -0
  100. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.d.ts +42 -0
  101. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.js +2 -0
  102. package/dist/server/modules/affairs-indexer/core/src/parser/parser-adapter.js.map +1 -0
  103. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.d.ts +18 -0
  104. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.js +91 -0
  105. package/dist/server/modules/affairs-indexer/core/src/parser/parser-capability-registry.js.map +1 -0
  106. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.d.ts +18 -0
  107. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.js +59 -0
  108. package/dist/server/modules/affairs-indexer/core/src/parser/parser-router.js.map +1 -0
  109. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.d.ts +48 -0
  110. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.js +193 -0
  111. package/dist/server/modules/affairs-indexer/core/src/parser/parser-skip-repository.js.map +1 -0
  112. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.d.ts +7 -0
  113. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.js +371 -0
  114. package/dist/server/modules/affairs-indexer/core/src/parser/pdf-parser-adapter.js.map +1 -0
  115. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.d.ts +10 -0
  116. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.js +55 -0
  117. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser-adapter.js.map +1 -0
  118. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.d.ts +9 -0
  119. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.js +2 -0
  120. package/dist/server/modules/affairs-indexer/core/src/parser/plain-text-parser.js.map +1 -0
  121. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.d.ts +7 -0
  122. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.js +130 -0
  123. package/dist/server/modules/affairs-indexer/core/src/parser/pptx-parser-adapter.js.map +1 -0
  124. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.d.ts +7 -0
  125. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.js +228 -0
  126. package/dist/server/modules/affairs-indexer/core/src/parser/xlsx-parser-adapter.js.map +1 -0
  127. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.d.ts +205 -0
  128. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.js +1471 -0
  129. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-repository.js.map +1 -0
  130. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.d.ts +161 -0
  131. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.js +1350 -0
  132. package/dist/server/modules/affairs-indexer/core/src/repositories/catalog-write-repository.js.map +1 -0
  133. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.d.ts +32 -0
  134. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.js +208 -0
  135. package/dist/server/modules/affairs-indexer/core/src/scanner/file-scanner.js.map +1 -0
  136. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.d.ts +30 -0
  137. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.js +66 -0
  138. package/dist/server/modules/affairs-indexer/core/src/services/dirty/dirty-scope-resolver.js.map +1 -0
  139. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.d.ts +33 -0
  140. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.js +705 -0
  141. package/dist/server/modules/affairs-indexer/core/src/services/export/export-builder.js.map +1 -0
  142. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.d.ts +80 -0
  143. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.js +193 -0
  144. package/dist/server/modules/affairs-indexer/core/src/services/indexer/allowed-extensions-diff-service.js.map +1 -0
  145. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.d.ts +77 -0
  146. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.js +467 -0
  147. package/dist/server/modules/affairs-indexer/core/src/services/indexer/text-indexer.js.map +1 -0
  148. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.d.ts +17 -0
  149. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.js +264 -0
  150. package/dist/server/modules/affairs-indexer/core/src/services/mcp/mcp-stdio-server.js.map +1 -0
  151. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.d.ts +11 -0
  152. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.js +76 -0
  153. package/dist/server/modules/affairs-indexer/core/src/services/search/offline-search-service.js.map +1 -0
  154. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.d.ts +26 -0
  155. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.js +305 -0
  156. package/dist/server/modules/affairs-indexer/core/src/services/search/search-index-builder.js.map +1 -0
  157. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.d.ts +53 -0
  158. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.js +566 -0
  159. package/dist/server/modules/affairs-indexer/core/src/services/tagging/tag-recompute-service.js.map +1 -0
  160. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.d.ts +47 -0
  161. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.js +227 -0
  162. package/dist/server/modules/affairs-indexer/core/src/services/watch/watch-service.js.map +1 -0
  163. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.d.ts +5 -0
  164. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.js +245 -0
  165. package/dist/server/modules/affairs-indexer/core/src/sqlite/catalog-schema.js.map +1 -0
  166. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.d.ts +14 -0
  167. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.js +87 -0
  168. package/dist/server/modules/affairs-indexer/core/src/sqlite/detect-catalog-schema.js.map +1 -0
  169. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.d.ts +13 -0
  170. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.js +16 -0
  171. package/dist/server/modules/affairs-indexer/core/src/sqlite/init-catalog.js.map +1 -0
  172. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.d.ts +22 -0
  173. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.js +430 -0
  174. package/dist/server/modules/affairs-indexer/core/src/sqlite/migration-runner.js.map +1 -0
  175. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.d.ts +9 -0
  176. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.js +19 -0
  177. package/dist/server/modules/affairs-indexer/core/src/sqlite/open-database.js.map +1 -0
  178. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.d.ts +21 -0
  179. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.js +94 -0
  180. package/dist/server/modules/affairs-indexer/core/src/tagging/simple-tag-inference.js.map +1 -0
  181. package/dist/server/modules/affairs-indexer/core/src/utils/abort.d.ts +2 -0
  182. package/dist/server/modules/affairs-indexer/core/src/utils/abort.js +13 -0
  183. package/dist/server/modules/affairs-indexer/core/src/utils/abort.js.map +1 -0
  184. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.d.ts +9 -0
  185. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.js +64 -0
  186. package/dist/server/modules/affairs-indexer/core/src/utils/file-streaming.js.map +1 -0
  187. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.d.ts +10 -0
  188. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.js +230 -0
  189. package/dist/server/modules/affairs-indexer/core/src/utils/root-command-lock.js.map +1 -0
  190. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.d.ts +2 -0
  191. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.js +19 -0
  192. package/dist/server/modules/affairs-indexer/core/src/utils/rss-log.js.map +1 -0
  193. package/dist/server/modules/affairs-indexer/internal-command-runner.d.ts +31 -0
  194. package/dist/server/modules/affairs-indexer/internal-command-runner.js +643 -0
  195. package/dist/server/modules/affairs-indexer/internal-command-runner.js.map +1 -0
  196. package/dist/server/modules/assistant-capability/assistant-capability-controller.d.ts +0 -49
  197. package/dist/server/modules/assistant-capability/assistant-capability-controller.js +10 -56
  198. package/dist/server/modules/assistant-capability/assistant-capability-controller.js.map +1 -1
  199. package/dist/server/modules/assistant-capability/assistant-capability-service.d.ts +2 -46
  200. package/dist/server/modules/assistant-capability/assistant-capability-service.js +15 -158
  201. package/dist/server/modules/assistant-capability/assistant-capability-service.js.map +1 -1
  202. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.d.ts +4 -2
  203. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js +62 -21
  204. package/dist/server/modules/browser-runtime/opencli-bridge-browser-executor.js.map +1 -1
  205. package/dist/server/modules/butler/butler-control-session-service.d.ts +3 -4
  206. package/dist/server/modules/butler/butler-control-session-service.js +39 -62
  207. package/dist/server/modules/butler/butler-control-session-service.js.map +1 -1
  208. package/dist/server/modules/butler/butler-controller.d.ts +11 -3
  209. package/dist/server/modules/butler/butler-controller.js +19 -4
  210. package/dist/server/modules/butler/butler-controller.js.map +1 -1
  211. package/dist/server/modules/butler/butler-follow-up-service.js.map +1 -1
  212. package/dist/server/modules/butler/butler-profile-service.d.ts +1 -1
  213. package/dist/server/modules/butler/butler-profile-service.js +34 -63
  214. package/dist/server/modules/butler/butler-profile-service.js.map +1 -1
  215. package/dist/server/modules/butler/butler-project-service.d.ts +1 -3
  216. package/dist/server/modules/butler/butler-project-service.js +1 -7
  217. package/dist/server/modules/butler/butler-project-service.js.map +1 -1
  218. package/dist/server/modules/butler/butler-session-service.d.ts +1 -0
  219. package/dist/server/modules/butler/butler-session-service.js +109 -0
  220. package/dist/server/modules/butler/butler-session-service.js.map +1 -1
  221. package/dist/server/modules/butler/butler-session-summary-service.js +0 -2
  222. package/dist/server/modules/butler/butler-session-summary-service.js.map +1 -1
  223. package/dist/server/modules/butler/butler-workspace-context.d.ts +5 -1
  224. package/dist/server/modules/butler/butler-workspace-context.js +21 -12
  225. package/dist/server/modules/butler/butler-workspace-context.js.map +1 -1
  226. package/dist/server/modules/file/file-access-guard.d.ts +2 -0
  227. package/dist/server/modules/file/file-access-guard.js +24 -2
  228. package/dist/server/modules/file/file-access-guard.js.map +1 -1
  229. package/dist/server/modules/file/file-content-service.d.ts +11 -0
  230. package/dist/server/modules/file/file-content-service.js +55 -0
  231. package/dist/server/modules/file/file-content-service.js.map +1 -1
  232. package/dist/server/modules/file/file-controller.d.ts +178 -1
  233. package/dist/server/modules/file/file-controller.js +273 -4
  234. package/dist/server/modules/file/file-controller.js.map +1 -1
  235. package/dist/server/modules/file/file-preview-link-service.d.ts +3 -0
  236. package/dist/server/modules/file/file-preview-link-service.js +30 -1
  237. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  238. package/dist/server/modules/file/file-preview-service.js +15 -4
  239. package/dist/server/modules/file/file-preview-service.js.map +1 -1
  240. package/dist/server/modules/file/file-preview-types.d.ts +9 -1
  241. package/dist/server/modules/file/file-preview-types.js +8 -1
  242. package/dist/server/modules/file/file-preview-types.js.map +1 -1
  243. package/dist/server/modules/file/recent-modified-file-service.d.ts +15 -0
  244. package/dist/server/modules/file/recent-modified-file-service.js +102 -0
  245. package/dist/server/modules/file/recent-modified-file-service.js.map +1 -0
  246. package/dist/server/modules/file/runtime/codingns-workspace-bridge.js +917 -0
  247. package/dist/server/modules/file/workspace-file-bridge-service.d.ts +137 -0
  248. package/dist/server/modules/file/workspace-file-bridge-service.js +490 -0
  249. package/dist/server/modules/file/workspace-file-bridge-service.js.map +1 -0
  250. package/dist/server/modules/file/workspace-file-bridge-watch-service.d.ts +42 -0
  251. package/dist/server/modules/file/workspace-file-bridge-watch-service.js +304 -0
  252. package/dist/server/modules/file/workspace-file-bridge-watch-service.js.map +1 -0
  253. package/dist/server/modules/file/workspace-index-apply-service.d.ts +25 -0
  254. package/dist/server/modules/file/workspace-index-apply-service.js +42 -0
  255. package/dist/server/modules/file/workspace-index-apply-service.js.map +1 -0
  256. package/dist/server/modules/model-switch/cc-switch-adapter.js +1 -1
  257. package/dist/server/modules/model-switch/cc-switch-adapter.js.map +1 -1
  258. package/dist/server/modules/office/office-controller.d.ts +15 -1
  259. package/dist/server/modules/office/office-controller.js +26 -1
  260. package/dist/server/modules/office/office-controller.js.map +1 -1
  261. package/dist/server/modules/office/onlyoffice-integration-service.d.ts +78 -0
  262. package/dist/server/modules/office/onlyoffice-integration-service.js +610 -0
  263. package/dist/server/modules/office/onlyoffice-integration-service.js.map +1 -0
  264. package/dist/server/modules/plugins/plugin-controller.d.ts +131 -0
  265. package/dist/server/modules/plugins/plugin-controller.js +277 -0
  266. package/dist/server/modules/plugins/plugin-controller.js.map +1 -0
  267. package/dist/server/modules/plugins/plugin-file-gateway-service.d.ts +50 -0
  268. package/dist/server/modules/plugins/plugin-file-gateway-service.js +191 -0
  269. package/dist/server/modules/plugins/plugin-file-gateway-service.js.map +1 -0
  270. package/dist/server/modules/plugins/plugin-manifest.d.ts +8 -0
  271. package/dist/server/modules/plugins/plugin-manifest.js +420 -0
  272. package/dist/server/modules/plugins/plugin-manifest.js.map +1 -0
  273. package/dist/server/modules/plugins/plugin-permission-service.d.ts +49 -0
  274. package/dist/server/modules/plugins/plugin-permission-service.js +267 -0
  275. package/dist/server/modules/plugins/plugin-permission-service.js.map +1 -0
  276. package/dist/server/modules/plugins/plugin-process-runner.d.ts +21 -0
  277. package/dist/server/modules/plugins/plugin-process-runner.js +127 -0
  278. package/dist/server/modules/plugins/plugin-process-runner.js.map +1 -0
  279. package/dist/server/modules/plugins/plugin-registry-service.d.ts +41 -0
  280. package/dist/server/modules/plugins/plugin-registry-service.js +238 -0
  281. package/dist/server/modules/plugins/plugin-registry-service.js.map +1 -0
  282. package/dist/server/modules/plugins/plugin-runtime-service.d.ts +55 -0
  283. package/dist/server/modules/plugins/plugin-runtime-service.js +252 -0
  284. package/dist/server/modules/plugins/plugin-runtime-service.js.map +1 -0
  285. package/dist/server/modules/plugins/plugin-runtime-session-service.d.ts +21 -0
  286. package/dist/server/modules/plugins/plugin-runtime-session-service.js +83 -0
  287. package/dist/server/modules/plugins/plugin-runtime-session-service.js.map +1 -0
  288. package/dist/server/modules/plugins/plugin-scheduler-service.d.ts +31 -0
  289. package/dist/server/modules/plugins/plugin-scheduler-service.js +232 -0
  290. package/dist/server/modules/plugins/plugin-scheduler-service.js.map +1 -0
  291. package/dist/server/modules/plugins/plugin-static-service.d.ts +11 -0
  292. package/dist/server/modules/plugins/plugin-static-service.js +145 -0
  293. package/dist/server/modules/plugins/plugin-static-service.js.map +1 -0
  294. package/dist/server/modules/preferences/profile-service.d.ts +1 -0
  295. package/dist/server/modules/preferences/profile-service.js +27 -3
  296. package/dist/server/modules/preferences/profile-service.js.map +1 -1
  297. package/dist/server/modules/presentation/presentation-controller.d.ts +3 -0
  298. package/dist/server/modules/presentation/presentation-controller.js +11 -0
  299. package/dist/server/modules/presentation/presentation-controller.js.map +1 -1
  300. package/dist/server/modules/presentation/presentation-export-task-service.d.ts +6 -0
  301. package/dist/server/modules/presentation/presentation-export-task-service.js +52 -8
  302. package/dist/server/modules/presentation/presentation-export-task-service.js.map +1 -1
  303. package/dist/server/modules/presentation/presentation-pptx-export-service.js +200 -14
  304. package/dist/server/modules/presentation/presentation-pptx-export-service.js.map +1 -1
  305. package/dist/server/modules/presentation/presentation-renderer.d.ts +50 -0
  306. package/dist/server/modules/presentation/presentation-renderer.js +450 -37
  307. package/dist/server/modules/presentation/presentation-renderer.js.map +1 -1
  308. package/dist/server/modules/sessions/codex-app-server-helper-process.js +0 -8
  309. package/dist/server/modules/sessions/codex-app-server-helper-process.js.map +1 -1
  310. package/dist/server/modules/sessions/session-controller.d.ts +1 -0
  311. package/dist/server/modules/sessions/session-controller.js +3 -0
  312. package/dist/server/modules/sessions/session-controller.js.map +1 -1
  313. package/dist/server/modules/sessions/session-history-service.d.ts +2 -0
  314. package/dist/server/modules/sessions/session-history-service.js +78 -3
  315. package/dist/server/modules/sessions/session-history-service.js.map +1 -1
  316. package/dist/server/modules/sessions/session-live-runtime-service.d.ts +1 -0
  317. package/dist/server/modules/sessions/session-live-runtime-service.js +4 -0
  318. package/dist/server/modules/sessions/session-live-runtime-service.js.map +1 -1
  319. package/dist/server/modules/sessions/session-permission-request-service.js +0 -4
  320. package/dist/server/modules/sessions/session-permission-request-service.js.map +1 -1
  321. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.d.ts +23 -0
  322. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.js +122 -0
  323. package/dist/server/modules/sessions/workspace-session-instruction-watch-service.js.map +1 -0
  324. package/dist/server/modules/sessions/workspace-session-runtime-context-service.d.ts +15 -0
  325. package/dist/server/modules/sessions/workspace-session-runtime-context-service.js +93 -10
  326. package/dist/server/modules/sessions/workspace-session-runtime-context-service.js.map +1 -1
  327. package/dist/server/modules/skills/builtin-skills/codingns-assistant/SKILL.md +6 -7
  328. package/dist/server/modules/skills/builtin-skills/codingns-assistant/references/cli-workflow.md +2 -3
  329. package/dist/server/modules/system/host-resource-controller.d.ts +7 -0
  330. package/dist/server/modules/system/host-resource-controller.js +12 -0
  331. package/dist/server/modules/system/host-resource-controller.js.map +1 -0
  332. package/dist/server/modules/system/host-resource-service.d.ts +54 -0
  333. package/dist/server/modules/system/host-resource-service.js +162 -0
  334. package/dist/server/modules/system/host-resource-service.js.map +1 -0
  335. package/dist/server/modules/tasks/observability-service.d.ts +12 -2
  336. package/dist/server/modules/tasks/observability-service.js +13 -1
  337. package/dist/server/modules/tasks/observability-service.js.map +1 -1
  338. package/dist/server/modules/tasks/task-helper-client.d.ts +36 -2
  339. package/dist/server/modules/tasks/task-helper-client.js +201 -19
  340. package/dist/server/modules/tasks/task-helper-client.js.map +1 -1
  341. package/dist/server/modules/tasks/task-helper-pool.d.ts +37 -0
  342. package/dist/server/modules/tasks/task-helper-pool.js +173 -0
  343. package/dist/server/modules/tasks/task-helper-pool.js.map +1 -0
  344. package/dist/server/modules/tasks/task-helper-process-handlers.d.ts +27 -0
  345. package/dist/server/modules/tasks/task-helper-process-handlers.js +25 -1
  346. package/dist/server/modules/tasks/task-helper-process-handlers.js.map +1 -1
  347. package/dist/server/modules/tasks/task-helper-process.js +75 -26
  348. package/dist/server/modules/tasks/task-helper-process.js.map +1 -1
  349. package/dist/server/modules/tasks/task-helper-scheduling.d.ts +11 -0
  350. package/dist/server/modules/tasks/task-helper-scheduling.js +43 -0
  351. package/dist/server/modules/tasks/task-helper-scheduling.js.map +1 -0
  352. package/dist/server/modules/tasks/task-lane-executors.js +19 -3
  353. package/dist/server/modules/tasks/task-lane-executors.js.map +1 -1
  354. package/dist/server/modules/tasks/task-manager.d.ts +1 -0
  355. package/dist/server/modules/tasks/task-manager.js +3 -0
  356. package/dist/server/modules/tasks/task-manager.js.map +1 -1
  357. package/dist/server/modules/tasks/task-registry.d.ts +1 -0
  358. package/dist/server/modules/tasks/task-registry.js +3 -0
  359. package/dist/server/modules/tasks/task-registry.js.map +1 -1
  360. package/dist/server/modules/tasks/task-scheduler.d.ts +6 -0
  361. package/dist/server/modules/tasks/task-scheduler.js +162 -7
  362. package/dist/server/modules/tasks/task-scheduler.js.map +1 -1
  363. package/dist/server/modules/tasks/task-types.d.ts +30 -3
  364. package/dist/server/modules/tasks/task-types.js +16 -2
  365. package/dist/server/modules/tasks/task-types.js.map +1 -1
  366. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js +1 -1
  367. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js.map +1 -1
  368. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.d.ts +68 -0
  369. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.js +286 -0
  370. package/dist/server/modules/workbench/affairs-assistant-session-snapshot-service.js.map +1 -0
  371. package/dist/server/modules/workbench/workbench-controller.js +11 -1
  372. package/dist/server/modules/workbench/workbench-controller.js.map +1 -1
  373. package/dist/server/modules/workbench/workbench-service.d.ts +9 -2
  374. package/dist/server/modules/workbench/workbench-service.js +58 -18
  375. package/dist/server/modules/workbench/workbench-service.js.map +1 -1
  376. package/dist/server/modules/workspace/affairs-library-controller.d.ts +117 -0
  377. package/dist/server/modules/workspace/affairs-library-controller.js +164 -0
  378. package/dist/server/modules/workspace/affairs-library-controller.js.map +1 -0
  379. package/dist/server/modules/workspace/affairs-library-debug-log.d.ts +23 -0
  380. package/dist/server/modules/workspace/affairs-library-debug-log.js +107 -0
  381. package/dist/server/modules/workspace/affairs-library-debug-log.js.map +1 -0
  382. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.d.ts +52 -0
  383. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.js +555 -0
  384. package/dist/server/modules/workspace/affairs-library-dirty-watch-service.js.map +1 -0
  385. package/dist/server/modules/workspace/affairs-library-preview-link-service.d.ts +24 -0
  386. package/dist/server/modules/workspace/affairs-library-preview-link-service.js +157 -0
  387. package/dist/server/modules/workspace/affairs-library-preview-link-service.js.map +1 -0
  388. package/dist/server/modules/workspace/affairs-library-refresh-contract.d.ts +56 -0
  389. package/dist/server/modules/workspace/affairs-library-refresh-contract.js +48 -0
  390. package/dist/server/modules/workspace/affairs-library-refresh-contract.js.map +1 -0
  391. package/dist/server/modules/workspace/affairs-library-service.d.ts +344 -0
  392. package/dist/server/modules/workspace/affairs-library-service.js +3755 -0
  393. package/dist/server/modules/workspace/affairs-library-service.js.map +1 -0
  394. package/dist/server/modules/workspace/affairs-lightweight-session-controller.d.ts +78 -0
  395. package/dist/server/modules/workspace/affairs-lightweight-session-controller.js +146 -0
  396. package/dist/server/modules/workspace/affairs-lightweight-session-controller.js.map +1 -0
  397. package/dist/server/modules/workspace/affairs-lightweight-session-service.d.ts +133 -0
  398. package/dist/server/modules/workspace/affairs-lightweight-session-service.js +1447 -0
  399. package/dist/server/modules/workspace/affairs-lightweight-session-service.js.map +1 -0
  400. package/dist/server/modules/workspace/affairs-tag-controller.d.ts +107 -0
  401. package/dist/server/modules/workspace/affairs-tag-controller.js +97 -0
  402. package/dist/server/modules/workspace/affairs-tag-controller.js.map +1 -0
  403. package/dist/server/modules/workspace/affairs-tag-service.d.ts +153 -0
  404. package/dist/server/modules/workspace/affairs-tag-service.js +680 -0
  405. package/dist/server/modules/workspace/affairs-tag-service.js.map +1 -0
  406. package/dist/server/modules/workspace/workspace-controller.d.ts +2 -1
  407. package/dist/server/modules/workspace/workspace-controller.js +8 -2
  408. package/dist/server/modules/workspace/workspace-controller.js.map +1 -1
  409. package/dist/server/modules/workspace/workspace-service.js +60 -9
  410. package/dist/server/modules/workspace/workspace-service.js.map +1 -1
  411. package/dist/server/routes/affairs.d.ts +3 -0
  412. package/dist/server/routes/affairs.js +7 -0
  413. package/dist/server/routes/affairs.js.map +1 -0
  414. package/dist/server/routes/assistant.js +0 -5
  415. package/dist/server/routes/assistant.js.map +1 -1
  416. package/dist/server/routes/files.js +45 -0
  417. package/dist/server/routes/files.js.map +1 -1
  418. package/dist/server/routes/office.js +4 -0
  419. package/dist/server/routes/office.js.map +1 -1
  420. package/dist/server/routes/plugins-public.d.ts +3 -0
  421. package/dist/server/routes/plugins-public.js +5 -0
  422. package/dist/server/routes/plugins-public.js.map +1 -0
  423. package/dist/server/routes/plugins.d.ts +3 -0
  424. package/dist/server/routes/plugins.js +19 -0
  425. package/dist/server/routes/plugins.js.map +1 -0
  426. package/dist/server/routes/presentation.js +1 -0
  427. package/dist/server/routes/presentation.js.map +1 -1
  428. package/dist/server/routes/system.d.ts +2 -1
  429. package/dist/server/routes/system.js +2 -1
  430. package/dist/server/routes/system.js.map +1 -1
  431. package/dist/server/routes/workspaces.d.ts +4 -1
  432. package/dist/server/routes/workspaces.js +46 -1
  433. package/dist/server/routes/workspaces.js.map +1 -1
  434. package/dist/server/server/create-server.d.ts +26 -2
  435. package/dist/server/server/create-server.js +159 -32
  436. package/dist/server/server/create-server.js.map +1 -1
  437. package/dist/server/shared/http/error-handler.js +20 -6
  438. package/dist/server/shared/http/error-handler.js.map +1 -1
  439. package/dist/server/shared/runtime/better-sqlite3.d.ts +5 -0
  440. package/dist/server/shared/runtime/better-sqlite3.js +6 -0
  441. package/dist/server/shared/runtime/better-sqlite3.js.map +1 -0
  442. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.d.ts +10 -0
  443. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.js +47 -0
  444. package/dist/server/storage/repositories/affairs-assistant-session-snapshot-repository.js.map +1 -0
  445. package/dist/server/storage/repositories/butler-profile-repository.js +7 -3
  446. package/dist/server/storage/repositories/butler-profile-repository.js.map +1 -1
  447. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.d.ts +19 -0
  448. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.js +55 -0
  449. package/dist/server/storage/repositories/office-onlyoffice-setting-repository.js.map +1 -0
  450. package/dist/server/storage/repositories/plugin-audit-event-repository.d.ts +8 -0
  451. package/dist/server/storage/repositories/plugin-audit-event-repository.js +49 -0
  452. package/dist/server/storage/repositories/plugin-audit-event-repository.js.map +1 -0
  453. package/dist/server/storage/repositories/plugin-definition-repository.d.ts +10 -0
  454. package/dist/server/storage/repositories/plugin-definition-repository.js +84 -0
  455. package/dist/server/storage/repositories/plugin-definition-repository.js.map +1 -0
  456. package/dist/server/storage/repositories/plugin-enablement-repository.d.ts +9 -0
  457. package/dist/server/storage/repositories/plugin-enablement-repository.js +74 -0
  458. package/dist/server/storage/repositories/plugin-enablement-repository.js.map +1 -0
  459. package/dist/server/storage/repositories/plugin-permission-grant-repository.d.ts +12 -0
  460. package/dist/server/storage/repositories/plugin-permission-grant-repository.js +142 -0
  461. package/dist/server/storage/repositories/plugin-permission-grant-repository.js.map +1 -0
  462. package/dist/server/storage/repositories/plugin-run-repository.d.ts +10 -0
  463. package/dist/server/storage/repositories/plugin-run-repository.js +111 -0
  464. package/dist/server/storage/repositories/plugin-run-repository.js.map +1 -0
  465. package/dist/server/storage/repositories/plugin-runtime-session-repository.d.ts +10 -0
  466. package/dist/server/storage/repositories/plugin-runtime-session-repository.js +86 -0
  467. package/dist/server/storage/repositories/plugin-runtime-session-repository.js.map +1 -0
  468. package/dist/server/storage/repositories/session-index-repository.js +9 -2
  469. package/dist/server/storage/repositories/session-index-repository.js.map +1 -1
  470. package/dist/server/storage/repositories/user-affairs-library-setting-repository.d.ts +10 -0
  471. package/dist/server/storage/repositories/user-affairs-library-setting-repository.js +69 -0
  472. package/dist/server/storage/repositories/user-affairs-library-setting-repository.js.map +1 -0
  473. package/dist/server/storage/repositories/user-preference-profile-repository.js +6 -3
  474. package/dist/server/storage/repositories/user-preference-profile-repository.js.map +1 -1
  475. package/dist/server/storage/repositories/workspace-navigation-state-repository.d.ts +3 -0
  476. package/dist/server/storage/repositories/workspace-navigation-state-repository.js +47 -4
  477. package/dist/server/storage/repositories/workspace-navigation-state-repository.js.map +1 -1
  478. package/dist/server/storage/sqlite/client.d.ts +2 -2
  479. package/dist/server/storage/sqlite/client.js +480 -124
  480. package/dist/server/storage/sqlite/client.js.map +1 -1
  481. package/dist/server/storage/sqlite/schema.sql +188 -25
  482. package/dist/server/types/domain.d.ts +149 -20
  483. package/dist/server/ws/workbench-ws-hub.js +2 -2
  484. package/dist/server/ws/workbench-ws-hub.js.map +1 -1
  485. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js +0 -2
  486. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-permissions.js.map +1 -1
  487. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js +0 -6
  488. package/node_modules/@codingns/session-sync-core/dist/runtime/codex-runtime.js.map +1 -1
  489. package/package.json +10 -3
  490. package/scripts/postinstall.mjs +248 -11
  491. package/vendor/better-sqlite3-win32-x64-node22/LICENSE +21 -0
  492. package/vendor/better-sqlite3-win32-x64-node22/README.md +12 -0
  493. package/vendor/better-sqlite3-win32-x64-node22/README.upstream.md +99 -0
  494. package/vendor/better-sqlite3-win32-x64-node22/binding.gyp +38 -0
  495. package/vendor/better-sqlite3-win32-x64-node22/build/Release/better_sqlite3.node +0 -0
  496. package/vendor/better-sqlite3-win32-x64-node22/deps/common.gypi +68 -0
  497. package/vendor/better-sqlite3-win32-x64-node22/deps/copy.js +31 -0
  498. package/vendor/better-sqlite3-win32-x64-node22/deps/defines.gypi +41 -0
  499. package/vendor/better-sqlite3-win32-x64-node22/deps/download.sh +122 -0
  500. package/vendor/better-sqlite3-win32-x64-node22/deps/patches/1208.patch +15 -0
  501. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.c +265994 -0
  502. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.h +13968 -0
  503. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3ext.h +730 -0
  504. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3.gyp +80 -0
  505. package/vendor/better-sqlite3-win32-x64-node22/deps/test_extension.c +21 -0
  506. package/vendor/better-sqlite3-win32-x64-node22/lib/database.js +90 -0
  507. package/vendor/better-sqlite3-win32-x64-node22/lib/index.js +3 -0
  508. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/aggregate.js +43 -0
  509. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/backup.js +67 -0
  510. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/function.js +31 -0
  511. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/inspect.js +7 -0
  512. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/pragma.js +12 -0
  513. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/serialize.js +16 -0
  514. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/table.js +189 -0
  515. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/transaction.js +78 -0
  516. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/wrappers.js +54 -0
  517. package/vendor/better-sqlite3-win32-x64-node22/lib/sqlite-error.js +20 -0
  518. package/vendor/better-sqlite3-win32-x64-node22/lib/util.js +12 -0
  519. package/vendor/better-sqlite3-win32-x64-node22/package.json +38 -0
  520. package/vendor/better-sqlite3-win32-x64-node22/scripts/verify-runtime.cjs +42 -0
  521. package/vendor/better-sqlite3-win32-x64-node22/src/addon.cpp +47 -0
  522. package/vendor/better-sqlite3-win32-x64-node22/src/better_sqlite3.cpp +74 -0
  523. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.cpp +120 -0
  524. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.hpp +36 -0
  525. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.cpp +417 -0
  526. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.hpp +103 -0
  527. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.cpp +113 -0
  528. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.hpp +50 -0
  529. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.cpp +383 -0
  530. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.hpp +58 -0
  531. package/vendor/better-sqlite3-win32-x64-node22/src/util/bind-map.cpp +73 -0
  532. package/vendor/better-sqlite3-win32-x64-node22/src/util/binder.cpp +193 -0
  533. package/vendor/better-sqlite3-win32-x64-node22/src/util/constants.cpp +172 -0
  534. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-aggregate.cpp +121 -0
  535. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-function.cpp +59 -0
  536. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-table.cpp +409 -0
  537. package/vendor/better-sqlite3-win32-x64-node22/src/util/data-converter.cpp +17 -0
  538. package/vendor/better-sqlite3-win32-x64-node22/src/util/data.cpp +194 -0
  539. package/vendor/better-sqlite3-win32-x64-node22/src/util/helpers.cpp +109 -0
  540. package/vendor/better-sqlite3-win32-x64-node22/src/util/macros.cpp +83 -0
  541. package/vendor/better-sqlite3-win32-x64-node22/src/util/query-macros.cpp +71 -0
  542. package/vendor/better-sqlite3-win32-x64-node22/src/util/row-builder.cpp +49 -0
  543. package/vendor/node-pty-fork/README.md +1 -0
  544. package/vendor/node-pty-fork/scripts/runtime-install-context.cjs +24 -0
  545. package/vendor/node-pty-fork/scripts/verify-runtime.cjs +8 -0
  546. package/vendor/node-pty-fork/scripts/verify-runtime.test.cjs +30 -0
  547. package/vendor-src/better-sqlite3-win32-x64-node22/README.md +12 -0
  548. package/dist/public/assets/AdaptiveButlerPage-B153lk5H.css +0 -1
  549. package/dist/public/assets/AdaptiveButlerPage-b7s6F_sd.js +0 -3
  550. package/dist/public/assets/App-B0q8uDA-.js +0 -30
  551. package/dist/public/assets/DesktopWindowPage-BdKUZrKG.js +0 -2
  552. package/dist/public/assets/FileContextPanel-lM5mBcfn.js +0 -1
  553. package/dist/public/assets/GitSidebar-CmXAhyjo.js +0 -6
  554. package/dist/public/assets/MobileCreateSessionSheet-CceV0-AH.js +0 -1
  555. package/dist/public/assets/MobileWorkspaceSwitcherHeader-DhaM9fgx.js +0 -1
  556. package/dist/public/assets/ServerSettingsModal-Rkgn3jft.js +0 -1
  557. package/dist/public/assets/SessionIndexPage-BOumP3ij.js +0 -1
  558. package/dist/public/assets/SettingsPage-vx_c-00-.js +0 -2
  559. package/dist/public/assets/TerminalManagerPanel-D9JHCS6d.js +0 -1
  560. package/dist/public/assets/TerminalRuntimeFallbackModal-W5NjqFEz.js +0 -1
  561. package/dist/public/assets/ToolFilesPage-DWtpaN_7.js +0 -1
  562. package/dist/public/assets/ToolGitPage-MpGXsw4_.js +0 -1
  563. package/dist/public/assets/ToolProcessesPage-B1jHQKhZ.js +0 -1
  564. package/dist/public/assets/ToolsHomePage-CJrn8ZFl.js +0 -1
  565. package/dist/public/assets/WorkbenchLandingPage-CJQ1V5U-.js +0 -1
  566. package/dist/public/assets/WorkbenchLayout-D48i71PU.js +0 -244
  567. package/dist/public/assets/WorkbenchModal-BYNuMIoV.js +0 -1
  568. package/dist/public/assets/WorkbenchShellRoute-B4XB8SwG.css +0 -1
  569. package/dist/public/assets/WorkbenchShellRoute-CGKjy4J-.js +0 -1
  570. package/dist/public/assets/WorkspaceDebugDetailPage-DCAYgays.js +0 -1
  571. package/dist/public/assets/WorkspaceDetailPage-D5v-nUIi.js +0 -1
  572. package/dist/public/assets/WorkspaceHomePage-I5G1p5SR.js +0 -1
  573. package/dist/public/assets/file-tree-icon-BFwaPxKs.js +0 -590
  574. package/dist/public/assets/index-CjewzOUG.js +0 -42
  575. package/dist/public/assets/index-VVxfF0s5.css +0 -1
  576. package/dist/public/assets/model-switch-api-Br0ivfe5.js +0 -1
  577. package/dist/public/assets/realtime-client-BlQRqVmm.js +0 -1
  578. package/dist/public/assets/useRegisteredDebugTemplates-CXmxu69X.js +0 -1
  579. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.d.ts +0 -32
  580. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js +0 -93
  581. package/dist/server/modules/butler/assistant-sandbox-cleanup-scheduler.js.map +0 -1
  582. package/dist/server/modules/butler/assistant-sandbox-service.d.ts +0 -69
  583. package/dist/server/modules/butler/assistant-sandbox-service.js +0 -399
  584. package/dist/server/modules/butler/assistant-sandbox-service.js.map +0 -1
  585. package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.d.ts +0 -18
  586. package/dist/server/storage/repositories/assistant-sandbox-workspace-repository.js +0 -191
  587. 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