agent-relay 2.0.23 → 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 (168) hide show
  1. package/dist/src/cli/index.js +66 -13
  2. package/package.json +18 -52
  3. package/packages/api-types/package.json +1 -1
  4. package/packages/bridge/package.json +8 -8
  5. package/packages/cli-tester/package.json +1 -1
  6. package/packages/config/package.json +2 -2
  7. package/packages/continuity/package.json +1 -1
  8. package/packages/daemon/package.json +12 -12
  9. package/packages/hooks/package.json +4 -4
  10. package/packages/mcp/package.json +2 -2
  11. package/packages/memory/package.json +2 -2
  12. package/packages/policy/package.json +2 -2
  13. package/packages/protocol/package.json +1 -1
  14. package/packages/resiliency/package.json +1 -1
  15. package/packages/sdk/package.json +2 -2
  16. package/packages/spawner/package.json +1 -1
  17. package/packages/state/package.json +1 -1
  18. package/packages/storage/package.json +2 -2
  19. package/packages/telemetry/package.json +1 -1
  20. package/packages/trajectory/package.json +2 -2
  21. package/packages/user-directory/package.json +2 -2
  22. package/packages/utils/package.json +1 -1
  23. package/packages/wrapper/package.json +6 -6
  24. package/deploy/init-db.sql +0 -5
  25. package/deploy/scripts/setup-fly-workspaces.sh +0 -69
  26. package/deploy/scripts/setup-railway.sh +0 -75
  27. package/dist/src/cloud/index.d.ts +0 -8
  28. package/dist/src/cloud/index.js +0 -8
  29. package/packages/cloud/dist/api/admin.d.ts +0 -8
  30. package/packages/cloud/dist/api/admin.js +0 -225
  31. package/packages/cloud/dist/api/auth.d.ts +0 -20
  32. package/packages/cloud/dist/api/auth.js +0 -138
  33. package/packages/cloud/dist/api/billing.d.ts +0 -7
  34. package/packages/cloud/dist/api/billing.js +0 -564
  35. package/packages/cloud/dist/api/cli-pty-runner.d.ts +0 -53
  36. package/packages/cloud/dist/api/cli-pty-runner.js +0 -175
  37. package/packages/cloud/dist/api/codex-auth-helper.d.ts +0 -21
  38. package/packages/cloud/dist/api/codex-auth-helper.js +0 -327
  39. package/packages/cloud/dist/api/consensus.d.ts +0 -13
  40. package/packages/cloud/dist/api/consensus.js +0 -261
  41. package/packages/cloud/dist/api/coordinators.d.ts +0 -8
  42. package/packages/cloud/dist/api/coordinators.js +0 -750
  43. package/packages/cloud/dist/api/daemons.d.ts +0 -12
  44. package/packages/cloud/dist/api/daemons.js +0 -535
  45. package/packages/cloud/dist/api/email-auth.d.ts +0 -11
  46. package/packages/cloud/dist/api/email-auth.js +0 -347
  47. package/packages/cloud/dist/api/generic-webhooks.d.ts +0 -8
  48. package/packages/cloud/dist/api/generic-webhooks.js +0 -129
  49. package/packages/cloud/dist/api/git.d.ts +0 -8
  50. package/packages/cloud/dist/api/git.js +0 -269
  51. package/packages/cloud/dist/api/github-app.d.ts +0 -11
  52. package/packages/cloud/dist/api/github-app.js +0 -223
  53. package/packages/cloud/dist/api/middleware/planLimits.d.ts +0 -43
  54. package/packages/cloud/dist/api/middleware/planLimits.js +0 -202
  55. package/packages/cloud/dist/api/monitoring.d.ts +0 -11
  56. package/packages/cloud/dist/api/monitoring.js +0 -578
  57. package/packages/cloud/dist/api/nango-auth.d.ts +0 -9
  58. package/packages/cloud/dist/api/nango-auth.js +0 -741
  59. package/packages/cloud/dist/api/onboarding.d.ts +0 -15
  60. package/packages/cloud/dist/api/onboarding.js +0 -679
  61. package/packages/cloud/dist/api/policy.d.ts +0 -8
  62. package/packages/cloud/dist/api/policy.js +0 -229
  63. package/packages/cloud/dist/api/provider-env.d.ts +0 -26
  64. package/packages/cloud/dist/api/provider-env.js +0 -141
  65. package/packages/cloud/dist/api/providers.d.ts +0 -7
  66. package/packages/cloud/dist/api/providers.js +0 -574
  67. package/packages/cloud/dist/api/repos.d.ts +0 -8
  68. package/packages/cloud/dist/api/repos.js +0 -577
  69. package/packages/cloud/dist/api/sessions.d.ts +0 -11
  70. package/packages/cloud/dist/api/sessions.js +0 -302
  71. package/packages/cloud/dist/api/teams.d.ts +0 -7
  72. package/packages/cloud/dist/api/teams.js +0 -281
  73. package/packages/cloud/dist/api/test-helpers.d.ts +0 -10
  74. package/packages/cloud/dist/api/test-helpers.js +0 -745
  75. package/packages/cloud/dist/api/usage.d.ts +0 -7
  76. package/packages/cloud/dist/api/usage.js +0 -111
  77. package/packages/cloud/dist/api/webhooks.d.ts +0 -8
  78. package/packages/cloud/dist/api/webhooks.js +0 -645
  79. package/packages/cloud/dist/api/workspaces.d.ts +0 -25
  80. package/packages/cloud/dist/api/workspaces.js +0 -1799
  81. package/packages/cloud/dist/billing/index.d.ts +0 -9
  82. package/packages/cloud/dist/billing/index.js +0 -9
  83. package/packages/cloud/dist/billing/plans.d.ts +0 -39
  84. package/packages/cloud/dist/billing/plans.js +0 -245
  85. package/packages/cloud/dist/billing/service.d.ts +0 -80
  86. package/packages/cloud/dist/billing/service.js +0 -388
  87. package/packages/cloud/dist/billing/types.d.ts +0 -141
  88. package/packages/cloud/dist/billing/types.js +0 -7
  89. package/packages/cloud/dist/config.d.ts +0 -5
  90. package/packages/cloud/dist/config.js +0 -5
  91. package/packages/cloud/dist/db/bulk-ingest.d.ts +0 -89
  92. package/packages/cloud/dist/db/bulk-ingest.js +0 -268
  93. package/packages/cloud/dist/db/drizzle.d.ts +0 -290
  94. package/packages/cloud/dist/db/drizzle.js +0 -1422
  95. package/packages/cloud/dist/db/index.d.ts +0 -56
  96. package/packages/cloud/dist/db/index.js +0 -70
  97. package/packages/cloud/dist/db/schema.d.ts +0 -5117
  98. package/packages/cloud/dist/db/schema.js +0 -656
  99. package/packages/cloud/dist/index.d.ts +0 -11
  100. package/packages/cloud/dist/index.js +0 -38
  101. package/packages/cloud/dist/provisioner/index.d.ts +0 -207
  102. package/packages/cloud/dist/provisioner/index.js +0 -2118
  103. package/packages/cloud/dist/server.d.ts +0 -17
  104. package/packages/cloud/dist/server.js +0 -2055
  105. package/packages/cloud/dist/services/auto-scaler.d.ts +0 -152
  106. package/packages/cloud/dist/services/auto-scaler.js +0 -439
  107. package/packages/cloud/dist/services/capacity-manager.d.ts +0 -148
  108. package/packages/cloud/dist/services/capacity-manager.js +0 -449
  109. package/packages/cloud/dist/services/ci-agent-spawner.d.ts +0 -49
  110. package/packages/cloud/dist/services/ci-agent-spawner.js +0 -373
  111. package/packages/cloud/dist/services/cloud-message-bus.d.ts +0 -28
  112. package/packages/cloud/dist/services/cloud-message-bus.js +0 -19
  113. package/packages/cloud/dist/services/compute-enforcement.d.ts +0 -57
  114. package/packages/cloud/dist/services/compute-enforcement.js +0 -175
  115. package/packages/cloud/dist/services/coordinator.d.ts +0 -62
  116. package/packages/cloud/dist/services/coordinator.js +0 -389
  117. package/packages/cloud/dist/services/index.d.ts +0 -17
  118. package/packages/cloud/dist/services/index.js +0 -25
  119. package/packages/cloud/dist/services/intro-expiration.d.ts +0 -60
  120. package/packages/cloud/dist/services/intro-expiration.js +0 -252
  121. package/packages/cloud/dist/services/mention-handler.d.ts +0 -65
  122. package/packages/cloud/dist/services/mention-handler.js +0 -405
  123. package/packages/cloud/dist/services/nango.d.ts +0 -219
  124. package/packages/cloud/dist/services/nango.js +0 -424
  125. package/packages/cloud/dist/services/persistence.d.ts +0 -131
  126. package/packages/cloud/dist/services/persistence.js +0 -200
  127. package/packages/cloud/dist/services/planLimits.d.ts +0 -147
  128. package/packages/cloud/dist/services/planLimits.js +0 -335
  129. package/packages/cloud/dist/services/presence-registry.d.ts +0 -56
  130. package/packages/cloud/dist/services/presence-registry.js +0 -91
  131. package/packages/cloud/dist/services/scaling-orchestrator.d.ts +0 -159
  132. package/packages/cloud/dist/services/scaling-orchestrator.js +0 -502
  133. package/packages/cloud/dist/services/scaling-policy.d.ts +0 -121
  134. package/packages/cloud/dist/services/scaling-policy.js +0 -415
  135. package/packages/cloud/dist/services/ssh-security.d.ts +0 -31
  136. package/packages/cloud/dist/services/ssh-security.js +0 -63
  137. package/packages/cloud/dist/services/workspace-keepalive.d.ts +0 -76
  138. package/packages/cloud/dist/services/workspace-keepalive.js +0 -234
  139. package/packages/cloud/dist/shims/consensus.d.ts +0 -23
  140. package/packages/cloud/dist/shims/consensus.js +0 -5
  141. package/packages/cloud/dist/webhooks/index.d.ts +0 -24
  142. package/packages/cloud/dist/webhooks/index.js +0 -29
  143. package/packages/cloud/dist/webhooks/parsers/github.d.ts +0 -8
  144. package/packages/cloud/dist/webhooks/parsers/github.js +0 -234
  145. package/packages/cloud/dist/webhooks/parsers/index.d.ts +0 -23
  146. package/packages/cloud/dist/webhooks/parsers/index.js +0 -30
  147. package/packages/cloud/dist/webhooks/parsers/linear.d.ts +0 -9
  148. package/packages/cloud/dist/webhooks/parsers/linear.js +0 -258
  149. package/packages/cloud/dist/webhooks/parsers/slack.d.ts +0 -9
  150. package/packages/cloud/dist/webhooks/parsers/slack.js +0 -214
  151. package/packages/cloud/dist/webhooks/responders/github.d.ts +0 -8
  152. package/packages/cloud/dist/webhooks/responders/github.js +0 -73
  153. package/packages/cloud/dist/webhooks/responders/index.d.ts +0 -23
  154. package/packages/cloud/dist/webhooks/responders/index.js +0 -30
  155. package/packages/cloud/dist/webhooks/responders/linear.d.ts +0 -9
  156. package/packages/cloud/dist/webhooks/responders/linear.js +0 -149
  157. package/packages/cloud/dist/webhooks/responders/slack.d.ts +0 -20
  158. package/packages/cloud/dist/webhooks/responders/slack.js +0 -178
  159. package/packages/cloud/dist/webhooks/router.d.ts +0 -25
  160. package/packages/cloud/dist/webhooks/router.js +0 -504
  161. package/packages/cloud/dist/webhooks/rules-engine.d.ts +0 -24
  162. package/packages/cloud/dist/webhooks/rules-engine.js +0 -287
  163. package/packages/cloud/dist/webhooks/types.d.ts +0 -186
  164. package/packages/cloud/dist/webhooks/types.js +0 -8
  165. package/packages/cloud/package.json +0 -60
  166. package/scripts/run-migrations.js +0 -43
  167. package/scripts/setup-stripe-products.ts +0 -312
  168. package/scripts/verify-schema.js +0 -134
