devchain-cli 0.11.4 → 0.12.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 (337) hide show
  1. package/README.md +8 -4
  2. package/dist/drizzle/0050_teams.sql +26 -0
  3. package/dist/drizzle/0051_teams_optional_lead.sql +17 -0
  4. package/dist/drizzle/0054_provider_config_description.sql +1 -0
  5. package/dist/drizzle/0055_team_profiles.sql +10 -0
  6. package/dist/drizzle/0056_team_profile_configs.sql +11 -0
  7. package/dist/drizzle/0057_white_lester.sql +2 -0
  8. package/dist/drizzle/0058_fluffy_wolverine.sql +1 -0
  9. package/dist/drizzle/0059_loving_daimon_hellstrom.sql +1 -0
  10. package/dist/drizzle/meta/0050_snapshot.json +4929 -0
  11. package/dist/drizzle/meta/0051_snapshot.json +4929 -0
  12. package/dist/drizzle/meta/0053_snapshot.json +4944 -0
  13. package/dist/drizzle/meta/0054_snapshot.json +4951 -0
  14. package/dist/drizzle/meta/0055_snapshot.json +5025 -0
  15. package/dist/drizzle/meta/0056_snapshot.json +5109 -0
  16. package/dist/drizzle/meta/0057_snapshot.json +5125 -0
  17. package/dist/drizzle/meta/0058_snapshot.json +5133 -0
  18. package/dist/drizzle/meta/0059_snapshot.json +5140 -0
  19. package/dist/drizzle/meta/_journal.json +60 -4
  20. package/dist/node_modules/@devchain/codebase-overview/index.d.ts +2 -0
  21. package/dist/node_modules/@devchain/codebase-overview/index.d.ts.map +1 -0
  22. package/dist/node_modules/@devchain/codebase-overview/index.js +2 -0
  23. package/dist/node_modules/@devchain/codebase-overview/index.js.map +1 -0
  24. package/dist/node_modules/@devchain/codebase-overview/package.json +8 -0
  25. package/dist/node_modules/@devchain/codebase-overview/tsconfig.tsbuildinfo +1 -0
  26. package/dist/node_modules/@devchain/codebase-overview/types.d.ts +232 -0
  27. package/dist/node_modules/@devchain/codebase-overview/types.d.ts.map +1 -0
  28. package/dist/node_modules/@devchain/codebase-overview/types.js +2 -0
  29. package/dist/node_modules/@devchain/codebase-overview/types.js.map +1 -0
  30. package/dist/node_modules/@devchain/shared/index.d.ts +1 -1
  31. package/dist/node_modules/@devchain/shared/index.d.ts.map +1 -1
  32. package/dist/node_modules/@devchain/shared/index.js +1 -1
  33. package/dist/node_modules/@devchain/shared/index.js.map +1 -1
  34. package/dist/node_modules/@devchain/shared/schemas/env-vars.d.ts +3 -0
  35. package/dist/node_modules/@devchain/shared/schemas/env-vars.d.ts.map +1 -0
  36. package/dist/node_modules/@devchain/shared/schemas/env-vars.js +14 -0
  37. package/dist/node_modules/@devchain/shared/schemas/env-vars.js.map +1 -0
  38. package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts +99 -13
  39. package/dist/node_modules/@devchain/shared/schemas/export-schema.d.ts.map +1 -1
  40. package/dist/node_modules/@devchain/shared/schemas/export-schema.js +25 -1
  41. package/dist/node_modules/@devchain/shared/schemas/export-schema.js.map +1 -1
  42. package/dist/node_modules/@devchain/shared/schemas/index.d.ts +1 -0
  43. package/dist/node_modules/@devchain/shared/schemas/index.d.ts.map +1 -1
  44. package/dist/node_modules/@devchain/shared/schemas/index.js +1 -0
  45. package/dist/node_modules/@devchain/shared/schemas/index.js.map +1 -1
  46. package/dist/node_modules/@devchain/shared/tsconfig.tsbuildinfo +1 -1
  47. package/dist/server/app.main.module.js +4 -0
  48. package/dist/server/app.main.module.js.map +1 -1
  49. package/dist/server/app.normal.module.js +4 -0
  50. package/dist/server/app.normal.module.js.map +1 -1
  51. package/dist/server/common/config/feature-flags.d.ts +0 -2
  52. package/dist/server/common/config/feature-flags.js +1 -4
  53. package/dist/server/common/config/feature-flags.js.map +1 -1
  54. package/dist/server/common/errors/error-types.d.ts +3 -0
  55. package/dist/server/common/errors/error-types.js +10 -1
  56. package/dist/server/common/errors/error-types.js.map +1 -1
  57. package/dist/server/common/resolve-binary.d.ts +1 -0
  58. package/dist/server/common/resolve-binary.js +35 -0
  59. package/dist/server/common/resolve-binary.js.map +1 -0
  60. package/dist/server/common/template/agent-recipient-context.d.ts +10 -0
  61. package/dist/server/common/template/agent-recipient-context.js +13 -0
  62. package/dist/server/common/template/agent-recipient-context.js.map +1 -0
  63. package/dist/server/common/template/handlebars-renderer.d.ts +1 -0
  64. package/dist/server/common/template/handlebars-renderer.js +26 -0
  65. package/dist/server/common/template/handlebars-renderer.js.map +1 -0
  66. package/dist/server/modules/agents/agents.module.js +2 -1
  67. package/dist/server/modules/agents/agents.module.js.map +1 -1
  68. package/dist/server/modules/agents/controllers/agents.controller.d.ts +3 -1
  69. package/dist/server/modules/agents/controllers/agents.controller.js +36 -3
  70. package/dist/server/modules/agents/controllers/agents.controller.js.map +1 -1
  71. package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.d.ts +2 -0
  72. package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js +51 -0
  73. package/dist/server/modules/codebase-overview-analyzer/codebase-overview-analyzer.module.js.map +1 -0
  74. package/dist/server/modules/codebase-overview-analyzer/controllers/codebase-overview.controller.d.ts +30 -0
  75. package/dist/server/modules/codebase-overview-analyzer/controllers/codebase-overview.controller.js +225 -0
  76. package/dist/server/modules/codebase-overview-analyzer/controllers/codebase-overview.controller.js.map +1 -0
  77. package/dist/server/modules/codebase-overview-analyzer/repositories/overview-scope.repository.d.ts +24 -0
  78. package/dist/server/modules/codebase-overview-analyzer/repositories/overview-scope.repository.js +188 -0
  79. package/dist/server/modules/codebase-overview-analyzer/repositories/overview-scope.repository.js.map +1 -0
  80. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.d.ts +71 -0
  81. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js +1128 -0
  82. package/dist/server/modules/codebase-overview-analyzer/services/codebase-overview-analyzer.service.js.map +1 -0
  83. package/dist/server/modules/codebase-overview-analyzer/services/dependency-aggregation.service.d.ts +14 -0
  84. package/dist/server/modules/codebase-overview-analyzer/services/dependency-aggregation.service.js +114 -0
  85. package/dist/server/modules/codebase-overview-analyzer/services/dependency-aggregation.service.js.map +1 -0
  86. package/dist/server/modules/codebase-overview-analyzer/services/district-splitting.service.d.ts +8 -0
  87. package/dist/server/modules/codebase-overview-analyzer/services/district-splitting.service.js +200 -0
  88. package/dist/server/modules/codebase-overview-analyzer/services/district-splitting.service.js.map +1 -0
  89. package/dist/server/modules/codebase-overview-analyzer/services/evidence-query.service.d.ts +11 -0
  90. package/dist/server/modules/codebase-overview-analyzer/services/evidence-query.service.js +164 -0
  91. package/dist/server/modules/codebase-overview-analyzer/services/evidence-query.service.js.map +1 -0
  92. package/dist/server/modules/codebase-overview-analyzer/services/go-adapter.d.ts +2 -0
  93. package/dist/server/modules/codebase-overview-analyzer/services/go-adapter.js +166 -0
  94. package/dist/server/modules/codebase-overview-analyzer/services/go-adapter.js.map +1 -0
  95. package/dist/server/modules/codebase-overview-analyzer/services/hotspot-scoring.service.d.ts +21 -0
  96. package/dist/server/modules/codebase-overview-analyzer/services/hotspot-scoring.service.js +252 -0
  97. package/dist/server/modules/codebase-overview-analyzer/services/hotspot-scoring.service.js.map +1 -0
  98. package/dist/server/modules/codebase-overview-analyzer/services/identity-resolver.service.d.ts +24 -0
  99. package/dist/server/modules/codebase-overview-analyzer/services/identity-resolver.service.js +98 -0
  100. package/dist/server/modules/codebase-overview-analyzer/services/identity-resolver.service.js.map +1 -0
  101. package/dist/server/modules/codebase-overview-analyzer/services/java-adapter.d.ts +2 -0
  102. package/dist/server/modules/codebase-overview-analyzer/services/java-adapter.js +155 -0
  103. package/dist/server/modules/codebase-overview-analyzer/services/java-adapter.js.map +1 -0
  104. package/dist/server/modules/codebase-overview-analyzer/services/language-adapter-registry.service.d.ts +19 -0
  105. package/dist/server/modules/codebase-overview-analyzer/services/language-adapter-registry.service.js +87 -0
  106. package/dist/server/modules/codebase-overview-analyzer/services/language-adapter-registry.service.js.map +1 -0
  107. package/dist/server/modules/codebase-overview-analyzer/services/php-adapter.d.ts +2 -0
  108. package/dist/server/modules/codebase-overview-analyzer/services/php-adapter.js +173 -0
  109. package/dist/server/modules/codebase-overview-analyzer/services/php-adapter.js.map +1 -0
  110. package/dist/server/modules/codebase-overview-analyzer/services/python-adapter.d.ts +2 -0
  111. package/dist/server/modules/codebase-overview-analyzer/services/python-adapter.js +171 -0
  112. package/dist/server/modules/codebase-overview-analyzer/services/python-adapter.js.map +1 -0
  113. package/dist/server/modules/codebase-overview-analyzer/services/ruby-adapter.d.ts +2 -0
  114. package/dist/server/modules/codebase-overview-analyzer/services/ruby-adapter.js +158 -0
  115. package/dist/server/modules/codebase-overview-analyzer/services/ruby-adapter.js.map +1 -0
  116. package/dist/server/modules/codebase-overview-analyzer/services/rust-adapter.d.ts +2 -0
  117. package/dist/server/modules/codebase-overview-analyzer/services/rust-adapter.js +222 -0
  118. package/dist/server/modules/codebase-overview-analyzer/services/rust-adapter.js.map +1 -0
  119. package/dist/server/modules/codebase-overview-analyzer/services/scope-auto-detector.service.d.ts +4 -0
  120. package/dist/server/modules/codebase-overview-analyzer/services/scope-auto-detector.service.js +72 -0
  121. package/dist/server/modules/codebase-overview-analyzer/services/scope-auto-detector.service.js.map +1 -0
  122. package/dist/server/modules/codebase-overview-analyzer/services/scope-resolver.service.d.ts +6 -0
  123. package/dist/server/modules/codebase-overview-analyzer/services/scope-resolver.service.js +37 -0
  124. package/dist/server/modules/codebase-overview-analyzer/services/scope-resolver.service.js.map +1 -0
  125. package/dist/server/modules/codebase-overview-analyzer/services/typescript-adapter.d.ts +2 -0
  126. package/dist/server/modules/codebase-overview-analyzer/services/typescript-adapter.js +108 -0
  127. package/dist/server/modules/codebase-overview-analyzer/services/typescript-adapter.js.map +1 -0
  128. package/dist/server/modules/codebase-overview-analyzer/types/index.d.ts +2 -0
  129. package/dist/server/modules/codebase-overview-analyzer/types/index.js +6 -0
  130. package/dist/server/modules/codebase-overview-analyzer/types/index.js.map +1 -0
  131. package/dist/server/modules/codebase-overview-analyzer/types/scope-defaults.d.ts +2 -0
  132. package/dist/server/modules/codebase-overview-analyzer/types/scope-defaults.js +13 -0
  133. package/dist/server/modules/codebase-overview-analyzer/types/scope-defaults.js.map +1 -0
  134. package/dist/server/modules/codebase-overview-analyzer/types/scope.schema.d.ts +54 -0
  135. package/dist/server/modules/codebase-overview-analyzer/types/scope.schema.js +27 -0
  136. package/dist/server/modules/codebase-overview-analyzer/types/scope.schema.js.map +1 -0
  137. package/dist/server/modules/codebase-overview-analyzer/types/scope.types.d.ts +12 -0
  138. package/dist/server/modules/codebase-overview-analyzer/types/scope.types.js +3 -0
  139. package/dist/server/modules/codebase-overview-analyzer/types/scope.types.js.map +1 -0
  140. package/dist/server/modules/codebase-overview-analyzer/utils/constants.d.ts +1 -0
  141. package/dist/server/modules/codebase-overview-analyzer/utils/constants.js +5 -0
  142. package/dist/server/modules/codebase-overview-analyzer/utils/constants.js.map +1 -0
  143. package/dist/server/modules/codebase-overview-analyzer/utils/path-matcher.d.ts +2 -0
  144. package/dist/server/modules/codebase-overview-analyzer/utils/path-matcher.js +17 -0
  145. package/dist/server/modules/codebase-overview-analyzer/utils/path-matcher.js.map +1 -0
  146. package/dist/server/modules/core/controllers/preflight.controller.d.ts +1 -1
  147. package/dist/server/modules/core/controllers/preflight.controller.js +6 -4
  148. package/dist/server/modules/core/controllers/preflight.controller.js.map +1 -1
  149. package/dist/server/modules/core/services/preflight.service.d.ts +7 -1
  150. package/dist/server/modules/core/services/preflight.service.js +127 -10
  151. package/dist/server/modules/core/services/preflight.service.js.map +1 -1
  152. package/dist/server/modules/events/catalog/agent.created.d.ts +42 -0
  153. package/dist/server/modules/events/catalog/agent.created.js +23 -0
  154. package/dist/server/modules/events/catalog/agent.created.js.map +1 -0
  155. package/dist/server/modules/events/catalog/agent.deleted.d.ts +42 -0
  156. package/dist/server/modules/events/catalog/agent.deleted.js +22 -0
  157. package/dist/server/modules/events/catalog/agent.deleted.js.map +1 -0
  158. package/dist/server/modules/events/catalog/index.d.ts +180 -0
  159. package/dist/server/modules/events/catalog/index.js +10 -0
  160. package/dist/server/modules/events/catalog/index.js.map +1 -1
  161. package/dist/server/modules/events/catalog/team.config.updated.d.ts +67 -0
  162. package/dist/server/modules/events/catalog/team.config.updated.js +21 -0
  163. package/dist/server/modules/events/catalog/team.config.updated.js.map +1 -0
  164. package/dist/server/modules/events/catalog/team.member.added.d.ts +27 -0
  165. package/dist/server/modules/events/catalog/team.member.added.js +16 -0
  166. package/dist/server/modules/events/catalog/team.member.added.js.map +1 -0
  167. package/dist/server/modules/events/catalog/team.member.removed.d.ts +27 -0
  168. package/dist/server/modules/events/catalog/team.member.removed.js +16 -0
  169. package/dist/server/modules/events/catalog/team.member.removed.js.map +1 -0
  170. package/dist/server/modules/events/controllers/event-log.controller.d.ts +1 -1
  171. package/dist/server/modules/events/controllers/event-log.controller.js +11 -9
  172. package/dist/server/modules/events/controllers/event-log.controller.js.map +1 -1
  173. package/dist/server/modules/events/dtos/event-log.dto.d.ts +1 -0
  174. package/dist/server/modules/events/services/event-log.service.js +3 -0
  175. package/dist/server/modules/events/services/event-log.service.js.map +1 -1
  176. package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.d.ts +2 -1
  177. package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js +30 -10
  178. package/dist/server/modules/events/subscribers/epic-assignment-notifier.subscriber.js.map +1 -1
  179. package/dist/server/modules/events/subscribers/index.js +8 -0
  180. package/dist/server/modules/events/subscribers/index.js.map +1 -1
  181. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.d.ts +16 -0
  182. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js +101 -0
  183. package/dist/server/modules/events/subscribers/project-state-broadcaster.subscriber.js.map +1 -0
  184. package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.d.ts +2 -1
  185. package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.js +30 -8
  186. package/dist/server/modules/events/subscribers/review-comment-notifier.subscriber.js.map +1 -1
  187. package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.d.ts +18 -0
  188. package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.js +154 -0
  189. package/dist/server/modules/events/subscribers/sub-epic-created-notifier.subscriber.js.map +1 -0
  190. package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.d.ts +18 -0
  191. package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.js +138 -0
  192. package/dist/server/modules/events/subscribers/team-config-updated-notifier.subscriber.js.map +1 -0
  193. package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.d.ts +18 -0
  194. package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.js +129 -0
  195. package/dist/server/modules/events/subscribers/team-membership-changed-notifier.subscriber.js.map +1 -0
  196. package/dist/server/modules/mcp/dtos/mcp.dto.d.ts +173 -0
  197. package/dist/server/modules/mcp/dtos/mcp.dto.js +69 -6
  198. package/dist/server/modules/mcp/dtos/mcp.dto.js.map +1 -1
  199. package/dist/server/modules/mcp/dtos/schema-registry.js +6 -0
  200. package/dist/server/modules/mcp/dtos/schema-registry.js.map +1 -1
  201. package/dist/server/modules/mcp/mcp.module.js +2 -0
  202. package/dist/server/modules/mcp/mcp.module.js.map +1 -1
  203. package/dist/server/modules/mcp/services/handlers/chat-tools.js +117 -3
  204. package/dist/server/modules/mcp/services/handlers/chat-tools.js.map +1 -1
  205. package/dist/server/modules/mcp/services/handlers/epic-tools.js +26 -4
  206. package/dist/server/modules/mcp/services/handlers/epic-tools.js.map +1 -1
  207. package/dist/server/modules/mcp/services/handlers/prompt-tools.js +33 -1
  208. package/dist/server/modules/mcp/services/handlers/prompt-tools.js.map +1 -1
  209. package/dist/server/modules/mcp/services/handlers/teams-tools.d.ts +8 -0
  210. package/dist/server/modules/mcp/services/handlers/teams-tools.js +457 -0
  211. package/dist/server/modules/mcp/services/handlers/teams-tools.js.map +1 -0
  212. package/dist/server/modules/mcp/services/handlers/types.d.ts +2 -0
  213. package/dist/server/modules/mcp/services/instructions-resolver.d.ts +7 -3
  214. package/dist/server/modules/mcp/services/instructions-resolver.js +50 -26
  215. package/dist/server/modules/mcp/services/instructions-resolver.js.map +1 -1
  216. package/dist/server/modules/mcp/services/mcp-provider-registration.service.d.ts +0 -1
  217. package/dist/server/modules/mcp/services/mcp-provider-registration.service.js +11 -43
  218. package/dist/server/modules/mcp/services/mcp-provider-registration.service.js.map +1 -1
  219. package/dist/server/modules/mcp/services/mcp.service.d.ts +3 -1
  220. package/dist/server/modules/mcp/services/mcp.service.js +15 -3
  221. package/dist/server/modules/mcp/services/mcp.service.js.map +1 -1
  222. package/dist/server/modules/mcp/tool-definitions.d.ts +501 -0
  223. package/dist/server/modules/mcp/tool-definitions.js +137 -3
  224. package/dist/server/modules/mcp/tool-definitions.js.map +1 -1
  225. package/dist/server/modules/profiles/controllers/profiles.controller.js +1 -0
  226. package/dist/server/modules/profiles/controllers/profiles.controller.js.map +1 -1
  227. package/dist/server/modules/profiles/controllers/provider-configs.controller.js +3 -0
  228. package/dist/server/modules/profiles/controllers/provider-configs.controller.js.map +1 -1
  229. package/dist/server/modules/profiles/dto.d.ts +19 -6
  230. package/dist/server/modules/profiles/dto.js +13 -15
  231. package/dist/server/modules/profiles/dto.js.map +1 -1
  232. package/dist/server/modules/projects/controllers/projects.controller.d.ts +34 -0
  233. package/dist/server/modules/projects/controllers/projects.controller.js +52 -1
  234. package/dist/server/modules/projects/controllers/projects.controller.js.map +1 -1
  235. package/dist/server/modules/projects/helpers/project-export.d.ts +47 -0
  236. package/dist/server/modules/projects/helpers/project-export.js +116 -40
  237. package/dist/server/modules/projects/helpers/project-export.js.map +1 -1
  238. package/dist/server/modules/projects/helpers/project-import.d.ts +62 -0
  239. package/dist/server/modules/projects/helpers/project-import.js +191 -1
  240. package/dist/server/modules/projects/helpers/project-import.js.map +1 -1
  241. package/dist/server/modules/projects/helpers/template-loader.d.ts +13 -0
  242. package/dist/server/modules/projects/helpers/template-loader.js +60 -1
  243. package/dist/server/modules/projects/helpers/template-loader.js.map +1 -1
  244. package/dist/server/modules/projects/projects.module.js +2 -1
  245. package/dist/server/modules/projects/projects.module.js.map +1 -1
  246. package/dist/server/modules/projects/services/projects.service.d.ts +41 -1
  247. package/dist/server/modules/projects/services/projects.service.js +9 -2
  248. package/dist/server/modules/projects/services/projects.service.js.map +1 -1
  249. package/dist/server/modules/providers/adapters/gemini.adapter.js +2 -2
  250. package/dist/server/modules/providers/adapters/gemini.adapter.js.map +1 -1
  251. package/dist/server/modules/providers/controllers/providers.controller.d.ts +17 -2
  252. package/dist/server/modules/providers/controllers/providers.controller.js +76 -3
  253. package/dist/server/modules/providers/controllers/providers.controller.js.map +1 -1
  254. package/dist/server/modules/providers/providers.module.js +14 -2
  255. package/dist/server/modules/providers/providers.module.js.map +1 -1
  256. package/dist/server/modules/providers/services/provider-discovery.service.d.ts +17 -0
  257. package/dist/server/modules/providers/services/provider-discovery.service.js +64 -0
  258. package/dist/server/modules/providers/services/provider-discovery.service.js.map +1 -0
  259. package/dist/server/modules/providers/services/provider-project-sync.service.d.ts +27 -0
  260. package/dist/server/modules/providers/services/provider-project-sync.service.js +171 -0
  261. package/dist/server/modules/providers/services/provider-project-sync.service.js.map +1 -0
  262. package/dist/server/modules/registry/controllers/templates.controller.d.ts +153 -0
  263. package/dist/server/modules/registry/controllers/templates.controller.js +56 -0
  264. package/dist/server/modules/registry/controllers/templates.controller.js.map +1 -1
  265. package/dist/server/modules/seeders/seeders/0007_seed_claude_no_flicker_env.d.ts +3 -0
  266. package/dist/server/modules/seeders/seeders/0007_seed_claude_no_flicker_env.js +28 -0
  267. package/dist/server/modules/seeders/seeders/0007_seed_claude_no_flicker_env.js.map +1 -0
  268. package/dist/server/modules/seeders/services/data-seeder.service.js +2 -0
  269. package/dist/server/modules/seeders/services/data-seeder.service.js.map +1 -1
  270. package/dist/server/modules/session-reader/data/pricing.json +242 -21
  271. package/dist/server/modules/sessions/services/sessions-message-pool.service.js +15 -9
  272. package/dist/server/modules/sessions/services/sessions-message-pool.service.js.map +1 -1
  273. package/dist/server/modules/sessions/services/sessions.service.d.ts +1 -0
  274. package/dist/server/modules/sessions/services/sessions.service.js +26 -5
  275. package/dist/server/modules/sessions/services/sessions.service.js.map +1 -1
  276. package/dist/server/modules/sessions/utils/profile-options.js +3 -0
  277. package/dist/server/modules/sessions/utils/profile-options.js.map +1 -1
  278. package/dist/server/modules/sessions/utils/template-renderer.d.ts +6 -0
  279. package/dist/server/modules/sessions/utils/template-renderer.js +15 -10
  280. package/dist/server/modules/sessions/utils/template-renderer.js.map +1 -1
  281. package/dist/server/modules/storage/db/schema.d.ts +440 -0
  282. package/dist/server/modules/storage/db/schema.js +65 -1
  283. package/dist/server/modules/storage/db/schema.js.map +1 -1
  284. package/dist/server/modules/storage/interfaces/storage.interface.d.ts +14 -0
  285. package/dist/server/modules/storage/interfaces/storage.interface.js.map +1 -1
  286. package/dist/server/modules/storage/local/delegates/agent.delegate.js +40 -15
  287. package/dist/server/modules/storage/local/delegates/agent.delegate.js.map +1 -1
  288. package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.d.ts +13 -0
  289. package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js +142 -11
  290. package/dist/server/modules/storage/local/delegates/profile-provider-config.delegate.js.map +1 -1
  291. package/dist/server/modules/storage/local/delegates/project.delegate.js +10 -0
  292. package/dist/server/modules/storage/local/delegates/project.delegate.js.map +1 -1
  293. package/dist/server/modules/storage/local/delegates/provider.delegate.js +38 -10
  294. package/dist/server/modules/storage/local/delegates/provider.delegate.js.map +1 -1
  295. package/dist/server/modules/storage/local/helpers/storage-helpers.d.ts +2 -0
  296. package/dist/server/modules/storage/local/helpers/storage-helpers.js +36 -0
  297. package/dist/server/modules/storage/local/helpers/storage-helpers.js.map +1 -1
  298. package/dist/server/modules/storage/local/local-storage.service.d.ts +2 -1
  299. package/dist/server/modules/storage/local/local-storage.service.js +3 -0
  300. package/dist/server/modules/storage/local/local-storage.service.js.map +1 -1
  301. package/dist/server/modules/storage/models/domain.models.d.ts +62 -0
  302. package/dist/server/modules/subscribers/services/subscriber-executor.service.d.ts +6 -2
  303. package/dist/server/modules/subscribers/services/subscriber-executor.service.js +52 -5
  304. package/dist/server/modules/subscribers/services/subscriber-executor.service.js.map +1 -1
  305. package/dist/server/modules/teams/controllers/teams.controller.d.ts +39 -0
  306. package/dist/server/modules/teams/controllers/teams.controller.js +214 -0
  307. package/dist/server/modules/teams/controllers/teams.controller.js.map +1 -0
  308. package/dist/server/modules/teams/services/teams.service.d.ts +106 -0
  309. package/dist/server/modules/teams/services/teams.service.js +748 -0
  310. package/dist/server/modules/teams/services/teams.service.js.map +1 -0
  311. package/dist/server/modules/teams/storage/teams.store.d.ts +58 -0
  312. package/dist/server/modules/teams/storage/teams.store.js +468 -0
  313. package/dist/server/modules/teams/storage/teams.store.js.map +1 -0
  314. package/dist/server/modules/teams/teams.module.d.ts +2 -0
  315. package/dist/server/modules/teams/teams.module.js +27 -0
  316. package/dist/server/modules/teams/teams.module.js.map +1 -0
  317. package/dist/server/modules/terminal/services/confirmed-delivery.helper.d.ts +2 -0
  318. package/dist/server/modules/terminal/services/confirmed-delivery.helper.js +8 -1
  319. package/dist/server/modules/terminal/services/confirmed-delivery.helper.js.map +1 -1
  320. package/dist/server/templates/3-agents-dev.json +169 -89
  321. package/dist/server/templates/5-agents-dev.json +243 -135
  322. package/dist/server/templates/teams-dev.json +1096 -0
  323. package/dist/server/tsconfig.tsbuildinfo +1 -1
  324. package/dist/server/ui/assets/{ReviewDetailPage-B5Wk-cyO.js → ReviewDetailPage-CEMxN6RQ.js} +1 -1
  325. package/dist/server/ui/assets/{ReviewsPage-SUvvu_uV.js → ReviewsPage-BzMksnGd.js} +1 -1
  326. package/dist/server/ui/assets/index-ChJ1IUMI.css +32 -0
  327. package/dist/server/ui/assets/index-Csagg3g2.js +1027 -0
  328. package/dist/server/ui/assets/{useReviewSubscription-C_dnAb0l.js → useReviewSubscription-B2ejeWE4.js} +1 -1
  329. package/dist/server/ui/index.html +2 -2
  330. package/dist/templates/3-agents-dev.json +169 -89
  331. package/dist/templates/5-agents-dev.json +243 -135
  332. package/dist/templates/teams-dev.json +1096 -0
  333. package/package.json +34 -2
  334. package/dist/server/ui/assets/index-Bl-zkrCF.js +0 -1011
  335. package/dist/server/ui/assets/index-C99ggRaD.css +0 -32
  336. /package/dist/drizzle/{0050_providers_one_million_context.sql → 0052_providers_one_million_context.sql} +0 -0
  337. /package/dist/drizzle/{0051_providers_auto_compact_threshold_1m.sql → 0053_providers_auto_compact_threshold_1m.sql} +0 -0
