@agent-relay/cloud 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. package/dist/api/admin.d.ts +8 -0
  2. package/dist/api/admin.d.ts.map +1 -0
  3. package/dist/api/admin.js +225 -0
  4. package/dist/api/admin.js.map +1 -0
  5. package/dist/api/auth.d.ts +20 -0
  6. package/dist/api/auth.d.ts.map +1 -0
  7. package/dist/api/auth.js +136 -0
  8. package/dist/api/auth.js.map +1 -0
  9. package/dist/api/billing.d.ts +7 -0
  10. package/dist/api/billing.d.ts.map +1 -0
  11. package/dist/api/billing.js +564 -0
  12. package/dist/api/billing.js.map +1 -0
  13. package/dist/api/cli-pty-runner.d.ts +53 -0
  14. package/dist/api/cli-pty-runner.d.ts.map +1 -0
  15. package/dist/api/cli-pty-runner.js +193 -0
  16. package/dist/api/cli-pty-runner.js.map +1 -0
  17. package/dist/api/codex-auth-helper.d.ts +21 -0
  18. package/dist/api/codex-auth-helper.d.ts.map +1 -0
  19. package/dist/api/codex-auth-helper.js +327 -0
  20. package/dist/api/codex-auth-helper.js.map +1 -0
  21. package/dist/api/consensus.d.ts +13 -0
  22. package/dist/api/consensus.d.ts.map +1 -0
  23. package/dist/api/consensus.js +261 -0
  24. package/dist/api/consensus.js.map +1 -0
  25. package/dist/api/coordinators.d.ts +8 -0
  26. package/dist/api/coordinators.d.ts.map +1 -0
  27. package/dist/api/coordinators.js +750 -0
  28. package/dist/api/coordinators.js.map +1 -0
  29. package/dist/api/daemons.d.ts +12 -0
  30. package/dist/api/daemons.d.ts.map +1 -0
  31. package/dist/api/daemons.js +535 -0
  32. package/dist/api/daemons.js.map +1 -0
  33. package/dist/api/generic-webhooks.d.ts +8 -0
  34. package/dist/api/generic-webhooks.d.ts.map +1 -0
  35. package/dist/api/generic-webhooks.js +129 -0
  36. package/dist/api/generic-webhooks.js.map +1 -0
  37. package/dist/api/git.d.ts +8 -0
  38. package/dist/api/git.d.ts.map +1 -0
  39. package/dist/api/git.js +269 -0
  40. package/dist/api/git.js.map +1 -0
  41. package/dist/api/github-app.d.ts +11 -0
  42. package/dist/api/github-app.d.ts.map +1 -0
  43. package/dist/api/github-app.js +223 -0
  44. package/dist/api/github-app.js.map +1 -0
  45. package/dist/api/middleware/planLimits.d.ts +43 -0
  46. package/dist/api/middleware/planLimits.d.ts.map +1 -0
  47. package/dist/api/middleware/planLimits.js +202 -0
  48. package/dist/api/middleware/planLimits.js.map +1 -0
  49. package/dist/api/monitoring.d.ts +11 -0
  50. package/dist/api/monitoring.d.ts.map +1 -0
  51. package/dist/api/monitoring.js +578 -0
  52. package/dist/api/monitoring.js.map +1 -0
  53. package/dist/api/nango-auth.d.ts +9 -0
  54. package/dist/api/nango-auth.d.ts.map +1 -0
  55. package/dist/api/nango-auth.js +674 -0
  56. package/dist/api/nango-auth.js.map +1 -0
  57. package/dist/api/onboarding.d.ts +15 -0
  58. package/dist/api/onboarding.d.ts.map +1 -0
  59. package/dist/api/onboarding.js +679 -0
  60. package/dist/api/onboarding.js.map +1 -0
  61. package/dist/api/policy.d.ts +8 -0
  62. package/dist/api/policy.d.ts.map +1 -0
  63. package/dist/api/policy.js +229 -0
  64. package/dist/api/policy.js.map +1 -0
  65. package/dist/api/provider-env.d.ts +14 -0
  66. package/dist/api/provider-env.d.ts.map +1 -0
  67. package/dist/api/provider-env.js +75 -0
  68. package/dist/api/provider-env.js.map +1 -0
  69. package/dist/api/providers.d.ts +7 -0
  70. package/dist/api/providers.d.ts.map +1 -0
  71. package/dist/api/providers.js +564 -0
  72. package/dist/api/providers.js.map +1 -0
  73. package/dist/api/repos.d.ts +8 -0
  74. package/dist/api/repos.d.ts.map +1 -0
  75. package/dist/api/repos.js +577 -0
  76. package/dist/api/repos.js.map +1 -0
  77. package/dist/api/sessions.d.ts +11 -0
  78. package/dist/api/sessions.d.ts.map +1 -0
  79. package/dist/api/sessions.js +302 -0
  80. package/dist/api/sessions.js.map +1 -0
  81. package/dist/api/teams.d.ts +7 -0
  82. package/dist/api/teams.d.ts.map +1 -0
  83. package/dist/api/teams.js +281 -0
  84. package/dist/api/teams.js.map +1 -0
  85. package/dist/api/test-helpers.d.ts +10 -0
  86. package/dist/api/test-helpers.d.ts.map +1 -0
  87. package/dist/api/test-helpers.js +745 -0
  88. package/dist/api/test-helpers.js.map +1 -0
  89. package/dist/api/usage.d.ts +7 -0
  90. package/dist/api/usage.d.ts.map +1 -0
  91. package/dist/api/usage.js +111 -0
  92. package/dist/api/usage.js.map +1 -0
  93. package/dist/api/webhooks.d.ts +8 -0
  94. package/dist/api/webhooks.d.ts.map +1 -0
  95. package/dist/api/webhooks.js +645 -0
  96. package/dist/api/webhooks.js.map +1 -0
  97. package/dist/api/workspaces.d.ts +25 -0
  98. package/dist/api/workspaces.d.ts.map +1 -0
  99. package/dist/api/workspaces.js +1799 -0
  100. package/dist/api/workspaces.js.map +1 -0
  101. package/dist/billing/index.d.ts +9 -0
  102. package/dist/billing/index.d.ts.map +1 -0
  103. package/dist/billing/index.js +9 -0
  104. package/dist/billing/index.js.map +1 -0
  105. package/dist/billing/plans.d.ts +39 -0
  106. package/dist/billing/plans.d.ts.map +1 -0
  107. package/dist/billing/plans.js +245 -0
  108. package/dist/billing/plans.js.map +1 -0
  109. package/dist/billing/service.d.ts +80 -0
  110. package/dist/billing/service.d.ts.map +1 -0
  111. package/dist/billing/service.js +388 -0
  112. package/dist/billing/service.js.map +1 -0
  113. package/dist/billing/types.d.ts +141 -0
  114. package/dist/billing/types.d.ts.map +1 -0
  115. package/dist/billing/types.js +7 -0
  116. package/dist/billing/types.js.map +1 -0
  117. package/dist/config.d.ts +5 -0
  118. package/dist/config.d.ts.map +1 -0
  119. package/dist/config.js +5 -0
  120. package/dist/config.js.map +1 -0
  121. package/dist/db/bulk-ingest.d.ts +89 -0
  122. package/dist/db/bulk-ingest.d.ts.map +1 -0
  123. package/dist/db/bulk-ingest.js +268 -0
  124. package/dist/db/bulk-ingest.js.map +1 -0
  125. package/dist/db/drizzle.d.ts +256 -0
  126. package/dist/db/drizzle.d.ts.map +1 -0
  127. package/dist/db/drizzle.js +1286 -0
  128. package/dist/db/drizzle.js.map +1 -0
  129. package/dist/db/index.d.ts +55 -0
  130. package/dist/db/index.d.ts.map +1 -0
  131. package/dist/db/index.js +68 -0
  132. package/dist/db/index.js.map +1 -0
  133. package/dist/db/schema.d.ts +4873 -0
  134. package/dist/db/schema.d.ts.map +1 -0
  135. package/dist/db/schema.js +620 -0
  136. package/dist/db/schema.js.map +1 -0
  137. package/dist/index.d.ts +11 -0
  138. package/dist/index.d.ts.map +1 -0
  139. package/dist/index.js +38 -0
  140. package/dist/index.js.map +1 -0
  141. package/dist/provisioner/index.d.ts +207 -0
  142. package/dist/provisioner/index.d.ts.map +1 -0
  143. package/dist/provisioner/index.js +2114 -0
  144. package/dist/provisioner/index.js.map +1 -0
  145. package/dist/server.d.ts +17 -0
  146. package/dist/server.d.ts.map +1 -0
  147. package/dist/server.js +1924 -0
  148. package/dist/server.js.map +1 -0
  149. package/dist/services/auto-scaler.d.ts +152 -0
  150. package/dist/services/auto-scaler.d.ts.map +1 -0
  151. package/dist/services/auto-scaler.js +439 -0
  152. package/dist/services/auto-scaler.js.map +1 -0
  153. package/dist/services/capacity-manager.d.ts +148 -0
  154. package/dist/services/capacity-manager.d.ts.map +1 -0
  155. package/dist/services/capacity-manager.js +449 -0
  156. package/dist/services/capacity-manager.js.map +1 -0
  157. package/dist/services/ci-agent-spawner.d.ts +49 -0
  158. package/dist/services/ci-agent-spawner.d.ts.map +1 -0
  159. package/dist/services/ci-agent-spawner.js +373 -0
  160. package/dist/services/ci-agent-spawner.js.map +1 -0
  161. package/dist/services/cloud-message-bus.d.ts +28 -0
  162. package/dist/services/cloud-message-bus.d.ts.map +1 -0
  163. package/dist/services/cloud-message-bus.js +19 -0
  164. package/dist/services/cloud-message-bus.js.map +1 -0
  165. package/dist/services/compute-enforcement.d.ts +57 -0
  166. package/dist/services/compute-enforcement.d.ts.map +1 -0
  167. package/dist/services/compute-enforcement.js +175 -0
  168. package/dist/services/compute-enforcement.js.map +1 -0
  169. package/dist/services/coordinator.d.ts +62 -0
  170. package/dist/services/coordinator.d.ts.map +1 -0
  171. package/dist/services/coordinator.js +389 -0
  172. package/dist/services/coordinator.js.map +1 -0
  173. package/dist/services/index.d.ts +17 -0
  174. package/dist/services/index.d.ts.map +1 -0
  175. package/dist/services/index.js +25 -0
  176. package/dist/services/index.js.map +1 -0
  177. package/dist/services/intro-expiration.d.ts +60 -0
  178. package/dist/services/intro-expiration.d.ts.map +1 -0
  179. package/dist/services/intro-expiration.js +252 -0
  180. package/dist/services/intro-expiration.js.map +1 -0
  181. package/dist/services/mention-handler.d.ts +65 -0
  182. package/dist/services/mention-handler.d.ts.map +1 -0
  183. package/dist/services/mention-handler.js +405 -0
  184. package/dist/services/mention-handler.js.map +1 -0
  185. package/dist/services/nango.d.ts +201 -0
  186. package/dist/services/nango.d.ts.map +1 -0
  187. package/dist/services/nango.js +392 -0
  188. package/dist/services/nango.js.map +1 -0
  189. package/dist/services/persistence.d.ts +131 -0
  190. package/dist/services/persistence.d.ts.map +1 -0
  191. package/dist/services/persistence.js +200 -0
  192. package/dist/services/persistence.js.map +1 -0
  193. package/dist/services/planLimits.d.ts +147 -0
  194. package/dist/services/planLimits.d.ts.map +1 -0
  195. package/dist/services/planLimits.js +335 -0
  196. package/dist/services/planLimits.js.map +1 -0
  197. package/dist/services/presence-registry.d.ts +56 -0
  198. package/dist/services/presence-registry.d.ts.map +1 -0
  199. package/dist/services/presence-registry.js +91 -0
  200. package/dist/services/presence-registry.js.map +1 -0
  201. package/dist/services/scaling-orchestrator.d.ts +159 -0
  202. package/dist/services/scaling-orchestrator.d.ts.map +1 -0
  203. package/dist/services/scaling-orchestrator.js +502 -0
  204. package/dist/services/scaling-orchestrator.js.map +1 -0
  205. package/dist/services/scaling-policy.d.ts +121 -0
  206. package/dist/services/scaling-policy.d.ts.map +1 -0
  207. package/dist/services/scaling-policy.js +415 -0
  208. package/dist/services/scaling-policy.js.map +1 -0
  209. package/dist/services/ssh-security.d.ts +31 -0
  210. package/dist/services/ssh-security.d.ts.map +1 -0
  211. package/dist/services/ssh-security.js +63 -0
  212. package/dist/services/ssh-security.js.map +1 -0
  213. package/dist/services/workspace-keepalive.d.ts +76 -0
  214. package/dist/services/workspace-keepalive.d.ts.map +1 -0
  215. package/dist/services/workspace-keepalive.js +234 -0
  216. package/dist/services/workspace-keepalive.js.map +1 -0
  217. package/dist/shims/consensus.d.ts +23 -0
  218. package/dist/shims/consensus.d.ts.map +1 -0
  219. package/dist/shims/consensus.js +5 -0
  220. package/dist/shims/consensus.js.map +1 -0
  221. package/dist/webhooks/index.d.ts +24 -0
  222. package/dist/webhooks/index.d.ts.map +1 -0
  223. package/dist/webhooks/index.js +29 -0
  224. package/dist/webhooks/index.js.map +1 -0
  225. package/dist/webhooks/parsers/github.d.ts +8 -0
  226. package/dist/webhooks/parsers/github.d.ts.map +1 -0
  227. package/dist/webhooks/parsers/github.js +234 -0
  228. package/dist/webhooks/parsers/github.js.map +1 -0
  229. package/dist/webhooks/parsers/index.d.ts +23 -0
  230. package/dist/webhooks/parsers/index.d.ts.map +1 -0
  231. package/dist/webhooks/parsers/index.js +30 -0
  232. package/dist/webhooks/parsers/index.js.map +1 -0
  233. package/dist/webhooks/parsers/linear.d.ts +9 -0
  234. package/dist/webhooks/parsers/linear.d.ts.map +1 -0
  235. package/dist/webhooks/parsers/linear.js +258 -0
  236. package/dist/webhooks/parsers/linear.js.map +1 -0
  237. package/dist/webhooks/parsers/slack.d.ts +9 -0
  238. package/dist/webhooks/parsers/slack.d.ts.map +1 -0
  239. package/dist/webhooks/parsers/slack.js +214 -0
  240. package/dist/webhooks/parsers/slack.js.map +1 -0
  241. package/dist/webhooks/responders/github.d.ts +8 -0
  242. package/dist/webhooks/responders/github.d.ts.map +1 -0
  243. package/dist/webhooks/responders/github.js +73 -0
  244. package/dist/webhooks/responders/github.js.map +1 -0
  245. package/dist/webhooks/responders/index.d.ts +23 -0
  246. package/dist/webhooks/responders/index.d.ts.map +1 -0
  247. package/dist/webhooks/responders/index.js +30 -0
  248. package/dist/webhooks/responders/index.js.map +1 -0
  249. package/dist/webhooks/responders/linear.d.ts +9 -0
  250. package/dist/webhooks/responders/linear.d.ts.map +1 -0
  251. package/dist/webhooks/responders/linear.js +149 -0
  252. package/dist/webhooks/responders/linear.js.map +1 -0
  253. package/dist/webhooks/responders/slack.d.ts +20 -0
  254. package/dist/webhooks/responders/slack.d.ts.map +1 -0
  255. package/dist/webhooks/responders/slack.js +178 -0
  256. package/dist/webhooks/responders/slack.js.map +1 -0
  257. package/dist/webhooks/router.d.ts +25 -0
  258. package/dist/webhooks/router.d.ts.map +1 -0
  259. package/dist/webhooks/router.js +504 -0
  260. package/dist/webhooks/router.js.map +1 -0
  261. package/dist/webhooks/rules-engine.d.ts +24 -0
  262. package/dist/webhooks/rules-engine.d.ts.map +1 -0
  263. package/dist/webhooks/rules-engine.js +287 -0
  264. package/dist/webhooks/rules-engine.js.map +1 -0
  265. package/dist/webhooks/types.d.ts +186 -0
  266. package/dist/webhooks/types.d.ts.map +1 -0
  267. package/dist/webhooks/types.js +8 -0
  268. package/dist/webhooks/types.js.map +1 -0
  269. package/package.json +55 -0
