@cicctencent/agent-server 0.1.1

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 (380) hide show
  1. package/README.md +235 -0
  2. package/dist/cjs/agent/agent-server.d.ts +6 -0
  3. package/dist/cjs/agent/agent-server.d.ts.map +1 -0
  4. package/dist/cjs/agent/agent-server.js +412 -0
  5. package/dist/cjs/agent/agent-server.js.map +1 -0
  6. package/dist/cjs/connectors/index.d.ts +13 -0
  7. package/dist/cjs/connectors/index.d.ts.map +1 -0
  8. package/dist/cjs/connectors/index.js +37 -0
  9. package/dist/cjs/connectors/index.js.map +1 -0
  10. package/dist/cjs/index.d.ts +56 -0
  11. package/dist/cjs/index.d.ts.map +1 -0
  12. package/dist/cjs/index.js +169 -0
  13. package/dist/cjs/index.js.map +1 -0
  14. package/dist/cjs/kb/doc-parser.d.ts +24 -0
  15. package/dist/cjs/kb/doc-parser.d.ts.map +1 -0
  16. package/dist/cjs/kb/doc-parser.js +137 -0
  17. package/dist/cjs/kb/doc-parser.js.map +1 -0
  18. package/dist/cjs/kb/embedding-vector-index.d.ts +30 -0
  19. package/dist/cjs/kb/embedding-vector-index.d.ts.map +1 -0
  20. package/dist/cjs/kb/embedding-vector-index.js +75 -0
  21. package/dist/cjs/kb/embedding-vector-index.js.map +1 -0
  22. package/dist/cjs/kb/file-knowledge-base.d.ts +25 -0
  23. package/dist/cjs/kb/file-knowledge-base.d.ts.map +1 -0
  24. package/dist/cjs/kb/file-knowledge-base.js +200 -0
  25. package/dist/cjs/kb/file-knowledge-base.js.map +1 -0
  26. package/dist/cjs/mcp/api-bridge-client.d.ts +36 -0
  27. package/dist/cjs/mcp/api-bridge-client.d.ts.map +1 -0
  28. package/dist/cjs/mcp/api-bridge-client.js +143 -0
  29. package/dist/cjs/mcp/api-bridge-client.js.map +1 -0
  30. package/dist/cjs/mcp/api-bridge-types.d.ts +91 -0
  31. package/dist/cjs/mcp/api-bridge-types.d.ts.map +1 -0
  32. package/dist/cjs/mcp/api-bridge-types.js +8 -0
  33. package/dist/cjs/mcp/api-bridge-types.js.map +1 -0
  34. package/dist/cjs/mcp/body-template.d.ts +16 -0
  35. package/dist/cjs/mcp/body-template.d.ts.map +1 -0
  36. package/dist/cjs/mcp/body-template.js +62 -0
  37. package/dist/cjs/mcp/body-template.js.map +1 -0
  38. package/dist/cjs/mcp/openapi-importer.d.ts +24 -0
  39. package/dist/cjs/mcp/openapi-importer.d.ts.map +1 -0
  40. package/dist/cjs/mcp/openapi-importer.js +183 -0
  41. package/dist/cjs/mcp/openapi-importer.js.map +1 -0
  42. package/dist/cjs/mcp/template-builder.d.ts +53 -0
  43. package/dist/cjs/mcp/template-builder.d.ts.map +1 -0
  44. package/dist/cjs/mcp/template-builder.js +177 -0
  45. package/dist/cjs/mcp/template-builder.js.map +1 -0
  46. package/dist/cjs/model/automation.d.ts +34 -0
  47. package/dist/cjs/model/automation.d.ts.map +1 -0
  48. package/dist/cjs/model/automation.js +6 -0
  49. package/dist/cjs/model/automation.js.map +1 -0
  50. package/dist/cjs/package.json +3 -0
  51. package/dist/cjs/prompt/prompt-builder.d.ts +14 -0
  52. package/dist/cjs/prompt/prompt-builder.d.ts.map +1 -0
  53. package/dist/cjs/prompt/prompt-builder.js +113 -0
  54. package/dist/cjs/prompt/prompt-builder.js.map +1 -0
  55. package/dist/cjs/sandbox/local-sandbox.d.ts +70 -0
  56. package/dist/cjs/sandbox/local-sandbox.d.ts.map +1 -0
  57. package/dist/cjs/sandbox/local-sandbox.js +442 -0
  58. package/dist/cjs/sandbox/local-sandbox.js.map +1 -0
  59. package/dist/cjs/sandbox/process-code-sandbox.d.ts +25 -0
  60. package/dist/cjs/sandbox/process-code-sandbox.d.ts.map +1 -0
  61. package/dist/cjs/sandbox/process-code-sandbox.js +113 -0
  62. package/dist/cjs/sandbox/process-code-sandbox.js.map +1 -0
  63. package/dist/cjs/sandbox/sandbox-manager.d.ts +47 -0
  64. package/dist/cjs/sandbox/sandbox-manager.d.ts.map +1 -0
  65. package/dist/cjs/sandbox/sandbox-manager.js +126 -0
  66. package/dist/cjs/sandbox/sandbox-manager.js.map +1 -0
  67. package/dist/cjs/service/agent-profile.service.d.ts +27 -0
  68. package/dist/cjs/service/agent-profile.service.d.ts.map +1 -0
  69. package/dist/cjs/service/agent-profile.service.js +143 -0
  70. package/dist/cjs/service/agent-profile.service.js.map +1 -0
  71. package/dist/cjs/service/artifact.service.d.ts +33 -0
  72. package/dist/cjs/service/artifact.service.d.ts.map +1 -0
  73. package/dist/cjs/service/artifact.service.js +214 -0
  74. package/dist/cjs/service/artifact.service.js.map +1 -0
  75. package/dist/cjs/service/audit.service.d.ts +30 -0
  76. package/dist/cjs/service/audit.service.d.ts.map +1 -0
  77. package/dist/cjs/service/audit.service.js +169 -0
  78. package/dist/cjs/service/audit.service.js.map +1 -0
  79. package/dist/cjs/service/chat.service.d.ts +90 -0
  80. package/dist/cjs/service/chat.service.d.ts.map +1 -0
  81. package/dist/cjs/service/chat.service.js +433 -0
  82. package/dist/cjs/service/chat.service.js.map +1 -0
  83. package/dist/cjs/service/engine-pool.d.ts +6 -0
  84. package/dist/cjs/service/engine-pool.d.ts.map +1 -0
  85. package/dist/cjs/service/engine-pool.js +24 -0
  86. package/dist/cjs/service/engine-pool.js.map +1 -0
  87. package/dist/cjs/service/memory.service.d.ts +45 -0
  88. package/dist/cjs/service/memory.service.d.ts.map +1 -0
  89. package/dist/cjs/service/memory.service.js +193 -0
  90. package/dist/cjs/service/memory.service.js.map +1 -0
  91. package/dist/cjs/service/observability.service.d.ts +3 -0
  92. package/dist/cjs/service/observability.service.d.ts.map +1 -0
  93. package/dist/cjs/service/observability.service.js +10 -0
  94. package/dist/cjs/service/observability.service.js.map +1 -0
  95. package/dist/cjs/service/permission.service.d.ts +5 -0
  96. package/dist/cjs/service/permission.service.d.ts.map +1 -0
  97. package/dist/cjs/service/permission.service.js +40 -0
  98. package/dist/cjs/service/permission.service.js.map +1 -0
  99. package/dist/cjs/service/run-registry.d.ts +7 -0
  100. package/dist/cjs/service/run-registry.d.ts.map +1 -0
  101. package/dist/cjs/service/run-registry.js +44 -0
  102. package/dist/cjs/service/run-registry.js.map +1 -0
  103. package/dist/cjs/service/safety-audit.middleware.d.ts +3 -0
  104. package/dist/cjs/service/safety-audit.middleware.d.ts.map +1 -0
  105. package/dist/cjs/service/safety-audit.middleware.js +115 -0
  106. package/dist/cjs/service/safety-audit.middleware.js.map +1 -0
  107. package/dist/cjs/service/security-policy.service.d.ts +18 -0
  108. package/dist/cjs/service/security-policy.service.d.ts.map +1 -0
  109. package/dist/cjs/service/security-policy.service.js +46 -0
  110. package/dist/cjs/service/security-policy.service.js.map +1 -0
  111. package/dist/cjs/service/settings.service.d.ts +18 -0
  112. package/dist/cjs/service/settings.service.d.ts.map +1 -0
  113. package/dist/cjs/service/settings.service.js +222 -0
  114. package/dist/cjs/service/settings.service.js.map +1 -0
  115. package/dist/cjs/service/tool-risk.service.d.ts +3 -0
  116. package/dist/cjs/service/tool-risk.service.d.ts.map +1 -0
  117. package/dist/cjs/service/tool-risk.service.js +23 -0
  118. package/dist/cjs/service/tool-risk.service.js.map +1 -0
  119. package/dist/cjs/service/workspace.service.d.ts +33 -0
  120. package/dist/cjs/service/workspace.service.d.ts.map +1 -0
  121. package/dist/cjs/service/workspace.service.js +107 -0
  122. package/dist/cjs/service/workspace.service.js.map +1 -0
  123. package/dist/cjs/sse/sse-handler.d.ts +15 -0
  124. package/dist/cjs/sse/sse-handler.d.ts.map +1 -0
  125. package/dist/cjs/sse/sse-handler.js +56 -0
  126. package/dist/cjs/sse/sse-handler.js.map +1 -0
  127. package/dist/cjs/store/app-stores.d.ts +42 -0
  128. package/dist/cjs/store/app-stores.d.ts.map +1 -0
  129. package/dist/cjs/store/app-stores.js +226 -0
  130. package/dist/cjs/store/app-stores.js.map +1 -0
  131. package/dist/cjs/store/index.d.ts +3 -0
  132. package/dist/cjs/store/index.d.ts.map +1 -0
  133. package/dist/cjs/store/index.js +10 -0
  134. package/dist/cjs/store/index.js.map +1 -0
  135. package/dist/cjs/store/mcp-server-store.d.ts +35 -0
  136. package/dist/cjs/store/mcp-server-store.d.ts.map +1 -0
  137. package/dist/cjs/store/mcp-server-store.js +288 -0
  138. package/dist/cjs/store/mcp-server-store.js.map +1 -0
  139. package/dist/cjs/tool/builtin.d.ts +18 -0
  140. package/dist/cjs/tool/builtin.d.ts.map +1 -0
  141. package/dist/cjs/tool/builtin.js +43 -0
  142. package/dist/cjs/tool/builtin.js.map +1 -0
  143. package/dist/cjs/tool/local-executors.d.ts +22 -0
  144. package/dist/cjs/tool/local-executors.d.ts.map +1 -0
  145. package/dist/cjs/tool/local-executors.js +126 -0
  146. package/dist/cjs/tool/local-executors.js.map +1 -0
  147. package/dist/cjs/tool/tools/automation.d.ts +3 -0
  148. package/dist/cjs/tool/tools/automation.d.ts.map +1 -0
  149. package/dist/cjs/tool/tools/automation.js +190 -0
  150. package/dist/cjs/tool/tools/automation.js.map +1 -0
  151. package/dist/cjs/tool/tools/communication.d.ts +3 -0
  152. package/dist/cjs/tool/tools/communication.d.ts.map +1 -0
  153. package/dist/cjs/tool/tools/communication.js +302 -0
  154. package/dist/cjs/tool/tools/communication.js.map +1 -0
  155. package/dist/cjs/tool/tools/discovery.d.ts +3 -0
  156. package/dist/cjs/tool/tools/discovery.d.ts.map +1 -0
  157. package/dist/cjs/tool/tools/discovery.js +248 -0
  158. package/dist/cjs/tool/tools/discovery.js.map +1 -0
  159. package/dist/cjs/tool/tools/filesystem.d.ts +3 -0
  160. package/dist/cjs/tool/tools/filesystem.d.ts.map +1 -0
  161. package/dist/cjs/tool/tools/filesystem.js +403 -0
  162. package/dist/cjs/tool/tools/filesystem.js.map +1 -0
  163. package/dist/cjs/tool/tools/git.d.ts +3 -0
  164. package/dist/cjs/tool/tools/git.d.ts.map +1 -0
  165. package/dist/cjs/tool/tools/git.js +224 -0
  166. package/dist/cjs/tool/tools/git.js.map +1 -0
  167. package/dist/cjs/tool/tools/memory.d.ts +3 -0
  168. package/dist/cjs/tool/tools/memory.d.ts.map +1 -0
  169. package/dist/cjs/tool/tools/memory.js +126 -0
  170. package/dist/cjs/tool/tools/memory.js.map +1 -0
  171. package/dist/cjs/tool/tools/sandbox.d.ts +3 -0
  172. package/dist/cjs/tool/tools/sandbox.d.ts.map +1 -0
  173. package/dist/cjs/tool/tools/sandbox.js +413 -0
  174. package/dist/cjs/tool/tools/sandbox.js.map +1 -0
  175. package/dist/cjs/tool/tools/web-utils.d.ts +16 -0
  176. package/dist/cjs/tool/tools/web-utils.d.ts.map +1 -0
  177. package/dist/cjs/tool/tools/web-utils.js +131 -0
  178. package/dist/cjs/tool/tools/web-utils.js.map +1 -0
  179. package/dist/cjs/tool/tools/web.d.ts +3 -0
  180. package/dist/cjs/tool/tools/web.d.ts.map +1 -0
  181. package/dist/cjs/tool/tools/web.js +358 -0
  182. package/dist/cjs/tool/tools/web.js.map +1 -0
  183. package/dist/cjs/types.d.ts +523 -0
  184. package/dist/cjs/types.d.ts.map +1 -0
  185. package/dist/cjs/types.js +6 -0
  186. package/dist/cjs/types.js.map +1 -0
  187. package/dist/cjs/utils/data-dir.d.ts +8 -0
  188. package/dist/cjs/utils/data-dir.d.ts.map +1 -0
  189. package/dist/cjs/utils/data-dir.js +92 -0
  190. package/dist/cjs/utils/data-dir.js.map +1 -0
  191. package/dist/esm/agent/agent-server.d.ts +6 -0
  192. package/dist/esm/agent/agent-server.d.ts.map +1 -0
  193. package/dist/esm/agent/agent-server.js +409 -0
  194. package/dist/esm/agent/agent-server.js.map +1 -0
  195. package/dist/esm/connectors/index.d.ts +13 -0
  196. package/dist/esm/connectors/index.d.ts.map +1 -0
  197. package/dist/esm/connectors/index.js +30 -0
  198. package/dist/esm/connectors/index.js.map +1 -0
  199. package/dist/esm/index.d.ts +56 -0
  200. package/dist/esm/index.d.ts.map +1 -0
  201. package/dist/esm/index.js +57 -0
  202. package/dist/esm/index.js.map +1 -0
  203. package/dist/esm/kb/doc-parser.d.ts +24 -0
  204. package/dist/esm/kb/doc-parser.d.ts.map +1 -0
  205. package/dist/esm/kb/doc-parser.js +100 -0
  206. package/dist/esm/kb/doc-parser.js.map +1 -0
  207. package/dist/esm/kb/embedding-vector-index.d.ts +30 -0
  208. package/dist/esm/kb/embedding-vector-index.d.ts.map +1 -0
  209. package/dist/esm/kb/embedding-vector-index.js +71 -0
  210. package/dist/esm/kb/embedding-vector-index.js.map +1 -0
  211. package/dist/esm/kb/file-knowledge-base.d.ts +25 -0
  212. package/dist/esm/kb/file-knowledge-base.d.ts.map +1 -0
  213. package/dist/esm/kb/file-knowledge-base.js +163 -0
  214. package/dist/esm/kb/file-knowledge-base.js.map +1 -0
  215. package/dist/esm/mcp/api-bridge-client.d.ts +36 -0
  216. package/dist/esm/mcp/api-bridge-client.d.ts.map +1 -0
  217. package/dist/esm/mcp/api-bridge-client.js +139 -0
  218. package/dist/esm/mcp/api-bridge-client.js.map +1 -0
  219. package/dist/esm/mcp/api-bridge-types.d.ts +91 -0
  220. package/dist/esm/mcp/api-bridge-types.d.ts.map +1 -0
  221. package/dist/esm/mcp/api-bridge-types.js +7 -0
  222. package/dist/esm/mcp/api-bridge-types.js.map +1 -0
  223. package/dist/esm/mcp/body-template.d.ts +16 -0
  224. package/dist/esm/mcp/body-template.d.ts.map +1 -0
  225. package/dist/esm/mcp/body-template.js +59 -0
  226. package/dist/esm/mcp/body-template.js.map +1 -0
  227. package/dist/esm/mcp/openapi-importer.d.ts +24 -0
  228. package/dist/esm/mcp/openapi-importer.d.ts.map +1 -0
  229. package/dist/esm/mcp/openapi-importer.js +177 -0
  230. package/dist/esm/mcp/openapi-importer.js.map +1 -0
  231. package/dist/esm/mcp/template-builder.d.ts +53 -0
  232. package/dist/esm/mcp/template-builder.d.ts.map +1 -0
  233. package/dist/esm/mcp/template-builder.js +173 -0
  234. package/dist/esm/mcp/template-builder.js.map +1 -0
  235. package/dist/esm/model/automation.d.ts +34 -0
  236. package/dist/esm/model/automation.d.ts.map +1 -0
  237. package/dist/esm/model/automation.js +5 -0
  238. package/dist/esm/model/automation.js.map +1 -0
  239. package/dist/esm/package.json +3 -0
  240. package/dist/esm/prompt/prompt-builder.d.ts +14 -0
  241. package/dist/esm/prompt/prompt-builder.d.ts.map +1 -0
  242. package/dist/esm/prompt/prompt-builder.js +109 -0
  243. package/dist/esm/prompt/prompt-builder.js.map +1 -0
  244. package/dist/esm/sandbox/local-sandbox.d.ts +70 -0
  245. package/dist/esm/sandbox/local-sandbox.d.ts.map +1 -0
  246. package/dist/esm/sandbox/local-sandbox.js +403 -0
  247. package/dist/esm/sandbox/local-sandbox.js.map +1 -0
  248. package/dist/esm/sandbox/process-code-sandbox.d.ts +25 -0
  249. package/dist/esm/sandbox/process-code-sandbox.d.ts.map +1 -0
  250. package/dist/esm/sandbox/process-code-sandbox.js +76 -0
  251. package/dist/esm/sandbox/process-code-sandbox.js.map +1 -0
  252. package/dist/esm/sandbox/sandbox-manager.d.ts +47 -0
  253. package/dist/esm/sandbox/sandbox-manager.d.ts.map +1 -0
  254. package/dist/esm/sandbox/sandbox-manager.js +88 -0
  255. package/dist/esm/sandbox/sandbox-manager.js.map +1 -0
  256. package/dist/esm/service/agent-profile.service.d.ts +27 -0
  257. package/dist/esm/service/agent-profile.service.d.ts.map +1 -0
  258. package/dist/esm/service/agent-profile.service.js +130 -0
  259. package/dist/esm/service/agent-profile.service.js.map +1 -0
  260. package/dist/esm/service/artifact.service.d.ts +33 -0
  261. package/dist/esm/service/artifact.service.d.ts.map +1 -0
  262. package/dist/esm/service/artifact.service.js +175 -0
  263. package/dist/esm/service/artifact.service.js.map +1 -0
  264. package/dist/esm/service/audit.service.d.ts +30 -0
  265. package/dist/esm/service/audit.service.d.ts.map +1 -0
  266. package/dist/esm/service/audit.service.js +131 -0
  267. package/dist/esm/service/audit.service.js.map +1 -0
  268. package/dist/esm/service/chat.service.d.ts +90 -0
  269. package/dist/esm/service/chat.service.d.ts.map +1 -0
  270. package/dist/esm/service/chat.service.js +388 -0
  271. package/dist/esm/service/chat.service.js.map +1 -0
  272. package/dist/esm/service/engine-pool.d.ts +6 -0
  273. package/dist/esm/service/engine-pool.d.ts.map +1 -0
  274. package/dist/esm/service/engine-pool.js +18 -0
  275. package/dist/esm/service/engine-pool.js.map +1 -0
  276. package/dist/esm/service/memory.service.d.ts +45 -0
  277. package/dist/esm/service/memory.service.d.ts.map +1 -0
  278. package/dist/esm/service/memory.service.js +154 -0
  279. package/dist/esm/service/memory.service.js.map +1 -0
  280. package/dist/esm/service/observability.service.d.ts +3 -0
  281. package/dist/esm/service/observability.service.d.ts.map +1 -0
  282. package/dist/esm/service/observability.service.js +5 -0
  283. package/dist/esm/service/observability.service.js.map +1 -0
  284. package/dist/esm/service/permission.service.d.ts +5 -0
  285. package/dist/esm/service/permission.service.d.ts.map +1 -0
  286. package/dist/esm/service/permission.service.js +33 -0
  287. package/dist/esm/service/permission.service.js.map +1 -0
  288. package/dist/esm/service/run-registry.d.ts +7 -0
  289. package/dist/esm/service/run-registry.d.ts.map +1 -0
  290. package/dist/esm/service/run-registry.js +37 -0
  291. package/dist/esm/service/run-registry.js.map +1 -0
  292. package/dist/esm/service/safety-audit.middleware.d.ts +3 -0
  293. package/dist/esm/service/safety-audit.middleware.d.ts.map +1 -0
  294. package/dist/esm/service/safety-audit.middleware.js +112 -0
  295. package/dist/esm/service/safety-audit.middleware.js.map +1 -0
  296. package/dist/esm/service/security-policy.service.d.ts +18 -0
  297. package/dist/esm/service/security-policy.service.d.ts.map +1 -0
  298. package/dist/esm/service/security-policy.service.js +42 -0
  299. package/dist/esm/service/security-policy.service.js.map +1 -0
  300. package/dist/esm/service/settings.service.d.ts +18 -0
  301. package/dist/esm/service/settings.service.d.ts.map +1 -0
  302. package/dist/esm/service/settings.service.js +181 -0
  303. package/dist/esm/service/settings.service.js.map +1 -0
  304. package/dist/esm/service/tool-risk.service.d.ts +3 -0
  305. package/dist/esm/service/tool-risk.service.d.ts.map +1 -0
  306. package/dist/esm/service/tool-risk.service.js +17 -0
  307. package/dist/esm/service/tool-risk.service.js.map +1 -0
  308. package/dist/esm/service/workspace.service.d.ts +33 -0
  309. package/dist/esm/service/workspace.service.d.ts.map +1 -0
  310. package/dist/esm/service/workspace.service.js +97 -0
  311. package/dist/esm/service/workspace.service.js.map +1 -0
  312. package/dist/esm/sse/sse-handler.d.ts +15 -0
  313. package/dist/esm/sse/sse-handler.d.ts.map +1 -0
  314. package/dist/esm/sse/sse-handler.js +49 -0
  315. package/dist/esm/sse/sse-handler.js.map +1 -0
  316. package/dist/esm/store/app-stores.d.ts +42 -0
  317. package/dist/esm/store/app-stores.d.ts.map +1 -0
  318. package/dist/esm/store/app-stores.js +181 -0
  319. package/dist/esm/store/app-stores.js.map +1 -0
  320. package/dist/esm/store/index.d.ts +3 -0
  321. package/dist/esm/store/index.d.ts.map +1 -0
  322. package/dist/esm/store/index.js +5 -0
  323. package/dist/esm/store/index.js.map +1 -0
  324. package/dist/esm/store/mcp-server-store.d.ts +35 -0
  325. package/dist/esm/store/mcp-server-store.d.ts.map +1 -0
  326. package/dist/esm/store/mcp-server-store.js +251 -0
  327. package/dist/esm/store/mcp-server-store.js.map +1 -0
  328. package/dist/esm/tool/builtin.d.ts +18 -0
  329. package/dist/esm/tool/builtin.d.ts.map +1 -0
  330. package/dist/esm/tool/builtin.js +40 -0
  331. package/dist/esm/tool/builtin.js.map +1 -0
  332. package/dist/esm/tool/local-executors.d.ts +22 -0
  333. package/dist/esm/tool/local-executors.d.ts.map +1 -0
  334. package/dist/esm/tool/local-executors.js +88 -0
  335. package/dist/esm/tool/local-executors.js.map +1 -0
  336. package/dist/esm/tool/tools/automation.d.ts +3 -0
  337. package/dist/esm/tool/tools/automation.d.ts.map +1 -0
  338. package/dist/esm/tool/tools/automation.js +154 -0
  339. package/dist/esm/tool/tools/automation.js.map +1 -0
  340. package/dist/esm/tool/tools/communication.d.ts +3 -0
  341. package/dist/esm/tool/tools/communication.d.ts.map +1 -0
  342. package/dist/esm/tool/tools/communication.js +266 -0
  343. package/dist/esm/tool/tools/communication.js.map +1 -0
  344. package/dist/esm/tool/tools/discovery.d.ts +3 -0
  345. package/dist/esm/tool/tools/discovery.d.ts.map +1 -0
  346. package/dist/esm/tool/tools/discovery.js +245 -0
  347. package/dist/esm/tool/tools/discovery.js.map +1 -0
  348. package/dist/esm/tool/tools/filesystem.d.ts +3 -0
  349. package/dist/esm/tool/tools/filesystem.d.ts.map +1 -0
  350. package/dist/esm/tool/tools/filesystem.js +367 -0
  351. package/dist/esm/tool/tools/filesystem.js.map +1 -0
  352. package/dist/esm/tool/tools/git.d.ts +3 -0
  353. package/dist/esm/tool/tools/git.d.ts.map +1 -0
  354. package/dist/esm/tool/tools/git.js +188 -0
  355. package/dist/esm/tool/tools/git.js.map +1 -0
  356. package/dist/esm/tool/tools/memory.d.ts +3 -0
  357. package/dist/esm/tool/tools/memory.d.ts.map +1 -0
  358. package/dist/esm/tool/tools/memory.js +123 -0
  359. package/dist/esm/tool/tools/memory.js.map +1 -0
  360. package/dist/esm/tool/tools/sandbox.d.ts +3 -0
  361. package/dist/esm/tool/tools/sandbox.d.ts.map +1 -0
  362. package/dist/esm/tool/tools/sandbox.js +377 -0
  363. package/dist/esm/tool/tools/sandbox.js.map +1 -0
  364. package/dist/esm/tool/tools/web-utils.d.ts +16 -0
  365. package/dist/esm/tool/tools/web-utils.d.ts.map +1 -0
  366. package/dist/esm/tool/tools/web-utils.js +88 -0
  367. package/dist/esm/tool/tools/web-utils.js.map +1 -0
  368. package/dist/esm/tool/tools/web.d.ts +3 -0
  369. package/dist/esm/tool/tools/web.d.ts.map +1 -0
  370. package/dist/esm/tool/tools/web.js +319 -0
  371. package/dist/esm/tool/tools/web.js.map +1 -0
  372. package/dist/esm/types.d.ts +523 -0
  373. package/dist/esm/types.d.ts.map +1 -0
  374. package/dist/esm/types.js +5 -0
  375. package/dist/esm/types.js.map +1 -0
  376. package/dist/esm/utils/data-dir.d.ts +8 -0
  377. package/dist/esm/utils/data-dir.d.ts.map +1 -0
  378. package/dist/esm/utils/data-dir.js +48 -0
  379. package/dist/esm/utils/data-dir.js.map +1 -0
  380. package/package.json +56 -0