@@ -0,0 +1,138 @@
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
+ var TeamConfigUpdatedNotifierSubscriber_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.TeamConfigUpdatedNotifierSubscriber = void 0;
17
+ exports.buildMessage = buildMessage;
18
+ const common_1 = require("@nestjs/common");
19
+ const core_1 = require("@nestjs/core");
20
+ const event_emitter_1 = require("@nestjs/event-emitter");
21
+ const events_service_1 = require("../services/events.service");
22
+ const event_log_service_1 = require("../services/event-log.service");
23
+ const sessions_service_1 = require("../../sessions/services/sessions.service");
24
+ const sessions_message_pool_service_1 = require("../../sessions/services/sessions-message-pool.service");
25
+ const storage_interface_1 = require("../../storage/interfaces/storage.interface");
26
+ function buildMessage(payload) {
27
+ const capacityChanged = payload.previous.maxMembers !== payload.current.maxMembers ||
28
+ payload.previous.maxConcurrentTasks !== payload.current.maxConcurrentTasks;
29
+ const flagChanged = payload.previous.allowTeamLeadCreateAgents !== payload.current.allowTeamLeadCreateAgents;
30
+ const capacityPart = `max members: ${payload.current.maxMembers}, ` +
31
+ `max concurrent tasks: ${payload.current.maxConcurrentTasks}`;
32
+ const flagPart = payload.current.allowTeamLeadCreateAgents
33
+ ? 'lead can now create team agents'
34
+ : 'lead can no longer create team agents';
35
+ if (capacityChanged && flagChanged) {
36
+ return `Team '${payload.teamName}' updated — ${capacityPart}; ${flagPart}.`;
37
+ }
38
+ if (flagChanged) {
39
+ return `Team '${payload.teamName}' setting updated — ${flagPart}.`;
40
+ }
41
+ return `Team '${payload.teamName}' config updated — ${capacityPart}.`;
42
+ }
43
+ let TeamConfigUpdatedNotifierSubscriber = TeamConfigUpdatedNotifierSubscriber_1 = class TeamConfigUpdatedNotifierSubscriber {
44
+ constructor(eventLogService, moduleRef, messagePoolService, storage) {
45
+ this.eventLogService = eventLogService;
46
+ this.moduleRef = moduleRef;
47
+ this.messagePoolService = messagePoolService;
48
+ this.storage = storage;
49
+ this.logger = new common_1.Logger(TeamConfigUpdatedNotifierSubscriber_1.name);
50
+ }
51
+ async handleTeamConfigUpdated(payload) {
52
+ if (!payload.teamLeadAgentId) {
53
+ return;
54
+ }
55
+ const metadata = (0, events_service_1.getEventMetadata)(payload);
56
+ const eventId = metadata?.id;
57
+ const handler = 'TeamConfigUpdatedNotifier';
58
+ const startedAt = new Date().toISOString();
59
+ try {
60
+ const leadAgent = await this.storage.getAgent(payload.teamLeadAgentId).catch(() => null);
61
+ const message = buildMessage(payload);
62
+ await this.launchSessionIfNeeded({
63
+ targetAgentId: payload.teamLeadAgentId,
64
+ projectId: payload.projectId,
65
+ teamId: payload.teamId,
66
+ });
67
+ const result = await this.messagePoolService.enqueue(payload.teamLeadAgentId, message, {
68
+ source: 'team.config.updated',
69
+ submitKeys: ['Enter'],
70
+ projectId: payload.projectId,
71
+ agentName: leadAgent?.name,
72
+ });
73
+ this.logger.log({ eventId, leadAgentId: payload.teamLeadAgentId, poolStatus: result.status }, 'Notified team lead about config update');
74
+ if (eventId) {
75
+ await this.eventLogService.recordHandledOk({
76
+ eventId,
77
+ handler,
78
+ detail: { poolStatus: result.status },
79
+ startedAt,
80
+ endedAt: new Date().toISOString(),
81
+ });
82
+ }
83
+ }
84
+ catch (error) {
85
+ this.logger.error({ error, payload }, 'Failed to notify team lead about config update');
86
+ if (eventId) {
87
+ await this.eventLogService.recordHandledFail({
88
+ eventId,
89
+ handler,
90
+ detail: error instanceof Error
91
+ ? { message: error.message }
92
+ : { message: 'Unknown error', value: String(error) },
93
+ startedAt,
94
+ endedAt: new Date().toISOString(),
95
+ });
96
+ }
97
+ }
98
+ }
99
+ async launchSessionIfNeeded(opts) {
100
+ const sessionsService = this.getSessionsService();
101
+ const activeSessions = await sessionsService.listActiveSessions();
102
+ const existing = activeSessions.find((s) => s.agentId === opts.targetAgentId);
103
+ if (existing?.tmuxSessionId) {
104
+ return { sessionId: existing.id, launched: false };
105
+ }
106
+ const session = await sessionsService.launchSession({
107
+ projectId: opts.projectId,
108
+ agentId: opts.targetAgentId,
109
+ options: { silent: true },
110
+ });
111
+ return { sessionId: session.id, launched: true };
112
+ }
113
+ getSessionsService() {
114
+ if (!this.sessionsServiceRef) {
115
+ this.sessionsServiceRef = this.moduleRef.get(sessions_service_1.SessionsService, { strict: false });
116
+ if (!this.sessionsServiceRef) {
117
+ throw new Error('SessionsService is not available in the current module context');
118
+ }
119
+ }
120
+ return this.sessionsServiceRef;
121
+ }
122
+ };
123
+ exports.TeamConfigUpdatedNotifierSubscriber = TeamConfigUpdatedNotifierSubscriber;
124
+ __decorate([
125
+ (0, event_emitter_1.OnEvent)('team.config.updated', { async: true }),
126
+ __metadata("design:type", Function),
127
+ __metadata("design:paramtypes", [Object]),
128
+ __metadata("design:returntype", Promise)
129
+ ], TeamConfigUpdatedNotifierSubscriber.prototype, "handleTeamConfigUpdated", null);
130
+ exports.TeamConfigUpdatedNotifierSubscriber = TeamConfigUpdatedNotifierSubscriber = TeamConfigUpdatedNotifierSubscriber_1 = __decorate([
131
+ (0, common_1.Injectable)(),
132
+ __param(2, (0, common_1.Inject)((0, common_1.forwardRef)(() => sessions_message_pool_service_1.SessionsMessagePoolService))),
133
+ __param(3, (0, common_1.Inject)(storage_interface_1.STORAGE_SERVICE)),
134
+ __metadata("design:paramtypes", [event_log_service_1.EventLogService,
135
+ core_1.ModuleRef,
136
+ sessions_message_pool_service_1.SessionsMessagePoolService, Object])
137
+ ], TeamConfigUpdatedNotifierSubscriber);
138
+ //# sourceMappingURL=team-config-updated-notifier.subscriber.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"team-config-updated-notifier.subscriber.js","sourceRoot":"","sources":["../../../../src/modules/events/subscribers/team-config-updated-notifier.subscriber.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { ModuleRef } from '@nestjs/core';
2
+ import { EventLogService } from '../services/event-log.service';
3
+ import { SessionsMessagePoolService } from '../../sessions/services/sessions-message-pool.service';
4
+ import type { TeamMemberAddedEventPayload } from '../catalog/team.member.added';
5
+ import type { TeamMemberRemovedEventPayload } from '../catalog/team.member.removed';
6
+ export declare class TeamMembershipChangedNotifierSubscriber {
7
+ private readonly eventLogService;
8
+ private readonly moduleRef;
9
+ private readonly messagePoolService;
10
+ private readonly logger;
11
+ private sessionsServiceRef?;
12
+ constructor(eventLogService: EventLogService, moduleRef: ModuleRef, messagePoolService: SessionsMessagePoolService);
13
+ handleMemberAdded(payload: TeamMemberAddedEventPayload): Promise<void>;
14
+ handleMemberRemoved(payload: TeamMemberRemovedEventPayload): Promise<void>;
15
+ private notify;
16
+ private launchSessionIfNeeded;
17
+ private getSessionsService;
18
+ }
@@ -0,0 +1,129 @@
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
+ var TeamMembershipChangedNotifierSubscriber_1;
15
+ Object.defineProperty(exports, "__esModule", { value: true });
16
+ exports.TeamMembershipChangedNotifierSubscriber = void 0;
17
+ const common_1 = require("@nestjs/common");
18
+ const core_1 = require("@nestjs/core");
19
+ const event_emitter_1 = require("@nestjs/event-emitter");
20
+ const events_service_1 = require("../services/events.service");
21
+ const event_log_service_1 = require("../services/event-log.service");
22
+ const sessions_service_1 = require("../../sessions/services/sessions.service");
23
+ const sessions_message_pool_service_1 = require("../../sessions/services/sessions-message-pool.service");
24
+ let TeamMembershipChangedNotifierSubscriber = TeamMembershipChangedNotifierSubscriber_1 = class TeamMembershipChangedNotifierSubscriber {
25
+ constructor(eventLogService, moduleRef, messagePoolService) {
26
+ this.eventLogService = eventLogService;
27
+ this.moduleRef = moduleRef;
28
+ this.messagePoolService = messagePoolService;
29
+ this.logger = new common_1.Logger(TeamMembershipChangedNotifierSubscriber_1.name);
30
+ }
31
+ async handleMemberAdded(payload) {
32
+ if (!payload.teamLeadAgentId)
33
+ return;
34
+ const message = `Agent '${payload.addedAgentName ?? payload.addedAgentId}' was added to team '${payload.teamName}'.`;
35
+ await this.notify(payload.teamLeadAgentId, message, 'team.member.added', payload);
36
+ }
37
+ async handleMemberRemoved(payload) {
38
+ if (!payload.teamLeadAgentId)
39
+ return;
40
+ const message = `Agent '${payload.removedAgentName ?? payload.removedAgentId}' was removed from team '${payload.teamName}'.`;
41
+ await this.notify(payload.teamLeadAgentId, message, 'team.member.removed', payload);
42
+ }
43
+ async notify(leadAgentId, message, source, payload) {
44
+ const metadata = (0, events_service_1.getEventMetadata)(payload);
45
+ const eventId = metadata?.id;
46
+ const handler = 'TeamMembershipChangedNotifier';
47
+ const startedAt = new Date().toISOString();
48
+ try {
49
+ await this.launchSessionIfNeeded({
50
+ targetAgentId: leadAgentId,
51
+ projectId: payload.projectId,
52
+ teamId: payload.teamId,
53
+ });
54
+ const result = await this.messagePoolService.enqueue(leadAgentId, message, {
55
+ source,
56
+ submitKeys: ['Enter'],
57
+ projectId: payload.projectId,
58
+ });
59
+ this.logger.log({ eventId, leadAgentId, poolStatus: result.status }, `Notified team lead about membership change (${source})`);
60
+ if (eventId) {
61
+ await this.eventLogService.recordHandledOk({
62
+ eventId,
63
+ handler,
64
+ detail: { poolStatus: result.status },
65
+ startedAt,
66
+ endedAt: new Date().toISOString(),
67
+ });
68
+ }
69
+ }
70
+ catch (error) {
71
+ this.logger.error({ error, payload }, `Failed to notify team lead (${source})`);
72
+ if (eventId) {
73
+ await this.eventLogService.recordHandledFail({
74
+ eventId,
75
+ handler,
76
+ detail: error instanceof Error
77
+ ? { message: error.message }
78
+ : { message: 'Unknown error', value: String(error) },
79
+ startedAt,
80
+ endedAt: new Date().toISOString(),
81
+ });
82
+ }
83
+ }
84
+ }
85
+ async launchSessionIfNeeded(opts) {
86
+ const sessionsService = this.getSessionsService();
87
+ const activeSessions = await sessionsService.listActiveSessions();
88
+ const existing = activeSessions.find((s) => s.agentId === opts.targetAgentId);
89
+ if (existing?.tmuxSessionId) {
90
+ return { sessionId: existing.id, launched: false };
91
+ }
92
+ const session = await sessionsService.launchSession({
93
+ projectId: opts.projectId,
94
+ agentId: opts.targetAgentId,
95
+ options: { silent: true },
96
+ });
97
+ return { sessionId: session.id, launched: true };
98
+ }
99
+ getSessionsService() {
100
+ if (!this.sessionsServiceRef) {
101
+ this.sessionsServiceRef = this.moduleRef.get(sessions_service_1.SessionsService, { strict: false });
102
+ if (!this.sessionsServiceRef) {
103
+ throw new Error('SessionsService is not available in the current module context');
104
+ }
105
+ }
106
+ return this.sessionsServiceRef;
107
+ }
108
+ };
109
+ exports.TeamMembershipChangedNotifierSubscriber = TeamMembershipChangedNotifierSubscriber;
110
+ __decorate([
111
+ (0, event_emitter_1.OnEvent)('team.member.added', { async: true }),
112
+ __metadata("design:type", Function),
113
+ __metadata("design:paramtypes", [Object]),
114
+ __metadata("design:returntype", Promise)
115
+ ], TeamMembershipChangedNotifierSubscriber.prototype, "handleMemberAdded", null);
116
+ __decorate([
117
+ (0, event_emitter_1.OnEvent)('team.member.removed', { async: true }),
118
+ __metadata("design:type", Function),
119
+ __metadata("design:paramtypes", [Object]),
120
+ __metadata("design:returntype", Promise)
121
+ ], TeamMembershipChangedNotifierSubscriber.prototype, "handleMemberRemoved", null);
122
+ exports.TeamMembershipChangedNotifierSubscriber = TeamMembershipChangedNotifierSubscriber = TeamMembershipChangedNotifierSubscriber_1 = __decorate([
123
+ (0, common_1.Injectable)(),
124
+ __param(2, (0, common_1.Inject)((0, common_1.forwardRef)(() => sessions_message_pool_service_1.SessionsMessagePoolService))),
125
+ __metadata("design:paramtypes", [event_log_service_1.EventLogService,
126
+ core_1.ModuleRef,
127
+ sessions_message_pool_service_1.SessionsMessagePoolService])
128
+ ], TeamMembershipChangedNotifierSubscriber);
129
+ //# sourceMappingURL=team-membership-changed-notifier.subscriber.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"team-membership-changed-notifier.subscriber.js","sourceRoot":"","sources":["../../../../src/modules/events/subscribers/team-membership-changed-notifier.subscriber.ts"],"names":[],"mappings":"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"}
@@ -821,35 +821,41 @@ export interface AddEpicCommentResponse {
821
821
  }
