agent-relay 2.0.22 → 2.0.24

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 (534) hide show
  1. package/bin/relay-pty-linux-arm64 +0 -0
  2. package/dist/src/cli/index.d.ts +3 -3
  3. package/dist/src/cli/index.js +58 -74
  4. package/package.json +21 -62
  5. package/packages/api-types/package.json +1 -1
  6. package/packages/bridge/package.json +8 -8
  7. package/packages/cli-tester/package.json +1 -1
  8. package/packages/config/package.json +2 -2
  9. package/packages/continuity/package.json +1 -1
  10. package/packages/daemon/dist/orchestrator.js +19 -1
  11. package/packages/daemon/package.json +12 -12
  12. package/packages/hooks/package.json +4 -4
  13. package/packages/mcp/package.json +2 -2
  14. package/packages/memory/package.json +2 -2
  15. package/packages/policy/package.json +2 -2
  16. package/packages/protocol/package.json +1 -1
  17. package/packages/resiliency/package.json +1 -1
  18. package/packages/sdk/package.json +2 -2
  19. package/packages/spawner/package.json +1 -1
  20. package/packages/state/package.json +1 -1
  21. package/packages/storage/package.json +2 -2
  22. package/packages/telemetry/package.json +1 -1
  23. package/packages/trajectory/package.json +2 -2
  24. package/packages/user-directory/package.json +2 -2
  25. package/packages/utils/dist/update-checker.js +4 -0
  26. package/packages/utils/package.json +1 -1
  27. package/packages/wrapper/package.json +6 -6
  28. package/deploy/init-db.sql +0 -5
  29. package/deploy/scripts/setup-fly-workspaces.sh +0 -69
  30. package/deploy/scripts/setup-railway.sh +0 -75
  31. package/deploy/workspace/codex.config.toml +0 -20
  32. package/deploy/workspace/entrypoint-browser.sh +0 -118
  33. package/deploy/workspace/entrypoint.sh +0 -612
  34. package/deploy/workspace/gh-credential-relay +0 -90
  35. package/deploy/workspace/gh-relay +0 -156
  36. package/deploy/workspace/git-credential-relay +0 -330
  37. package/deploy/workspace/git-credential-relay.test.sh +0 -230
  38. package/dist/dashboard/out/404.html +0 -1
  39. package/dist/dashboard/out/_next/static/91mkGYq3qbG8WHE6VytQ8/_buildManifest.js +0 -1
  40. package/dist/dashboard/out/_next/static/91mkGYq3qbG8WHE6VytQ8/_ssgManifest.js +0 -1
  41. package/dist/dashboard/out/_next/static/chunks/116-a883fca163f3a5bc.js +0 -1
  42. package/dist/dashboard/out/_next/static/chunks/117-c8afed19e821a35d.js +0 -2
  43. package/dist/dashboard/out/_next/static/chunks/282-980c2eb8fff20123.js +0 -1
  44. package/dist/dashboard/out/_next/static/chunks/320-a6304232cd0ee2ce.js +0 -1
  45. package/dist/dashboard/out/_next/static/chunks/532-bace199897eeab37.js +0 -9
  46. package/dist/dashboard/out/_next/static/chunks/631-16b905e5920f9b59.js +0 -1
  47. package/dist/dashboard/out/_next/static/chunks/648-acb2ff9f77cbfbd3.js +0 -1
  48. package/dist/dashboard/out/_next/static/chunks/766-2aea80818f7eb0d8.js +0 -1
  49. package/dist/dashboard/out/_next/static/chunks/83-26d2bde54616ee90.js +0 -1
  50. package/dist/dashboard/out/_next/static/chunks/847-f1f467060f32afff.js +0 -1
  51. package/dist/dashboard/out/_next/static/chunks/891-5cb1513eeb97a891.js +0 -1
  52. package/dist/dashboard/out/_next/static/chunks/app/_not-found/page-60501fddbafba9dc.js +0 -1
  53. package/dist/dashboard/out/_next/static/chunks/app/app/onboarding/page-9914652442f7e4fb.js +0 -1
  54. package/dist/dashboard/out/_next/static/chunks/app/app/page-366fb7c078d4e9e0.js +0 -1
  55. package/dist/dashboard/out/_next/static/chunks/app/cloud/link/page-fa1d5842aa90e8a6.js +0 -1
  56. package/dist/dashboard/out/_next/static/chunks/app/complete-profile/page-dd64bbdf66b639cd.js +0 -1
  57. package/dist/dashboard/out/_next/static/chunks/app/connect-repos/page-113060009ef35bc2.js +0 -1
  58. package/dist/dashboard/out/_next/static/chunks/app/history/page-9965d2483011b846.js +0 -1
  59. package/dist/dashboard/out/_next/static/chunks/app/layout-6b91e33784c20610.js +0 -1
  60. package/dist/dashboard/out/_next/static/chunks/app/login/page-435eceb0073be027.js +0 -1
  61. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-1e37ef8e73940b40.js +0 -1
  62. package/dist/dashboard/out/_next/static/chunks/app/page-8119d4246743574e.js +0 -1
  63. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-9db3ebdfa567a7c9.js +0 -1
  64. package/dist/dashboard/out/_next/static/chunks/app/providers/page-ecb16ffd3b36262b.js +0 -1
  65. package/dist/dashboard/out/_next/static/chunks/app/providers/setup/[provider]/page-4dbe33f0f7691b7c.js +0 -1
  66. package/dist/dashboard/out/_next/static/chunks/app/signup/page-c7a0a28341365ae0.js +0 -1
  67. package/dist/dashboard/out/_next/static/chunks/e868780c-48e5f147c90a3a41.js +0 -18
  68. package/dist/dashboard/out/_next/static/chunks/fd9d1056-609918ca7b6280bb.js +0 -1
  69. package/dist/dashboard/out/_next/static/chunks/framework-f66176bb897dc684.js +0 -1
  70. package/dist/dashboard/out/_next/static/chunks/main-311c3db74dcfadb7.js +0 -1
  71. package/dist/dashboard/out/_next/static/chunks/main-app-fdbeb09028f57c9f.js +0 -1
  72. package/dist/dashboard/out/_next/static/chunks/pages/_app-72b849fbd24ac258.js +0 -1
  73. package/dist/dashboard/out/_next/static/chunks/pages/_error-7ba65e1336b92748.js +0 -1
  74. package/dist/dashboard/out/_next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  75. package/dist/dashboard/out/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +0 -1
  76. package/dist/dashboard/out/_next/static/css/4034f236dd1a3178.css +0 -1
  77. package/dist/dashboard/out/_next/static/css/6892f8422896ef7a.css +0 -1
  78. package/dist/dashboard/out/alt-logos/agent-relay-logo-128.png +0 -0
  79. package/dist/dashboard/out/alt-logos/agent-relay-logo-256.png +0 -0
  80. package/dist/dashboard/out/alt-logos/agent-relay-logo-32.png +0 -0
  81. package/dist/dashboard/out/alt-logos/agent-relay-logo-512.png +0 -0
  82. package/dist/dashboard/out/alt-logos/agent-relay-logo-64.png +0 -0
  83. package/dist/dashboard/out/alt-logos/agent-relay-logo.svg +0 -45
  84. package/dist/dashboard/out/alt-logos/logo.svg +0 -38
  85. package/dist/dashboard/out/alt-logos/monogram-logo-128.png +0 -0
  86. package/dist/dashboard/out/alt-logos/monogram-logo-256.png +0 -0
  87. package/dist/dashboard/out/alt-logos/monogram-logo-32.png +0 -0
  88. package/dist/dashboard/out/alt-logos/monogram-logo-512.png +0 -0
  89. package/dist/dashboard/out/alt-logos/monogram-logo-64.png +0 -0
  90. package/dist/dashboard/out/alt-logos/monogram-logo.svg +0 -38
  91. package/dist/dashboard/out/app/onboarding.html +0 -1
  92. package/dist/dashboard/out/app/onboarding.txt +0 -7
  93. package/dist/dashboard/out/app.html +0 -1
  94. package/dist/dashboard/out/app.txt +0 -7
  95. package/dist/dashboard/out/apple-icon.png +0 -0
  96. package/dist/dashboard/out/cloud/link.html +0 -1
  97. package/dist/dashboard/out/cloud/link.txt +0 -7
  98. package/dist/dashboard/out/complete-profile.html +0 -5
  99. package/dist/dashboard/out/complete-profile.txt +0 -7
  100. package/dist/dashboard/out/connect-repos.html +0 -1
  101. package/dist/dashboard/out/connect-repos.txt +0 -7
  102. package/dist/dashboard/out/history.html +0 -1
  103. package/dist/dashboard/out/history.txt +0 -7
  104. package/dist/dashboard/out/index.html +0 -1
  105. package/dist/dashboard/out/index.txt +0 -7
  106. package/dist/dashboard/out/login.html +0 -5
  107. package/dist/dashboard/out/login.txt +0 -7
  108. package/dist/dashboard/out/metrics.html +0 -1
  109. package/dist/dashboard/out/metrics.txt +0 -7
  110. package/dist/dashboard/out/pricing.html +0 -13
  111. package/dist/dashboard/out/pricing.txt +0 -7
  112. package/dist/dashboard/out/providers/setup/claude.html +0 -1
  113. package/dist/dashboard/out/providers/setup/claude.txt +0 -8
  114. package/dist/dashboard/out/providers/setup/codex.html +0 -1
  115. package/dist/dashboard/out/providers/setup/codex.txt +0 -8
  116. package/dist/dashboard/out/providers/setup/cursor.html +0 -1
  117. package/dist/dashboard/out/providers/setup/cursor.txt +0 -8
  118. package/dist/dashboard/out/providers.html +0 -1
  119. package/dist/dashboard/out/providers.txt +0 -7
  120. package/dist/dashboard/out/signup.html +0 -6
  121. package/dist/dashboard/out/signup.txt +0 -7
  122. package/dist/src/cloud/index.d.ts +0 -8
  123. package/dist/src/cloud/index.js +0 -8
  124. package/dist/src/dashboard-server/index.d.ts +0 -8
  125. package/dist/src/dashboard-server/index.js +0 -8
  126. package/packages/cloud/dist/api/admin.d.ts +0 -8
  127. package/packages/cloud/dist/api/admin.js +0 -225
  128. package/packages/cloud/dist/api/auth.d.ts +0 -20
  129. package/packages/cloud/dist/api/auth.js +0 -138
  130. package/packages/cloud/dist/api/billing.d.ts +0 -7
  131. package/packages/cloud/dist/api/billing.js +0 -564
  132. package/packages/cloud/dist/api/cli-pty-runner.d.ts +0 -53
  133. package/packages/cloud/dist/api/cli-pty-runner.js +0 -175
  134. package/packages/cloud/dist/api/codex-auth-helper.d.ts +0 -21
  135. package/packages/cloud/dist/api/codex-auth-helper.js +0 -327
  136. package/packages/cloud/dist/api/consensus.d.ts +0 -13
  137. package/packages/cloud/dist/api/consensus.js +0 -261
  138. package/packages/cloud/dist/api/coordinators.d.ts +0 -8
  139. package/packages/cloud/dist/api/coordinators.js +0 -750
  140. package/packages/cloud/dist/api/daemons.d.ts +0 -12
  141. package/packages/cloud/dist/api/daemons.js +0 -535
  142. package/packages/cloud/dist/api/email-auth.d.ts +0 -11
  143. package/packages/cloud/dist/api/email-auth.js +0 -347
  144. package/packages/cloud/dist/api/generic-webhooks.d.ts +0 -8
  145. package/packages/cloud/dist/api/generic-webhooks.js +0 -129
  146. package/packages/cloud/dist/api/git.d.ts +0 -8
  147. package/packages/cloud/dist/api/git.js +0 -269
  148. package/packages/cloud/dist/api/github-app.d.ts +0 -11
  149. package/packages/cloud/dist/api/github-app.js +0 -223
  150. package/packages/cloud/dist/api/middleware/planLimits.d.ts +0 -43
  151. package/packages/cloud/dist/api/middleware/planLimits.js +0 -202
  152. package/packages/cloud/dist/api/monitoring.d.ts +0 -11
  153. package/packages/cloud/dist/api/monitoring.js +0 -578
  154. package/packages/cloud/dist/api/nango-auth.d.ts +0 -9
  155. package/packages/cloud/dist/api/nango-auth.js +0 -741
  156. package/packages/cloud/dist/api/onboarding.d.ts +0 -15
  157. package/packages/cloud/dist/api/onboarding.js +0 -679
  158. package/packages/cloud/dist/api/policy.d.ts +0 -8
  159. package/packages/cloud/dist/api/policy.js +0 -229
  160. package/packages/cloud/dist/api/provider-env.d.ts +0 -26
  161. package/packages/cloud/dist/api/provider-env.js +0 -141
  162. package/packages/cloud/dist/api/providers.d.ts +0 -7
  163. package/packages/cloud/dist/api/providers.js +0 -574
  164. package/packages/cloud/dist/api/repos.d.ts +0 -8
  165. package/packages/cloud/dist/api/repos.js +0 -577
  166. package/packages/cloud/dist/api/sessions.d.ts +0 -11
  167. package/packages/cloud/dist/api/sessions.js +0 -302
  168. package/packages/cloud/dist/api/teams.d.ts +0 -7
  169. package/packages/cloud/dist/api/teams.js +0 -281
  170. package/packages/cloud/dist/api/test-helpers.d.ts +0 -10
  171. package/packages/cloud/dist/api/test-helpers.js +0 -745
  172. package/packages/cloud/dist/api/usage.d.ts +0 -7
  173. package/packages/cloud/dist/api/usage.js +0 -111
  174. package/packages/cloud/dist/api/webhooks.d.ts +0 -8
  175. package/packages/cloud/dist/api/webhooks.js +0 -645
  176. package/packages/cloud/dist/api/workspaces.d.ts +0 -25
  177. package/packages/cloud/dist/api/workspaces.js +0 -1799
  178. package/packages/cloud/dist/billing/index.d.ts +0 -9
  179. package/packages/cloud/dist/billing/index.js +0 -9
  180. package/packages/cloud/dist/billing/plans.d.ts +0 -39
  181. package/packages/cloud/dist/billing/plans.js +0 -245
  182. package/packages/cloud/dist/billing/service.d.ts +0 -80
  183. package/packages/cloud/dist/billing/service.js +0 -388
  184. package/packages/cloud/dist/billing/types.d.ts +0 -141
  185. package/packages/cloud/dist/billing/types.js +0 -7
  186. package/packages/cloud/dist/config.d.ts +0 -5
  187. package/packages/cloud/dist/config.js +0 -5
  188. package/packages/cloud/dist/db/bulk-ingest.d.ts +0 -89
  189. package/packages/cloud/dist/db/bulk-ingest.js +0 -268
  190. package/packages/cloud/dist/db/drizzle.d.ts +0 -290
  191. package/packages/cloud/dist/db/drizzle.js +0 -1422
  192. package/packages/cloud/dist/db/index.d.ts +0 -56
  193. package/packages/cloud/dist/db/index.js +0 -70
  194. package/packages/cloud/dist/db/schema.d.ts +0 -5117
  195. package/packages/cloud/dist/db/schema.js +0 -656
  196. package/packages/cloud/dist/index.d.ts +0 -11
  197. package/packages/cloud/dist/index.js +0 -38
  198. package/packages/cloud/dist/provisioner/index.d.ts +0 -207
  199. package/packages/cloud/dist/provisioner/index.js +0 -2118
  200. package/packages/cloud/dist/server.d.ts +0 -17
  201. package/packages/cloud/dist/server.js +0 -2034
  202. package/packages/cloud/dist/services/auto-scaler.d.ts +0 -152
  203. package/packages/cloud/dist/services/auto-scaler.js +0 -439
  204. package/packages/cloud/dist/services/capacity-manager.d.ts +0 -148
  205. package/packages/cloud/dist/services/capacity-manager.js +0 -449
  206. package/packages/cloud/dist/services/ci-agent-spawner.d.ts +0 -49
  207. package/packages/cloud/dist/services/ci-agent-spawner.js +0 -373
  208. package/packages/cloud/dist/services/cloud-message-bus.d.ts +0 -28
  209. package/packages/cloud/dist/services/cloud-message-bus.js +0 -19
  210. package/packages/cloud/dist/services/compute-enforcement.d.ts +0 -57
  211. package/packages/cloud/dist/services/compute-enforcement.js +0 -175
  212. package/packages/cloud/dist/services/coordinator.d.ts +0 -62
  213. package/packages/cloud/dist/services/coordinator.js +0 -389
  214. package/packages/cloud/dist/services/index.d.ts +0 -17
  215. package/packages/cloud/dist/services/index.js +0 -25
  216. package/packages/cloud/dist/services/intro-expiration.d.ts +0 -60
  217. package/packages/cloud/dist/services/intro-expiration.js +0 -252
  218. package/packages/cloud/dist/services/mention-handler.d.ts +0 -65
  219. package/packages/cloud/dist/services/mention-handler.js +0 -405
  220. package/packages/cloud/dist/services/nango.d.ts +0 -219
  221. package/packages/cloud/dist/services/nango.js +0 -424
  222. package/packages/cloud/dist/services/persistence.d.ts +0 -131
  223. package/packages/cloud/dist/services/persistence.js +0 -200
  224. package/packages/cloud/dist/services/planLimits.d.ts +0 -147
  225. package/packages/cloud/dist/services/planLimits.js +0 -335
  226. package/packages/cloud/dist/services/presence-registry.d.ts +0 -56
  227. package/packages/cloud/dist/services/presence-registry.js +0 -91
  228. package/packages/cloud/dist/services/scaling-orchestrator.d.ts +0 -159
  229. package/packages/cloud/dist/services/scaling-orchestrator.js +0 -502
  230. package/packages/cloud/dist/services/scaling-policy.d.ts +0 -121
  231. package/packages/cloud/dist/services/scaling-policy.js +0 -415
  232. package/packages/cloud/dist/services/ssh-security.d.ts +0 -31
  233. package/packages/cloud/dist/services/ssh-security.js +0 -63
  234. package/packages/cloud/dist/services/workspace-keepalive.d.ts +0 -76
  235. package/packages/cloud/dist/services/workspace-keepalive.js +0 -234
  236. package/packages/cloud/dist/shims/consensus.d.ts +0 -23
  237. package/packages/cloud/dist/shims/consensus.js +0 -5
  238. package/packages/cloud/dist/webhooks/index.d.ts +0 -24
  239. package/packages/cloud/dist/webhooks/index.js +0 -29
  240. package/packages/cloud/dist/webhooks/parsers/github.d.ts +0 -8
  241. package/packages/cloud/dist/webhooks/parsers/github.js +0 -234
  242. package/packages/cloud/dist/webhooks/parsers/index.d.ts +0 -23
  243. package/packages/cloud/dist/webhooks/parsers/index.js +0 -30
  244. package/packages/cloud/dist/webhooks/parsers/linear.d.ts +0 -9
  245. package/packages/cloud/dist/webhooks/parsers/linear.js +0 -258
  246. package/packages/cloud/dist/webhooks/parsers/slack.d.ts +0 -9
  247. package/packages/cloud/dist/webhooks/parsers/slack.js +0 -214
  248. package/packages/cloud/dist/webhooks/responders/github.d.ts +0 -8
  249. package/packages/cloud/dist/webhooks/responders/github.js +0 -73
  250. package/packages/cloud/dist/webhooks/responders/index.d.ts +0 -23
  251. package/packages/cloud/dist/webhooks/responders/index.js +0 -30
  252. package/packages/cloud/dist/webhooks/responders/linear.d.ts +0 -9
  253. package/packages/cloud/dist/webhooks/responders/linear.js +0 -149
  254. package/packages/cloud/dist/webhooks/responders/slack.d.ts +0 -20
  255. package/packages/cloud/dist/webhooks/responders/slack.js +0 -178
  256. package/packages/cloud/dist/webhooks/router.d.ts +0 -25
  257. package/packages/cloud/dist/webhooks/router.js +0 -504
  258. package/packages/cloud/dist/webhooks/rules-engine.d.ts +0 -24
  259. package/packages/cloud/dist/webhooks/rules-engine.js +0 -287
  260. package/packages/cloud/dist/webhooks/types.d.ts +0 -186
  261. package/packages/cloud/dist/webhooks/types.js +0 -8
  262. package/packages/cloud/package.json +0 -60
  263. package/packages/dashboard/README.md +0 -48
  264. package/packages/dashboard/dist/health-worker-manager.d.ts +0 -62
  265. package/packages/dashboard/dist/health-worker-manager.js +0 -144
  266. package/packages/dashboard/dist/health-worker.d.ts +0 -9
  267. package/packages/dashboard/dist/health-worker.js +0 -79
  268. package/packages/dashboard/dist/index.d.ts +0 -20
  269. package/packages/dashboard/dist/index.js +0 -19
  270. package/packages/dashboard/dist/metrics.d.ts +0 -105
  271. package/packages/dashboard/dist/metrics.js +0 -193
  272. package/packages/dashboard/dist/needs-attention.d.ts +0 -24
  273. package/packages/dashboard/dist/needs-attention.js +0 -78
  274. package/packages/dashboard/dist/server.d.ts +0 -25
  275. package/packages/dashboard/dist/server.js +0 -5270
  276. package/packages/dashboard/dist/start.d.ts +0 -6
  277. package/packages/dashboard/dist/start.js +0 -13
  278. package/packages/dashboard/dist/types/threading.d.ts +0 -8
  279. package/packages/dashboard/dist/types/threading.js +0 -2
  280. package/packages/dashboard/dist/user-bridge.d.ts +0 -154
  281. package/packages/dashboard/dist/user-bridge.js +0 -372
  282. package/packages/dashboard/package.json +0 -65
  283. package/packages/dashboard/ui/app/app/onboarding/page.tsx +0 -394
  284. package/packages/dashboard/ui/app/app/page.tsx +0 -667
  285. package/packages/dashboard/ui/app/apple-icon.png +0 -0
  286. package/packages/dashboard/ui/app/cloud/link/page.tsx +0 -464
  287. package/packages/dashboard/ui/app/complete-profile/page.tsx +0 -204
  288. package/packages/dashboard/ui/app/connect-repos/page.tsx +0 -410
  289. package/packages/dashboard/ui/app/favicon.png +0 -0
  290. package/packages/dashboard/ui/app/globals.css +0 -59
  291. package/packages/dashboard/ui/app/history/page.tsx +0 -658
  292. package/packages/dashboard/ui/app/layout.tsx +0 -25
  293. package/packages/dashboard/ui/app/login/page.tsx +0 -424
  294. package/packages/dashboard/ui/app/metrics/page.tsx +0 -751
  295. package/packages/dashboard/ui/app/page.tsx +0 -59
  296. package/packages/dashboard/ui/app/pricing/page.tsx +0 -7
  297. package/packages/dashboard/ui/app/providers/page.tsx +0 -193
  298. package/packages/dashboard/ui/app/providers/setup/[provider]/ProviderSetupClient.tsx +0 -148
  299. package/packages/dashboard/ui/app/providers/setup/[provider]/constants.ts +0 -35
  300. package/packages/dashboard/ui/app/providers/setup/[provider]/page.tsx +0 -42
  301. package/packages/dashboard/ui/app/signup/page.tsx +0 -533
  302. package/packages/dashboard/ui/index.ts +0 -49
  303. package/packages/dashboard/ui/landing/LandingPage.tsx +0 -713
  304. package/packages/dashboard/ui/landing/PricingPage.tsx +0 -559
  305. package/packages/dashboard/ui/landing/index.ts +0 -6
  306. package/packages/dashboard/ui/landing/styles.css +0 -2850
  307. package/packages/dashboard/ui/lib/agent-merge.ts +0 -35
  308. package/packages/dashboard/ui/lib/api.ts +0 -1155
  309. package/packages/dashboard/ui/lib/cloudApi.ts +0 -877
  310. package/packages/dashboard/ui/lib/colors.ts +0 -218
  311. package/packages/dashboard/ui/lib/hierarchy.ts +0 -242
  312. package/packages/dashboard/ui/lib/stuckDetection.ts +0 -142
  313. package/packages/dashboard/ui/next-env.d.ts +0 -5
  314. package/packages/dashboard/ui/next.config.js +0 -41
  315. package/packages/dashboard/ui/package-lock.json +0 -2882
  316. package/packages/dashboard/ui/package.json +0 -33
  317. package/packages/dashboard/ui/postcss.config.js +0 -5
  318. package/packages/dashboard/ui/react-components/ActivityFeed.tsx +0 -216
  319. package/packages/dashboard/ui/react-components/AddWorkspaceModal.tsx +0 -170
  320. package/packages/dashboard/ui/react-components/AgentCard.tsx +0 -587
  321. package/packages/dashboard/ui/react-components/AgentList.tsx +0 -411
  322. package/packages/dashboard/ui/react-components/AgentProfilePanel.tsx +0 -564
  323. package/packages/dashboard/ui/react-components/App.tsx +0 -3033
  324. package/packages/dashboard/ui/react-components/BillingPanel.tsx +0 -922
  325. package/packages/dashboard/ui/react-components/BillingResult.tsx +0 -447
  326. package/packages/dashboard/ui/react-components/BroadcastComposer.tsx +0 -690
  327. package/packages/dashboard/ui/react-components/ChannelAdminPanel.tsx +0 -773
  328. package/packages/dashboard/ui/react-components/ChannelBrowser.tsx +0 -385
  329. package/packages/dashboard/ui/react-components/ChannelChat.tsx +0 -261
  330. package/packages/dashboard/ui/react-components/ChannelSidebar.tsx +0 -399
  331. package/packages/dashboard/ui/react-components/CloudSessionProvider.tsx +0 -130
  332. package/packages/dashboard/ui/react-components/CommandPalette.tsx +0 -815
  333. package/packages/dashboard/ui/react-components/ConfirmationDialog.tsx +0 -133
  334. package/packages/dashboard/ui/react-components/ConversationHistory.tsx +0 -518
  335. package/packages/dashboard/ui/react-components/CoordinatorPanel.tsx +0 -944
  336. package/packages/dashboard/ui/react-components/DecisionQueue.tsx +0 -717
  337. package/packages/dashboard/ui/react-components/DirectMessageView.tsx +0 -164
  338. package/packages/dashboard/ui/react-components/FileAutocomplete.tsx +0 -368
  339. package/packages/dashboard/ui/react-components/FleetOverview.tsx +0 -278
  340. package/packages/dashboard/ui/react-components/LogViewer.tsx +0 -310
  341. package/packages/dashboard/ui/react-components/LogViewerPanel.tsx +0 -482
  342. package/packages/dashboard/ui/react-components/Logo.tsx +0 -284
  343. package/packages/dashboard/ui/react-components/MentionAutocomplete.tsx +0 -384
  344. package/packages/dashboard/ui/react-components/MessageComposer.tsx +0 -457
  345. package/packages/dashboard/ui/react-components/MessageList.tsx +0 -649
  346. package/packages/dashboard/ui/react-components/MessageSenderName.tsx +0 -91
  347. package/packages/dashboard/ui/react-components/MessageStatusIndicator.tsx +0 -142
  348. package/packages/dashboard/ui/react-components/NewConversationModal.tsx +0 -400
  349. package/packages/dashboard/ui/react-components/NotificationToast.tsx +0 -488
  350. package/packages/dashboard/ui/react-components/OnlineUsersIndicator.tsx +0 -164
  351. package/packages/dashboard/ui/react-components/Pagination.tsx +0 -124
  352. package/packages/dashboard/ui/react-components/PricingPlans.tsx +0 -386
  353. package/packages/dashboard/ui/react-components/ProjectList.tsx +0 -625
  354. package/packages/dashboard/ui/react-components/ProviderAuthFlow.tsx +0 -853
  355. package/packages/dashboard/ui/react-components/ProviderConnectionList.tsx +0 -378
  356. package/packages/dashboard/ui/react-components/ProvisioningProgress.tsx +0 -730
  357. package/packages/dashboard/ui/react-components/RepoAccessPanel.tsx +0 -549
  358. package/packages/dashboard/ui/react-components/ServerCard.tsx +0 -202
  359. package/packages/dashboard/ui/react-components/SessionExpiredModal.tsx +0 -128
  360. package/packages/dashboard/ui/react-components/SpawnModal.tsx +0 -804
  361. package/packages/dashboard/ui/react-components/TaskAssignmentUI.tsx +0 -375
  362. package/packages/dashboard/ui/react-components/TerminalProviderSetup.tsx +0 -608
  363. package/packages/dashboard/ui/react-components/ThemeProvider.tsx +0 -325
  364. package/packages/dashboard/ui/react-components/ThinkingIndicator.tsx +0 -231
  365. package/packages/dashboard/ui/react-components/ThreadList.tsx +0 -198
  366. package/packages/dashboard/ui/react-components/ThreadPanel.tsx +0 -346
  367. package/packages/dashboard/ui/react-components/TrajectoryViewer.tsx +0 -698
  368. package/packages/dashboard/ui/react-components/TypingIndicator.tsx +0 -69
  369. package/packages/dashboard/ui/react-components/UsageBanner.tsx +0 -231
  370. package/packages/dashboard/ui/react-components/UserProfilePanel.tsx +0 -233
  371. package/packages/dashboard/ui/react-components/WorkspaceContext.tsx +0 -107
  372. package/packages/dashboard/ui/react-components/WorkspaceSelector.tsx +0 -234
  373. package/packages/dashboard/ui/react-components/WorkspaceStatusIndicator.tsx +0 -370
  374. package/packages/dashboard/ui/react-components/XTermInteractive.tsx +0 -510
  375. package/packages/dashboard/ui/react-components/XTermLogViewer.tsx +0 -719
  376. package/packages/dashboard/ui/react-components/channels/ChannelDialogs.tsx +0 -1411
  377. package/packages/dashboard/ui/react-components/channels/ChannelHeader.tsx +0 -317
  378. package/packages/dashboard/ui/react-components/channels/ChannelMessageList.tsx +0 -463
  379. package/packages/dashboard/ui/react-components/channels/ChannelViewV1.tsx +0 -146
  380. package/packages/dashboard/ui/react-components/channels/MessageInput.tsx +0 -288
  381. package/packages/dashboard/ui/react-components/channels/SearchInput.tsx +0 -172
  382. package/packages/dashboard/ui/react-components/channels/SearchResults.tsx +0 -336
  383. package/packages/dashboard/ui/react-components/channels/api.ts +0 -697
  384. package/packages/dashboard/ui/react-components/channels/index.ts +0 -76
  385. package/packages/dashboard/ui/react-components/channels/mockApi.ts +0 -344
  386. package/packages/dashboard/ui/react-components/channels/types.ts +0 -566
  387. package/packages/dashboard/ui/react-components/hooks/index.ts +0 -57
  388. package/packages/dashboard/ui/react-components/hooks/useAgentLogs.ts +0 -394
  389. package/packages/dashboard/ui/react-components/hooks/useAgents.ts +0 -127
  390. package/packages/dashboard/ui/react-components/hooks/useBroadcastDedup.ts +0 -86
  391. package/packages/dashboard/ui/react-components/hooks/useChannelAdmin.ts +0 -329
  392. package/packages/dashboard/ui/react-components/hooks/useChannelBrowser.ts +0 -239
  393. package/packages/dashboard/ui/react-components/hooks/useChannelCommands.ts +0 -138
  394. package/packages/dashboard/ui/react-components/hooks/useChannels.ts +0 -328
  395. package/packages/dashboard/ui/react-components/hooks/useDebounce.ts +0 -29
  396. package/packages/dashboard/ui/react-components/hooks/useDirectMessage.ts +0 -141
  397. package/packages/dashboard/ui/react-components/hooks/useMessages.ts +0 -309
  398. package/packages/dashboard/ui/react-components/hooks/useOrchestrator.ts +0 -364
  399. package/packages/dashboard/ui/react-components/hooks/usePinnedAgents.ts +0 -140
  400. package/packages/dashboard/ui/react-components/hooks/usePresence.ts +0 -340
  401. package/packages/dashboard/ui/react-components/hooks/useRecentRepos.ts +0 -130
  402. package/packages/dashboard/ui/react-components/hooks/useSession.ts +0 -209
  403. package/packages/dashboard/ui/react-components/hooks/useTrajectory.ts +0 -265
  404. package/packages/dashboard/ui/react-components/hooks/useWebSocket.ts +0 -169
  405. package/packages/dashboard/ui/react-components/hooks/useWorkspaceMembers.ts +0 -120
  406. package/packages/dashboard/ui/react-components/hooks/useWorkspaceRepos.ts +0 -73
  407. package/packages/dashboard/ui/react-components/hooks/useWorkspaceStatus.ts +0 -237
  408. package/packages/dashboard/ui/react-components/index.ts +0 -81
  409. package/packages/dashboard/ui/react-components/layout/Header.tsx +0 -355
  410. package/packages/dashboard/ui/react-components/layout/RepoContextHeader.tsx +0 -361
  411. package/packages/dashboard/ui/react-components/layout/Sidebar.archive.test.tsx +0 -126
  412. package/packages/dashboard/ui/react-components/layout/Sidebar.test.tsx +0 -691
  413. package/packages/dashboard/ui/react-components/layout/Sidebar.tsx +0 -930
  414. package/packages/dashboard/ui/react-components/layout/index.ts +0 -7
  415. package/packages/dashboard/ui/react-components/settings/BillingSettingsPanel.tsx +0 -564
  416. package/packages/dashboard/ui/react-components/settings/SettingsPage.tsx +0 -544
  417. package/packages/dashboard/ui/react-components/settings/TeamSettingsPanel.tsx +0 -560
  418. package/packages/dashboard/ui/react-components/settings/WorkspaceSettingsPanel.tsx +0 -1386
  419. package/packages/dashboard/ui/react-components/settings/index.ts +0 -11
  420. package/packages/dashboard/ui/react-components/settings/types.ts +0 -53
  421. package/packages/dashboard/ui/react-components/utils/messageFormatting.tsx +0 -370
  422. package/packages/dashboard/ui/tailwind.config.js +0 -148
  423. package/packages/dashboard/ui/types/index.ts +0 -304
  424. package/packages/dashboard/ui/types/threading.ts +0 -7
  425. package/packages/dashboard/ui-dist/404.html +0 -1
  426. package/packages/dashboard/ui-dist/_next/static/91mkGYq3qbG8WHE6VytQ8/_buildManifest.js +0 -1
  427. package/packages/dashboard/ui-dist/_next/static/91mkGYq3qbG8WHE6VytQ8/_ssgManifest.js +0 -1
  428. package/packages/dashboard/ui-dist/_next/static/T2rV14eEU5OweDeV29SvG/_buildManifest.js +0 -1
  429. package/packages/dashboard/ui-dist/_next/static/T2rV14eEU5OweDeV29SvG/_ssgManifest.js +0 -1
  430. package/packages/dashboard/ui-dist/_next/static/chunks/116-a883fca163f3a5bc.js +0 -1
  431. package/packages/dashboard/ui-dist/_next/static/chunks/117-c8afed19e821a35d.js +0 -2
  432. package/packages/dashboard/ui-dist/_next/static/chunks/282-980c2eb8fff20123.js +0 -1
  433. package/packages/dashboard/ui-dist/_next/static/chunks/320-a6304232cd0ee2ce.js +0 -1
  434. package/packages/dashboard/ui-dist/_next/static/chunks/532-bace199897eeab37.js +0 -9
  435. package/packages/dashboard/ui-dist/_next/static/chunks/631-16b905e5920f9b59.js +0 -1
  436. package/packages/dashboard/ui-dist/_next/static/chunks/648-acb2ff9f77cbfbd3.js +0 -1
  437. package/packages/dashboard/ui-dist/_next/static/chunks/766-2aea80818f7eb0d8.js +0 -1
  438. package/packages/dashboard/ui-dist/_next/static/chunks/83-26d2bde54616ee90.js +0 -1
  439. package/packages/dashboard/ui-dist/_next/static/chunks/847-f1f467060f32afff.js +0 -1
  440. package/packages/dashboard/ui-dist/_next/static/chunks/891-5cb1513eeb97a891.js +0 -1
  441. package/packages/dashboard/ui-dist/_next/static/chunks/app/_not-found/page-60501fddbafba9dc.js +0 -1
  442. package/packages/dashboard/ui-dist/_next/static/chunks/app/app/onboarding/page-9914652442f7e4fb.js +0 -1
  443. package/packages/dashboard/ui-dist/_next/static/chunks/app/app/page-366fb7c078d4e9e0.js +0 -1
  444. package/packages/dashboard/ui-dist/_next/static/chunks/app/cloud/link/page-fa1d5842aa90e8a6.js +0 -1
  445. package/packages/dashboard/ui-dist/_next/static/chunks/app/complete-profile/page-dd64bbdf66b639cd.js +0 -1
  446. package/packages/dashboard/ui-dist/_next/static/chunks/app/connect-repos/page-113060009ef35bc2.js +0 -1
  447. package/packages/dashboard/ui-dist/_next/static/chunks/app/history/page-9965d2483011b846.js +0 -1
  448. package/packages/dashboard/ui-dist/_next/static/chunks/app/layout-6b91e33784c20610.js +0 -1
  449. package/packages/dashboard/ui-dist/_next/static/chunks/app/login/page-435eceb0073be027.js +0 -1
  450. package/packages/dashboard/ui-dist/_next/static/chunks/app/metrics/page-1e37ef8e73940b40.js +0 -1
  451. package/packages/dashboard/ui-dist/_next/static/chunks/app/page-8119d4246743574e.js +0 -1
  452. package/packages/dashboard/ui-dist/_next/static/chunks/app/pricing/page-9db3ebdfa567a7c9.js +0 -1
  453. package/packages/dashboard/ui-dist/_next/static/chunks/app/providers/page-ecb16ffd3b36262b.js +0 -1
  454. package/packages/dashboard/ui-dist/_next/static/chunks/app/providers/setup/[provider]/page-4dbe33f0f7691b7c.js +0 -1
  455. package/packages/dashboard/ui-dist/_next/static/chunks/app/signup/page-c7a0a28341365ae0.js +0 -1
  456. package/packages/dashboard/ui-dist/_next/static/chunks/e868780c-48e5f147c90a3a41.js +0 -18
  457. package/packages/dashboard/ui-dist/_next/static/chunks/fd9d1056-609918ca7b6280bb.js +0 -1
  458. package/packages/dashboard/ui-dist/_next/static/chunks/framework-f66176bb897dc684.js +0 -1
  459. package/packages/dashboard/ui-dist/_next/static/chunks/main-311c3db74dcfadb7.js +0 -1
  460. package/packages/dashboard/ui-dist/_next/static/chunks/main-app-fdbeb09028f57c9f.js +0 -1
  461. package/packages/dashboard/ui-dist/_next/static/chunks/pages/_app-72b849fbd24ac258.js +0 -1
  462. package/packages/dashboard/ui-dist/_next/static/chunks/pages/_error-7ba65e1336b92748.js +0 -1
  463. package/packages/dashboard/ui-dist/_next/static/chunks/polyfills-42372ed130431b0a.js +0 -1
  464. package/packages/dashboard/ui-dist/_next/static/chunks/webpack-1cdd8ed57114d5e1.js +0 -1
  465. package/packages/dashboard/ui-dist/_next/static/css/4034f236dd1a3178.css +0 -1
  466. package/packages/dashboard/ui-dist/_next/static/css/6892f8422896ef7a.css +0 -1
  467. package/packages/dashboard/ui-dist/_next/static/l8L2OscDSR2vsMIlWcC48/_buildManifest.js +0 -1
  468. package/packages/dashboard/ui-dist/_next/static/l8L2OscDSR2vsMIlWcC48/_ssgManifest.js +0 -1
  469. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-128.png +0 -0
  470. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-256.png +0 -0
  471. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-32.png +0 -0
  472. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-512.png +0 -0
  473. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo-64.png +0 -0
  474. package/packages/dashboard/ui-dist/alt-logos/agent-relay-logo.svg +0 -45
  475. package/packages/dashboard/ui-dist/alt-logos/logo.svg +0 -38
  476. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-128.png +0 -0
  477. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-256.png +0 -0
  478. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-32.png +0 -0
  479. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-512.png +0 -0
  480. package/packages/dashboard/ui-dist/alt-logos/monogram-logo-64.png +0 -0
  481. package/packages/dashboard/ui-dist/alt-logos/monogram-logo.svg +0 -38
  482. package/packages/dashboard/ui-dist/app/onboarding.html +0 -1
  483. package/packages/dashboard/ui-dist/app/onboarding.txt +0 -7
  484. package/packages/dashboard/ui-dist/app.html +0 -1
  485. package/packages/dashboard/ui-dist/app.txt +0 -7
  486. package/packages/dashboard/ui-dist/apple-icon.png +0 -0
  487. package/packages/dashboard/ui-dist/cloud/link.html +0 -1
  488. package/packages/dashboard/ui-dist/cloud/link.txt +0 -7
  489. package/packages/dashboard/ui-dist/complete-profile.html +0 -5
  490. package/packages/dashboard/ui-dist/complete-profile.txt +0 -7
  491. package/packages/dashboard/ui-dist/connect-repos.html +0 -1
  492. package/packages/dashboard/ui-dist/connect-repos.txt +0 -7
  493. package/packages/dashboard/ui-dist/history.html +0 -1
  494. package/packages/dashboard/ui-dist/history.txt +0 -7
  495. package/packages/dashboard/ui-dist/index.html +0 -1
  496. package/packages/dashboard/ui-dist/index.txt +0 -7
  497. package/packages/dashboard/ui-dist/login.html +0 -5
  498. package/packages/dashboard/ui-dist/login.txt +0 -7
  499. package/packages/dashboard/ui-dist/metrics.html +0 -1
  500. package/packages/dashboard/ui-dist/metrics.txt +0 -7
  501. package/packages/dashboard/ui-dist/pricing.html +0 -13
  502. package/packages/dashboard/ui-dist/pricing.txt +0 -7
  503. package/packages/dashboard/ui-dist/providers/setup/claude.html +0 -1
  504. package/packages/dashboard/ui-dist/providers/setup/claude.txt +0 -8
  505. package/packages/dashboard/ui-dist/providers/setup/codex.html +0 -1
  506. package/packages/dashboard/ui-dist/providers/setup/codex.txt +0 -8
  507. package/packages/dashboard/ui-dist/providers/setup/cursor.html +0 -1
  508. package/packages/dashboard/ui-dist/providers/setup/cursor.txt +0 -8
  509. package/packages/dashboard/ui-dist/providers.html +0 -1
  510. package/packages/dashboard/ui-dist/providers.txt +0 -7
  511. package/packages/dashboard/ui-dist/signup.html +0 -6
  512. package/packages/dashboard/ui-dist/signup.txt +0 -7
  513. package/packages/dashboard-server/dist/health-worker-manager.d.ts +0 -62
  514. package/packages/dashboard-server/dist/health-worker-manager.js +0 -144
  515. package/packages/dashboard-server/dist/health-worker.d.ts +0 -9
  516. package/packages/dashboard-server/dist/health-worker.js +0 -79
  517. package/packages/dashboard-server/dist/index.d.ts +0 -18
  518. package/packages/dashboard-server/dist/index.js +0 -17
  519. package/packages/dashboard-server/dist/metrics.d.ts +0 -105
  520. package/packages/dashboard-server/dist/metrics.js +0 -193
  521. package/packages/dashboard-server/dist/needs-attention.d.ts +0 -24
  522. package/packages/dashboard-server/dist/needs-attention.js +0 -78
  523. package/packages/dashboard-server/dist/server.d.ts +0 -25
  524. package/packages/dashboard-server/dist/server.js +0 -5158
  525. package/packages/dashboard-server/dist/start.d.ts +0 -6
  526. package/packages/dashboard-server/dist/start.js +0 -13
  527. package/packages/dashboard-server/dist/types/threading.d.ts +0 -8
  528. package/packages/dashboard-server/dist/types/threading.js +0 -2
  529. package/packages/dashboard-server/dist/user-bridge.d.ts +0 -158
  530. package/packages/dashboard-server/dist/user-bridge.js +0 -390
  531. package/packages/dashboard-server/package.json +0 -55
  532. package/scripts/run-migrations.js +0 -43
  533. package/scripts/setup-stripe-products.ts +0 -312
  534. package/scripts/verify-schema.js +0 -134
