@stardust-bytes/agent-hub 0.1.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 (562) hide show
  1. package/README.md +184 -0
  2. package/backend/.env.example +26 -0
  3. package/backend/dist/agent/agent.controller.d.ts +23 -0
  4. package/backend/dist/agent/agent.controller.js +114 -0
  5. package/backend/dist/agent/agent.controller.js.map +1 -0
  6. package/backend/dist/agent/agent.module.d.ts +2 -0
  7. package/backend/dist/agent/agent.module.js +128 -0
  8. package/backend/dist/agent/agent.module.js.map +1 -0
  9. package/backend/dist/agent/agent.service.d.ts +25 -0
  10. package/backend/dist/agent/agent.service.js +198 -0
  11. package/backend/dist/agent/agent.service.js.map +1 -0
  12. package/backend/dist/agent/dto/agent-action.dto.d.ts +10 -0
  13. package/backend/dist/agent/dto/agent-action.dto.js +73 -0
  14. package/backend/dist/agent/dto/agent-action.dto.js.map +1 -0
  15. package/backend/dist/agent/dto/agent-command.util.d.ts +4 -0
  16. package/backend/dist/agent/dto/agent-command.util.js +13 -0
  17. package/backend/dist/agent/dto/agent-command.util.js.map +1 -0
  18. package/backend/dist/agent/dto/agent-run-state.d.ts +21 -0
  19. package/backend/dist/agent/dto/agent-run-state.js +19 -0
  20. package/backend/dist/agent/dto/agent-run-state.js.map +1 -0
  21. package/backend/dist/agent/dto/agent-state.enum.d.ts +6 -0
  22. package/backend/dist/agent/dto/agent-state.enum.js +11 -0
  23. package/backend/dist/agent/dto/agent-state.enum.js.map +1 -0
  24. package/backend/dist/agent/dto/approve-tool.dto.d.ts +4 -0
  25. package/backend/dist/agent/dto/approve-tool.dto.js +25 -0
  26. package/backend/dist/agent/dto/approve-tool.dto.js.map +1 -0
  27. package/backend/dist/agent/dto/chat.dto.d.ts +6 -0
  28. package/backend/dist/agent/dto/chat.dto.js +35 -0
  29. package/backend/dist/agent/dto/chat.dto.js.map +1 -0
  30. package/backend/dist/agent/dto/execute-plan.dto.d.ts +4 -0
  31. package/backend/dist/agent/dto/execute-plan.dto.js +25 -0
  32. package/backend/dist/agent/dto/execute-plan.dto.js.map +1 -0
  33. package/backend/dist/agent/dto/permissions-config.d.ts +8 -0
  34. package/backend/dist/agent/dto/permissions-config.js +11 -0
  35. package/backend/dist/agent/dto/permissions-config.js.map +1 -0
  36. package/backend/dist/agent/dto/update-permissions.dto.d.ts +7 -0
  37. package/backend/dist/agent/dto/update-permissions.dto.js +46 -0
  38. package/backend/dist/agent/dto/update-permissions.dto.js.map +1 -0
  39. package/backend/dist/agent/dto/write-stream.interface.d.ts +3 -0
  40. package/backend/dist/agent/dto/write-stream.interface.js +3 -0
  41. package/backend/dist/agent/dto/write-stream.interface.js.map +1 -0
  42. package/backend/dist/agent/dto/yolo-config.dto.d.ts +5 -0
  43. package/backend/dist/agent/dto/yolo-config.dto.js +33 -0
  44. package/backend/dist/agent/dto/yolo-config.dto.js.map +1 -0
  45. package/backend/dist/agent/mcp/mcp-client.service.d.ts +15 -0
  46. package/backend/dist/agent/mcp/mcp-client.service.js +71 -0
  47. package/backend/dist/agent/mcp/mcp-client.service.js.map +1 -0
  48. package/backend/dist/agent/mcp/mcp.module.d.ts +2 -0
  49. package/backend/dist/agent/mcp/mcp.module.js +24 -0
  50. package/backend/dist/agent/mcp/mcp.module.js.map +1 -0
  51. package/backend/dist/agent/mcp/mcp.service.d.ts +23 -0
  52. package/backend/dist/agent/mcp/mcp.service.js +123 -0
  53. package/backend/dist/agent/mcp/mcp.service.js.map +1 -0
  54. package/backend/dist/agent/providers/llm-provider.interface.d.ts +41 -0
  55. package/backend/dist/agent/providers/llm-provider.interface.js +3 -0
  56. package/backend/dist/agent/providers/llm-provider.interface.js.map +1 -0
  57. package/backend/dist/agent/providers/ollama.provider.d.ts +5 -0
  58. package/backend/dist/agent/providers/ollama.provider.js +92 -0
  59. package/backend/dist/agent/providers/ollama.provider.js.map +1 -0
  60. package/backend/dist/agent/providers/openai.provider.d.ts +5 -0
  61. package/backend/dist/agent/providers/openai.provider.js +169 -0
  62. package/backend/dist/agent/providers/openai.provider.js.map +1 -0
  63. package/backend/dist/agent/services/agent-loop.service.d.ts +131 -0
  64. package/backend/dist/agent/services/agent-loop.service.js +764 -0
  65. package/backend/dist/agent/services/agent-loop.service.js.map +1 -0
  66. package/backend/dist/agent/services/approval-manager.service.d.ts +8 -0
  67. package/backend/dist/agent/services/approval-manager.service.js +50 -0
  68. package/backend/dist/agent/services/approval-manager.service.js.map +1 -0
  69. package/backend/dist/agent/services/context-builder.service.d.ts +32 -0
  70. package/backend/dist/agent/services/context-builder.service.js +118 -0
  71. package/backend/dist/agent/services/context-builder.service.js.map +1 -0
  72. package/backend/dist/agent/services/danger-patterns.config.d.ts +10 -0
  73. package/backend/dist/agent/services/danger-patterns.config.js +82 -0
  74. package/backend/dist/agent/services/danger-patterns.config.js.map +1 -0
  75. package/backend/dist/agent/services/denial-tracking.d.ts +12 -0
  76. package/backend/dist/agent/services/denial-tracking.js +34 -0
  77. package/backend/dist/agent/services/denial-tracking.js.map +1 -0
  78. package/backend/dist/agent/services/llm-controller.service.d.ts +19 -0
  79. package/backend/dist/agent/services/llm-controller.service.js +70 -0
  80. package/backend/dist/agent/services/llm-controller.service.js.map +1 -0
  81. package/backend/dist/agent/services/permissions.service.d.ts +24 -0
  82. package/backend/dist/agent/services/permissions.service.js +106 -0
  83. package/backend/dist/agent/services/permissions.service.js.map +1 -0
  84. package/backend/dist/agent/services/yolo-classifier.constants.d.ts +6 -0
  85. package/backend/dist/agent/services/yolo-classifier.constants.js +39 -0
  86. package/backend/dist/agent/services/yolo-classifier.constants.js.map +1 -0
  87. package/backend/dist/agent/services/yolo-classifier.service.d.ts +29 -0
  88. package/backend/dist/agent/services/yolo-classifier.service.js +139 -0
  89. package/backend/dist/agent/services/yolo-classifier.service.js.map +1 -0
  90. package/backend/dist/agent/subagent/subagent-tools.util.d.ts +3 -0
  91. package/backend/dist/agent/subagent/subagent-tools.util.js +37 -0
  92. package/backend/dist/agent/subagent/subagent-tools.util.js.map +1 -0
  93. package/backend/dist/agent/subagent/subagent.service.d.ts +17 -0
  94. package/backend/dist/agent/subagent/subagent.service.js +89 -0
  95. package/backend/dist/agent/subagent/subagent.service.js.map +1 -0
  96. package/backend/dist/agent-output/agent-output.controller.d.ts +20 -0
  97. package/backend/dist/agent-output/agent-output.controller.js +123 -0
  98. package/backend/dist/agent-output/agent-output.controller.js.map +1 -0
  99. package/backend/dist/agent-output/agent-output.module.d.ts +2 -0
  100. package/backend/dist/agent-output/agent-output.module.js +22 -0
  101. package/backend/dist/agent-output/agent-output.module.js.map +1 -0
  102. package/backend/dist/agent-profiles/agent-profiles.controller.d.ts +59 -0
  103. package/backend/dist/agent-profiles/agent-profiles.controller.js +70 -0
  104. package/backend/dist/agent-profiles/agent-profiles.controller.js.map +1 -0
  105. package/backend/dist/agent-profiles/agent-profiles.module.d.ts +2 -0
  106. package/backend/dist/agent-profiles/agent-profiles.module.js +23 -0
  107. package/backend/dist/agent-profiles/agent-profiles.module.js.map +1 -0
  108. package/backend/dist/agent-profiles/agent-profiles.service.d.ts +85 -0
  109. package/backend/dist/agent-profiles/agent-profiles.service.js +48 -0
  110. package/backend/dist/agent-profiles/agent-profiles.service.js.map +1 -0
  111. package/backend/dist/agent-profiles/dto/create-agent-profile.dto.d.ts +9 -0
  112. package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js +52 -0
  113. package/backend/dist/agent-profiles/dto/create-agent-profile.dto.js.map +1 -0
  114. package/backend/dist/agent-profiles/dto/update-agent-profile.dto.d.ts +5 -0
  115. package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js +9 -0
  116. package/backend/dist/agent-profiles/dto/update-agent-profile.dto.js.map +1 -0
  117. package/backend/dist/app.controller.d.ts +10 -0
  118. package/backend/dist/app.controller.js +39 -0
  119. package/backend/dist/app.controller.js.map +1 -0
  120. package/backend/dist/app.module.d.ts +2 -0
  121. package/backend/dist/app.module.js +68 -0
  122. package/backend/dist/app.module.js.map +1 -0
  123. package/backend/dist/connector/connector.controller.d.ts +67 -0
  124. package/backend/dist/connector/connector.controller.js +150 -0
  125. package/backend/dist/connector/connector.controller.js.map +1 -0
  126. package/backend/dist/connector/connector.module.d.ts +2 -0
  127. package/backend/dist/connector/connector.module.js +28 -0
  128. package/backend/dist/connector/connector.module.js.map +1 -0
  129. package/backend/dist/connector/connector.service.d.ts +61 -0
  130. package/backend/dist/connector/connector.service.js +63 -0
  131. package/backend/dist/connector/connector.service.js.map +1 -0
  132. package/backend/dist/connector/dto/oauth-confirm.dto.d.ts +4 -0
  133. package/backend/dist/connector/dto/oauth-confirm.dto.js +25 -0
  134. package/backend/dist/connector/dto/oauth-confirm.dto.js.map +1 -0
  135. package/backend/dist/connector/dto/update-connector.dto.d.ts +5 -0
  136. package/backend/dist/connector/dto/update-connector.dto.js +9 -0
  137. package/backend/dist/connector/dto/update-connector.dto.js.map +1 -0
  138. package/backend/dist/connector/dto/upsert-connector.dto.d.ts +6 -0
  139. package/backend/dist/connector/dto/upsert-connector.dto.js +35 -0
  140. package/backend/dist/connector/dto/upsert-connector.dto.js.map +1 -0
  141. package/backend/dist/connector/providers/google/gmail.service.d.ts +31 -0
  142. package/backend/dist/connector/providers/google/gmail.service.js +114 -0
  143. package/backend/dist/connector/providers/google/gmail.service.js.map +1 -0
  144. package/backend/dist/connector/providers/google/google-calendar.service.d.ts +37 -0
  145. package/backend/dist/connector/providers/google/google-calendar.service.js +105 -0
  146. package/backend/dist/connector/providers/google/google-calendar.service.js.map +1 -0
  147. package/backend/dist/connector/providers/google/google-drive.service.d.ts +22 -0
  148. package/backend/dist/connector/providers/google/google-drive.service.js +130 -0
  149. package/backend/dist/connector/providers/google/google-drive.service.js.map +1 -0
  150. package/backend/dist/connector/providers/google/google-oauth.service.d.ts +23 -0
  151. package/backend/dist/connector/providers/google/google-oauth.service.js +74 -0
  152. package/backend/dist/connector/providers/google/google-oauth.service.js.map +1 -0
  153. package/backend/dist/connector/providers/google/google-sheets.service.d.ts +29 -0
  154. package/backend/dist/connector/providers/google/google-sheets.service.js +246 -0
  155. package/backend/dist/connector/providers/google/google-sheets.service.js.map +1 -0
  156. package/backend/dist/cowork/cowork.controller.d.ts +37 -0
  157. package/backend/dist/cowork/cowork.controller.js +127 -0
  158. package/backend/dist/cowork/cowork.controller.js.map +1 -0
  159. package/backend/dist/cowork/cowork.module.d.ts +2 -0
  160. package/backend/dist/cowork/cowork.module.js +26 -0
  161. package/backend/dist/cowork/cowork.module.js.map +1 -0
  162. package/backend/dist/cowork/cowork.service.d.ts +40 -0
  163. package/backend/dist/cowork/cowork.service.js +116 -0
  164. package/backend/dist/cowork/cowork.service.js.map +1 -0
  165. package/backend/dist/cowork/dto/set-project.dto.d.ts +3 -0
  166. package/backend/dist/cowork/dto/set-project.dto.js +21 -0
  167. package/backend/dist/cowork/dto/set-project.dto.js.map +1 -0
  168. package/backend/dist/excel/excel.module.d.ts +2 -0
  169. package/backend/dist/excel/excel.module.js +26 -0
  170. package/backend/dist/excel/excel.module.js.map +1 -0
  171. package/backend/dist/excel/excel.service.d.ts +33 -0
  172. package/backend/dist/excel/excel.service.js +204 -0
  173. package/backend/dist/excel/excel.service.js.map +1 -0
  174. package/backend/dist/excel/executors/excel-add-sheet.executor.d.ts +12 -0
  175. package/backend/dist/excel/executors/excel-add-sheet.executor.js +64 -0
  176. package/backend/dist/excel/executors/excel-add-sheet.executor.js.map +1 -0
  177. package/backend/dist/excel/executors/excel-chart.executor.d.ts +12 -0
  178. package/backend/dist/excel/executors/excel-chart.executor.js +68 -0
  179. package/backend/dist/excel/executors/excel-chart.executor.js.map +1 -0
  180. package/backend/dist/excel/executors/list-excel-sheets.executor.d.ts +8 -0
  181. package/backend/dist/excel/executors/list-excel-sheets.executor.js +38 -0
  182. package/backend/dist/excel/executors/list-excel-sheets.executor.js.map +1 -0
  183. package/backend/dist/excel/executors/read-excel.executor.d.ts +8 -0
  184. package/backend/dist/excel/executors/read-excel.executor.js +40 -0
  185. package/backend/dist/excel/executors/read-excel.executor.js.map +1 -0
  186. package/backend/dist/excel/executors/write-excel.executor.d.ts +12 -0
  187. package/backend/dist/excel/executors/write-excel.executor.js +66 -0
  188. package/backend/dist/excel/executors/write-excel.executor.js.map +1 -0
  189. package/backend/dist/files/files.controller.d.ts +8 -0
  190. package/backend/dist/files/files.controller.js +53 -0
  191. package/backend/dist/files/files.controller.js.map +1 -0
  192. package/backend/dist/files/files.module.d.ts +2 -0
  193. package/backend/dist/files/files.module.js +20 -0
  194. package/backend/dist/files/files.module.js.map +1 -0
  195. package/backend/dist/http-exception.filter.d.ts +4 -0
  196. package/backend/dist/http-exception.filter.js +32 -0
  197. package/backend/dist/http-exception.filter.js.map +1 -0
  198. package/backend/dist/knowledge/dto/search.dto.d.ts +3 -0
  199. package/backend/dist/knowledge/dto/search.dto.js +21 -0
  200. package/backend/dist/knowledge/dto/search.dto.js.map +1 -0
  201. package/backend/dist/knowledge/knowledge.controller.d.ts +38 -0
  202. package/backend/dist/knowledge/knowledge.controller.js +91 -0
  203. package/backend/dist/knowledge/knowledge.controller.js.map +1 -0
  204. package/backend/dist/knowledge/knowledge.module.d.ts +2 -0
  205. package/backend/dist/knowledge/knowledge.module.js +25 -0
  206. package/backend/dist/knowledge/knowledge.module.js.map +1 -0
  207. package/backend/dist/knowledge/knowledge.service.d.ts +103 -0
  208. package/backend/dist/knowledge/knowledge.service.js +379 -0
  209. package/backend/dist/knowledge/knowledge.service.js.map +1 -0
  210. package/backend/dist/main.d.ts +1 -0
  211. package/backend/dist/main.js +33 -0
  212. package/backend/dist/main.js.map +1 -0
  213. package/backend/dist/memory/dto/create-memory.dto.d.ts +6 -0
  214. package/backend/dist/memory/dto/create-memory.dto.js +34 -0
  215. package/backend/dist/memory/dto/create-memory.dto.js.map +1 -0
  216. package/backend/dist/memory/dto/search-memory.dto.d.ts +5 -0
  217. package/backend/dist/memory/dto/search-memory.dto.js +32 -0
  218. package/backend/dist/memory/dto/search-memory.dto.js.map +1 -0
  219. package/backend/dist/memory/dto/update-memory.dto.d.ts +5 -0
  220. package/backend/dist/memory/dto/update-memory.dto.js +9 -0
  221. package/backend/dist/memory/dto/update-memory.dto.js.map +1 -0
  222. package/backend/dist/memory/memory-extraction.service.d.ts +19 -0
  223. package/backend/dist/memory/memory-extraction.service.js +87 -0
  224. package/backend/dist/memory/memory-extraction.service.js.map +1 -0
  225. package/backend/dist/memory/memory.constants.d.ts +9 -0
  226. package/backend/dist/memory/memory.constants.js +13 -0
  227. package/backend/dist/memory/memory.constants.js.map +1 -0
  228. package/backend/dist/memory/memory.controller.d.ts +53 -0
  229. package/backend/dist/memory/memory.controller.js +81 -0
  230. package/backend/dist/memory/memory.controller.js.map +1 -0
  231. package/backend/dist/memory/memory.gateway.d.ts +8 -0
  232. package/backend/dist/memory/memory.gateway.js +37 -0
  233. package/backend/dist/memory/memory.gateway.js.map +1 -0
  234. package/backend/dist/memory/memory.module.d.ts +2 -0
  235. package/backend/dist/memory/memory.module.js +25 -0
  236. package/backend/dist/memory/memory.module.js.map +1 -0
  237. package/backend/dist/memory/memory.service.d.ts +70 -0
  238. package/backend/dist/memory/memory.service.js +144 -0
  239. package/backend/dist/memory/memory.service.js.map +1 -0
  240. package/backend/dist/mode-policy/mode-policy.config.d.ts +20 -0
  241. package/backend/dist/mode-policy/mode-policy.config.js +17 -0
  242. package/backend/dist/mode-policy/mode-policy.config.js.map +1 -0
  243. package/backend/dist/mode-policy/mode-policy.module.d.ts +2 -0
  244. package/backend/dist/mode-policy/mode-policy.module.js +21 -0
  245. package/backend/dist/mode-policy/mode-policy.module.js.map +1 -0
  246. package/backend/dist/mode-policy/mode-policy.service.d.ts +18 -0
  247. package/backend/dist/mode-policy/mode-policy.service.js +66 -0
  248. package/backend/dist/mode-policy/mode-policy.service.js.map +1 -0
  249. package/backend/dist/notes/dto/create-note.dto.d.ts +4 -0
  250. package/backend/dist/notes/dto/create-note.dto.js +27 -0
  251. package/backend/dist/notes/dto/create-note.dto.js.map +1 -0
  252. package/backend/dist/notes/dto/update-note.dto.d.ts +5 -0
  253. package/backend/dist/notes/dto/update-note.dto.js +9 -0
  254. package/backend/dist/notes/dto/update-note.dto.js.map +1 -0
  255. package/backend/dist/notes/notes.controller.d.ts +35 -0
  256. package/backend/dist/notes/notes.controller.js +70 -0
  257. package/backend/dist/notes/notes.controller.js.map +1 -0
  258. package/backend/dist/notes/notes.gateway.d.ts +8 -0
  259. package/backend/dist/notes/notes.gateway.js +37 -0
  260. package/backend/dist/notes/notes.gateway.js.map +1 -0
  261. package/backend/dist/notes/notes.module.d.ts +2 -0
  262. package/backend/dist/notes/notes.module.js +24 -0
  263. package/backend/dist/notes/notes.module.js.map +1 -0
  264. package/backend/dist/notes/notes.service.d.ts +45 -0
  265. package/backend/dist/notes/notes.service.js +57 -0
  266. package/backend/dist/notes/notes.service.js.map +1 -0
  267. package/backend/dist/plans/plans.controller.d.ts +100 -0
  268. package/backend/dist/plans/plans.controller.js +80 -0
  269. package/backend/dist/plans/plans.controller.js.map +1 -0
  270. package/backend/dist/plans/plans.module.d.ts +2 -0
  271. package/backend/dist/plans/plans.module.js +23 -0
  272. package/backend/dist/plans/plans.module.js.map +1 -0
  273. package/backend/dist/plans/plans.service.d.ts +141 -0
  274. package/backend/dist/plans/plans.service.js +94 -0
  275. package/backend/dist/plans/plans.service.js.map +1 -0
  276. package/backend/dist/prisma/prisma.module.d.ts +2 -0
  277. package/backend/dist/prisma/prisma.module.js +22 -0
  278. package/backend/dist/prisma/prisma.module.js.map +1 -0
  279. package/backend/dist/prisma/prisma.service.d.ts +6 -0
  280. package/backend/dist/prisma/prisma.service.js +24 -0
  281. package/backend/dist/prisma/prisma.service.js.map +1 -0
  282. package/backend/dist/providers/dto/create-provider-model.dto.d.ts +3 -0
  283. package/backend/dist/providers/dto/create-provider-model.dto.js +22 -0
  284. package/backend/dist/providers/dto/create-provider-model.dto.js.map +1 -0
  285. package/backend/dist/providers/dto/create-provider.dto.d.ts +6 -0
  286. package/backend/dist/providers/dto/create-provider.dto.js +37 -0
  287. package/backend/dist/providers/dto/create-provider.dto.js.map +1 -0
  288. package/backend/dist/providers/dto/update-provider.dto.d.ts +5 -0
  289. package/backend/dist/providers/dto/update-provider.dto.js +9 -0
  290. package/backend/dist/providers/dto/update-provider.dto.js.map +1 -0
  291. package/backend/dist/providers/providers.controller.d.ts +60 -0
  292. package/backend/dist/providers/providers.controller.js +113 -0
  293. package/backend/dist/providers/providers.controller.js.map +1 -0
  294. package/backend/dist/providers/providers.module.d.ts +2 -0
  295. package/backend/dist/providers/providers.module.js +23 -0
  296. package/backend/dist/providers/providers.module.js.map +1 -0
  297. package/backend/dist/providers/providers.service.d.ts +86 -0
  298. package/backend/dist/providers/providers.service.js +100 -0
  299. package/backend/dist/providers/providers.service.js.map +1 -0
  300. package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.d.ts +13 -0
  301. package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js +81 -0
  302. package/backend/dist/schedule-tasks/dto/create-schedule-task.dto.js.map +1 -0
  303. package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.d.ts +5 -0
  304. package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js +9 -0
  305. package/backend/dist/schedule-tasks/dto/update-schedule-task.dto.js.map +1 -0
  306. package/backend/dist/schedule-tasks/schedule-cron.service.d.ts +8 -0
  307. package/backend/dist/schedule-tasks/schedule-cron.service.js +50 -0
  308. package/backend/dist/schedule-tasks/schedule-cron.service.js.map +1 -0
  309. package/backend/dist/schedule-tasks/schedule-runner.service.d.ts +25 -0
  310. package/backend/dist/schedule-tasks/schedule-runner.service.js +109 -0
  311. package/backend/dist/schedule-tasks/schedule-runner.service.js.map +1 -0
  312. package/backend/dist/schedule-tasks/schedule-tasks.controller.d.ts +108 -0
  313. package/backend/dist/schedule-tasks/schedule-tasks.controller.js +85 -0
  314. package/backend/dist/schedule-tasks/schedule-tasks.controller.js.map +1 -0
  315. package/backend/dist/schedule-tasks/schedule-tasks.module.d.ts +2 -0
  316. package/backend/dist/schedule-tasks/schedule-tasks.module.js +32 -0
  317. package/backend/dist/schedule-tasks/schedule-tasks.module.js.map +1 -0
  318. package/backend/dist/schedule-tasks/schedule-tasks.service.d.ts +141 -0
  319. package/backend/dist/schedule-tasks/schedule-tasks.service.js +80 -0
  320. package/backend/dist/schedule-tasks/schedule-tasks.service.js.map +1 -0
  321. package/backend/dist/sessions/sessions.controller.d.ts +40 -0
  322. package/backend/dist/sessions/sessions.controller.js +75 -0
  323. package/backend/dist/sessions/sessions.controller.js.map +1 -0
  324. package/backend/dist/sessions/sessions.module.d.ts +2 -0
  325. package/backend/dist/sessions/sessions.module.js +23 -0
  326. package/backend/dist/sessions/sessions.module.js.map +1 -0
  327. package/backend/dist/sessions/sessions.service.d.ts +55 -0
  328. package/backend/dist/sessions/sessions.service.js +73 -0
  329. package/backend/dist/sessions/sessions.service.js.map +1 -0
  330. package/backend/dist/settings/settings.controller.d.ts +14 -0
  331. package/backend/dist/settings/settings.controller.js +56 -0
  332. package/backend/dist/settings/settings.controller.js.map +1 -0
  333. package/backend/dist/settings/settings.module.d.ts +2 -0
  334. package/backend/dist/settings/settings.module.js +24 -0
  335. package/backend/dist/settings/settings.module.js.map +1 -0
  336. package/backend/dist/settings/settings.service.d.ts +10 -0
  337. package/backend/dist/settings/settings.service.js +49 -0
  338. package/backend/dist/settings/settings.service.js.map +1 -0
  339. package/backend/dist/tools/executors/convert-note-to-task.executor.d.ts +12 -0
  340. package/backend/dist/tools/executors/convert-note-to-task.executor.js +59 -0
  341. package/backend/dist/tools/executors/convert-note-to-task.executor.js.map +1 -0
  342. package/backend/dist/tools/executors/create-note.executor.d.ts +8 -0
  343. package/backend/dist/tools/executors/create-note.executor.js +39 -0
  344. package/backend/dist/tools/executors/create-note.executor.js.map +1 -0
  345. package/backend/dist/tools/executors/create-plan.executor.d.ts +8 -0
  346. package/backend/dist/tools/executors/create-plan.executor.js +45 -0
  347. package/backend/dist/tools/executors/create-plan.executor.js.map +1 -0
  348. package/backend/dist/tools/executors/create-task.executor.d.ts +10 -0
  349. package/backend/dist/tools/executors/create-task.executor.js +53 -0
  350. package/backend/dist/tools/executors/create-task.executor.js.map +1 -0
  351. package/backend/dist/tools/executors/delete-note.executor.d.ts +8 -0
  352. package/backend/dist/tools/executors/delete-note.executor.js +38 -0
  353. package/backend/dist/tools/executors/delete-note.executor.js.map +1 -0
  354. package/backend/dist/tools/executors/delete-tasks.executor.d.ts +8 -0
  355. package/backend/dist/tools/executors/delete-tasks.executor.js +33 -0
  356. package/backend/dist/tools/executors/delete-tasks.executor.js.map +1 -0
  357. package/backend/dist/tools/executors/get-task.executor.d.ts +8 -0
  358. package/backend/dist/tools/executors/get-task.executor.js +44 -0
  359. package/backend/dist/tools/executors/get-task.executor.js.map +1 -0
  360. package/backend/dist/tools/executors/glob.executor.d.ts +10 -0
  361. package/backend/dist/tools/executors/glob.executor.js +82 -0
  362. package/backend/dist/tools/executors/glob.executor.js.map +1 -0
  363. package/backend/dist/tools/executors/google-calendar-availability.executor.d.ts +23 -0
  364. package/backend/dist/tools/executors/google-calendar-availability.executor.js +46 -0
  365. package/backend/dist/tools/executors/google-calendar-availability.executor.js.map +1 -0
  366. package/backend/dist/tools/executors/google-calendar-create.executor.d.ts +42 -0
  367. package/backend/dist/tools/executors/google-calendar-create.executor.js +48 -0
  368. package/backend/dist/tools/executors/google-calendar-create.executor.js.map +1 -0
  369. package/backend/dist/tools/executors/google-calendar-list.executor.d.ts +22 -0
  370. package/backend/dist/tools/executors/google-calendar-list.executor.js +45 -0
  371. package/backend/dist/tools/executors/google-calendar-list.executor.js.map +1 -0
  372. package/backend/dist/tools/executors/google-calendar-update.executor.d.ts +31 -0
  373. package/backend/dist/tools/executors/google-calendar-update.executor.js +50 -0
  374. package/backend/dist/tools/executors/google-calendar-update.executor.js.map +1 -0
  375. package/backend/dist/tools/executors/google-drive-create-folder.executor.d.ts +23 -0
  376. package/backend/dist/tools/executors/google-drive-create-folder.executor.js +44 -0
  377. package/backend/dist/tools/executors/google-drive-create-folder.executor.js.map +1 -0
  378. package/backend/dist/tools/executors/google-drive-list.executor.d.ts +18 -0
  379. package/backend/dist/tools/executors/google-drive-list.executor.js +44 -0
  380. package/backend/dist/tools/executors/google-drive-list.executor.js.map +1 -0
  381. package/backend/dist/tools/executors/google-drive-read.executor.d.ts +19 -0
  382. package/backend/dist/tools/executors/google-drive-read.executor.js +48 -0
  383. package/backend/dist/tools/executors/google-drive-read.executor.js.map +1 -0
  384. package/backend/dist/tools/executors/google-drive-search.executor.d.ts +23 -0
  385. package/backend/dist/tools/executors/google-drive-search.executor.js +46 -0
  386. package/backend/dist/tools/executors/google-drive-search.executor.js.map +1 -0
  387. package/backend/dist/tools/executors/google-drive-upload.executor.d.ts +30 -0
  388. package/backend/dist/tools/executors/google-drive-upload.executor.js +49 -0
  389. package/backend/dist/tools/executors/google-drive-upload.executor.js.map +1 -0
  390. package/backend/dist/tools/executors/google-gmail-draft.executor.d.ts +30 -0
  391. package/backend/dist/tools/executors/google-gmail-draft.executor.js +45 -0
  392. package/backend/dist/tools/executors/google-gmail-draft.executor.js.map +1 -0
  393. package/backend/dist/tools/executors/google-gmail-labels.executor.d.ts +13 -0
  394. package/backend/dist/tools/executors/google-gmail-labels.executor.js +39 -0
  395. package/backend/dist/tools/executors/google-gmail-labels.executor.js.map +1 -0
  396. package/backend/dist/tools/executors/google-gmail-read.executor.d.ts +19 -0
  397. package/backend/dist/tools/executors/google-gmail-read.executor.js +43 -0
  398. package/backend/dist/tools/executors/google-gmail-read.executor.js.map +1 -0
  399. package/backend/dist/tools/executors/google-gmail-search.executor.d.ts +23 -0
  400. package/backend/dist/tools/executors/google-gmail-search.executor.js +46 -0
  401. package/backend/dist/tools/executors/google-gmail-search.executor.js.map +1 -0
  402. package/backend/dist/tools/executors/google-gmail-send.executor.d.ts +44 -0
  403. package/backend/dist/tools/executors/google-gmail-send.executor.js +47 -0
  404. package/backend/dist/tools/executors/google-gmail-send.executor.js.map +1 -0
  405. package/backend/dist/tools/executors/google-sheets-add-tab.executor.d.ts +23 -0
  406. package/backend/dist/tools/executors/google-sheets-add-tab.executor.js +44 -0
  407. package/backend/dist/tools/executors/google-sheets-add-tab.executor.js.map +1 -0
  408. package/backend/dist/tools/executors/google-sheets-append.executor.d.ts +30 -0
  409. package/backend/dist/tools/executors/google-sheets-append.executor.js +45 -0
  410. package/backend/dist/tools/executors/google-sheets-append.executor.js.map +1 -0
  411. package/backend/dist/tools/executors/google-sheets-chart.executor.d.ts +40 -0
  412. package/backend/dist/tools/executors/google-sheets-chart.executor.js +48 -0
  413. package/backend/dist/tools/executors/google-sheets-chart.executor.js.map +1 -0
  414. package/backend/dist/tools/executors/google-sheets-create.executor.d.ts +27 -0
  415. package/backend/dist/tools/executors/google-sheets-create.executor.js +44 -0
  416. package/backend/dist/tools/executors/google-sheets-create.executor.js.map +1 -0
  417. package/backend/dist/tools/executors/google-sheets-format.executor.d.ts +57 -0
  418. package/backend/dist/tools/executors/google-sheets-format.executor.js +58 -0
  419. package/backend/dist/tools/executors/google-sheets-format.executor.js.map +1 -0
  420. package/backend/dist/tools/executors/google-sheets-list-tabs.executor.d.ts +19 -0
  421. package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js +43 -0
  422. package/backend/dist/tools/executors/google-sheets-list-tabs.executor.js.map +1 -0
  423. package/backend/dist/tools/executors/google-sheets-read.executor.d.ts +27 -0
  424. package/backend/dist/tools/executors/google-sheets-read.executor.js +45 -0
  425. package/backend/dist/tools/executors/google-sheets-read.executor.js.map +1 -0
  426. package/backend/dist/tools/executors/google-sheets-update.executor.d.ts +34 -0
  427. package/backend/dist/tools/executors/google-sheets-update.executor.js +46 -0
  428. package/backend/dist/tools/executors/google-sheets-update.executor.js.map +1 -0
  429. package/backend/dist/tools/executors/grep.executor.d.ts +9 -0
  430. package/backend/dist/tools/executors/grep.executor.js +82 -0
  431. package/backend/dist/tools/executors/grep.executor.js.map +1 -0
  432. package/backend/dist/tools/executors/list-directory.executor.d.ts +8 -0
  433. package/backend/dist/tools/executors/list-directory.executor.js +37 -0
  434. package/backend/dist/tools/executors/list-directory.executor.js.map +1 -0
  435. package/backend/dist/tools/executors/list-notes.executor.d.ts +8 -0
  436. package/backend/dist/tools/executors/list-notes.executor.js +37 -0
  437. package/backend/dist/tools/executors/list-notes.executor.js.map +1 -0
  438. package/backend/dist/tools/executors/list-tasks.executor.d.ts +8 -0
  439. package/backend/dist/tools/executors/list-tasks.executor.js +32 -0
  440. package/backend/dist/tools/executors/list-tasks.executor.js.map +1 -0
  441. package/backend/dist/tools/executors/read-file.executor.d.ts +8 -0
  442. package/backend/dist/tools/executors/read-file.executor.js +44 -0
  443. package/backend/dist/tools/executors/read-file.executor.js.map +1 -0
  444. package/backend/dist/tools/executors/resume-plan.executor.d.ts +8 -0
  445. package/backend/dist/tools/executors/resume-plan.executor.js +58 -0
  446. package/backend/dist/tools/executors/resume-plan.executor.js.map +1 -0
  447. package/backend/dist/tools/executors/run-command.executor.d.ts +5 -0
  448. package/backend/dist/tools/executors/run-command.executor.js +55 -0
  449. package/backend/dist/tools/executors/run-command.executor.js.map +1 -0
  450. package/backend/dist/tools/executors/search-knowledge.executor.d.ts +8 -0
  451. package/backend/dist/tools/executors/search-knowledge.executor.js +33 -0
  452. package/backend/dist/tools/executors/search-knowledge.executor.js.map +1 -0
  453. package/backend/dist/tools/executors/spawn-subagent.executor.d.ts +5 -0
  454. package/backend/dist/tools/executors/spawn-subagent.executor.js +27 -0
  455. package/backend/dist/tools/executors/spawn-subagent.executor.js.map +1 -0
  456. package/backend/dist/tools/executors/tool-executor.interface.d.ts +8 -0
  457. package/backend/dist/tools/executors/tool-executor.interface.js +3 -0
  458. package/backend/dist/tools/executors/tool-executor.interface.js.map +1 -0
  459. package/backend/dist/tools/executors/update-note.executor.d.ts +8 -0
  460. package/backend/dist/tools/executors/update-note.executor.js +43 -0
  461. package/backend/dist/tools/executors/update-note.executor.js.map +1 -0
  462. package/backend/dist/tools/executors/update-task.executor.d.ts +8 -0
  463. package/backend/dist/tools/executors/update-task.executor.js +50 -0
  464. package/backend/dist/tools/executors/update-task.executor.js.map +1 -0
  465. package/backend/dist/tools/executors/web-fetch.executor.d.ts +8 -0
  466. package/backend/dist/tools/executors/web-fetch.executor.js +57 -0
  467. package/backend/dist/tools/executors/web-fetch.executor.js.map +1 -0
  468. package/backend/dist/tools/executors/web-search.executor.d.ts +8 -0
  469. package/backend/dist/tools/executors/web-search.executor.js +70 -0
  470. package/backend/dist/tools/executors/web-search.executor.js.map +1 -0
  471. package/backend/dist/tools/executors/write-file.executor.d.ts +10 -0
  472. package/backend/dist/tools/executors/write-file.executor.js +60 -0
  473. package/backend/dist/tools/executors/write-file.executor.js.map +1 -0
  474. package/backend/dist/tools/tools.controller.d.ts +37 -0
  475. package/backend/dist/tools/tools.controller.js +63 -0
  476. package/backend/dist/tools/tools.controller.js.map +1 -0
  477. package/backend/dist/tools/tools.module.d.ts +2 -0
  478. package/backend/dist/tools/tools.module.js +128 -0
  479. package/backend/dist/tools/tools.module.js.map +1 -0
  480. package/backend/dist/tools/tools.service.d.ts +55 -0
  481. package/backend/dist/tools/tools.service.js +49 -0
  482. package/backend/dist/tools/tools.service.js.map +1 -0
  483. package/backend/dist/usage/dto/create-usage.dto.d.ts +8 -0
  484. package/backend/dist/usage/dto/create-usage.dto.js +45 -0
  485. package/backend/dist/usage/dto/create-usage.dto.js.map +1 -0
  486. package/backend/dist/usage/usage.controller.d.ts +19 -0
  487. package/backend/dist/usage/usage.controller.js +43 -0
  488. package/backend/dist/usage/usage.controller.js.map +1 -0
  489. package/backend/dist/usage/usage.module.d.ts +2 -0
  490. package/backend/dist/usage/usage.module.js +24 -0
  491. package/backend/dist/usage/usage.module.js.map +1 -0
  492. package/backend/dist/usage/usage.service.d.ts +30 -0
  493. package/backend/dist/usage/usage.service.js +61 -0
  494. package/backend/dist/usage/usage.service.js.map +1 -0
  495. package/backend/dist/word/executors/edit-word.executor.d.ts +12 -0
  496. package/backend/dist/word/executors/edit-word.executor.js +65 -0
  497. package/backend/dist/word/executors/edit-word.executor.js.map +1 -0
  498. package/backend/dist/word/executors/read-word.executor.d.ts +10 -0
  499. package/backend/dist/word/executors/read-word.executor.js +49 -0
  500. package/backend/dist/word/executors/read-word.executor.js.map +1 -0
  501. package/backend/dist/word/executors/write-word.executor.d.ts +12 -0
  502. package/backend/dist/word/executors/write-word.executor.js +63 -0
  503. package/backend/dist/word/executors/write-word.executor.js.map +1 -0
  504. package/backend/dist/word/word.module.d.ts +2 -0
  505. package/backend/dist/word/word.module.js +21 -0
  506. package/backend/dist/word/word.module.js.map +1 -0
  507. package/backend/dist/word/word.service.d.ts +22 -0
  508. package/backend/dist/word/word.service.js +155 -0
  509. package/backend/dist/word/word.service.js.map +1 -0
  510. package/backend/dist/workspace/dto/watch.dto.d.ts +3 -0
  511. package/backend/dist/workspace/dto/watch.dto.js +22 -0
  512. package/backend/dist/workspace/dto/watch.dto.js.map +1 -0
  513. package/backend/dist/workspace/indexer.service.d.ts +24 -0
  514. package/backend/dist/workspace/indexer.service.js +109 -0
  515. package/backend/dist/workspace/indexer.service.js.map +1 -0
  516. package/backend/dist/workspace/workspace-watcher.service.d.ts +20 -0
  517. package/backend/dist/workspace/workspace-watcher.service.js +73 -0
  518. package/backend/dist/workspace/workspace-watcher.service.js.map +1 -0
  519. package/backend/dist/workspace/workspace.controller.d.ts +21 -0
  520. package/backend/dist/workspace/workspace.controller.js +72 -0
  521. package/backend/dist/workspace/workspace.controller.js.map +1 -0
  522. package/backend/dist/workspace/workspace.module.d.ts +2 -0
  523. package/backend/dist/workspace/workspace.module.js +27 -0
  524. package/backend/dist/workspace/workspace.module.js.map +1 -0
  525. package/backend/dist/workspace/workspace.service.d.ts +16 -0
  526. package/backend/dist/workspace/workspace.service.js +70 -0
  527. package/backend/dist/workspace/workspace.service.js.map +1 -0
  528. package/backend/package.json +80 -0
  529. package/backend/prisma/migrations/20260607051149_init/migration.sql +11 -0
  530. package/backend/prisma/migrations/20260607082131_add_settings/migration.sql +5 -0
  531. package/backend/prisma/migrations/20260607090628_add_knowledge_file/migration.sql +12 -0
  532. package/backend/prisma/migrations/20260607102620_add_sessions_chat_messages/migration.sql +17 -0
  533. package/backend/prisma/migrations/20260607160733_add_tool_fields_to_message/migration.sql +18 -0
  534. package/backend/prisma/migrations/20260608120000_add_providers/migration.sql +19 -0
  535. package/backend/prisma/migrations/20260608150513_add_tools/migration.sql +9 -0
  536. package/backend/prisma/migrations/20260608155121_add_tool_config/migration.sql +3 -0
  537. package/backend/prisma/migrations/20260609044217_add_error_message/migration.sql +2 -0
  538. package/backend/prisma/migrations/20260609110505_add_notes/migration.sql +8 -0
  539. package/backend/prisma/migrations/20260609151214_add_plan_tables/migration.sql +21 -0
  540. package/backend/prisma/migrations/20260610100714_add_agent_file/migration.sql +9 -0
  541. package/backend/prisma/migrations/20260611085424_add_session_mode/migration.sql +2 -0
  542. package/backend/prisma/migrations/20260611120000_add_memory_model/migration.sql +13 -0
  543. package/backend/prisma/migrations/20260612120000_add_usage_record/migration.sql +12 -0
  544. package/backend/prisma/migrations/20260612130000_add_project_model/migration.sql +7 -0
  545. package/backend/prisma/migrations/20260612130000_add_project_model/migration_lock.toml +5 -0
  546. package/backend/prisma/migrations/20260612140000_add_connector_model/migration.sql +9 -0
  547. package/backend/prisma/migrations/20260612173937_add_connector_services_account/migration.sql +24 -0
  548. package/backend/prisma/migrations/20260612181017_remove_connector_services/migration.sql +23 -0
  549. package/backend/prisma/migrations/20260613135109_add_schedule_tasks/migration.sql +45 -0
  550. package/backend/prisma/migrations/20260613140915_add_cron_days_of_week/migration.sql +2 -0
  551. package/backend/prisma/migrations/20260613142809_add_timezone/migration.sql +2 -0
  552. package/backend/prisma/migrations/20260613163408_remove_task_model/migration.sql +10 -0
  553. package/backend/prisma/migrations/20260620120025_add_agent_profile/migration.sql +17 -0
  554. package/backend/prisma/migrations/migration_lock.toml +3 -0
  555. package/backend/prisma/schema.prisma +208 -0
  556. package/backend/prisma/seed.cjs +132 -0
  557. package/bin/workspace-cli.js +296 -0
  558. package/frontend/dist/assets/index-DRtpgPPc.css +1 -0
  559. package/frontend/dist/assets/index-Dn28_pkr.js +101 -0
  560. package/frontend/dist/index.html +19 -0
  561. package/frontend/dist/logo.png +0 -0
  562. package/package.json +54 -0