822
822
  export interface UpdateEpicResponse {
823
823
  epic: EpicSummary;
824
+ hint?: string;
824
825
  }
825
826
  export declare const SendMessageParamsSchema: z.ZodEffects<z.ZodObject<{
826
827
  sessionId: z.ZodString;
827
828
  threadId: z.ZodOptional<z.ZodString>;
828
829
  recipientAgentNames: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
830
+ teamName: z.ZodOptional<z.ZodString>;
829
831
  message: z.ZodString;
830
832
  recipient: z.ZodOptional<z.ZodEnum<["user", "agents"]>>;
831
833
  }, "strict", z.ZodTypeAny, {
832
834
  message: string;
833
835
  sessionId: string;
834
836
  threadId?: string | undefined;
837
+ teamName?: string | undefined;
835
838
  recipientAgentNames?: string[] | undefined;
836
839
  recipient?: "user" | "agents" | undefined;
837
840
  }, {
838
841
  message: string;
839
842
  sessionId: string;
840
843
  threadId?: string | undefined;
844
+ teamName?: string | undefined;
841
845
  recipientAgentNames?: string[] | undefined;
842
846
  recipient?: "user" | "agents" | undefined;
843
847
  }>, {
844
848
  message: string;
845
849
  sessionId: string;
846
850
  threadId?: string | undefined;
851
+ teamName?: string | undefined;
847
852
  recipientAgentNames?: string[] | undefined;
848
853
  recipient?: "user" | "agents" | undefined;
849
854
  }, {
850
855
  message: string;
851
856
  sessionId: string;
852
857
  threadId?: string | undefined;
858
+ teamName?: string | undefined;
853
859
  recipientAgentNames?: string[] | undefined;
854
860
  recipient?: "user" | "agents" | undefined;
855
861
  }>;