@@ -1,750 +0,0 @@
1
- /**
2
- * Coordinator Agent API Routes
3
- *
4
- * Manage coordinator agents for project groups.
5
- * Coordinators oversee and orchestrate work across repositories in a group.
6
- */
7
- import { Router } from 'express';
8
- import { requireAuth } from './auth.js';
9
- import { checkCoordinatorAccess } from './middleware/planLimits.js';
10
- import { db } from '../db/index.js';
11
- import { getCoordinatorService, sendToWorkspace, broadcastToGroup, routeToCoordinator, getActiveCoordinators, } from '../services/coordinator.js';
12
- export const coordinatorsRouter = Router();
13
- // All routes require authentication
14
- coordinatorsRouter.use(requireAuth);
15
- // Coordinator modification routes require Pro plan or higher
16
- const coordinatorWriteRoutes = [
17
- '/:groupId/coordinator/enable',
18
- '/:groupId/coordinator/disable',
19
- ];
20
- coordinatorWriteRoutes.forEach(route => {
21
- coordinatorsRouter.use(route, checkCoordinatorAccess);
22
- });
23
- // ============================================================================
24
- // Project Group CRUD Routes
25
- // These must come BEFORE the /:groupId/coordinator routes
26
- // ============================================================================
27
- /**
28
- * GET /api/project-groups
29
- * List all project groups for the authenticated user
30
- */
31
- coordinatorsRouter.get('/', async (req, res) => {
32
- const userId = req.session.userId;
33
- try {
34
- const result = await db.projectGroups.findAllWithRepositories(userId);
35
- res.json({
36
- groups: result.groups.map(group => ({
37
- id: group.id,
38
- name: group.name,
39
- description: group.description,
40
- color: group.color,
41
- icon: group.icon,
42
- coordinatorAgent: group.coordinatorAgent,
43
- sortOrder: group.sortOrder,
44
- repositoryCount: group.repositories.length,
45
- repositories: group.repositories.map(repo => ({
46
- id: repo.id,
47
- githubFullName: repo.githubFullName,
48
- defaultBranch: repo.defaultBranch,
49
- isPrivate: repo.isPrivate,
50
- })),
51
- createdAt: group.createdAt,
52
- updatedAt: group.updatedAt,
53
- })),
54
- ungroupedRepositories: result.ungroupedRepositories.map(repo => ({
55
- id: repo.id,
56
- githubFullName: repo.githubFullName,
57
- defaultBranch: repo.defaultBranch,
58
- isPrivate: repo.isPrivate,
59
- workspaceId: repo.workspaceId,
60
- })),
61
- });
62
- }
63
- catch (error) {
64
- console.error('Error listing project groups:', error);
65
- res.status(500).json({ error: 'Failed to list project groups' });
66
- }
67
- });
68
- /**
69
- * POST /api/project-groups
70
- * Create a new project group
71
- */
72
- coordinatorsRouter.post('/', async (req, res) => {
73
- const userId = req.session.userId;
74
- const { name, description, color, icon, repositoryIds } = req.body;
75
- if (!name || typeof name !== 'string' || name.trim().length === 0) {
76
- return res.status(400).json({ error: 'Name is required' });
77
- }
78
- if (name.length > 255) {
79
- return res.status(400).json({ error: 'Name must be 255 characters or less' });
80
- }
81
- try {
82
- // Check for duplicate name
83
- const existing = await db.projectGroups.findByName(userId, name.trim());
84
- if (existing) {
85
- return res.status(409).json({ error: 'A project group with this name already exists' });
86
- }
87
- // Create the group
88
- const group = await db.projectGroups.create({
89
- userId,
90
- name: name.trim(),
91
- description: description?.trim() || null,
92
- color: color || null,
93
- icon: icon || null,
94
- coordinatorAgent: { enabled: false },
95
- sortOrder: 0,
96
- });
97
- // Assign repositories to the group if provided
98
- if (repositoryIds && Array.isArray(repositoryIds) && repositoryIds.length > 0) {
99
- // Verify all repositories belong to the user
100
- const userRepos = await db.repositories.findByUserId(userId);
101
- const userRepoIds = new Set(userRepos.map(r => r.id));
102
- for (const repoId of repositoryIds) {
103
- if (!userRepoIds.has(repoId)) {
104
- return res.status(400).json({
105
- error: `Repository ${repoId} not found or not owned by user`,
106
- });
107
- }
108
- }
109
- // Assign repositories to the group
110
- for (const repoId of repositoryIds) {
111
- await db.repositories.assignToGroup(repoId, group.id);
112
- }
113
- }
114
- // Fetch the group with repositories for response
115
- const groupWithRepos = await db.projectGroups.findWithRepositories(group.id);
116
- res.status(201).json({
117
- success: true,
118
- group: {
119
- id: groupWithRepos.id,
120
- name: groupWithRepos.name,
121
- description: groupWithRepos.description,
122
- color: groupWithRepos.color,
123
- icon: groupWithRepos.icon,
124
- coordinatorAgent: groupWithRepos.coordinatorAgent,
125
- repositories: groupWithRepos.repositories.map(repo => ({
126
- id: repo.id,
127
- githubFullName: repo.githubFullName,
128
- defaultBranch: repo.defaultBranch,
129
- isPrivate: repo.isPrivate,
130
- })),
131
- createdAt: groupWithRepos.createdAt,
132
- updatedAt: groupWithRepos.updatedAt,
133
- },
134
- });
135
- }
136
- catch (error) {
137
- console.error('Error creating project group:', error);
138
- res.status(500).json({ error: 'Failed to create project group' });
139
- }
140
- });
141
- /**
142
- * GET /api/project-groups/:id
143
- * Get a specific project group with its repositories
144
- */
145
- coordinatorsRouter.get('/:id', async (req, res) => {
146
- const userId = req.session.userId;
147
- const id = req.params.id;
148
- // Skip if this looks like a coordinator route
149
- if (id === 'coordinators') {
150
- return res.status(404).json({ error: 'Not found' });
151
- }
152
- try {
153
- const group = await db.projectGroups.findWithRepositories(id);
154
- if (!group) {
155
- return res.status(404).json({ error: 'Project group not found' });
156
- }
157
- if (group.userId !== userId) {
158
- return res.status(403).json({ error: 'Unauthorized' });
159
- }
160
- res.json({
161
- id: group.id,
162
- name: group.name,
163
- description: group.description,
164
- color: group.color,
165
- icon: group.icon,
166
- coordinatorAgent: group.coordinatorAgent,
167
- sortOrder: group.sortOrder,
168
- repositories: group.repositories.map(repo => ({
169
- id: repo.id,
170
- githubFullName: repo.githubFullName,
171
- defaultBranch: repo.defaultBranch,
172
- isPrivate: repo.isPrivate,
173
- syncStatus: repo.syncStatus,
174
- lastSyncedAt: repo.lastSyncedAt,
175
- workspaceId: repo.workspaceId,
176
- })),
177
- createdAt: group.createdAt,
178
- updatedAt: group.updatedAt,
179
- });
180
- }
181
- catch (error) {
182
- console.error('Error getting project group:', error);
183
- res.status(500).json({ error: 'Failed to get project group' });
184
- }
185
- });
186
- /**
187
- * PATCH /api/project-groups/:id
188
- * Update a project group's metadata
189
- */
190
- coordinatorsRouter.patch('/:id', async (req, res) => {
191
- const userId = req.session.userId;
192
- const id = req.params.id;
193
- const { name, description, color, icon } = req.body;
194
- try {
195
- const group = await db.projectGroups.findById(id);
196
- if (!group) {
197
- return res.status(404).json({ error: 'Project group not found' });
198
- }
199
- if (group.userId !== userId) {
200
- return res.status(403).json({ error: 'Unauthorized' });
201
- }
202
- // Build update object with only provided fields
203
- const updates = {};
204
- if (name !== undefined) {
205
- if (typeof name !== 'string' || name.trim().length === 0) {
206
- return res.status(400).json({ error: 'Name cannot be empty' });
207
- }
208
- if (name.length > 255) {
209
- return res.status(400).json({ error: 'Name must be 255 characters or less' });
210
- }
211
- // Check for duplicate name (excluding current group)
212
- const existing = await db.projectGroups.findByName(userId, name.trim());
213
- if (existing && existing.id !== id) {
214
- return res.status(409).json({ error: 'A project group with this name already exists' });
215
- }
216
- updates.name = name.trim();
217
- }
218
- if (description !== undefined) {
219
- updates.description = description?.trim() || null;
220
- }
221
- if (color !== undefined) {
222
- // Validate hex color format if provided
223
- if (color && !/^#[0-9A-Fa-f]{6}$/.test(color)) {
224
- return res.status(400).json({ error: 'Color must be a valid hex color (e.g., #3B82F6)' });
225
- }
226
- updates.color = color || null;
227
- }
228
- if (icon !== undefined) {
229
- updates.icon = icon || null;
230
- }
231
- if (Object.keys(updates).length === 0) {
232
- return res.status(400).json({ error: 'No valid fields to update' });
233
- }
234
- await db.projectGroups.update(id, updates);
235
- // Fetch updated group
236
- const updatedGroup = await db.projectGroups.findWithRepositories(id);
237
- res.json({
238
- success: true,
239
- group: {
240
- id: updatedGroup.id,
241
- name: updatedGroup.name,
242
- description: updatedGroup.description,
243
- color: updatedGroup.color,
244
- icon: updatedGroup.icon,
245
- coordinatorAgent: updatedGroup.coordinatorAgent,
246
- repositories: updatedGroup.repositories.map(repo => ({
247
- id: repo.id,
248
- githubFullName: repo.githubFullName,
249
- defaultBranch: repo.defaultBranch,
250
- isPrivate: repo.isPrivate,
251
- })),
252
- updatedAt: updatedGroup.updatedAt,
253
- },
254
- });
255
- }
256
- catch (error) {
257
- console.error('Error updating project group:', error);
258
- res.status(500).json({ error: 'Failed to update project group' });
259
- }
260
- });
261
- /**
262
- * DELETE /api/project-groups/:id
263
- * Delete a project group (repositories are unassigned, not deleted)
264
- */
265
- coordinatorsRouter.delete('/:id', async (req, res) => {
266
- const userId = req.session.userId;
267
- const id = req.params.id;
268
- try {
269
- const group = await db.projectGroups.findById(id);
270
- if (!group) {
271
- return res.status(404).json({ error: 'Project group not found' });
272
- }
273
- if (group.userId !== userId) {
274
- return res.status(403).json({ error: 'Unauthorized' });
275
- }
276
- // Stop coordinator if running
277
- if (group.coordinatorAgent?.enabled) {
278
- try {
279
- const coordinatorService = getCoordinatorService();
280
- await coordinatorService.stop(id);
281
- }
282
- catch (err) {
283
- console.warn('Error stopping coordinator during group deletion:', err);
284
- }
285
- }
286
- // Delete the group (repositories will have projectGroupId set to null due to ON DELETE SET NULL)
287
- await db.projectGroups.delete(id);
288
- res.json({
289
- success: true,
290
- message: 'Project group deleted',
291
- });
292
- }
293
- catch (error) {
294
- console.error('Error deleting project group:', error);
295
- res.status(500).json({ error: 'Failed to delete project group' });
296
- }
297
- });
298
- /**
299
- * POST /api/project-groups/:id/repositories
300
- * Add repositories to a project group
301
- */
302
- coordinatorsRouter.post('/:id/repositories', async (req, res) => {
303
- const userId = req.session.userId;
304
- const id = req.params.id;
305
- const { repositoryIds } = req.body;
306
- if (!repositoryIds || !Array.isArray(repositoryIds) || repositoryIds.length === 0) {
307
- return res.status(400).json({ error: 'repositoryIds array is required' });
308
- }
309
- try {
310
- const group = await db.projectGroups.findById(id);
311
- if (!group) {
312
- return res.status(404).json({ error: 'Project group not found' });
313
- }
314
- if (group.userId !== userId) {
315
- return res.status(403).json({ error: 'Unauthorized' });
316
- }
317
- // Verify all repositories belong to the user
318
- const userRepos = await db.repositories.findByUserId(userId);
319
- const userRepoIds = new Set(userRepos.map(r => r.id));
320
- for (const repoId of repositoryIds) {
321
- if (!userRepoIds.has(repoId)) {
322
- return res.status(400).json({
323
- error: `Repository ${repoId} not found or not owned by user`,
324
- });
325
- }
326
- }
327
- // Assign repositories to the group
328
- for (const repoId of repositoryIds) {
329
- await db.repositories.assignToGroup(repoId, id);
330
- }
331
- // Fetch updated group
332
- const updatedGroup = await db.projectGroups.findWithRepositories(id);
333
- res.json({
334
- success: true,
335
- group: {
336
- id: updatedGroup.id,
337
- name: updatedGroup.name,
338
- repositories: updatedGroup.repositories.map(repo => ({
339
- id: repo.id,
340
- githubFullName: repo.githubFullName,
341
- defaultBranch: repo.defaultBranch,
342
- isPrivate: repo.isPrivate,
343
- })),
344
- },
345
- });
346
- }
347
- catch (error) {
348
- console.error('Error adding repositories to group:', error);
349
- res.status(500).json({ error: 'Failed to add repositories to group' });
350
- }
351
- });
352
- /**
353
- * DELETE /api/project-groups/:id/repositories/:repoId
354
- * Remove a repository from a project group
355
- */
356
- coordinatorsRouter.delete('/:id/repositories/:repoId', async (req, res) => {
357
- const userId = req.session.userId;
358
- const id = req.params.id;
359
- const repoId = req.params.repoId;
360
- try {
361
- const group = await db.projectGroups.findById(id);
362
- if (!group) {
363
- return res.status(404).json({ error: 'Project group not found' });
364
- }
365
- if (group.userId !== userId) {
366
- return res.status(403).json({ error: 'Unauthorized' });
367
- }
368
- // Verify repository exists and belongs to this group
369
- const repo = await db.repositories.findById(repoId);
370
- if (!repo) {
371
- return res.status(404).json({ error: 'Repository not found' });
372
- }
373
- if (repo.userId !== userId) {
374
- return res.status(403).json({ error: 'Unauthorized' });
375
- }
376
- if (repo.projectGroupId !== id) {
377
- return res.status(400).json({ error: 'Repository is not in this group' });
378
- }
379
- // Remove repository from group (set projectGroupId to null)
380
- await db.repositories.assignToGroup(repoId, null);
381
- res.json({
382
- success: true,
383
- message: 'Repository removed from group',
384
- });
385
- }
386
- catch (error) {
387
- console.error('Error removing repository from group:', error);
388
- res.status(500).json({ error: 'Failed to remove repository from group' });
389
- }
390
- });
391
- /**
392
- * PUT /api/project-groups/reorder
393
- * Reorder project groups
394
- */
395
- coordinatorsRouter.put('/reorder', async (req, res) => {
396
- const userId = req.session.userId;
397
- const { orderedIds } = req.body;
398
- if (!orderedIds || !Array.isArray(orderedIds)) {
399
- return res.status(400).json({ error: 'orderedIds array is required' });
400
- }
401
- try {
402
- // Verify all groups belong to user
403
- const userGroups = await db.projectGroups.findByUserId(userId);
404
- const userGroupIds = new Set(userGroups.map(g => g.id));
405
- for (const groupId of orderedIds) {
406
- if (!userGroupIds.has(groupId)) {
407
- return res.status(400).json({
408
- error: `Group ${groupId} not found or not owned by user`,
409
- });
410
- }
411
- }
412
- await db.projectGroups.reorder(userId, orderedIds);
413
- res.json({
414
- success: true,
415
- message: 'Groups reordered',
416
- });
417
- }
418
- catch (error) {
419
- console.error('Error reordering project groups:', error);
420
- res.status(500).json({ error: 'Failed to reorder project groups' });
421
- }
422
- });
423
- // ============================================================================
424
- // Coordinator Agent Routes
425
- // ============================================================================
426
- /**
427
- * GET /api/project-groups/:groupId/coordinator
428
- * Get coordinator agent configuration
429
- */
430
- coordinatorsRouter.get('/:groupId/coordinator', async (req, res) => {
431
- const userId = req.session.userId;
432
- const groupId = req.params.groupId;
433
- try {
434
- const group = await db.projectGroups.findById(groupId);
435
- if (!group) {
436
- return res.status(404).json({ error: 'Project group not found' });
437
- }
438
- if (group.userId !== userId) {
439
- return res.status(403).json({ error: 'Unauthorized' });
440
- }
441
- res.json({
442
- groupId: group.id,
443
- groupName: group.name,
444
- coordinator: group.coordinatorAgent || { enabled: false },
445
- });
446
- }
447
- catch (error) {
448
- console.error('Error getting coordinator config:', error);
449
- res.status(500).json({ error: 'Failed to get coordinator configuration' });
450
- }
451
- });
452
- /**
453
- * PUT /api/project-groups/:groupId/coordinator
454
- * Update coordinator agent configuration
455
- */
456
- coordinatorsRouter.put('/:groupId/coordinator', async (req, res) => {
457
- const userId = req.session.userId;
458
- const groupId = req.params.groupId;
459
- const { name, model, systemPrompt, capabilities } = req.body;
460
- try {
461
- const group = await db.projectGroups.findById(groupId);
462
- if (!group) {
463
- return res.status(404).json({ error: 'Project group not found' });
464
- }
465
- if (group.userId !== userId) {
466
- return res.status(403).json({ error: 'Unauthorized' });
467
- }
468
- // Build updated config, preserving enabled state
469
- const currentConfig = group.coordinatorAgent || { enabled: false };
470
- const updatedConfig = {
471
- enabled: currentConfig.enabled,
472
- name: name !== undefined ? name : currentConfig.name,
473
- model: model !== undefined ? model : currentConfig.model,
474
- systemPrompt: systemPrompt !== undefined ? systemPrompt : currentConfig.systemPrompt,
475
- capabilities: capabilities !== undefined ? capabilities : currentConfig.capabilities,
476
- };
477
- await db.projectGroups.updateCoordinatorAgent(groupId, updatedConfig);
478
- // If coordinator is currently enabled, restart it with new config
479
- if (updatedConfig.enabled) {
480
- const coordinatorService = getCoordinatorService();
481
- await coordinatorService.restart(groupId);
482
- }
483
- res.json({
484
- success: true,
485
- coordinator: updatedConfig,
486
- });
487
- }
488
- catch (error) {
489
- console.error('Error updating coordinator config:', error);
490
- res.status(500).json({ error: 'Failed to update coordinator configuration' });
491
- }
492
- });
493
- /**
494
- * POST /api/project-groups/:groupId/coordinator/enable
495
- * Enable coordinator agent for a project group
496
- */
497
- coordinatorsRouter.post('/:groupId/coordinator/enable', async (req, res) => {
498
- const userId = req.session.userId;
499
- const groupId = req.params.groupId;
500
- try {
501
- const group = await db.projectGroups.findById(groupId);
502
- if (!group) {
503
- return res.status(404).json({ error: 'Project group not found' });
504
- }
505
- if (group.userId !== userId) {
506
- return res.status(403).json({ error: 'Unauthorized' });
507
- }
508
- // Plan check is handled by checkCoordinatorAccess middleware
509
- // Get repositories in the group
510
- const repositories = await db.repositories.findByProjectGroupId(groupId);
511
- if (repositories.length === 0) {
512
- return res.status(400).json({
513
- error: 'Cannot enable coordinator for empty group',
514
- message: 'Add at least one repository to this group first',
515
- });
516
- }
517
- // Enable coordinator
518
- const currentConfig = group.coordinatorAgent || { enabled: false };
519
- const updatedConfig = {
520
- ...currentConfig,
521
- enabled: true,
522
- name: currentConfig.name || `${group.name} Coordinator`,
523
- };
524
- await db.projectGroups.updateCoordinatorAgent(groupId, updatedConfig);
525
- // Start the coordinator agent
526
- const coordinatorService = getCoordinatorService();
527
- await coordinatorService.start(groupId);
528
- res.json({
529
- success: true,
530
- message: 'Coordinator agent enabled',
531
- coordinator: updatedConfig,
532
- });
533
- }
534
- catch (error) {
535
- console.error('Error enabling coordinator:', error);
536
- res.status(500).json({ error: 'Failed to enable coordinator agent' });
537
- }
538
- });
539
- /**
540
- * POST /api/project-groups/:groupId/coordinator/disable
541
- * Disable coordinator agent for a project group
542
- */
543
- coordinatorsRouter.post('/:groupId/coordinator/disable', async (req, res) => {
544
- const userId = req.session.userId;
545
- const groupId = req.params.groupId;
546
- try {
547
- const group = await db.projectGroups.findById(groupId);
548
- if (!group) {
549
- return res.status(404).json({ error: 'Project group not found' });
550
- }
551
- if (group.userId !== userId) {
552
- return res.status(403).json({ error: 'Unauthorized' });
553
- }
554
- // Disable coordinator
555
- const currentConfig = group.coordinatorAgent || { enabled: false };
556
- const updatedConfig = {
557
- ...currentConfig,
558
- enabled: false,
559
- };
560
- await db.projectGroups.updateCoordinatorAgent(groupId, updatedConfig);
561
- // Stop the coordinator agent
562
- const coordinatorService = getCoordinatorService();
563
- await coordinatorService.stop(groupId);
564
- res.json({
565
- success: true,
566
- message: 'Coordinator agent disabled',
567
- coordinator: updatedConfig,
568
- });
569
- }
570
- catch (error) {
571
- console.error('Error disabling coordinator:', error);
572
- res.status(500).json({ error: 'Failed to disable coordinator agent' });
573
- }
574
- });
575
- /**
576
- * GET /api/project-groups/coordinators/active
577
- * List all active coordinators for the user
578
- */
579
- coordinatorsRouter.get('/coordinators/active', async (req, res) => {
580
- const userId = req.session.userId;
581
- try {
582
- // Get all coordinators
583
- const activeCoordinators = await getActiveCoordinators();
584
- // Filter to only user's project groups
585
- const userGroups = await db.projectGroups.findByUserId(userId);
586
- const userGroupIds = new Set(userGroups.map((g) => g.id));
587
- const userCoordinators = activeCoordinators.filter((c) => userGroupIds.has(c.groupId));
588
- res.json({
589
- coordinators: userCoordinators,
590
- });
591
- }
592
- catch (error) {
593
- console.error('Error listing active coordinators:', error);
594
- res.status(500).json({ error: 'Failed to list coordinators' });
595
- }
596
- });
597
- /**
598
- * POST /api/project-groups/:groupId/coordinator/message
599
- * Send a message from coordinator to a specific workspace/agent
600
- */
601
- coordinatorsRouter.post('/:groupId/coordinator/message', async (req, res) => {
602
- const userId = req.session.userId;
603
- const groupId = req.params.groupId;
604
- const { workspaceId, agentName, message, thread } = req.body;
605
- if (!workspaceId || !agentName || !message) {
606
- return res.status(400).json({
607
- error: 'workspaceId, agentName, and message are required',
608
- });
609
- }
610
- try {
611
- const group = await db.projectGroups.findById(groupId);
612
- if (!group) {
613
- return res.status(404).json({ error: 'Project group not found' });
614
- }
615
- if (group.userId !== userId) {
616
- return res.status(403).json({ error: 'Unauthorized' });
617
- }
618
- if (!group.coordinatorAgent?.enabled) {
619
- return res.status(400).json({ error: 'Coordinator is not enabled' });
620
- }
621
- await sendToWorkspace(groupId, workspaceId, agentName, message, thread);
622
- res.json({
623
- success: true,
624
- message: 'Message sent',
625
- });
626
- }
627
- catch (error) {
628
- console.error('Error sending coordinator message:', error);
629
- res.status(500).json({ error: 'Failed to send message' });
630
- }
631
- });
632
- /**
633
- * POST /api/project-groups/:groupId/coordinator/broadcast
634
- * Broadcast a message from coordinator to all workspaces in the group
635
- */
636
- coordinatorsRouter.post('/:groupId/coordinator/broadcast', async (req, res) => {
637
- const userId = req.session.userId;
638
- const groupId = req.params.groupId;
639
- const { message, thread } = req.body;
640
- if (!message) {
641
- return res.status(400).json({ error: 'message is required' });
642
- }
643
- try {
644
- const group = await db.projectGroups.findById(groupId);
645
- if (!group) {
646
- return res.status(404).json({ error: 'Project group not found' });
647
- }
648
- if (group.userId !== userId) {
649
- return res.status(403).json({ error: 'Unauthorized' });
650
- }
651
- if (!group.coordinatorAgent?.enabled) {
652
- return res.status(400).json({ error: 'Coordinator is not enabled' });
653
- }
654
- await broadcastToGroup(groupId, message, thread);
655
- res.json({
656
- success: true,
657
- message: 'Broadcast sent',
658
- });
659
- }
660
- catch (error) {
661
- console.error('Error broadcasting coordinator message:', error);
662
- res.status(500).json({ error: 'Failed to broadcast message' });
663
- }
664
- });
665
- /**
666
- * POST /api/project-groups/coordinator/route
667
- * Route a message from a workspace to its coordinator
668
- * (Called by workspace daemons)
669
- */
670
- coordinatorsRouter.post('/coordinator/route', async (req, res) => {
671
- const { workspaceId, agentName, message, thread } = req.body;
672
- if (!workspaceId || !agentName || !message) {
673
- return res.status(400).json({
674
- error: 'workspaceId, agentName, and message are required',
675
- });
676
- }
677
- try {
678
- // Verify workspace exists and get its owner
679
- const workspace = await db.workspaces.findById(workspaceId);
680
- if (!workspace) {
681
- return res.status(404).json({ error: 'Workspace not found' });
682
- }
683
- await routeToCoordinator(workspaceId, agentName, message, thread);
684
- res.json({
685
- success: true,
686
- message: 'Message routed to coordinator',
687
- });
688
- }
689
- catch (error) {
690
- console.error('Error routing to coordinator:', error);
691
- res.status(500).json({ error: 'Failed to route message' });
692
- }
693
- });
694
- /**
695
- * GET /api/project-groups/:groupId/coordinator/status
696
- * Get detailed coordinator status including connected workspaces
697
- */
698
- coordinatorsRouter.get('/:groupId/coordinator/status', async (req, res) => {
699
- const userId = req.session.userId;
700
- const groupId = req.params.groupId;
701
- try {
702
- const group = await db.projectGroups.findById(groupId);
703
- if (!group) {
704
- return res.status(404).json({ error: 'Project group not found' });
705
- }
706
- if (group.userId !== userId) {
707
- return res.status(403).json({ error: 'Unauthorized' });
708
- }
709
- const coordinatorService = getCoordinatorService();
710
- const status = await coordinatorService.getStatus(groupId);
711
- // Get connected workspaces info
712
- const repositories = await db.repositories.findByProjectGroupId(groupId);
713
- const workspaceIds = new Set();
714
- for (const repo of repositories) {
715
- if (repo.workspaceId) {
716
- workspaceIds.add(repo.workspaceId);
717
- }
718
- }
719
- const workspaces = await Promise.all(Array.from(workspaceIds).map(async (id) => {
720
- const ws = await db.workspaces.findById(id);
721
- return ws
722
- ? {
723
- id: ws.id,
724
- name: ws.name,
725
- status: ws.status,
726
- publicUrl: ws.publicUrl,
727
- }
728
- : null;
729
- }));
730
- res.json({
731
- groupId,
732
- groupName: group.name,
733
- coordinator: {
734
- enabled: group.coordinatorAgent?.enabled || false,
735
- name: group.coordinatorAgent?.name,
736
- model: group.coordinatorAgent?.model,
737
- status: status?.status || 'stopped',
738
- startedAt: status?.startedAt,
739
- error: status?.error,
740
- },
741
- workspaces: workspaces.filter(Boolean),
742
- repositoryCount: repositories.length,
743
- });
744
- }
745
- catch (error) {
746
- console.error('Error getting coordinator status:', error);
747
- res.status(500).json({ error: 'Failed to get coordinator status' });
748
- }
749
- });
750
- //# sourceMappingURL=coordinators.js.map