@@ -0,0 +1,764 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.AgentLoopService = void 0;
16
+ const crypto = require("crypto");
17
+ const common_1 = require("@nestjs/common");
18
+ const event_emitter_1 = require("@nestjs/event-emitter");
19
+ const agent_state_enum_1 = require("../dto/agent-state.enum");
20
+ const llm_controller_service_1 = require("./llm-controller.service");
21
+ const sessions_service_1 = require("../../sessions/sessions.service");
22
+ const knowledge_service_1 = require("../../knowledge/knowledge.service");
23
+ const create_task_executor_1 = require("../../tools/executors/create-task.executor");
24
+ const update_task_executor_1 = require("../../tools/executors/update-task.executor");
25
+ const list_tasks_executor_1 = require("../../tools/executors/list-tasks.executor");
26
+ const get_task_executor_1 = require("../../tools/executors/get-task.executor");
27
+ const delete_tasks_executor_1 = require("../../tools/executors/delete-tasks.executor");
28
+ const search_knowledge_executor_1 = require("../../tools/executors/search-knowledge.executor");
29
+ const web_fetch_executor_1 = require("../../tools/executors/web-fetch.executor");
30
+ const web_search_executor_1 = require("../../tools/executors/web-search.executor");
31
+ const create_note_executor_1 = require("../../tools/executors/create-note.executor");
32
+ const update_note_executor_1 = require("../../tools/executors/update-note.executor");
33
+ const list_notes_executor_1 = require("../../tools/executors/list-notes.executor");
34
+ const delete_note_executor_1 = require("../../tools/executors/delete-note.executor");
35
+ const convert_note_to_task_executor_1 = require("../../tools/executors/convert-note-to-task.executor");
36
+ const write_file_executor_1 = require("../../tools/executors/write-file.executor");
37
+ const read_file_executor_1 = require("../../tools/executors/read-file.executor");
38
+ const list_directory_executor_1 = require("../../tools/executors/list-directory.executor");
39
+ const run_command_executor_1 = require("../../tools/executors/run-command.executor");
40
+ const grep_executor_1 = require("../../tools/executors/grep.executor");
41
+ const glob_executor_1 = require("../../tools/executors/glob.executor");
42
+ const resume_plan_executor_1 = require("../../tools/executors/resume-plan.executor");
43
+ const create_plan_executor_1 = require("../../tools/executors/create-plan.executor");
44
+ const permissions_service_1 = require("./permissions.service");
45
+ const approval_manager_service_1 = require("./approval-manager.service");
46
+ const plans_service_1 = require("../../plans/plans.service");
47
+ const mcp_service_1 = require("../mcp/mcp.service");
48
+ const subagent_service_1 = require("../subagent/subagent.service");
49
+ const subagent_tools_util_1 = require("../subagent/subagent-tools.util");
50
+ const agent_profiles_service_1 = require("../../agent-profiles/agent-profiles.service");
51
+ const usage_service_1 = require("../../usage/usage.service");
52
+ const read_excel_executor_1 = require("../../excel/executors/read-excel.executor");
53
+ const write_excel_executor_1 = require("../../excel/executors/write-excel.executor");
54
+ const excel_add_sheet_executor_1 = require("../../excel/executors/excel-add-sheet.executor");
55
+ const list_excel_sheets_executor_1 = require("../../excel/executors/list-excel-sheets.executor");
56
+ const excel_chart_executor_1 = require("../../excel/executors/excel-chart.executor");
57
+ const read_word_executor_1 = require("../../word/executors/read-word.executor");
58
+ const write_word_executor_1 = require("../../word/executors/write-word.executor");
59
+ const edit_word_executor_1 = require("../../word/executors/edit-word.executor");
60
+ const google_gmail_search_executor_1 = require("../../tools/executors/google-gmail-search.executor");
61
+ const google_gmail_read_executor_1 = require("../../tools/executors/google-gmail-read.executor");
62
+ const google_gmail_send_executor_1 = require("../../tools/executors/google-gmail-send.executor");
63
+ const google_gmail_draft_executor_1 = require("../../tools/executors/google-gmail-draft.executor");
64
+ const google_gmail_labels_executor_1 = require("../../tools/executors/google-gmail-labels.executor");
65
+ const google_calendar_list_executor_1 = require("../../tools/executors/google-calendar-list.executor");
66
+ const google_calendar_create_executor_1 = require("../../tools/executors/google-calendar-create.executor");
67
+ const google_calendar_update_executor_1 = require("../../tools/executors/google-calendar-update.executor");
68
+ const google_calendar_availability_executor_1 = require("../../tools/executors/google-calendar-availability.executor");
69
+ const google_drive_search_executor_1 = require("../../tools/executors/google-drive-search.executor");
70
+ const google_drive_read_executor_1 = require("../../tools/executors/google-drive-read.executor");
71
+ const google_drive_list_executor_1 = require("../../tools/executors/google-drive-list.executor");
72
+ const google_drive_upload_executor_1 = require("../../tools/executors/google-drive-upload.executor");
73
+ const google_drive_create_folder_executor_1 = require("../../tools/executors/google-drive-create-folder.executor");
74
+ const google_sheets_read_executor_1 = require("../../tools/executors/google-sheets-read.executor");
75
+ const google_sheets_list_tabs_executor_1 = require("../../tools/executors/google-sheets-list-tabs.executor");
76
+ const google_sheets_update_executor_1 = require("../../tools/executors/google-sheets-update.executor");
77
+ const google_sheets_append_executor_1 = require("../../tools/executors/google-sheets-append.executor");
78
+ const google_sheets_create_executor_1 = require("../../tools/executors/google-sheets-create.executor");
79
+ const google_sheets_add_tab_executor_1 = require("../../tools/executors/google-sheets-add-tab.executor");
80
+ const google_sheets_format_executor_1 = require("../../tools/executors/google-sheets-format.executor");
81
+ const google_sheets_chart_executor_1 = require("../../tools/executors/google-sheets-chart.executor");
82
+ const MAX_ITERATIONS = 100;
83
+ const KB_NO_RESULTS = 'No relevant information found in knowledge base.';
84
+ let AgentLoopService = class AgentLoopService {
85
+ constructor(llmController, sessionsService, knowledgeService, permissionsService, approvalManager, plansService, mcpService, subagentService, agentProfilesService, eventEmitter, createTask, updateTask, listTasks, getTask, deleteTasks, searchKnowledge, webFetch, webSearch, createNote, updateNote, listNotes, deleteNote, convertNoteToTask, writeFile, readFile, listDirectory, runCommand, grep, glob, resumePlan, createPlan, readExcel, writeExcel, excelAddSheet, listExcelSheets, excelChart, readWord, writeWord, editWord, googleGmailSearch, googleGmailRead, googleGmailSend, googleGmailDraft, googleGmailLabels, googleCalendarList, googleCalendarCreate, googleCalendarUpdate, googleCalendarAvailability, googleDriveSearch, googleDriveRead, googleDriveList, googleDriveUpload, googleDriveCreateFolder, googleSheetsRead, googleSheetsListTabs, googleSheetsUpdate, googleSheetsAppend, googleSheetsCreate, googleSheetsAddTab, googleSheetsFormat, googleSheetsChart, usageService) {
86
+ this.llmController = llmController;
87
+ this.sessionsService = sessionsService;
88
+ this.knowledgeService = knowledgeService;
89
+ this.permissionsService = permissionsService;
90
+ this.approvalManager = approvalManager;
91
+ this.plansService = plansService;
92
+ this.mcpService = mcpService;
93
+ this.subagentService = subagentService;
94
+ this.agentProfilesService = agentProfilesService;
95
+ this.eventEmitter = eventEmitter;
96
+ this.grep = grep;
97
+ this.glob = glob;
98
+ this.resumePlan = resumePlan;
99
+ this.createPlan = createPlan;
100
+ this.readWord = readWord;
101
+ this.writeWord = writeWord;
102
+ this.editWord = editWord;
103
+ this.googleGmailSearch = googleGmailSearch;
104
+ this.googleGmailRead = googleGmailRead;
105
+ this.googleGmailSend = googleGmailSend;
106
+ this.googleGmailDraft = googleGmailDraft;
107
+ this.googleGmailLabels = googleGmailLabels;
108
+ this.googleCalendarList = googleCalendarList;
109
+ this.googleCalendarCreate = googleCalendarCreate;
110
+ this.googleCalendarUpdate = googleCalendarUpdate;
111
+ this.googleCalendarAvailability = googleCalendarAvailability;
112
+ this.googleDriveSearch = googleDriveSearch;
113
+ this.googleDriveRead = googleDriveRead;
114
+ this.googleDriveList = googleDriveList;
115
+ this.googleDriveUpload = googleDriveUpload;
116
+ this.googleDriveCreateFolder = googleDriveCreateFolder;
117
+ this.googleSheetsRead = googleSheetsRead;
118
+ this.googleSheetsListTabs = googleSheetsListTabs;
119
+ this.googleSheetsUpdate = googleSheetsUpdate;
120
+ this.googleSheetsAppend = googleSheetsAppend;
121
+ this.googleSheetsCreate = googleSheetsCreate;
122
+ this.googleSheetsAddTab = googleSheetsAddTab;
123
+ this.googleSheetsFormat = googleSheetsFormat;
124
+ this.googleSheetsChart = googleSheetsChart;
125
+ this.usageService = usageService;
126
+ this.state = agent_state_enum_1.AgentState.PLANNING;
127
+ this.executorMap = new Map([
128
+ [createTask.name, createTask],
129
+ [updateTask.name, updateTask],
130
+ [listTasks.name, listTasks],
131
+ [getTask.name, getTask],
132
+ [deleteTasks.name, deleteTasks],
133
+ [searchKnowledge.name, searchKnowledge],
134
+ [webFetch.name, webFetch],
135
+ [webSearch.name, webSearch],
136
+ [createNote.name, createNote],
137
+ [updateNote.name, updateNote],
138
+ [listNotes.name, listNotes],
139
+ [deleteNote.name, deleteNote],
140
+ [convertNoteToTask.name, convertNoteToTask],
141
+ [writeFile.name, writeFile],
142
+ [readFile.name, readFile],
143
+ [listDirectory.name, listDirectory],
144
+ [runCommand.name, runCommand],
145
+ [grep.name, grep],
146
+ [glob.name, glob],
147
+ [resumePlan.name, resumePlan],
148
+ [createPlan.name, createPlan],
149
+ [readExcel.name, readExcel],
150
+ [writeExcel.name, writeExcel],
151
+ [excelAddSheet.name, excelAddSheet],
152
+ [listExcelSheets.name, listExcelSheets],
153
+ [excelChart.name, excelChart],
154
+ [readWord.name, readWord],
155
+ [writeWord.name, writeWord],
156
+ [editWord.name, editWord],
157
+ [googleGmailSearch.name, googleGmailSearch],
158
+ [googleGmailRead.name, googleGmailRead],
159
+ [googleGmailSend.name, googleGmailSend],
160
+ [googleGmailDraft.name, googleGmailDraft],
161
+ [googleGmailLabels.name, googleGmailLabels],
162
+ [googleCalendarList.name, googleCalendarList],
163
+ [googleCalendarCreate.name, googleCalendarCreate],
164
+ [googleCalendarUpdate.name, googleCalendarUpdate],
165
+ [googleCalendarAvailability.name, googleCalendarAvailability],
166
+ [googleDriveSearch.name, googleDriveSearch],
167
+ [googleDriveRead.name, googleDriveRead],
168
+ [googleDriveList.name, googleDriveList],
169
+ [googleDriveUpload.name, googleDriveUpload],
170
+ [googleDriveCreateFolder.name, googleDriveCreateFolder],
171
+ [googleSheetsRead.name, googleSheetsRead],
172
+ [googleSheetsListTabs.name, googleSheetsListTabs],
173
+ [googleSheetsUpdate.name, googleSheetsUpdate],
174
+ [googleSheetsAppend.name, googleSheetsAppend],
175
+ [googleSheetsCreate.name, googleSheetsCreate],
176
+ [googleSheetsAddTab.name, googleSheetsAddTab],
177
+ [googleSheetsFormat.name, googleSheetsFormat],
178
+ [googleSheetsChart.name, googleSheetsChart],
179
+ ]);
180
+ }
181
+ async run(providerType, model, systemPrompt, history, userMessage, tools, res, signal, sessionId, projectPath, providerConfig = { baseUrl: 'http://localhost:11434' }, subagentName, subagentRunId) {
182
+ this.state = agent_state_enum_1.AgentState.PLANNING;
183
+ let activeTools = tools;
184
+ let finalText = '';
185
+ const downloadLinks = [];
186
+ let messages = this.llmController.buildMessages(systemPrompt, history, userMessage);
187
+ while (!signal.aborted) {
188
+ this.state = agent_state_enum_1.AgentState.EXECUTING;
189
+ let text;
190
+ let toolCalls;
191
+ try {
192
+ const stepResult = await this.executeStep(model, messages, activeTools, signal, providerConfig, res, sessionId, providerType);
193
+ text = stepResult.text;
194
+ toolCalls = stepResult.toolCalls;
195
+ if (stepResult.usage && sessionId) {
196
+ this.usageService.record({
197
+ sessionId,
198
+ modelName: model,
199
+ providerType,
200
+ promptTokens: stepResult.usage.promptTokens,
201
+ completionTokens: stepResult.usage.completionTokens,
202
+ totalTokens: stepResult.usage.totalTokens,
203
+ }).catch(() => { });
204
+ }
205
+ }
206
+ catch {
207
+ break;
208
+ }
209
+ if (text && sessionId) {
210
+ await this.sessionsService.saveMessage(sessionId, 'assistant', text);
211
+ }
212
+ finalText += text;
213
+ if (toolCalls.length === 0)
214
+ break;
215
+ let reasoningContent;
216
+ messages = this.addToolCallsToMessages(messages, text, toolCalls, reasoningContent);
217
+ for (let ti = 0; ti < toolCalls.length; ti++) {
218
+ if (signal.aborted)
219
+ break;
220
+ const tc = toolCalls[ti];
221
+ const name = tc.name;
222
+ const toolCallId = `call_${ti}_${name}`;
223
+ const args = this.normalizeArgs(tc.arguments);
224
+ const saPrefix = subagentName ? `[subagent:${subagentName}] ` : '';
225
+ res.write(`data: ${JSON.stringify({ subagentName, toolCall: { name, args } })}\n\n`);
226
+ if (sessionId) {
227
+ await this.sessionsService.saveMessage(sessionId, 'tool', `${saPrefix}${name}(${JSON.stringify(args)})`, name, false);
228
+ }
229
+ const toolInput = JSON.stringify(args);
230
+ const transcript = this.buildTranscript(messages);
231
+ const decision = await this.permissionsService.decide(name, toolInput, transcript, sessionId);
232
+ if (signal.aborted)
233
+ break;
234
+ if (decision.action === 'allow') {
235
+ }
236
+ else if (decision.action === 'deny') {
237
+ const denialResult = `Tool '${name}' is not permitted by workspace policy.${decision.reason ? ' ' + decision.reason : ''}`;
238
+ const denialWithPrefix = `${saPrefix}${denialResult}`;
239
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result: denialResult } })}\n\n`);
240
+ if (sessionId) {
241
+ await this.sessionsService.saveMessage(sessionId, 'tool', denialWithPrefix, name, true);
242
+ }
243
+ messages.push({ role: 'tool', content: denialWithPrefix, toolCallId });
244
+ continue;
245
+ }
246
+ else if (decision.action === 'ask') {
247
+ const approvalId = crypto.randomUUID();
248
+ res.write(`data: ${JSON.stringify({ subagentName, toolApprovalRequired: { id: approvalId, name, args } })}\n\n`);
249
+ const approved = await this.approvalManager.requestApproval(approvalId, name, args, sessionId ?? 0);
250
+ if (signal.aborted)
251
+ break;
252
+ if (approved) {
253
+ }
254
+ else {
255
+ const deniedMsg = `${saPrefix}Tool execution denied by user`;
256
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result: 'Tool execution denied by user' } })}\n\n`);
257
+ if (sessionId) {
258
+ await this.sessionsService.saveMessage(sessionId, 'tool', deniedMsg, name, true);
259
+ }
260
+ messages.push({ role: 'tool', content: deniedMsg, toolCallId });
261
+ continue;
262
+ }
263
+ }
264
+ let result;
265
+ if (signal.aborted)
266
+ break;
267
+ if (name === 'spawn_subagent') {
268
+ const argsObj = typeof args === 'object' && args !== null ? args : {};
269
+ const task = String(argsObj.task ?? '');
270
+ const profileSlug = argsObj.profile ? String(argsObj.profile) : undefined;
271
+ if (!task) {
272
+ result = 'Error: spawn_subagent requires a "task" parameter';
273
+ }
274
+ else {
275
+ const { error, promptOverride, allowedTools } = await this.resolveProfile(profileSlug);
276
+ if (signal.aborted)
277
+ break;
278
+ if (error) {
279
+ result = error;
280
+ }
281
+ else {
282
+ const subTools = (0, subagent_tools_util_1.filterSubagentTools)(activeTools, allowedTools);
283
+ const subagentProfileName = profileSlug ?? subagentName;
284
+ try {
285
+ result = await this.subagentService.spawn(task, providerType, model, providerConfig, subTools, signal, res, sessionId, projectPath, promptOverride, subagentProfileName);
286
+ }
287
+ catch (e) {
288
+ result = `Error: Subagent failed: ${e instanceof Error ? e.message : 'Unknown error'}`;
289
+ }
290
+ }
291
+ }
292
+ }
293
+ else if (name === 'delegate') {
294
+ const argsObj = typeof args === 'object' && args !== null ? args : {};
295
+ const tasks = argsObj.tasks;
296
+ const taskList = Array.isArray(tasks) ? tasks.map(String) : [];
297
+ const profileSlug = argsObj.profile ? String(argsObj.profile) : undefined;
298
+ if (taskList.length === 0) {
299
+ result = 'Error: delegate requires a non-empty "tasks" array';
300
+ }
301
+ else {
302
+ const { error, promptOverride, allowedTools } = await this.resolveProfile(profileSlug);
303
+ if (signal.aborted)
304
+ break;
305
+ if (error) {
306
+ result = error;
307
+ }
308
+ else {
309
+ const subTools = (0, subagent_tools_util_1.filterSubagentTools)(activeTools, allowedTools);
310
+ const subagentProfileName = profileSlug ?? subagentName;
311
+ try {
312
+ result = await this.subagentService.delegate(taskList, providerType, model, providerConfig, subTools, signal, res, sessionId, projectPath, promptOverride, subagentProfileName);
313
+ }
314
+ catch (e) {
315
+ result = `Error: Delegate failed: ${e instanceof Error ? e.message : 'Unknown error'}`;
316
+ }
317
+ }
318
+ }
319
+ }
320
+ else {
321
+ try {
322
+ result = await this.executeTool(name, args, signal, { sessionId: sessionId ?? 0, projectPath });
323
+ }
324
+ catch (e) {
325
+ result = `Error: ${e instanceof Error ? e.message : 'Unknown error'}`;
326
+ }
327
+ }
328
+ if (result.startsWith('[PLAN_CREATED]')) {
329
+ const idMatch = result.match(/id=(\d+)/);
330
+ const approvalMatch = result.match(/requireApproval=(\w+)/);
331
+ const titleMatch = result.match(/title="([^"]*)"/);
332
+ const planId = idMatch ? parseInt(idMatch[1], 10) : 0;
333
+ const requireApproval = approvalMatch ? approvalMatch[1] === 'true' : true;
334
+ if (planId > 0) {
335
+ const plan = await this.plansService.findOne(planId);
336
+ res.write(`data: ${JSON.stringify({
337
+ plan: {
338
+ id: plan.id,
339
+ title: plan.title,
340
+ status: plan.status,
341
+ steps: plan.steps.map(s => ({ id: s.id, order: s.order, text: s.text, status: s.status })),
342
+ },
343
+ })}\n\n`);
344
+ await this.savePlanExecutionMessage(sessionId, plan);
345
+ if (requireApproval) {
346
+ res.write('data: [DONE]\n\n');
347
+ return finalText;
348
+ }
349
+ else {
350
+ await this.executePlan(planId, providerType, model, systemPrompt, activeTools, providerConfig, signal, res, sessionId, projectPath);
351
+ return finalText;
352
+ }
353
+ }
354
+ }
355
+ const resultWithPrefix = `${saPrefix}${result}`;
356
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result } })}\n\n`);
357
+ if (sessionId) {
358
+ await this.sessionsService.saveMessage(sessionId, 'tool', resultWithPrefix, name, true);
359
+ }
360
+ messages.push({ role: 'tool', content: resultWithPrefix, toolCallId });
361
+ const linkMatch = result.match(/\[Download[^\]]+\]\(([^)]+)\)/);
362
+ if (linkMatch)
363
+ downloadLinks.push(linkMatch[1]);
364
+ if (name === 'search_knowledge') {
365
+ messages = await this.handleKnowledgeResult(messages, result, res, sessionId);
366
+ }
367
+ }
368
+ }
369
+ this.state = agent_state_enum_1.AgentState.RESPONDING;
370
+ if (!signal.aborted) {
371
+ for (const link of downloadLinks) {
372
+ if (!finalText.includes(link)) {
373
+ finalText += `\n\n📥 [Tải file xuống](${link})`;
374
+ }
375
+ }
376
+ if (sessionId) {
377
+ this.eventEmitter.emit('agent.idle', {
378
+ sessionId,
379
+ providerType,
380
+ model,
381
+ providerConfig,
382
+ });
383
+ }
384
+ res.write('data: [DONE]\n\n');
385
+ }
386
+ return finalText;
387
+ }
388
+ async executePlan(planId, providerType, model, systemPrompt, tools, providerConfig, signal, res, sessionId, projectPath) {
389
+ const plan = await this.plansService.findOne(planId);
390
+ await this.plansService.updateStatus(planId, 'EXECUTING');
391
+ const sortedSteps = [...plan.steps]
392
+ .filter(s => s.status !== 'DONE')
393
+ .sort((a, b) => a.order - b.order);
394
+ let currentStepId = null;
395
+ for (const step of sortedSteps) {
396
+ currentStepId = step.id;
397
+ if (signal.aborted)
398
+ break;
399
+ await this.plansService.updateStepStatus(step.id, 'DOING');
400
+ if (!signal.aborted)
401
+ res.write(`data: ${JSON.stringify({ planStepUpdate: { planId, stepId: step.id, status: 'DOING' } })}\n\n`);
402
+ if (sessionId) {
403
+ await this.sessionsService.saveMessage(sessionId, 'system', `Executing step: ${step.text}`);
404
+ }
405
+ try {
406
+ const stepSystemPrompt = `${systemPrompt}\n\nYou are executing plan step ${step.order + 1}: "${step.text}". Complete only this step.`;
407
+ const messages = this.llmController.buildMessages(stepSystemPrompt, [], step.text);
408
+ await this.runForStep(model, messages, tools, providerConfig, res, sessionId, signal, providerType, projectPath);
409
+ if (signal.aborted)
410
+ break;
411
+ await this.plansService.updateStepStatus(step.id, 'DONE');
412
+ if (!signal.aborted)
413
+ res.write(`data: ${JSON.stringify({ planStepUpdate: { planId, stepId: step.id, status: 'DONE' } })}\n\n`);
414
+ if (sessionId) {
415
+ await this.sessionsService.saveMessage(sessionId, 'system', `Step completed: ${step.text}`);
416
+ }
417
+ }
418
+ catch {
419
+ if (signal.aborted)
420
+ break;
421
+ await this.plansService.updateStepStatus(step.id, 'FAILED');
422
+ if (!signal.aborted)
423
+ res.write(`data: ${JSON.stringify({ planStepUpdate: { planId, stepId: step.id, status: 'FAILED' } })}\n\n`);
424
+ if (sessionId) {
425
+ await this.sessionsService.saveMessage(sessionId, 'system', `Step failed: ${step.text}`);
426
+ }
427
+ }
428
+ }
429
+ if (signal.aborted) {
430
+ res.write(`data: ${JSON.stringify({ planInterrupted: { planId, stepId: currentStepId, reason: 'user_stopped' } })}\n\n`);
431
+ res.write('data: [DONE]\n\n');
432
+ if (sessionId) {
433
+ await this.sessionsService.saveMessage(sessionId, 'system', '[Plan execution interrupted by user]');
434
+ }
435
+ await this.plansService.setInterrupted(planId);
436
+ }
437
+ else {
438
+ await this.plansService.updateStatus(planId, 'DONE');
439
+ res.write('data: [DONE]\n\n');
440
+ }
441
+ }
442
+ async savePlanExecutionMessage(sessionId, plan) {
443
+ if (sessionId) {
444
+ await this.sessionsService.saveMessage(sessionId, 'plan', JSON.stringify({
445
+ id: plan.id, title: plan.title, status: plan.status,
446
+ steps: plan.steps.map(s => ({ id: s.id, order: s.order, text: s.text, status: s.status })),
447
+ }));
448
+ await this.sessionsService.saveMessage(sessionId, 'system', `[Plan] ${plan.title} — ${plan.steps.length} steps created`);
449
+ }
450
+ }
451
+ async runPlanMode(taskText, providerType, model, providerConfig, sessionId, res, signal) {
452
+ if (signal?.aborted) {
453
+ res.write('data: [DONE]\n\n');
454
+ return;
455
+ }
456
+ const planningPrompt = 'You are in Plan Mode. Output ONLY a JSON object — no prose, no markdown, no code fences.\n' +
457
+ 'Format: { "title": "short plan title", "steps": ["step 1", "step 2", ...] }\n' +
458
+ 'Maximum 10 steps. Be specific and actionable.';
459
+ res.write(`data: ${JSON.stringify({ thinking: 'Generating plan...' })}\n\n`);
460
+ const messages = [
461
+ { role: 'system', content: planningPrompt },
462
+ { role: 'user', content: taskText },
463
+ ];
464
+ let fullText = '';
465
+ const stream = this.llmController.stream(providerType, model, messages, [], signal ?? new AbortController().signal, providerConfig.baseUrl, providerConfig.key);
466
+ for await (const chunk of stream) {
467
+ if (chunk.type === 'token' && chunk.token)
468
+ fullText += chunk.token;
469
+ if (chunk.type === 'error')
470
+ break;
471
+ if (chunk.type === 'done')
472
+ break;
473
+ }
474
+ let planData;
475
+ try {
476
+ planData = JSON.parse(fullText);
477
+ if (!planData.title || !Array.isArray(planData.steps))
478
+ throw new Error('invalid shape');
479
+ }
480
+ catch {
481
+ res.write(`data: ${JSON.stringify({ error: 'Agent failed to produce a valid plan. Try again.' })}\n\n`);
482
+ res.write('data: [DONE]\n\n');
483
+ return;
484
+ }
485
+ const plan = await this.plansService.create(sessionId, planData.title, planData.steps);
486
+ if (sessionId) {
487
+ await this.sessionsService.saveMessage(sessionId, 'system', `[Plan] ${plan.title} — ${plan.steps.length} steps created`);
488
+ await this.sessionsService.saveMessage(sessionId, 'plan', JSON.stringify({
489
+ id: plan.id, title: plan.title, status: plan.status, steps: plan.steps.map(s => ({ id: s.id, order: s.order, text: s.text, status: s.status })),
490
+ }));
491
+ }
492
+ res.write(`data: ${JSON.stringify({
493
+ plan: {
494
+ id: plan.id,
495
+ title: plan.title,
496
+ status: plan.status,
497
+ steps: plan.steps.map(s => ({ id: s.id, order: s.order, text: s.text, status: s.status })),
498
+ },
499
+ })}\n\n`);
500
+ res.write('data: [DONE]\n\n');
501
+ }
502
+ async executeStep(model, messages, tools, signal, providerConfig, res, sessionId, providerType = 'ollama') {
503
+ let text = '';
504
+ const toolCalls = [];
505
+ let reasoningContent = '';
506
+ let usage;
507
+ const stream = this.llmController.stream(providerType, model, messages, tools, signal, providerConfig.baseUrl, providerConfig.key);
508
+ for await (const chunk of stream) {
509
+ if (signal.aborted)
510
+ return { text, toolCalls };
511
+ switch (chunk.type) {
512
+ case 'token':
513
+ if (chunk.token) {
514
+ text += chunk.token;
515
+ res.write(`data: ${JSON.stringify({ token: chunk.token })}\n\n`);
516
+ }
517
+ break;
518
+ case 'tool_call':
519
+ if (chunk.toolCall) {
520
+ toolCalls.push(chunk.toolCall);
521
+ if (chunk.reasoningContent)
522
+ reasoningContent = chunk.reasoningContent;
523
+ }
524
+ break;
525
+ case 'error':
526
+ res.write(`data: ${JSON.stringify({ error: chunk.error })}\n\n`);
527
+ throw new Error(chunk.error);
528
+ case 'done':
529
+ if (chunk.usage) {
530
+ usage = chunk.usage;
531
+ }
532
+ break;
533
+ }
534
+ }
535
+ return { text, toolCalls, reasoningContent: reasoningContent || undefined, usage };
536
+ }
537
+ normalizeArgs(args) {
538
+ if (typeof args === 'string') {
539
+ try {
540
+ return JSON.parse(args);
541
+ }
542
+ catch {
543
+ return { raw: args };
544
+ }
545
+ }
546
+ if (typeof args === 'object' && args !== null)
547
+ return args;
548
+ return {};
549
+ }
550
+ addToolCallsToMessages(messages, text, toolCalls, reasoningContent) {
551
+ return [
552
+ ...messages,
553
+ {
554
+ role: 'assistant',
555
+ content: text || '',
556
+ reasoningContent,
557
+ toolCalls: toolCalls.map((tc, i) => ({
558
+ id: `call_${i}_${tc.name}`,
559
+ function: { name: tc.name, arguments: this.normalizeArgs(tc.arguments) },
560
+ })),
561
+ },
562
+ ];
563
+ }
564
+ async handleKnowledgeResult(messages, result, res, sessionId) {
565
+ res.write(`data: ${JSON.stringify({ thinking: 'Synthesizing search results...' })}\n\n`);
566
+ if (sessionId) {
567
+ await this.sessionsService.saveMessage(sessionId, 'system', 'Synthesizing search results...');
568
+ }
569
+ if (result === KB_NO_RESULTS) {
570
+ let fileList = 'none indexed yet';
571
+ try {
572
+ const files = await this.knowledgeService.findAll();
573
+ if (files.length > 0) {
574
+ fileList = files.slice(0, 10).map(f => `"${f.filename}"`).join(', ');
575
+ }
576
+ }
577
+ catch { }
578
+ return [
579
+ ...messages,
580
+ {
581
+ role: 'user',
582
+ content: `The knowledge base returned no results.\nAvailable KB files: ${fileList}.\nFollow KB guidance in system prompt.`,
583
+ },
584
+ ];
585
+ }
586
+ return [
587
+ ...messages,
588
+ {
589
+ role: 'user',
590
+ content: `I searched the knowledge base and found:\n\n${result}\n\nProvide a comprehensive answer with inline citations [Source: "filename", \u00a7N].`,
591
+ },
592
+ ];
593
+ }
594
+ async executeTool(name, args, signal, context) {
595
+ if (signal.aborted)
596
+ return 'Error: Execution aborted by user';
597
+ const executor = this.executorMap.get(name);
598
+ if (executor)
599
+ return executor.execute(args, context);
600
+ const mcpResult = await this.mcpService.tryExecute(name, args);
601
+ if (mcpResult !== null)
602
+ return mcpResult;
603
+ return `Error: Unknown tool: ${name}`;
604
+ }
605
+ async resolveProfile(profileSlug) {
606
+ if (!profileSlug)
607
+ return {};
608
+ const profile = await this.agentProfilesService.findBySlug(profileSlug);
609
+ if (!profile || !profile.enabled) {
610
+ return { error: `Error: unknown agent profile "${profileSlug}"` };
611
+ }
612
+ return { promptOverride: profile.systemPrompt, allowedTools: profile.allowedTools };
613
+ }
614
+ buildTranscript(messages) {
615
+ return messages.map(m => `${m.role}: ${m.content}`).join('\n');
616
+ }
617
+ async runForStep(model, messages, tools, providerConfig, res, sessionId, parentSignal, providerType = 'ollama', projectPath, subagentName, subagentRunId) {
618
+ const signal = parentSignal ?? new AbortController().signal;
619
+ let currentMessages = [...messages];
620
+ let iterations = 0;
621
+ while (!signal.aborted && iterations < MAX_ITERATIONS) {
622
+ iterations++;
623
+ const { text, toolCalls, reasoningContent } = await this.executeStep(model, currentMessages, tools, signal, providerConfig, res, sessionId, providerType);
624
+ if (toolCalls.length === 0) {
625
+ if (text && sessionId) {
626
+ await this.sessionsService.saveMessage(sessionId, 'assistant', text);
627
+ }
628
+ break;
629
+ }
630
+ currentMessages = this.addToolCallsToMessages(currentMessages, text, toolCalls, reasoningContent);
631
+ for (let ti = 0; ti < toolCalls.length; ti++) {
632
+ if (signal.aborted)
633
+ break;
634
+ const tc = toolCalls[ti];
635
+ const name = tc.name;
636
+ const toolCallId = `call_${ti}_${name}`;
637
+ const args = this.normalizeArgs(tc.arguments);
638
+ const saPrefix = subagentName ? `[subagent:${subagentName}] ` : '';
639
+ res.write(`data: ${JSON.stringify({ subagentName, toolCall: { name, args } })}\n\n`);
640
+ if (sessionId) {
641
+ await this.sessionsService.saveMessage(sessionId, 'tool', `${saPrefix}${name}(${JSON.stringify(args)})`, name, false);
642
+ }
643
+ const toolInput = JSON.stringify(args);
644
+ const transcript = this.buildTranscript(currentMessages);
645
+ const decision = await this.permissionsService.decide(name, toolInput, transcript, sessionId);
646
+ if (signal.aborted)
647
+ break;
648
+ if (decision.action === 'allow') {
649
+ }
650
+ else if (decision.action === 'deny') {
651
+ const denialResult = `Tool '${name}' is not permitted by workspace policy.${decision.reason ? ' ' + decision.reason : ''}`;
652
+ const denialWithPrefix = `${saPrefix}${denialResult}`;
653
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result: denialResult } })}\n\n`);
654
+ if (sessionId) {
655
+ await this.sessionsService.saveMessage(sessionId, 'tool', denialWithPrefix, name, true);
656
+ }
657
+ currentMessages.push({ role: 'tool', content: denialWithPrefix, toolCallId });
658
+ continue;
659
+ }
660
+ else if (decision.action === 'ask') {
661
+ const approvalId = crypto.randomUUID();
662
+ res.write(`data: ${JSON.stringify({ subagentName, toolApprovalRequired: { id: approvalId, name, args } })}\n\n`);
663
+ const approved = await this.approvalManager.requestApproval(approvalId, name, args, sessionId ?? 0);
664
+ if (signal.aborted)
665
+ break;
666
+ if (approved) {
667
+ }
668
+ else {
669
+ const deniedMsg = `${saPrefix}Tool execution denied by user`;
670
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result: 'Tool execution denied by user' } })}\n\n`);
671
+ if (sessionId) {
672
+ await this.sessionsService.saveMessage(sessionId, 'tool', deniedMsg, name, true);
673
+ }
674
+ currentMessages.push({ role: 'tool', content: deniedMsg, toolCallId });
675
+ continue;
676
+ }
677
+ }
678
+ if (signal.aborted)
679
+ break;
680
+ let result;
681
+ try {
682
+ result = await this.executeTool(name, args, signal, { sessionId: sessionId ?? 0, projectPath });
683
+ }
684
+ catch (e) {
685
+ result = `Error: ${e instanceof Error ? e.message : 'Unknown error'}`;
686
+ }
687
+ const resultWithPrefix = `${saPrefix}${result}`;
688
+ res.write(`data: ${JSON.stringify({ subagentName, toolResult: { name, result } })}\n\n`);
689
+ if (sessionId) {
690
+ await this.sessionsService.saveMessage(sessionId, 'tool', resultWithPrefix, name, true);
691
+ }
692
+ currentMessages.push({ role: 'tool', content: resultWithPrefix, toolCallId });
693
+ }
694
+ }
695
+ }
696
+ };
697
+ exports.AgentLoopService = AgentLoopService;
698
+ exports.AgentLoopService = AgentLoopService = __decorate([
699
+ (0, common_1.Injectable)(),
700
+ __param(7, (0, common_1.Inject)((0, common_1.forwardRef)(() => subagent_service_1.SubagentService))),
701
+ __metadata("design:paramtypes", [llm_controller_service_1.LLMControllerService,
702
+ sessions_service_1.SessionsService,
703
+ knowledge_service_1.KnowledgeService,
704
+ permissions_service_1.PermissionsService,
705
+ approval_manager_service_1.ApprovalManagerService,
706
+ plans_service_1.PlansService,
707
+ mcp_service_1.McpService,
708
+ subagent_service_1.SubagentService,
709
+ agent_profiles_service_1.AgentProfilesService,
710
+ event_emitter_1.EventEmitter2,
711
+ create_task_executor_1.CreateTaskExecutor,
712
+ update_task_executor_1.UpdateTaskExecutor,
713
+ list_tasks_executor_1.ListTasksExecutor,
714
+ get_task_executor_1.GetTaskExecutor,
715
+ delete_tasks_executor_1.DeleteTasksExecutor,
716
+ search_knowledge_executor_1.SearchKnowledgeExecutor,
717
+ web_fetch_executor_1.WebFetchExecutor,
718
+ web_search_executor_1.WebSearchExecutor,
719
+ create_note_executor_1.CreateNoteExecutor,
720
+ update_note_executor_1.UpdateNoteExecutor,
721
+ list_notes_executor_1.ListNotesExecutor,
722
+ delete_note_executor_1.DeleteNoteExecutor,
723
+ convert_note_to_task_executor_1.ConvertNoteToTaskExecutor,
724
+ write_file_executor_1.WriteFileExecutor,
725
+ read_file_executor_1.ReadFileExecutor,
726
+ list_directory_executor_1.ListDirectoryExecutor,
727
+ run_command_executor_1.RunCommandExecutor,
728
+ grep_executor_1.GrepExecutor,
729
+ glob_executor_1.GlobExecutor,
730
+ resume_plan_executor_1.ResumePlanExecutor,
731
+ create_plan_executor_1.CreatePlanExecutor,
732
+ read_excel_executor_1.ReadExcelExecutor,
733
+ write_excel_executor_1.WriteExcelExecutor,
734
+ excel_add_sheet_executor_1.ExcelAddSheetExecutor,
735
+ list_excel_sheets_executor_1.ListExcelSheetsExecutor,
736
+ excel_chart_executor_1.ExcelChartExecutor,
737
+ read_word_executor_1.ReadWordExecutor,
738
+ write_word_executor_1.WriteWordExecutor,
739
+ edit_word_executor_1.EditWordExecutor,
740
+ google_gmail_search_executor_1.GoogleGmailSearchExecutor,
741
+ google_gmail_read_executor_1.GoogleGmailReadExecutor,
742
+ google_gmail_send_executor_1.GoogleGmailSendExecutor,
743
+ google_gmail_draft_executor_1.GoogleGmailDraftExecutor,
744
+ google_gmail_labels_executor_1.GoogleGmailLabelsExecutor,
745
+ google_calendar_list_executor_1.GoogleCalendarListExecutor,
746
+ google_calendar_create_executor_1.GoogleCalendarCreateExecutor,
747
+ google_calendar_update_executor_1.GoogleCalendarUpdateExecutor,
748
+ google_calendar_availability_executor_1.GoogleCalendarAvailabilityExecutor,
749
+ google_drive_search_executor_1.GoogleDriveSearchExecutor,
750
+ google_drive_read_executor_1.GoogleDriveReadExecutor,
751
+ google_drive_list_executor_1.GoogleDriveListExecutor,
752
+ google_drive_upload_executor_1.GoogleDriveUploadExecutor,
753
+ google_drive_create_folder_executor_1.GoogleDriveCreateFolderExecutor,
754
+ google_sheets_read_executor_1.GoogleSheetsReadExecutor,
755
+ google_sheets_list_tabs_executor_1.GoogleSheetsListTabsExecutor,
756
+ google_sheets_update_executor_1.GoogleSheetsUpdateExecutor,
757
+ google_sheets_append_executor_1.GoogleSheetsAppendExecutor,
758
+ google_sheets_create_executor_1.GoogleSheetsCreateExecutor,
759
+ google_sheets_add_tab_executor_1.GoogleSheetsAddTabExecutor,
760
+ google_sheets_format_executor_1.GoogleSheetsFormatExecutor,
761
+ google_sheets_chart_executor_1.GoogleSheetsChartExecutor,
762
+ usage_service_1.UsageService])
763
+ ], AgentLoopService);
764
+ //# sourceMappingURL=agent-loop.service.js.map