@@ -864,6 +870,12 @@ export type SendMessageResponse = {
864
870
  error?: string;
865
871
  }>;
866
872
  estimatedDeliveryMs: number;
873
+ teamDelivery?: {
874
+ teamName: string;
875
+ recipientCount: number;
876
+ routedToLead: boolean;
877
+ summary: string;
878
+ };
867
879
  } | {
868
880
  mode: 'thread';
869
881
  threadId: string;
@@ -1259,6 +1271,167 @@ export interface LegacySessionContext {
1259
1271
  rootPath: string;
1260
1272
  } | null;
1261
1273
  }
1274
+ export declare const TeamsListParamsSchema: z.ZodObject<{
1275
+ sessionId: z.ZodString;
1276
+ q: z.ZodOptional<z.ZodString>;
1277
+ limit: z.ZodOptional<z.ZodNumber>;
1278
+ offset: z.ZodOptional<z.ZodNumber>;
1279
+ }, "strict", z.ZodTypeAny, {
1280
+ sessionId: string;
1281
+ limit?: number | undefined;
1282
+ offset?: number | undefined;
1283
+ q?: string | undefined;
1284
+ }, {
1285
+ sessionId: string;
1286
+ limit?: number | undefined;
1287
+ offset?: number | undefined;
1288
+ q?: string | undefined;
1289
+ }>;
1290
+ export type TeamsListParams = z.infer<typeof TeamsListParamsSchema>;
1291
+ export interface TeamSummary {
1292
+ id: string;
1293
+ name: string;
1294
+ description: string | null;
1295
+ teamLeadAgentId: string | null;
1296
+ teamLeadName: string | null;
1297
+ memberCount: number;
1298
+ }
1299
+ export interface ListTeamsResponse {
1300
+ teams: TeamSummary[];
1301
+ total: number;
1302
+ limit: number;
1303
+ offset: number;
1304
+ }
1305
+ export declare const TeamsMembersListParamsSchema: z.ZodObject<{
1306
+ sessionId: z.ZodString;
1307
+ teamId: z.ZodOptional<z.ZodString>;
1308
+ }, "strict", z.ZodTypeAny, {
1309
+ sessionId: string;
1310
+ teamId?: string | undefined;
1311
+ }, {
1312
+ sessionId: string;
1313
+ teamId?: string | undefined;
1314
+ }>;
1315
+ export type TeamsMembersListParams = z.infer<typeof TeamsMembersListParamsSchema>;
1316
+ export interface TeamMemberSummary {
1317
+ agentId: string;
1318
+ agentName: string;
1319
+ isTeamLead: boolean;
1320
+ }
1321
+ export interface TeamMembersEntry {
1322
+ teamId: string;
1323
+ teamName: string;
1324
+ members: TeamMemberSummary[];
1325
+ }
1326
+ export interface ListTeamMembersResponse {
1327
+ teams: TeamMembersEntry[];
1328
+ }
1329
+ export declare const TeamsConfigsListParamsSchema: z.ZodObject<{
1330
+ sessionId: z.ZodString;
1331
+ }, "strict", z.ZodTypeAny, {
1332
+ sessionId: string;
1333
+ }, {
1334
+ sessionId: string;
1335
+ }>;
1336
+ export type TeamsConfigsListParams = z.infer<typeof TeamsConfigsListParamsSchema>;
1337
+ export interface TeamsConfigsListEntry {
1338
+ configName: string;
1339
+ description: string | null;
1340
+ profileName: string;
1341
+ teamName: string;
1342
+ }
1343
+ export interface TeamsConfigsListResponse {
1344
+ configs: TeamsConfigsListEntry[];
1345
+ }
1346
+ export declare const TeamsCreateAgentParamsSchema: z.ZodObject<{
1347
+ sessionId: z.ZodString;
1348
+ name: z.ZodString;
1349
+ description: z.ZodOptional<z.ZodString>;
1350
+ configName: z.ZodString;
1351
+ profileName: z.ZodOptional<z.ZodString>;
1352
+ teamName: z.ZodOptional<z.ZodString>;
1353
+ }, "strict", z.ZodTypeAny, {
1354
+ name: string;
1355
+ sessionId: string;
1356
+ configName: string;
1357
+ description?: string | undefined;
1358
+ profileName?: string | undefined;
1359
+ teamName?: string | undefined;
1360
+ }, {
1361
+ name: string;
1362
+ sessionId: string;
1363
+ configName: string;
1364
+ description?: string | undefined;
1365
+ profileName?: string | undefined;
1366
+ teamName?: string | undefined;
1367
+ }>;
1368
+ export type TeamsCreateAgentParams = z.infer<typeof TeamsCreateAgentParamsSchema>;
1369
+ export declare const TeamsDeleteAgentParamsSchema: z.ZodObject<{
1370
+ sessionId: z.ZodString;
1371
+ name: z.ZodString;
1372
+ teamName: z.ZodOptional<z.ZodString>;
1373
+ }, "strict", z.ZodTypeAny, {
1374
+ name: string;
1375
+ sessionId: string;
1376
+ teamName?: string | undefined;
1377
+ }, {
1378
+ name: string;
1379
+ sessionId: string;
1380
+ teamName?: string | undefined;
1381
+ }>;
1382
+ export type TeamsDeleteAgentParams = z.infer<typeof TeamsDeleteAgentParamsSchema>;
1383
+ export interface TeamsDeleteAgentResponse {
1384
+ deletedAgentId: string;
1385
+ deletedAgentName: string;
1386
+ teamName: string;
1387
+ }
1388
+ export declare const DevchainTeamParamsSchema: z.ZodObject<{
1389
+ sessionId: z.ZodString;
1390
+ teamName: z.ZodOptional<z.ZodString>;
1391
+ }, "strict", z.ZodTypeAny, {
1392
+ sessionId: string;
1393
+ teamName?: string | undefined;
1394
+ }, {
1395
+ sessionId: string;
1396
+ teamName?: string | undefined;
1397
+ }>;
1398
+ export type DevchainTeamParams = z.infer<typeof DevchainTeamParamsSchema>;
1399
+ export interface DevchainTeamMemberProjection {
1400
+ agentId: string;
1401
+ agentName: string;
1402
+ isLead: boolean;
1403
+ profileId: string | null;
1404
+ profileName: string | null;
1405
+ providerConfigId: string | null;
1406
+ providerConfigName: string | null;
1407
+ }
1408
+ export interface DevchainTeamResponse {
1409
+ id: string;
1410
+ name: string;
1411
+ description: string | null;
1412
+ teamLeadAgentId: string | null;
1413
+ teamLeadAgentName: string | null;
1414
+ members: DevchainTeamMemberProjection[];
1415
+ maxMembers: number;
1416
+ maxConcurrentTasks: number;
1417
+ allowTeamLeadCreateAgents: boolean;
1418
+ currentMemberCount: number;
1419
+ busyMembersCount: number;
1420
+ freeSeats: number;
1421
+ freeConcurrentSlots: number;
1422
+ createdAt: string;
1423
+ updatedAt: string;
1424
+ }
1425
+ export interface TeamsCreateAgentResponse {
1426
+ agent: {
1427
+ id: string;
1428
+ name: string;
1429
+ description: string | null;
1430
+ profileName: string;
1431
+ configName: string;
1432
+ };
1433
+ teamName: string;
1434
+ }
1262
1435
  export declare const ListReviewsParamsSchema: z.ZodObject<{
1263
1436
  sessionId: z.ZodString;
1264
1437
  status: z.ZodOptional<z.ZodEnum<["draft", "pending", "changes_requested", "approved", "closed"]>>;
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ApplySuggestionParamsSchema = exports.ResolveCommentParamsSchema = exports.ReplyCommentParamsSchema = exports.GetReviewCommentsParamsSchema = exports.GetReviewParamsSchema = exports.ListReviewsParamsSchema = exports.RegisterGuestParamsSchema = exports.TmuxSessionIdSchema = exports.ActivityFinishResponseSchema = exports.ActivityFinishParamsSchema = exports.ActivityStartResponseSchema = exports.ActivityStartParamsSchema = exports.ChatListMembersResponseSchema = exports.ChatThreadMemberSchema = exports.ChatListMembersParamsSchema = exports.ChatReadHistoryResponseSchema = exports.ChatHistoryThreadSchema = exports.ChatHistoryMessageSchema = exports.ChatReadHistoryParamsSchema = exports.ChatAckParamsSchema = exports.SendMessageParamsSchema = exports.McpResourceRequestSchema = exports.McpToolCallSchema = exports.GetSkillParamsSchema = exports.getSkillSchema = exports.ListSkillsParamsSchema = exports.listSkillsSchema = exports.GetPromptParamsSchema = exports.UpdateEpicParamsSchema = exports.AddEpicCommentParamsSchema = exports.GetEpicByIdParamsSchema = exports.CreateEpicParamsSchema = exports.ListAssignedEpicsTasksParamsSchema = exports.ListEpicsParamsSchema = exports.ListStatusesParamsSchema = exports.GetAgentByNameParamsSchema = exports.ListAgentsParamsSchema = exports.ListPromptsParamsSchema = exports.UpdateDocumentParamsSchema = exports.CreateDocumentParamsSchema = exports.GetDocumentParamsSchema = exports.ListDocumentsParamsSchema = exports.RemoveTagsParamsSchema = exports.AddTagsParamsSchema = exports.ListRecordsParamsSchema = exports.GetRecordParamsSchema = exports.UpdateRecordParamsSchema = exports.CreateRecordParamsSchema = void 0;
3
+ exports.GetReviewParamsSchema = exports.ListReviewsParamsSchema = exports.DevchainTeamParamsSchema = exports.TeamsDeleteAgentParamsSchema = exports.TeamsCreateAgentParamsSchema = exports.TeamsConfigsListParamsSchema = exports.TeamsMembersListParamsSchema = exports.TeamsListParamsSchema = exports.RegisterGuestParamsSchema = exports.TmuxSessionIdSchema = exports.ActivityFinishResponseSchema = exports.ActivityFinishParamsSchema = exports.ActivityStartResponseSchema = exports.ActivityStartParamsSchema = exports.ChatListMembersResponseSchema = exports.ChatThreadMemberSchema = exports.ChatListMembersParamsSchema = exports.ChatReadHistoryResponseSchema = exports.ChatHistoryThreadSchema = exports.ChatHistoryMessageSchema = exports.ChatReadHistoryParamsSchema = exports.ChatAckParamsSchema = exports.SendMessageParamsSchema = exports.McpResourceRequestSchema = exports.McpToolCallSchema = exports.GetSkillParamsSchema = exports.getSkillSchema = exports.ListSkillsParamsSchema = exports.listSkillsSchema = exports.GetPromptParamsSchema = exports.UpdateEpicParamsSchema = exports.AddEpicCommentParamsSchema = exports.GetEpicByIdParamsSchema = exports.CreateEpicParamsSchema = exports.ListAssignedEpicsTasksParamsSchema = exports.ListEpicsParamsSchema = exports.ListStatusesParamsSchema = exports.GetAgentByNameParamsSchema = exports.ListAgentsParamsSchema = exports.ListPromptsParamsSchema = exports.UpdateDocumentParamsSchema = exports.CreateDocumentParamsSchema = exports.GetDocumentParamsSchema = exports.ListDocumentsParamsSchema = exports.RemoveTagsParamsSchema = exports.AddTagsParamsSchema = exports.ListRecordsParamsSchema = exports.GetRecordParamsSchema = exports.UpdateRecordParamsSchema = exports.CreateRecordParamsSchema = void 0;
4
+ exports.ApplySuggestionParamsSchema = exports.ResolveCommentParamsSchema = exports.ReplyCommentParamsSchema = exports.GetReviewCommentsParamsSchema = void 0;
4
5
  const zod_1 = require("zod");
5
6
  const skill_dto_1 = require("../../skills/dtos/skill.dto");
6
7
  const EpicIdPrefixSchema = zod_1.z
@@ -236,15 +237,35 @@ exports.SendMessageParamsSchema = zod_1.z
236
237
  .object({
237
238
  sessionId: zod_1.z.string().min(8),
238
239
  threadId: zod_1.z.string().uuid().optional(),
239
- recipientAgentNames: zod_1.z.array(zod_1.z.string().min(1)).optional(),
240
+ recipientAgentNames: zod_1.z.array(zod_1.z.string().min(1)).min(1).optional(),
241
+ teamName: zod_1.z.string().min(1).optional(),
240
242
  message: zod_1.z.string().min(1),
241
243
  recipient: zod_1.z.enum(['user', 'agents']).optional(),
242
244
  })
243
245
  .strict()
244
- .refine((v) => Boolean(v.threadId ||
245
- (v.recipientAgentNames && v.recipientAgentNames.length > 0) ||
246
- v.recipient === 'user'), {
247
- message: 'Provide threadId or recipientAgentNames to send a message',
246
+ .superRefine((v, ctx) => {
247
+ const hasRecipientAgentNames = Boolean(v.recipientAgentNames && v.recipientAgentNames.length > 0);
248
+ if (v.teamName && hasRecipientAgentNames) {
249
+ ctx.addIssue({
250
+ code: zod_1.z.ZodIssueCode.custom,
251
+ path: ['teamName'],
252
+ message: 'teamName and recipientAgentNames are mutually exclusive',
253
+ });
254
+ }
255
+ if (v.teamName && v.threadId) {
256
+ ctx.addIssue({
257
+ code: zod_1.z.ZodIssueCode.custom,
258
+ path: ['teamName'],
259
+ message: 'teamName cannot be combined with threadId in v1',
260
+ });
261
+ }
262
+ if (v.teamName && v.recipient === 'user') {
263
+ ctx.addIssue({
264
+ code: zod_1.z.ZodIssueCode.custom,
265
+ path: ['teamName'],
266
+ message: 'teamName cannot be combined with recipient: "user"',
267
+ });
268
+ }
248
269
  });
249
270
  exports.ChatAckParamsSchema = zod_1.z
250
271
  .object({
@@ -340,6 +361,48 @@ exports.RegisterGuestParamsSchema = zod_1.z
340
361
  description: zod_1.z.string().optional(),
341
362
  })
342
363
  .strict();
364
+ exports.TeamsListParamsSchema = zod_1.z
365
+ .object({
366
+ sessionId: zod_1.z.string().min(8),
367
+ q: zod_1.z.string().optional(),
368
+ limit: zod_1.z.number().int().positive().optional(),
369
+ offset: zod_1.z.number().int().nonnegative().optional(),
370
+ })
371
+ .strict();
372
+ exports.TeamsMembersListParamsSchema = zod_1.z
373
+ .object({
374
+ sessionId: zod_1.z.string().min(8),
375
+ teamId: zod_1.z.string().uuid().optional(),
376
+ })
377
+ .strict();
378
+ exports.TeamsConfigsListParamsSchema = zod_1.z
379
+ .object({
380
+ sessionId: zod_1.z.string().min(8),
381
+ })
382
+ .strict();
383
+ exports.TeamsCreateAgentParamsSchema = zod_1.z
384
+ .object({
385
+ sessionId: zod_1.z.string().min(8),
386
+ name: zod_1.z.string().trim().min(1, 'Name is required and must not be whitespace-only'),
387
+ description: zod_1.z.string().trim().min(1, 'Description must not be whitespace-only').optional(),
388
+ configName: zod_1.z.string().trim().min(1, 'configName is required and must not be whitespace-only'),
389
+ profileName: zod_1.z.string().trim().min(1, 'profileName must not be whitespace-only').optional(),
390
+ teamName: zod_1.z.string().trim().min(1, 'teamName must not be whitespace-only').optional(),
391
+ })
392
+ .strict();
393
+ exports.TeamsDeleteAgentParamsSchema = zod_1.z
394
+ .object({
395
+ sessionId: zod_1.z.string().min(8),
396
+ name: zod_1.z.string().trim().min(1, 'Name is required and must not be whitespace-only'),
397
+ teamName: zod_1.z.string().trim().min(1, 'teamName must not be whitespace-only').optional(),
398
+ })
399
+ .strict();
400
+ exports.DevchainTeamParamsSchema = zod_1.z
401
+ .object({
402
+ sessionId: zod_1.z.string().min(8),
403
+ teamName: zod_1.z.string().optional(),
404
+ })
405
+ .strict();
343
406
  exports.ListReviewsParamsSchema = zod_1.z
344
407
  .object({
345
408
  sessionId: zod_1.z.string().min(8),