@@ -0,0 +1,88 @@
1
+ /**
2
+ * @file LocalSandboxManager — 沙箱生命周期管理
3
+ * @description 管理沙箱的创建、获取、销毁,沙箱目录统一在 {cwd}/data/sandboxes/ 下
4
+ */
5
+ import * as path from 'path';
6
+ import { LocalSandbox } from "./local-sandbox.js";
7
+ import { getProjectDataPath } from "../utils/data-dir.js";
8
+ /**
9
+ * 本地沙箱管理器
10
+ * - 创建沙箱时自动在 baseDir/{id} 下创建隔离目录
11
+ * - 支持获取已创建的沙箱实例
12
+ * - 销毁时清理沙箱目录
13
+ */
14
+ export class LocalSandboxManager {
15
+ sandboxes = new Map();
16
+ baseDir;
17
+ constructor(baseDir) {
18
+ this.baseDir = baseDir || getProjectDataPath('sandboxes');
19
+ }
20
+ /**
21
+ * 创建沙箱(复用已有实例)
22
+ * 同一 thread 的多次对话复用同一个沙箱,避免销毁导致 artifacts 丢失。
23
+ * 如需强制清理,请先调用 destroy()。
24
+ */
25
+ async create(id, config) {
26
+ // 复用已有沙箱:保留 _artifacts/ 等目录,避免历史产物丢失
27
+ const existing = this.sandboxes.get(id);
28
+ if (existing) {
29
+ return existing;
30
+ }
31
+ const rootDir = config?.rootDir || path.join(this.baseDir, id);
32
+ const fullConfig = {
33
+ rootDir,
34
+ ...config,
35
+ };
36
+ const sandbox = new LocalSandbox(id, fullConfig);
37
+ await sandbox.init();
38
+ this.sandboxes.set(id, sandbox);
39
+ return sandbox;
40
+ }
41
+ /**
42
+ * 获取已创建的沙箱
43
+ */
44
+ get(id) {
45
+ return this.sandboxes.get(id);
46
+ }
47
+ /**
48
+ * 销毁指定沙箱(清理目录 + 移除引用)
49
+ */
50
+ async destroy(id) {
51
+ const sandbox = this.sandboxes.get(id);
52
+ if (sandbox) {
53
+ await sandbox.destroy();
54
+ this.sandboxes.delete(id);
55
+ }
56
+ }
57
+ /**
58
+ * 销毁所有沙箱
59
+ */
60
+ async destroyAll() {
61
+ const destroyPromises = [...this.sandboxes.keys()].map(id => this.destroy(id));
62
+ await Promise.allSettled(destroyPromises);
63
+ }
64
+ /**
65
+ * 获取当前活跃沙箱数量
66
+ */
67
+ get size() {
68
+ return this.sandboxes.size;
69
+ }
70
+ /**
71
+ * 获取所有活跃沙箱 ID
72
+ */
73
+ listIds() {
74
+ return [...this.sandboxes.keys()];
75
+ }
76
+ }
77
+ // ---- 单例导出 ----
78
+ let defaultManager = null;
79
+ /**
80
+ * 获取默认沙箱管理器单例
81
+ */
82
+ export function getSandboxManager() {
83
+ if (!defaultManager) {
84
+ defaultManager = new LocalSandboxManager();
85
+ }
86
+ return defaultManager;
87
+ }
88
+ //# sourceMappingURL=sandbox-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sandbox-manager.js","sourceRoot":"","sources":["../../../src/sandbox/sandbox-manager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE1D;;;;;GAKG;AACH,MAAM,OAAO,mBAAmB;IACtB,SAAS,GAAG,IAAI,GAAG,EAAwB,CAAC;IACnC,OAAO,CAAS;IAEjC,YAAY,OAAgB;QAC1B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,kBAAkB,CAAC,WAAW,CAAC,CAAC;IAC5D,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,MAAM,CAAC,EAAU,EAAE,MAA+B;QACtD,qCAAqC;QACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACxC,IAAI,QAAQ,EAAE,CAAC;YACb,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,MAAM,OAAO,GAAG,MAAM,EAAE,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QAC/D,MAAM,UAAU,GAAkB;YAChC,OAAO;YACP,GAAG,MAAM;SACV,CAAC;QAEF,MAAM,OAAO,GAAG,IAAI,YAAY,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QACjD,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;QAErB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;QAChC,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACH,GAAG,CAAC,EAAU;QACZ,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,EAAU;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,OAAO,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU;QACd,MAAM,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QAC/E,MAAM,OAAO,CAAC,UAAU,CAAC,eAAe,CAAC,CAAC;IAC5C,CAAC;IAED;;OAEG;IACH,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,OAAO;QACL,OAAO,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC;IACpC,CAAC;CACF;AAED,iBAAiB;AAEjB,IAAI,cAAc,GAA+B,IAAI,CAAC;AAEtD;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,CAAC,cAAc,EAAE,CAAC;QACpB,cAAc,GAAG,IAAI,mBAAmB,EAAE,CAAC;IAC7C,CAAC;IACD,OAAO,cAAc,CAAC;AACxB,CAAC"}
@@ -0,0 +1,27 @@
1
+ import type { AgentProfileEntity, AgentProfileProvider } from '../types.js';
2
+ declare function nextId(namespace: string): number;
3
+ declare function setIdCounter(namespace: string, val: number): void;
4
+ declare function getIdCounter(namespace: string): number;
5
+ /**
6
+ * 默认 AgentProfileProvider 实现 — JSON 文件存储
7
+ */
8
+ export declare class DefaultAgentProfileProvider implements AgentProfileProvider {
9
+ private store;
10
+ constructor(dataDir?: string);
11
+ private ensureDefaultProfile;
12
+ listProfiles(): AgentProfileEntity[];
13
+ getProfile(id: number): AgentProfileEntity | undefined;
14
+ getDefaultProfile(): AgentProfileEntity | undefined;
15
+ createProfile(data: Partial<AgentProfileEntity>): AgentProfileEntity;
16
+ updateProfile(id: number, data: Partial<AgentProfileEntity>): AgentProfileEntity | undefined;
17
+ deleteProfile(id: number): boolean;
18
+ }
19
+ export declare function getAgentProfileProvider(dataDir?: string): DefaultAgentProfileProvider;
20
+ export declare function listProfiles(): AgentProfileEntity[];
21
+ export declare function getProfile(id: number): AgentProfileEntity | undefined;
22
+ export declare function getDefaultProfile(): AgentProfileEntity | undefined;
23
+ export declare function createProfile(data: Partial<AgentProfileEntity>): AgentProfileEntity;
24
+ export declare function updateProfile(id: number, data: Partial<AgentProfileEntity>): AgentProfileEntity | undefined;
25
+ export declare function deleteProfile(id: number): boolean;
26
+ export { nextId, setIdCounter, getIdCounter };
27
+ //# sourceMappingURL=agent-profile.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-profile.service.d.ts","sourceRoot":"","sources":["../../../src/service/agent-profile.service.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAQ5E,iBAAS,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAGzC;AAED,iBAAS,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,IAAI,CAE1D;AAED,iBAAS,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAE/C;AAED;;GAEG;AACH,qBAAa,2BAA4B,YAAW,oBAAoB;IACtE,OAAO,CAAC,KAAK,CAAoC;gBAErC,OAAO,CAAC,EAAE,MAAM;IAK5B,OAAO,CAAC,oBAAoB;IAuB5B,YAAY,IAAI,kBAAkB,EAAE;IAIpC,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS;IAItD,iBAAiB,IAAI,kBAAkB,GAAG,SAAS;IAKnD,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB;IAgCpE,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,GAAG,SAAS;IAI5F,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO;CAKnC;AAMD,wBAAgB,uBAAuB,CAAC,OAAO,CAAC,EAAE,MAAM,GAAG,2BAA2B,CAGrF;AAGD,wBAAgB,YAAY,IAAI,kBAAkB,EAAE,CAEnD;AACD,wBAAgB,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,kBAAkB,GAAG,SAAS,CAErE;AACD,wBAAgB,iBAAiB,IAAI,kBAAkB,GAAG,SAAS,CAElE;AACD,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,CAEnF;AACD,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,kBAAkB,GAAG,SAAS,CAE3G;AACD,wBAAgB,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAEjD;AAED,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,CAAC"}
@@ -0,0 +1,130 @@
1
+ // ============================================================
2
+ // AgentProfileService — 多 Agent 配置管理(默认 JSON 文件实现)
3
+ // ============================================================
4
+ import { JsonListStore } from "../store/index.js";
5
+ import { formatLocalDateTime } from '@cicctencent/agent-core';
6
+ const DEFAULT_BASE_PROMPT = 'You are a helpful AI assistant with access to tools. Use tools when needed to accomplish tasks. Always explain your actions clearly. Respond in the same language as the user.';
7
+ // 自增 ID 辅助
8
+ let _idCounters = {};
9
+ function nextId(namespace) {
10
+ if (!_idCounters[namespace])
11
+ _idCounters[namespace] = Date.now();
12
+ return ++_idCounters[namespace];
13
+ }
14
+ function setIdCounter(namespace, val) {
15
+ _idCounters[namespace] = val;
16
+ }
17
+ function getIdCounter(namespace) {
18
+ return _idCounters[namespace] || 0;
19
+ }
20
+ /**
21
+ * 默认 AgentProfileProvider 实现 — JSON 文件存储
22
+ */
23
+ export class DefaultAgentProfileProvider {
24
+ store;
25
+ constructor(dataDir) {
26
+ this.store = new JsonListStore('agent-profiles.json', { projectLocal: true, ttl: 5 * 60 * 1000 });
27
+ this.ensureDefaultProfile();
28
+ }
29
+ ensureDefaultProfile() {
30
+ if (this.store.list().length > 0)
31
+ return;
32
+ this.store.add({
33
+ id: nextId('agent-profile'),
34
+ name: '默认 Agent',
35
+ description: '内置默认 Agent,支持工具调用和任务委派',
36
+ icon: '🤖',
37
+ color: '#6B5CE7',
38
+ basePrompt: DEFAULT_BASE_PROMPT,
39
+ maxIterations: 15,
40
+ maxMessages: 50,
41
+ toolTimeout: 30000,
42
+ disabledTools: [],
43
+ mcpServers: [],
44
+ connectorIds: [],
45
+ agentType: 'default',
46
+ isDefault: true,
47
+ createdAt: formatLocalDateTime(),
48
+ updatedAt: formatLocalDateTime(),
49
+ });
50
+ console.log('[AgentProfileService] 已创建默认 Agent');
51
+ }
52
+ listProfiles() {
53
+ return this.store.list();
54
+ }
55
+ getProfile(id) {
56
+ return this.store.findById(id);
57
+ }
58
+ getDefaultProfile() {
59
+ const list = this.store.list();
60
+ return list.find(p => p.isDefault) || list[0];
61
+ }
62
+ createProfile(data) {
63
+ const now = formatLocalDateTime();
64
+ const agentType = data.agentType === 'remote' ? 'remote' : 'specialist';
65
+ const profile = {
66
+ id: nextId('agent-profile'),
67
+ name: data.name || 'New Agent',
68
+ description: data.description,
69
+ icon: data.icon,
70
+ color: data.color,
71
+ basePrompt: data.basePrompt || DEFAULT_BASE_PROMPT,
72
+ model: data.model,
73
+ modelConfigId: data.modelConfigId,
74
+ maxIterations: data.maxIterations || 15,
75
+ maxMessages: data.maxMessages || 50,
76
+ toolTimeout: data.toolTimeout || 30000,
77
+ disabledTools: data.disabledTools || [],
78
+ mcpServers: data.mcpServers || [],
79
+ selectedSkills: data.selectedSkills,
80
+ alwaysInjectSkills: data.alwaysInjectSkills,
81
+ connectorIds: data.connectorIds || [],
82
+ agentType,
83
+ domain: data.domain,
84
+ remoteUrl: data.remoteUrl,
85
+ remoteAuth: data.remoteAuth,
86
+ a2aProtocol: data.a2aProtocol,
87
+ restA2AConfig: data.restA2AConfig,
88
+ createdAt: now,
89
+ updatedAt: now,
90
+ };
91
+ return this.store.add(profile);
92
+ }
93
+ updateProfile(id, data) {
94
+ return this.store.update(id, { ...data, updatedAt: formatLocalDateTime() });
95
+ }
96
+ deleteProfile(id) {
97
+ const profile = this.store.findById(id);
98
+ if (profile?.isDefault)
99
+ return false;
100
+ return this.store.remove(id);
101
+ }
102
+ }
103
+ // ---- 全局单例 ----
104
+ let globalProvider = null;
105
+ export function getAgentProfileProvider(dataDir) {
106
+ if (!globalProvider)
107
+ globalProvider = new DefaultAgentProfileProvider(dataDir);
108
+ return globalProvider;
109
+ }
110
+ // 向后兼容的导出
111
+ export function listProfiles() {
112
+ return getAgentProfileProvider().listProfiles();
113
+ }
114
+ export function getProfile(id) {
115
+ return getAgentProfileProvider().getProfile(id);
116
+ }
117
+ export function getDefaultProfile() {
118
+ return getAgentProfileProvider().getDefaultProfile();
119
+ }
120
+ export function createProfile(data) {
121
+ return getAgentProfileProvider().createProfile(data);
122
+ }
123
+ export function updateProfile(id, data) {
124
+ return getAgentProfileProvider().updateProfile(id, data);
125
+ }
126
+ export function deleteProfile(id) {
127
+ return getAgentProfileProvider().deleteProfile(id);
128
+ }
129
+ export { nextId, setIdCounter, getIdCounter };
130
+ //# sourceMappingURL=agent-profile.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"agent-profile.service.js","sourceRoot":"","sources":["../../../src/service/agent-profile.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,33 @@
1
+ /**
2
+ * @file Artifact 存储服务
3
+ * @description 将 Agent 生成的文件 Artifact(图表、数据文件等)持久化到沙箱目录内,
4
+ * 遵循沙箱隔离原则:所有 I/O 操作限制在沙箱 rootDir 中。
5
+ * 提供 HTTP URL 供前端下载/预览。
6
+ */
7
+ /** 根据文件扩展名推断 MIME 类型 */
8
+ export declare function getMimeType(filename: string): string;
9
+ /** 判断 MIME 类型是否为可内联预览的图片 */
10
+ export declare function isImageMime(mime: string): boolean;
11
+ /**
12
+ * 保存 Artifact 文件到沙箱目录内
13
+ *
14
+ * @param sandboxRoot 沙箱根目录(如 data/sandboxes/{sessionId})
15
+ * @param sessionId 会话 ID(用于生成唯一 artifactId)
16
+ * @param filename 原始文件名
17
+ * @param content 文件内容(字符串或 Buffer)
18
+ * @returns 保存结果:artifactId、文件大小、URL
19
+ */
20
+ export declare function saveArtifact(sandboxRoot: string, sessionId: string, filename: string, content: string | Buffer): {
21
+ artifactId: string;
22
+ filename: string;
23
+ mimeType: string;
24
+ size: number;
25
+ url: string;
26
+ dedup?: boolean;
27
+ };
28
+ /**
29
+ * 根据 sessionId + artifactId + filename 解析沙箱内文件路径
30
+ * 返回 null 如果文件不存在
31
+ */
32
+ export declare function resolveArtifactPath(sessionId: string, artifactId: string, filename: string): string | null;
33
+ //# sourceMappingURL=artifact.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"artifact.service.d.ts","sourceRoot":"","sources":["../../../src/service/artifact.service.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AA2BH,wBAAwB;AACxB,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAiCpD;AAED,4BAA4B;AAC5B,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAEjD;AAED;;;;;;;;GAQG;AACH,wBAAgB,YAAY,CAC1B,WAAW,EAAE,MAAM,EACnB,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,MAAM,GAAG,MAAM,GACvB;IACD,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAmDA;AAED;;;GAGG;AACH,wBAAgB,mBAAmB,CAAC,SAAS,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CA0B1G"}
@@ -0,0 +1,175 @@
1
+ /**
2
+ * @file Artifact 存储服务
3
+ * @description 将 Agent 生成的文件 Artifact(图表、数据文件等)持久化到沙箱目录内,
4
+ * 遵循沙箱隔离原则:所有 I/O 操作限制在沙箱 rootDir 中。
5
+ * 提供 HTTP URL 供前端下载/预览。
6
+ */
7
+ import * as fs from 'fs';
8
+ import * as path from 'path';
9
+ import * as crypto from 'crypto';
10
+ import { getSandboxManager } from "../sandbox/sandbox-manager.js";
11
+ import { getProjectDataPath } from "../utils/data-dir.js";
12
+ /** 最大文件大小:5MB */
13
+ const MAX_FILE_SIZE = 5 * 1024 * 1024;
14
+ /** 沙箱内 Artifact 子目录名 */
15
+ const ARTIFACTS_SUBDIR = '_artifacts';
16
+ /** 获取沙箱内的 _artifacts/ 目录,不存在则创建 */
17
+ function getSandboxArtifactsDir(sandboxRoot) {
18
+ const dir = path.join(sandboxRoot, ARTIFACTS_SUBDIR);
19
+ if (!fs.existsSync(dir)) {
20
+ fs.mkdirSync(dir, { recursive: true });
21
+ }
22
+ return dir;
23
+ }
24
+ function getArtifactStoredPath(sandboxRoot, artifactId, filename) {
25
+ return path.join(getSandboxArtifactsDir(sandboxRoot), artifactId, filename);
26
+ }
27
+ /** 根据文件扩展名推断 MIME 类型 */
28
+ export function getMimeType(filename) {
29
+ const ext = path.extname(filename).toLowerCase();
30
+ const mimeMap = {
31
+ // 图片
32
+ '.png': 'image/png',
33
+ '.jpg': 'image/jpeg',
34
+ '.jpeg': 'image/jpeg',
35
+ '.gif': 'image/gif',
36
+ '.svg': 'image/svg+xml',
37
+ '.webp': 'image/webp',
38
+ '.bmp': 'image/bmp',
39
+ // 数据
40
+ '.json': 'application/json',
41
+ '.csv': 'text/csv',
42
+ '.tsv': 'text/tab-separated-values',
43
+ '.xml': 'application/xml',
44
+ // 文档
45
+ '.pdf': 'application/pdf',
46
+ '.html': 'text/html',
47
+ '.md': 'text/markdown',
48
+ '.txt': 'text/plain',
49
+ // 压缩包
50
+ '.zip': 'application/zip',
51
+ '.gz': 'application/gzip',
52
+ // 表格
53
+ '.xlsx': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
54
+ '.xls': 'application/vnd.ms-excel',
55
+ '.pptx': 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
56
+ '.ppt': 'application/vnd.ms-powerpoint',
57
+ '.docx': 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
58
+ '.doc': 'application/msword',
59
+ };
60
+ return mimeMap[ext] || 'application/octet-stream';
61
+ }
62
+ /** 判断 MIME 类型是否为可内联预览的图片 */
63
+ export function isImageMime(mime) {
64
+ return mime.startsWith('image/');
65
+ }
66
+ /**
67
+ * 保存 Artifact 文件到沙箱目录内
68
+ *
69
+ * @param sandboxRoot 沙箱根目录(如 data/sandboxes/{sessionId})
70
+ * @param sessionId 会话 ID(用于生成唯一 artifactId)
71
+ * @param filename 原始文件名
72
+ * @param content 文件内容(字符串或 Buffer)
73
+ * @returns 保存结果:artifactId、文件大小、URL
74
+ */
75
+ export function saveArtifact(sandboxRoot, sessionId, filename, content) {
76
+ const buffer = typeof content === 'string' ? Buffer.from(content, 'utf-8') : content;
77
+ if (buffer.length > MAX_FILE_SIZE) {
78
+ throw new Error(`Artifact too large: ${buffer.length} bytes (max ${MAX_FILE_SIZE})`);
79
+ }
80
+ // 安全化文件名(去除路径分隔符和特殊字符)
81
+ const safeName = path.basename(filename).replace(/[^a-zA-Z0-9._\-\u4e00-\u9fff]/g, '_');
82
+ // 去重:检查是否已有同名同大小的 artifact,避免重复保存
83
+ const artifactsDir = getSandboxArtifactsDir(sandboxRoot);
84
+ try {
85
+ const entries = fs.readdirSync(artifactsDir, { withFileTypes: true });
86
+ for (const entry of entries) {
87
+ if (!entry.isDirectory() || entry.name === '.tmp')
88
+ continue;
89
+ const existingPath = path.join(artifactsDir, entry.name, safeName);
90
+ if (fs.existsSync(existingPath)) {
91
+ const stat = fs.statSync(existingPath);
92
+ if (stat.size === buffer.length) {
93
+ // Same file already saved — return existing artifact info (skip emit)
94
+ const mimeType = getMimeType(filename);
95
+ const url = `/api/work/artifacts/${encodeURIComponent(sessionId)}/${entry.name}/${encodeURIComponent(safeName)}`;
96
+ return {
97
+ artifactId: entry.name,
98
+ filename: safeName,
99
+ mimeType,
100
+ size: buffer.length,
101
+ url,
102
+ dedup: true,
103
+ };
104
+ }
105
+ }
106
+ }
107
+ }
108
+ catch { /* ignore dedup scan errors */ }
109
+ // 生成 artifactId
110
+ const timestamp = Date.now();
111
+ const hash = crypto.createHash('md5').update(sessionId + filename + timestamp).digest('hex').slice(0, 8);
112
+ const artifactId = `art_${timestamp}_${hash}`;
113
+ // 写入沙箱内 _artifacts/{artifactId}/ 目录
114
+ const filePath = getArtifactStoredPath(sandboxRoot, artifactId, safeName);
115
+ fs.mkdirSync(path.dirname(filePath), { recursive: true });
116
+ fs.writeFileSync(filePath, buffer);
117
+ const mimeType = getMimeType(filename);
118
+ // URL 路径:/api/work/artifacts/:sessionId/:artifactId/:filename
119
+ const url = `/api/work/artifacts/${encodeURIComponent(sessionId)}/${artifactId}/${encodeURIComponent(safeName)}`;
120
+ return { artifactId, filename: safeName, mimeType, size: buffer.length, url };
121
+ }
122
+ /**
123
+ * 根据 sessionId + artifactId + filename 解析沙箱内文件路径
124
+ * 返回 null 如果文件不存在
125
+ */
126
+ export function resolveArtifactPath(sessionId, artifactId, filename) {
127
+ const decodedName = decodeURIComponent(filename);
128
+ // 1. 优先从沙箱管理器获取对应沙箱的 rootDir
129
+ const sandbox = getSandboxManager().get(sessionId);
130
+ if (sandbox) {
131
+ const result = findInSandbox(sandbox.rootDir, artifactId, decodedName);
132
+ if (result)
133
+ return result;
134
+ }
135
+ // 2. 回退:delegate 子 Agent 复用父级沙箱,sessionId 未注册到 SandboxManager
136
+ // 扫描 data/sandboxes/ 下所有沙箱目录查找匹配的 artifactId
137
+ const sandboxesBase = getProjectDataPath('sandboxes');
138
+ if (fs.existsSync(sandboxesBase)) {
139
+ try {
140
+ const dirs = fs.readdirSync(sandboxesBase, { withFileTypes: true });
141
+ for (const entry of dirs) {
142
+ if (!entry.isDirectory())
143
+ continue;
144
+ const sandboxDir = path.join(sandboxesBase, entry.name);
145
+ const result = findInSandbox(sandboxDir, artifactId, decodedName);
146
+ if (result)
147
+ return result;
148
+ }
149
+ }
150
+ catch { /* ignore scan errors */ }
151
+ }
152
+ return null;
153
+ }
154
+ /** 在指定沙箱目录内查找 artifact 文件 */
155
+ function findInSandbox(sandboxRoot, artifactId, filename) {
156
+ const nestedPath = path.join(sandboxRoot, ARTIFACTS_SUBDIR, artifactId, filename);
157
+ if (fs.existsSync(nestedPath))
158
+ return nestedPath;
159
+ const dir = path.join(sandboxRoot, ARTIFACTS_SUBDIR);
160
+ const legacyPath = path.join(dir, `${artifactId}_${filename}`);
161
+ if (fs.existsSync(legacyPath))
162
+ return legacyPath;
163
+ // 兼容老格式:扫描 _artifacts/ 目录查找以 artifactId_ 开头的文件
164
+ try {
165
+ if (!fs.existsSync(dir))
166
+ return null;
167
+ const files = fs.readdirSync(dir);
168
+ const match = files.find(f => f.startsWith(artifactId + '_'));
169
+ if (match)
170
+ return path.join(dir, match);
171
+ }
172
+ catch { /* ignore */ }
173
+ return null;
174
+ }
175
+ //# sourceMappingURL=artifact.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"artifact.service.js","sourceRoot":"","sources":["../../../src/service/artifact.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ import type { ToolRiskAssessment } from '@cicctencent/agent-core';
2
+ export interface AuditLogEntry {
3
+ id: string;
4
+ ts: number;
5
+ sessionId: string;
6
+ traceId?: string;
7
+ iteration?: number;
8
+ phase: 'before_tool' | 'after_tool' | 'blocked';
9
+ tool: string;
10
+ args?: Record<string, unknown>;
11
+ result?: string;
12
+ isError?: boolean;
13
+ duration?: number;
14
+ risk: ToolRiskAssessment;
15
+ }
16
+ export interface AuditQuery {
17
+ limit?: number;
18
+ since?: number;
19
+ until?: number;
20
+ tool?: string;
21
+ level?: string;
22
+ sessionId?: string;
23
+ }
24
+ export declare function redactAuditEntry(entry: AuditLogEntry): AuditLogEntry;
25
+ export declare function appendAuditLog(entry: Omit<AuditLogEntry, 'id' | 'ts'> & {
26
+ id?: string;
27
+ ts?: number;
28
+ }): AuditLogEntry;
29
+ export declare function listAuditLogs(query?: AuditQuery): AuditLogEntry[];
30
+ //# sourceMappingURL=audit.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"audit.service.d.ts","sourceRoot":"","sources":["../../../src/service/audit.service.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAIlE,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,aAAa,GAAG,YAAY,GAAG,SAAS,CAAC;IAChD,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,kBAAkB,CAAC;CAC1B;AAED,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAqCD,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,aAAa,GAAG,aAAa,CAOpE;AA4BD,wBAAgB,cAAc,CAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,GAAG,IAAI,CAAC,GAAG;IAAE,EAAE,CAAC,EAAE,MAAM,CAAC;IAAC,EAAE,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,aAAa,CAcpH;AAED,wBAAgB,aAAa,CAAC,KAAK,GAAE,UAAe,GAAG,aAAa,EAAE,CAuBrE"}
@@ -0,0 +1,131 @@
1
+ // ============================================================
2
+ // AuditService — 审计日志(JSONL 文件存储)
3
+ // ============================================================
4
+ import * as fs from 'fs';
5
+ import * as fsp from 'fs/promises';
6
+ import * as path from 'path';
7
+ import { getProjectDataPath, ensureProjectDataDir } from "../utils/data-dir.js";
8
+ import { isLowRiskTool } from "./tool-risk.service.js";
9
+ import { getSecurityPolicy } from "./security-policy.service.js";
10
+ function auditDir() {
11
+ ensureProjectDataDir();
12
+ const dir = getProjectDataPath('audit');
13
+ if (!fs.existsSync(dir))
14
+ fs.mkdirSync(dir, { recursive: true });
15
+ return dir;
16
+ }
17
+ function auditFile(ts = Date.now()) {
18
+ const day = new Date(ts).toISOString().slice(0, 10);
19
+ return path.join(auditDir(), `${day}.jsonl`);
20
+ }
21
+ function safeJson(value) {
22
+ try {
23
+ return JSON.stringify(value);
24
+ }
25
+ catch {
26
+ return JSON.stringify(String(value));
27
+ }
28
+ }
29
+ function shouldRedactKey(key) {
30
+ return /(api[_-]?key|token|secret|password|passwd|authorization|cookie|credential|access[_-]?key|private[_-]?key)/i.test(key);
31
+ }
32
+ function redactValue(value, key = '') {
33
+ if (shouldRedactKey(key))
34
+ return '[REDACTED]';
35
+ if (typeof value === 'string') {
36
+ return value
37
+ .replace(/Bearer\s+[A-Za-z0-9._~+/=-]+/gi, 'Bearer [REDACTED]')
38
+ .replace(/(sk-[A-Za-z0-9_-]{8,})/g, '[REDACTED_KEY]')
39
+ .replace(/([A-Za-z0-9_-]{16,}\.[A-Za-z0-9_-]{16,}\.[A-Za-z0-9_-]{16,})/g, '[REDACTED_JWT]');
40
+ }
41
+ if (Array.isArray(value))
42
+ return value.map(item => redactValue(item));
43
+ if (value && typeof value === 'object') {
44
+ return Object.fromEntries(Object.entries(value).map(([k, v]) => [k, redactValue(v, k)]));
45
+ }
46
+ return value;
47
+ }
48
+ export function redactAuditEntry(entry) {
49
+ if (!getSecurityPolicy().redactAuditFields)
50
+ return entry;
51
+ return {
52
+ ...entry,
53
+ args: entry.args ? redactValue(entry.args) : undefined,
54
+ result: typeof entry.result === 'string' ? redactValue(entry.result) : entry.result,
55
+ };
56
+ }
57
+ // ===== 异步批量写入审计日志 =====
58
+ const _writeBuffer = [];
59
+ let _flushTimer = null;
60
+ const FLUSH_INTERVAL = 500;
61
+ async function flushAuditBuffer() {
62
+ if (_writeBuffer.length === 0)
63
+ return;
64
+ const batch = _writeBuffer.splice(0);
65
+ const groups = new Map();
66
+ for (const item of batch) {
67
+ const lines = groups.get(item.file) || [];
68
+ lines.push(item.line);
69
+ groups.set(item.file, lines);
70
+ }
71
+ for (const [file, lines] of groups) {
72
+ try {
73
+ await fsp.appendFile(file, lines.join('\n') + '\n', 'utf-8');
74
+ }
75
+ catch (e) {
76
+ console.error('[audit] flush failed:', file, e);
77
+ }
78
+ }
79
+ _flushTimer = null;
80
+ }
81
+ function scheduleFlush() {
82
+ if (_flushTimer)
83
+ return;
84
+ _flushTimer = setTimeout(() => { flushAuditBuffer(); }, FLUSH_INTERVAL);
85
+ if (_flushTimer && typeof _flushTimer === 'object' && 'unref' in _flushTimer)
86
+ _flushTimer.unref();
87
+ }
88
+ export function appendAuditLog(entry) {
89
+ if (!getSecurityPolicy().auditEnabled) {
90
+ return { id: entry.id || 'audit_disabled', ts: entry.ts || Date.now(), ...entry };
91
+ }
92
+ const needsRedaction = !isLowRiskTool(entry.tool);
93
+ const full = needsRedaction
94
+ ? redactAuditEntry({ id: entry.id || `${Date.now()}_${Math.random().toString(36).slice(2, 10)}`, ts: entry.ts || Date.now(), ...entry })
95
+ : { id: entry.id || `${Date.now()}_${Math.random().toString(36).slice(2, 10)}`, ts: entry.ts || Date.now(), ...entry };
96
+ const file = auditFile(full.ts);
97
+ _writeBuffer.push({ file, line: safeJson(full) });
98
+ scheduleFlush();
99
+ return full;
100
+ }
101
+ export function listAuditLogs(query = {}) {
102
+ const dir = auditDir();
103
+ const limit = Math.max(1, Math.min(Number(query.limit) || 100, 1000));
104
+ const files = fs.readdirSync(dir).filter(f => f.endsWith('.jsonl')).sort().reverse();
105
+ const results = [];
106
+ for (const file of files) {
107
+ const raw = fs.readFileSync(path.join(dir, file), 'utf-8');
108
+ const lines = raw.split('\n').filter(Boolean).reverse();
109
+ for (const line of lines) {
110
+ try {
111
+ const item = JSON.parse(line);
112
+ if (query.since && item.ts < query.since)
113
+ continue;
114
+ if (query.until && item.ts > query.until)
115
+ continue;
116
+ if (query.tool && item.tool !== query.tool)
117
+ continue;
118
+ if (query.level && item.risk?.level !== query.level)
119
+ continue;
120
+ if (query.sessionId && item.sessionId !== query.sessionId)
121
+ continue;
122
+ results.push(item);
123
+ if (results.length >= limit)
124
+ return results;
125
+ }
126
+ catch { /* skip */ }
127
+ }
128
+ }
129
+ return results;
130
+ }
131
+ //# sourceMappingURL=audit.service.js.map