@@ -0,0 +1,564 @@
1
+ /**
2
+ * Providers API Routes
3
+ *
4
+ * Handles device flow authentication for AI providers (Claude, Codex, etc.)
5
+ */
6
+ import { Router } from 'express';
7
+ import crypto from 'crypto';
8
+ import { createClient } from 'redis';
9
+ import { requireAuth } from './auth.js';
10
+ import { getConfig } from '../config.js';
11
+ import { db } from '../db/index.js';
12
+ import { setProviderApiKeyEnv } from './provider-env.js';
13
+ export const providersRouter = Router();
14
+ // All routes require authentication
15
+ providersRouter.use(requireAuth);
16
+ const PROVIDERS = {
17
+ anthropic: {
18
+ name: 'Anthropic',
19
+ displayName: 'Claude',
20
+ description: 'Claude Code - recommended for code tasks',
21
+ authStrategy: 'cli',
22
+ cliCommand: 'claude',
23
+ credentialPath: '~/.claude/credentials.json',
24
+ color: '#D97757',
25
+ },
26
+ codex: {
27
+ name: 'OpenAI',
28
+ displayName: 'Codex',
29
+ description: 'Codex - OpenAI coding assistant',
30
+ authStrategy: 'cli',
31
+ cliCommand: 'codex login',
32
+ credentialPath: '~/.codex/credentials.json',
33
+ color: '#10A37F',
34
+ },
35
+ opencode: {
36
+ name: 'OpenCode',
37
+ displayName: 'OpenCode',
38
+ description: 'OpenCode - AI coding assistant',
39
+ authStrategy: 'cli',
40
+ cliCommand: 'opencode',
41
+ credentialPath: '~/.opencode/credentials.json',
42
+ color: '#00D4AA',
43
+ },
44
+ droid: {
45
+ name: 'Factory',
46
+ displayName: 'Droid',
47
+ description: 'Droid - Factory AI coding agent',
48
+ authStrategy: 'cli',
49
+ cliCommand: 'droid',
50
+ credentialPath: '~/.factory/credentials.json',
51
+ color: '#6366F1',
52
+ },
53
+ cursor: {
54
+ name: 'Cursor',
55
+ displayName: 'Cursor',
56
+ description: 'Cursor - AI-first code editor agent',
57
+ authStrategy: 'cli',
58
+ cliCommand: 'agent',
59
+ credentialPath: '~/.cursor/auth.json',
60
+ color: '#7C3AED',
61
+ },
62
+ google: {
63
+ name: 'Google',
64
+ displayName: 'Gemini',
65
+ description: 'Gemini - multi-modal capabilities',
66
+ authStrategy: 'device_flow',
67
+ deviceCodeUrl: 'https://oauth2.googleapis.com/device/code',
68
+ tokenUrl: 'https://oauth2.googleapis.com/token',
69
+ userInfoUrl: 'https://www.googleapis.com/oauth2/v2/userinfo',
70
+ scopes: ['openid', 'email', 'profile', 'https://www.googleapis.com/auth/generative-language'],
71
+ color: '#4285F4',
72
+ },
73
+ };
74
+ // Type guard for device flow providers
75
+ function isDeviceFlowProvider(provider) {
76
+ return provider.authStrategy === 'device_flow';
77
+ }
78
+ let redisClient = null;
79
+ async function getRedisClient() {
80
+ if (!redisClient) {
81
+ const config = getConfig();
82
+ redisClient = createClient({ url: config.redisUrl });
83
+ redisClient.on('error', (err) => console.error('[redis] provider flow error', err));
84
+ await redisClient.connect();
85
+ }
86
+ return redisClient;
87
+ }
88
+ const flowKey = (flowId) => `provider-flow:${flowId}`;
89
+ async function saveFlow(flowId, flow) {
90
+ const client = await getRedisClient();
91
+ const ttlSeconds = Math.max(60, Math.ceil((flow.expiresAt.getTime() - Date.now()) / 1000));
92
+ await client.setEx(flowKey(flowId), ttlSeconds, JSON.stringify(flow));
93
+ }
94
+ async function loadFlow(flowId) {
95
+ const client = await getRedisClient();
96
+ const raw = await client.get(flowKey(flowId));
97
+ if (!raw)
98
+ return null;
99
+ const parsed = JSON.parse(raw);
100
+ parsed.expiresAt = new Date(parsed.expiresAt);
101
+ return parsed;
102
+ }
103
+ async function deleteFlow(flowId) {
104
+ const client = await getRedisClient();
105
+ await client.del(flowKey(flowId));
106
+ }
107
+ /**
108
+ * GET /api/providers
109
+ * List all providers with connection status
110
+ *
111
+ * Query: ?workspaceId=xxx (optional - if provided, shows workspace-specific connection status)
112
+ */
113
+ providersRouter.get('/', async (req, res) => {
114
+ const userId = req.session.userId;
115
+ const { workspaceId } = req.query;
116
+ try {
117
+ // If workspaceId is provided, get workspace-specific credentials
118
+ // Otherwise get all user credentials (legacy behavior for backwards compatibility)
119
+ let credentials;
120
+ if (workspaceId && typeof workspaceId === 'string') {
121
+ credentials = await db.credentials.findByUserAndWorkspace(userId, workspaceId);
122
+ }
123
+ else {
124
+ credentials = await db.credentials.findByUserId(userId);
125
+ }
126
+ const providers = Object.entries(PROVIDERS).map(([id, provider]) => {
127
+ const credential = credentials.find((c) => c.provider === id);
128
+ return {
129
+ id,
130
+ name: provider.name,
131
+ displayName: provider.displayName,
132
+ description: provider.description,
133
+ color: provider.color,
134
+ authStrategy: provider.authStrategy,
135
+ cliCommand: provider.authStrategy === 'cli' ? provider.cliCommand : undefined,
136
+ isConnected: !!credential,
137
+ connectedAs: credential?.providerAccountEmail,
138
+ connectedAt: credential?.createdAt,
139
+ };
140
+ });
141
+ // Add GitHub (always connected via signup - not workspace-specific)
142
+ const allCredentials = await db.credentials.findByUserId(userId);
143
+ const githubCred = allCredentials.find((c) => c.provider === 'github');
144
+ providers.unshift({
145
+ id: 'github',
146
+ name: 'GitHub',
147
+ displayName: 'Copilot',
148
+ description: 'GitHub Copilot - connected via signup',
149
+ color: '#24292F',
150
+ authStrategy: 'device_flow',
151
+ cliCommand: undefined,
152
+ isConnected: true,
153
+ connectedAs: githubCred?.providerAccountEmail,
154
+ connectedAt: githubCred?.createdAt,
155
+ });
156
+ res.json({ providers });
157
+ }
158
+ catch (error) {
159
+ console.error('Error listing providers:', error);
160
+ res.status(500).json({ error: 'Failed to list providers' });
161
+ }
162
+ });
163
+ /**
164
+ * POST /api/providers/:provider/connect
165
+ * Start auth flow for a provider (device flow or CLI instructions)
166
+ *
167
+ * Body: { workspaceId: string }
168
+ */
169
+ providersRouter.post('/:provider/connect', async (req, res) => {
170
+ const { provider } = req.params;
171
+ const userId = req.session.userId;
172
+ const { workspaceId } = req.body;
173
+ const config = getConfig();
174
+ if (!workspaceId || typeof workspaceId !== 'string') {
175
+ return res.status(400).json({ error: 'workspaceId is required' });
176
+ }
177
+ const providerConfig = PROVIDERS[provider];
178
+ if (!providerConfig) {
179
+ return res.status(404).json({ error: 'Unknown provider' });
180
+ }
181
+ // CLI-based auth (Claude, Codex) - return instructions
182
+ if (providerConfig.authStrategy === 'cli') {
183
+ return res.json({
184
+ authStrategy: 'cli',
185
+ provider: provider,
186
+ displayName: providerConfig.displayName,
187
+ instructions: [
188
+ `1. Open your terminal`,
189
+ `2. Run: ${providerConfig.cliCommand}`,
190
+ `3. Complete the login in your browser`,
191
+ `4. Return here and click "Verify Connection"`,
192
+ ],
193
+ cliCommand: providerConfig.cliCommand,
194
+ // For cloud-hosted: we'll check the workspace container for credentials
195
+ // For self-hosted: user's local credentials will be synced
196
+ verifyEndpoint: `/api/providers/${provider}/verify`,
197
+ });
198
+ }
199
+ // Device flow auth (Google) - start OAuth device flow
200
+ // At this point, we know it's a device flow provider (CLI was handled above)
201
+ if (!isDeviceFlowProvider(providerConfig)) {
202
+ return res.status(400).json({ error: 'Provider does not support device flow' });
203
+ }
204
+ // Only google is configured for device flow in config
205
+ const clientConfig = provider === 'google' ? config.providers.google : undefined;
206
+ if (!clientConfig) {
207
+ return res.status(400).json({ error: `Provider ${provider} not configured` });
208
+ }
209
+ try {
210
+ // Request device code from provider
211
+ const response = await fetch(providerConfig.deviceCodeUrl, {
212
+ method: 'POST',
213
+ headers: {
214
+ 'Content-Type': 'application/x-www-form-urlencoded',
215
+ },
216
+ body: new URLSearchParams({
217
+ client_id: clientConfig.clientId,
218
+ scope: providerConfig.scopes.join(' '),
219
+ ...((provider === 'google') && { client_secret: clientConfig.clientSecret }),
220
+ }),
221
+ });
222
+ if (!response.ok) {
223
+ const error = await response.text();
224
+ throw new Error(`Failed to get device code: ${error}`);
225
+ }
226
+ const data = await response.json();
227
+ // Generate flow ID
228
+ const flowId = crypto.randomUUID();
229
+ const flow = {
230
+ userId,
231
+ workspaceId,
232
+ provider,
233
+ deviceCode: data.device_code,
234
+ userCode: data.user_code,
235
+ verificationUri: data.verification_uri,
236
+ verificationUriComplete: data.verification_uri_complete,
237
+ expiresAt: new Date(Date.now() + data.expires_in * 1000),
238
+ pollInterval: data.interval || 5,
239
+ status: 'pending',
240
+ };
241
+ await saveFlow(flowId, flow);
242
+ // Start background polling
243
+ pollForToken(flowId, provider, clientConfig.clientId);
244
+ res.json({
245
+ authStrategy: 'device_flow',
246
+ flowId,
247
+ userCode: data.user_code,
248
+ verificationUri: data.verification_uri,
249
+ verificationUriComplete: data.verification_uri_complete,
250
+ expiresIn: data.expires_in,
251
+ });
252
+ }
253
+ catch (error) {
254
+ console.error(`Error starting device flow for ${provider}:`, error);
255
+ res.status(500).json({ error: 'Failed to start device flow' });
256
+ }
257
+ });
258
+ /**
259
+ * POST /api/providers/:provider/verify
260
+ * Verify CLI-based auth completed (for Claude, Codex)
261
+ * User calls this after running the CLI login command
262
+ *
263
+ * Body: { workspaceId: string, email?: string }
264
+ */
265
+ providersRouter.post('/:provider/verify', async (req, res) => {
266
+ const { provider } = req.params;
267
+ const userId = req.session.userId;
268
+ const { workspaceId, email } = req.body;
269
+ if (!workspaceId || typeof workspaceId !== 'string') {
270
+ return res.status(400).json({ error: 'workspaceId is required' });
271
+ }
272
+ const providerConfig = PROVIDERS[provider];
273
+ if (!providerConfig || providerConfig.authStrategy !== 'cli') {
274
+ return res.status(400).json({ error: 'Provider does not use CLI auth' });
275
+ }
276
+ // For cloud-hosted workspaces: the workspace container will have the credentials
277
+ // For self-hosted: we trust the user completed the CLI flow
278
+ // In production, we'd verify by making a test API call with the credentials
279
+ try {
280
+ // Mark as connected for this specific workspace
281
+ // (tokens are not stored centrally - CLI tools authenticate directly on workspace instances)
282
+ await db.credentials.upsert({
283
+ userId,
284
+ workspaceId,
285
+ provider,
286
+ scopes: [], // CLI auth doesn't use scopes
287
+ providerAccountEmail: email, // User can optionally provide
288
+ });
289
+ res.json({
290
+ success: true,
291
+ message: `${providerConfig.displayName} connected via CLI`,
292
+ note: 'CLI credentials remain on your local machine',
293
+ });
294
+ }
295
+ catch (error) {
296
+ console.error(`Error verifying ${provider} auth:`, error);
297
+ res.status(500).json({ error: 'Failed to verify connection' });
298
+ }
299
+ });
300
+ /**
301
+ * POST /api/providers/:provider/api-key
302
+ * Connect a provider using an API key (for cloud-hosted workspaces)
303
+ *
304
+ * Body: { apiKey: string, workspaceId: string }
305
+ */
306
+ providersRouter.post('/:provider/api-key', async (req, res) => {
307
+ const { provider } = req.params;
308
+ const userId = req.session.userId;
309
+ const { apiKey, workspaceId } = req.body;
310
+ if (!apiKey || typeof apiKey !== 'string') {
311
+ return res.status(400).json({ error: 'API key is required' });
312
+ }
313
+ if (!workspaceId || typeof workspaceId !== 'string') {
314
+ return res.status(400).json({ error: 'workspaceId is required' });
315
+ }
316
+ const providerConfig = PROVIDERS[provider];
317
+ if (!providerConfig) {
318
+ return res.status(404).json({ error: 'Unknown provider' });
319
+ }
320
+ // Validate the API key by making a test request
321
+ try {
322
+ let isValid = false;
323
+ if (provider === 'anthropic') {
324
+ // Test Anthropic API key
325
+ const testRes = await fetch('https://api.anthropic.com/v1/messages', {
326
+ method: 'POST',
327
+ headers: {
328
+ 'Content-Type': 'application/json',
329
+ 'x-api-key': apiKey,
330
+ 'anthropic-version': '2023-06-01',
331
+ },
332
+ body: JSON.stringify({
333
+ model: 'claude-3-haiku-20240307',
334
+ max_tokens: 1,
335
+ messages: [{ role: 'user', content: 'hi' }],
336
+ }),
337
+ });
338
+ // 200 = valid, 401 = invalid key, 400/other = might still be valid key
339
+ isValid = testRes.status !== 401;
340
+ }
341
+ else if (provider === 'google') {
342
+ // Test Google/Gemini API key (uses query param auth, not Bearer token)
343
+ const testRes = await fetch(`https://generativelanguage.googleapis.com/v1/models?key=${encodeURIComponent(apiKey)}`);
344
+ // 200 = valid, 400/401/403 = invalid key
345
+ isValid = testRes.status === 200;
346
+ }
347
+ else {
348
+ // For other providers, just accept the key
349
+ isValid = true;
350
+ }
351
+ if (!isValid) {
352
+ return res.status(400).json({ error: 'Invalid API key' });
353
+ }
354
+ // Mark provider as connected for this specific workspace
355
+ const scopes = isDeviceFlowProvider(providerConfig) ? providerConfig.scopes : [];
356
+ await db.credentials.upsert({
357
+ userId,
358
+ workspaceId,
359
+ provider,
360
+ scopes,
361
+ });
362
+ // Set API key env var on the specific workspace
363
+ await setProviderApiKeyEnv(userId, provider, apiKey, workspaceId);
364
+ res.json({
365
+ success: true,
366
+ message: `${providerConfig.displayName} connected`,
367
+ note: 'API key validated and configured on workspace.',
368
+ });
369
+ }
370
+ catch (error) {
371
+ console.error(`Error connecting ${provider} with API key:`, error);
372
+ res.status(500).json({ error: 'Failed to connect provider' });
373
+ }
374
+ });
375
+ /**
376
+ * GET /api/providers/:provider/status/:flowId
377
+ * Check status of device flow
378
+ */
379
+ providersRouter.get('/:provider/status/:flowId', (req, res) => {
380
+ const flowId = req.params.flowId;
381
+ const userId = req.session.userId;
382
+ loadFlow(flowId)
383
+ .then((flow) => {
384
+ if (!flow) {
385
+ return res.status(404).json({ error: 'Flow not found or expired' });
386
+ }
387
+ if (flow.userId !== userId) {
388
+ return res.status(403).json({ error: 'Unauthorized' });
389
+ }
390
+ const expiresIn = Math.max(0, Math.floor((flow.expiresAt.getTime() - Date.now()) / 1000));
391
+ res.json({
392
+ status: flow.status,
393
+ expiresIn,
394
+ error: flow.error,
395
+ });
396
+ })
397
+ .catch((error) => {
398
+ console.error('Error checking flow status:', error);
399
+ res.status(500).json({ error: 'Failed to check flow status' });
400
+ });
401
+ });
402
+ /**
403
+ * DELETE /api/providers/:provider
404
+ * Disconnect a provider from a specific workspace
405
+ *
406
+ * Query: ?workspaceId=xxx
407
+ */
408
+ providersRouter.delete('/:provider', async (req, res) => {
409
+ const providerParam = req.params.provider;
410
+ const userId = req.session.userId;
411
+ const workspaceIdParam = req.query.workspaceId;
412
+ if (typeof providerParam !== 'string') {
413
+ return res.status(400).json({ error: 'Invalid provider' });
414
+ }
415
+ if (providerParam === 'github') {
416
+ return res.status(400).json({ error: 'Cannot disconnect GitHub' });
417
+ }
418
+ if (!workspaceIdParam || typeof workspaceIdParam !== 'string') {
419
+ return res.status(400).json({ error: 'workspaceId query parameter is required' });
420
+ }
421
+ const workspaceId = workspaceIdParam;
422
+ const provider = providerParam;
423
+ try {
424
+ await db.credentials.deleteForWorkspace(userId, workspaceId, provider);
425
+ res.json({ success: true });
426
+ }
427
+ catch (error) {
428
+ console.error(`Error disconnecting ${provider}:`, error);
429
+ res.status(500).json({ error: 'Failed to disconnect provider' });
430
+ }
431
+ });
432
+ /**
433
+ * DELETE /api/providers/:provider/flow/:flowId
434
+ * Cancel a device flow
435
+ */
436
+ providersRouter.delete('/:provider/flow/:flowId', (req, res) => {
437
+ const flowId = req.params.flowId;
438
+ const userId = req.session.userId;
439
+ loadFlow(flowId)
440
+ .then(async (flow) => {
441
+ if (flow?.userId === userId) {
442
+ await deleteFlow(flowId);
443
+ }
444
+ res.json({ success: true });
445
+ })
446
+ .catch((error) => {
447
+ console.error('Error deleting flow:', error);
448
+ res.status(500).json({ error: 'Failed to cancel flow' });
449
+ });
450
+ });
451
+ /**
452
+ * Background polling for device authorization
453
+ */
454
+ async function pollForToken(flowId, provider, clientId) {
455
+ const providerConfig = PROVIDERS[provider];
456
+ // Only device flow providers can poll for tokens
457
+ if (!isDeviceFlowProvider(providerConfig)) {
458
+ console.error(`Provider ${provider} does not support device flow polling`);
459
+ return;
460
+ }
461
+ const poll = async (intervalMs) => {
462
+ const current = await loadFlow(flowId);
463
+ if (!current || current.status !== 'pending')
464
+ return;
465
+ if (Date.now() > current.expiresAt.getTime()) {
466
+ current.status = 'expired';
467
+ await saveFlow(flowId, current);
468
+ return;
469
+ }
470
+ try {
471
+ const response = await fetch(providerConfig.tokenUrl, {
472
+ method: 'POST',
473
+ headers: {
474
+ 'Content-Type': 'application/x-www-form-urlencoded',
475
+ },
476
+ body: new URLSearchParams({
477
+ client_id: clientId,
478
+ device_code: current.deviceCode,
479
+ grant_type: 'urn:ietf:params:oauth:grant-type:device_code',
480
+ }),
481
+ });
482
+ const data = await response.json();
483
+ if (data.error) {
484
+ switch (data.error) {
485
+ case 'authorization_pending':
486
+ return setTimeout(() => poll(intervalMs), intervalMs).unref();
487
+ case 'slow_down': {
488
+ const nextInterval = (data.interval || intervalMs / 1000 || 5) * 1000;
489
+ return setTimeout(() => poll(nextInterval), nextInterval).unref();
490
+ }
491
+ case 'expired_token':
492
+ current.status = 'expired';
493
+ break;
494
+ case 'access_denied':
495
+ current.status = 'denied';
496
+ break;
497
+ default:
498
+ current.status = 'error';
499
+ current.error = data.error_description || data.error;
500
+ }
501
+ await saveFlow(flowId, current);
502
+ return;
503
+ }
504
+ // Success! Store tokens
505
+ await storeProviderTokens(current.userId, current.workspaceId, provider, {
506
+ accessToken: data.access_token,
507
+ refreshToken: data.refresh_token,
508
+ expiresIn: data.expires_in,
509
+ scope: data.scope,
510
+ });
511
+ current.status = 'success';
512
+ await saveFlow(flowId, current);
513
+ setTimeout(() => {
514
+ deleteFlow(flowId).catch((err) => console.error('Error cleaning up flow', err));
515
+ }, 60000).unref();
516
+ }
517
+ catch (error) {
518
+ console.error('Poll error:', error);
519
+ const nextInterval = intervalMs * 2;
520
+ setTimeout(() => poll(nextInterval), nextInterval).unref();
521
+ }
522
+ };
523
+ loadFlow(flowId)
524
+ .then((flow) => {
525
+ const initialInterval = (flow?.pollInterval ?? 5) * 1000;
526
+ setTimeout(() => poll(initialInterval), initialInterval).unref();
527
+ })
528
+ .catch((err) => console.error('Poll start error:', err));
529
+ }
530
+ /**
531
+ * Mark provider as connected after successful device flow
532
+ * Note: Tokens are not stored centrally - CLI tools authenticate directly
533
+ * on workspace instances. We only record the connection status and user info.
534
+ */
535
+ async function storeProviderTokens(userId, workspaceId, provider, tokens) {
536
+ const providerConfig = PROVIDERS[provider];
537
+ // Fetch user info from provider (only device flow providers have userInfoUrl)
538
+ let userInfo = {};
539
+ if (isDeviceFlowProvider(providerConfig)) {
540
+ try {
541
+ const response = await fetch(providerConfig.userInfoUrl, {
542
+ headers: {
543
+ Authorization: `Bearer ${tokens.accessToken}`,
544
+ },
545
+ });
546
+ if (response.ok) {
547
+ userInfo = await response.json();
548
+ }
549
+ }
550
+ catch (error) {
551
+ console.error('Error fetching user info:', error);
552
+ }
553
+ }
554
+ // Mark provider as connected for this specific workspace (without storing tokens)
555
+ await db.credentials.upsert({
556
+ userId,
557
+ workspaceId,
558
+ provider,
559
+ scopes: tokens.scope?.split(' '),
560
+ providerAccountId: userInfo.id,
561
+ providerAccountEmail: userInfo.email,
562
+ });
563
+ }
564
+ //# sourceMappingURL=providers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"providers.js","sourceRoot":"","sources":["../../src/api/providers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Repos API Routes
3
+ *
4
+ * GitHub repository management - list, import, sync.
5
+ * Includes Nango-based GitHub permission checking for dashboard access control.
6
+ */
7
+ export declare const reposRouter: import("express-serve-static-core").Router;
8
+ //# sourceMappingURL=repos.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"repos.d.ts","sourceRoot":"","sources":["../../src/api/repos.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAmEH,eAAO,MAAM,WAAW,4CAAW,CAAC"}