@@ -1,261 +0,0 @@
1
- /**
2
- * Consensus API Routes (Read-Only)
3
- *
4
- * Provides API endpoints for observing multi-agent consensus decisions.
5
- * The dashboard is read-only - agents handle all consensus activity via relay messages.
6
- *
7
- * Architecture:
8
- * - Agents create proposals and vote via ->relay:_consensus messages
9
- * - The daemon processes these and syncs state to cloud via /sync endpoint
10
- * - Dashboard reads consensus state for display only
11
- */
12
- import { Router } from 'express';
13
- import { createHash } from 'crypto';
14
- import { requireAuth } from './auth.js';
15
- /**
16
- * Hash an API key for lookup
17
- */
18
- function hashApiKey(apiKey) {
19
- return createHash('sha256').update(apiKey).digest('hex');
20
- }
21
- export const consensusRouter = Router();
22
- // ============================================================================
23
- // In-Memory Consensus State (synced from daemon)
24
- // ============================================================================
25
- // Stores proposals synced from the daemon
26
- // In production, this would be backed by a database
27
- const workspaceProposals = new Map();
28
- function getProposalsForWorkspace(workspaceId) {
29
- let proposals = workspaceProposals.get(workspaceId);
30
- if (!proposals) {
31
- proposals = new Map();
32
- workspaceProposals.set(workspaceId, proposals);
33
- }
34
- return proposals;
35
- }
36
- function computeStats(proposals) {
37
- let pending = 0;
38
- let approved = 0;
39
- let rejected = 0;
40
- let expired = 0;
41
- let cancelled = 0;
42
- for (const proposal of proposals.values()) {
43
- switch (proposal.status) {
44
- case 'pending':
45
- pending++;
46
- break;
47
- case 'approved':
48
- approved++;
49
- break;
50
- case 'rejected':
51
- rejected++;
52
- break;
53
- case 'expired':
54
- expired++;
55
- break;
56
- case 'cancelled':
57
- cancelled++;
58
- break;
59
- }
60
- }
61
- return {
62
- total: proposals.size,
63
- pending,
64
- approved,
65
- rejected,
66
- expired,
67
- cancelled,
68
- };
69
- }
70
- // ============================================================================
71
- // Read-Only Routes (require user authentication)
72
- // ============================================================================
73
- /**
74
- * GET /api/workspaces/:workspaceId/consensus/proposals
75
- * List all proposals for a workspace (read-only)
76
- */
77
- consensusRouter.get('/workspaces/:workspaceId/consensus/proposals', requireAuth, async (req, res) => {
78
- try {
79
- const workspaceId = req.params.workspaceId;
80
- const { status, agent } = req.query;
81
- const proposalsMap = getProposalsForWorkspace(workspaceId);
82
- let proposals = Array.from(proposalsMap.values());
83
- // Filter by agent if provided
84
- if (agent && typeof agent === 'string') {
85
- proposals = proposals.filter(p => p.proposer === agent || p.participants.includes(agent));
86
- }
87
- // Filter by status if provided
88
- if (status && typeof status === 'string') {
89
- proposals = proposals.filter(p => p.status === status);
90
- }
91
- // Sort by creation time (most recent first)
92
- proposals.sort((a, b) => b.createdAt - a.createdAt);
93
- const stats = computeStats(proposalsMap);
94
- res.json({
95
- proposals,
96
- stats,
97
- });
98
- }
99
- catch (error) {
100
- console.error('Error listing proposals:', error);
101
- res.status(500).json({ error: 'Failed to list proposals' });
102
- }
103
- });
104
- /**
105
- * GET /api/workspaces/:workspaceId/consensus/proposals/:proposalId
106
- * Get a specific proposal (read-only)
107
- */
108
- consensusRouter.get('/workspaces/:workspaceId/consensus/proposals/:proposalId', requireAuth, async (req, res) => {
109
- try {
110
- const workspaceId = req.params.workspaceId;
111
- const proposalId = req.params.proposalId;
112
- const proposalsMap = getProposalsForWorkspace(workspaceId);
113
- const proposal = proposalsMap.get(proposalId);
114
- if (!proposal) {
115
- return res.status(404).json({ error: 'Proposal not found' });
116
- }
117
- res.json({ proposal });
118
- }
119
- catch (error) {
120
- console.error('Error getting proposal:', error);
121
- res.status(500).json({ error: 'Failed to get proposal' });
122
- }
123
- });
124
- /**
125
- * GET /api/workspaces/:workspaceId/consensus/agents/:agentName/pending
126
- * Get pending votes for an agent (read-only)
127
- */
128
- consensusRouter.get('/workspaces/:workspaceId/consensus/agents/:agentName/pending', requireAuth, async (req, res) => {
129
- try {
130
- const workspaceId = req.params.workspaceId;
131
- const agentName = req.params.agentName;
132
- const proposalsMap = getProposalsForWorkspace(workspaceId);
133
- const proposals = Array.from(proposalsMap.values()).filter((p) => {
134
- if (p.status !== 'pending')
135
- return false;
136
- if (!p.participants.includes(agentName))
137
- return false;
138
- // Check if agent hasn't voted yet
139
- return !p.votes.some((v) => v.agent === agentName);
140
- });
141
- res.json({ proposals });
142
- }
143
- catch (error) {
144
- console.error('Error getting pending votes:', error);
145
- res.status(500).json({ error: 'Failed to get pending votes' });
146
- }
147
- });
148
- /**
149
- * GET /api/workspaces/:workspaceId/consensus/stats
150
- * Get consensus statistics for a workspace (read-only)
151
- */
152
- consensusRouter.get('/workspaces/:workspaceId/consensus/stats', requireAuth, async (req, res) => {
153
- try {
154
- const workspaceId = req.params.workspaceId;
155
- const proposalsMap = getProposalsForWorkspace(workspaceId);
156
- const stats = computeStats(proposalsMap);
157
- res.json({ stats });
158
- }
159
- catch (error) {
160
- console.error('Error getting consensus stats:', error);
161
- res.status(500).json({ error: 'Failed to get consensus stats' });
162
- }
163
- });
164
- // ============================================================================
165
- // Sync Endpoint (daemon -> cloud)
166
- // ============================================================================
167
- /**
168
- * POST /api/daemons/consensus/sync
169
- * Sync consensus state from daemon (called by daemon on proposal events)
170
- *
171
- * This endpoint receives state updates from the daemon and stores them
172
- * so the dashboard can display agent consensus activity.
173
- *
174
- * Authentication options (in order of precedence):
175
- * 1. Daemon API key (Authorization: Bearer ar_live_xxx) - workspace from daemon record
176
- * 2. Workspace ID in request body - for self-hosted setups
177
- * 3. Default workspace "local" - for simple local development
178
- */
179
- consensusRouter.post('/daemons/consensus/sync', async (req, res) => {
180
- try {
181
- const { proposal, event, workspaceId: bodyWorkspaceId } = req.body;
182
- if (!proposal || !event) {
183
- return res.status(400).json({ error: 'Missing proposal or event' });
184
- }
185
- let workspaceId;
186
- // Try to authenticate via API key first
187
- const authHeader = req.headers.authorization;
188
- if (authHeader?.startsWith('Bearer ar_live_')) {
189
- const apiKey = authHeader.replace('Bearer ', '');
190
- const apiKeyHash = hashApiKey(apiKey);
191
- const { db } = await import('../db/index.js');
192
- const daemon = await db.linkedDaemons.findByApiKeyHash(apiKeyHash);
193
- if (daemon?.workspaceId) {
194
- workspaceId = daemon.workspaceId;
195
- }
196
- else if (bodyWorkspaceId) {
197
- workspaceId = bodyWorkspaceId;
198
- }
199
- else {
200
- return res.status(400).json({ error: 'Daemon not associated with a workspace' });
201
- }
202
- }
203
- else if (bodyWorkspaceId) {
204
- // Self-hosted: workspace specified in body
205
- workspaceId = bodyWorkspaceId;
206
- }
207
- else {
208
- // Default for simple local setups
209
- workspaceId = 'local';
210
- }
211
- // Store/update the proposal
212
- const proposalsMap = getProposalsForWorkspace(workspaceId);
213
- proposalsMap.set(proposal.id, proposal);
214
- console.log(`[consensus] Synced ${event} for proposal "${proposal.title}" (${proposal.id}) in workspace ${workspaceId}`);
215
- res.json({ success: true, workspaceId });
216
- }
217
- catch (error) {
218
- console.error('Error syncing consensus:', error);
219
- res.status(500).json({ error: 'Failed to sync consensus' });
220
- }
221
- });
222
- /**
223
- * DELETE /api/daemons/consensus/proposals/:proposalId
224
- * Remove a proposal from the sync cache (daemon cleanup)
225
- *
226
- * Authentication: Uses daemon API key (Authorization: Bearer ar_live_xxx)
227
- * Workspace is derived from the linked daemon's record.
228
- */
229
- consensusRouter.delete('/daemons/consensus/proposals/:proposalId', async (req, res) => {
230
- try {
231
- // Check for daemon API key (Bearer token)
232
- const authHeader = req.headers.authorization;
233
- if (!authHeader?.startsWith('Bearer ar_live_')) {
234
- return res.status(401).json({ error: 'Unauthorized - daemon API key required' });
235
- }
236
- // Validate the API key
237
- const apiKey = authHeader.replace('Bearer ', '');
238
- const apiKeyHash = hashApiKey(apiKey);
239
- const { db } = await import('../db/index.js');
240
- const daemon = await db.linkedDaemons.findByApiKeyHash(apiKeyHash);
241
- if (!daemon) {
242
- return res.status(401).json({ error: 'Invalid API key' });
243
- }
244
- if (!daemon.workspaceId) {
245
- return res.status(400).json({ error: 'Daemon not associated with a workspace' });
246
- }
247
- const proposalId = req.params.proposalId;
248
- const proposalsMap = getProposalsForWorkspace(daemon.workspaceId);
249
- const deleted = proposalsMap.delete(proposalId);
250
- if (!deleted) {
251
- return res.status(404).json({ error: 'Proposal not found' });
252
- }
253
- console.log(`[consensus] Removed proposal ${proposalId} from workspace ${daemon.workspaceId}`);
254
- res.json({ success: true });
255
- }
256
- catch (error) {
257
- console.error('Error removing proposal:', error);
258
- res.status(500).json({ error: 'Failed to remove proposal' });
259
- }
260
- });
261
- //# sourceMappingURL=consensus.js.map
@@ -1,8 +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
- export declare const coordinatorsRouter: import("express-serve-static-core").Router;
8
- //# sourceMappingURL=coordinators.d.ts.map