agent-relay 1.0.21 → 1.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 (283) hide show
  1. package/dist/bridge/shadow-cli.d.ts +17 -0
  2. package/dist/bridge/shadow-cli.d.ts.map +1 -0
  3. package/dist/bridge/shadow-cli.js +75 -0
  4. package/dist/bridge/shadow-cli.js.map +1 -0
  5. package/dist/bridge/shadow-config.d.ts +87 -0
  6. package/dist/bridge/shadow-config.d.ts.map +1 -0
  7. package/dist/bridge/shadow-config.js +134 -0
  8. package/dist/bridge/shadow-config.js.map +1 -0
  9. package/dist/bridge/spawner.d.ts +15 -1
  10. package/dist/bridge/spawner.d.ts.map +1 -1
  11. package/dist/bridge/spawner.js +164 -4
  12. package/dist/bridge/spawner.js.map +1 -1
  13. package/dist/bridge/types.d.ts +55 -0
  14. package/dist/bridge/types.d.ts.map +1 -1
  15. package/dist/cli/index.js +796 -11
  16. package/dist/cli/index.js.map +1 -1
  17. package/dist/cloud/api/auth.d.ts +19 -0
  18. package/dist/cloud/api/auth.d.ts.map +1 -0
  19. package/dist/cloud/api/auth.js +216 -0
  20. package/dist/cloud/api/auth.js.map +1 -0
  21. package/dist/cloud/api/billing.d.ts +17 -0
  22. package/dist/cloud/api/billing.d.ts.map +1 -0
  23. package/dist/cloud/api/billing.js +353 -0
  24. package/dist/cloud/api/billing.js.map +1 -0
  25. package/dist/cloud/api/coordinators.d.ts +8 -0
  26. package/dist/cloud/api/coordinators.d.ts.map +1 -0
  27. package/dist/cloud/api/coordinators.js +347 -0
  28. package/dist/cloud/api/coordinators.js.map +1 -0
  29. package/dist/cloud/api/daemons.d.ts +12 -0
  30. package/dist/cloud/api/daemons.d.ts.map +1 -0
  31. package/dist/cloud/api/daemons.js +320 -0
  32. package/dist/cloud/api/daemons.js.map +1 -0
  33. package/dist/cloud/api/middleware/planLimits.d.ts +36 -0
  34. package/dist/cloud/api/middleware/planLimits.d.ts.map +1 -0
  35. package/dist/cloud/api/middleware/planLimits.js +164 -0
  36. package/dist/cloud/api/middleware/planLimits.js.map +1 -0
  37. package/dist/cloud/api/onboarding.d.ts +8 -0
  38. package/dist/cloud/api/onboarding.d.ts.map +1 -0
  39. package/dist/cloud/api/onboarding.js +407 -0
  40. package/dist/cloud/api/onboarding.js.map +1 -0
  41. package/dist/cloud/api/providers.d.ts +7 -0
  42. package/dist/cloud/api/providers.d.ts.map +1 -0
  43. package/dist/cloud/api/providers.js +435 -0
  44. package/dist/cloud/api/providers.js.map +1 -0
  45. package/dist/cloud/api/repos.d.ts +7 -0
  46. package/dist/cloud/api/repos.d.ts.map +1 -0
  47. package/dist/cloud/api/repos.js +314 -0
  48. package/dist/cloud/api/repos.js.map +1 -0
  49. package/dist/cloud/api/teams.d.ts +7 -0
  50. package/dist/cloud/api/teams.d.ts.map +1 -0
  51. package/dist/cloud/api/teams.js +279 -0
  52. package/dist/cloud/api/teams.js.map +1 -0
  53. package/dist/cloud/api/usage.d.ts +7 -0
  54. package/dist/cloud/api/usage.d.ts.map +1 -0
  55. package/dist/cloud/api/usage.js +98 -0
  56. package/dist/cloud/api/usage.js.map +1 -0
  57. package/dist/cloud/api/workspaces.d.ts +7 -0
  58. package/dist/cloud/api/workspaces.d.ts.map +1 -0
  59. package/dist/cloud/api/workspaces.js +510 -0
  60. package/dist/cloud/api/workspaces.js.map +1 -0
  61. package/dist/cloud/billing/index.d.ts +9 -0
  62. package/dist/cloud/billing/index.d.ts.map +1 -0
  63. package/dist/cloud/billing/index.js +9 -0
  64. package/dist/cloud/billing/index.js.map +1 -0
  65. package/dist/cloud/billing/plans.d.ts +39 -0
  66. package/dist/cloud/billing/plans.d.ts.map +1 -0
  67. package/dist/cloud/billing/plans.js +232 -0
  68. package/dist/cloud/billing/plans.js.map +1 -0
  69. package/dist/cloud/billing/service.d.ts +80 -0
  70. package/dist/cloud/billing/service.d.ts.map +1 -0
  71. package/dist/cloud/billing/service.js +388 -0
  72. package/dist/cloud/billing/service.js.map +1 -0
  73. package/dist/cloud/billing/types.d.ts +135 -0
  74. package/dist/cloud/billing/types.d.ts.map +1 -0
  75. package/dist/cloud/billing/types.js +7 -0
  76. package/dist/cloud/billing/types.js.map +1 -0
  77. package/dist/cloud/config.d.ts +59 -0
  78. package/dist/cloud/config.d.ts.map +1 -0
  79. package/dist/cloud/config.js +83 -0
  80. package/dist/cloud/config.js.map +1 -0
  81. package/dist/cloud/db/drizzle.d.ts +132 -0
  82. package/dist/cloud/db/drizzle.d.ts.map +1 -0
  83. package/dist/cloud/db/drizzle.js +613 -0
  84. package/dist/cloud/db/drizzle.js.map +1 -0
  85. package/dist/cloud/db/index.d.ts +30 -0
  86. package/dist/cloud/db/index.d.ts.map +1 -0
  87. package/dist/cloud/db/index.js +44 -0
  88. package/dist/cloud/db/index.js.map +1 -0
  89. package/dist/cloud/db/schema.d.ts +1792 -0
  90. package/dist/cloud/db/schema.d.ts.map +1 -0
  91. package/dist/cloud/db/schema.js +234 -0
  92. package/dist/cloud/db/schema.js.map +1 -0
  93. package/dist/cloud/index.d.ts +11 -0
  94. package/dist/cloud/index.d.ts.map +1 -0
  95. package/dist/cloud/index.js +37 -0
  96. package/dist/cloud/index.js.map +1 -0
  97. package/dist/cloud/provisioner/index.d.ts +51 -0
  98. package/dist/cloud/provisioner/index.d.ts.map +1 -0
  99. package/dist/cloud/provisioner/index.js +676 -0
  100. package/dist/cloud/provisioner/index.js.map +1 -0
  101. package/dist/cloud/server.d.ts +16 -0
  102. package/dist/cloud/server.d.ts.map +1 -0
  103. package/dist/cloud/server.js +190 -0
  104. package/dist/cloud/server.js.map +1 -0
  105. package/dist/cloud/services/coordinator.d.ts +62 -0
  106. package/dist/cloud/services/coordinator.d.ts.map +1 -0
  107. package/dist/cloud/services/coordinator.js +389 -0
  108. package/dist/cloud/services/coordinator.js.map +1 -0
  109. package/dist/cloud/services/planLimits.d.ts +110 -0
  110. package/dist/cloud/services/planLimits.d.ts.map +1 -0
  111. package/dist/cloud/services/planLimits.js +254 -0
  112. package/dist/cloud/services/planLimits.js.map +1 -0
  113. package/dist/cloud/vault/index.d.ts +76 -0
  114. package/dist/cloud/vault/index.d.ts.map +1 -0
  115. package/dist/cloud/vault/index.js +219 -0
  116. package/dist/cloud/vault/index.js.map +1 -0
  117. package/dist/daemon/agent-manager.d.ts +87 -0
  118. package/dist/daemon/agent-manager.d.ts.map +1 -0
  119. package/dist/daemon/agent-manager.js +412 -0
  120. package/dist/daemon/agent-manager.js.map +1 -0
  121. package/dist/daemon/agent-registry.d.ts +2 -0
  122. package/dist/daemon/agent-registry.d.ts.map +1 -1
  123. package/dist/daemon/agent-registry.js +3 -0
  124. package/dist/daemon/agent-registry.js.map +1 -1
  125. package/dist/daemon/api.d.ts +69 -0
  126. package/dist/daemon/api.d.ts.map +1 -0
  127. package/dist/daemon/api.js +425 -0
  128. package/dist/daemon/api.js.map +1 -0
  129. package/dist/daemon/cloud-sync.d.ts +101 -0
  130. package/dist/daemon/cloud-sync.d.ts.map +1 -0
  131. package/dist/daemon/cloud-sync.js +261 -0
  132. package/dist/daemon/cloud-sync.js.map +1 -0
  133. package/dist/daemon/index.d.ts +4 -0
  134. package/dist/daemon/index.d.ts.map +1 -1
  135. package/dist/daemon/index.js +6 -0
  136. package/dist/daemon/index.js.map +1 -1
  137. package/dist/daemon/orchestrator.d.ts +155 -0
  138. package/dist/daemon/orchestrator.d.ts.map +1 -0
  139. package/dist/daemon/orchestrator.js +736 -0
  140. package/dist/daemon/orchestrator.js.map +1 -0
  141. package/dist/daemon/router.d.ts +24 -0
  142. package/dist/daemon/router.d.ts.map +1 -1
  143. package/dist/daemon/router.js +71 -1
  144. package/dist/daemon/router.js.map +1 -1
  145. package/dist/daemon/server.d.ts +37 -0
  146. package/dist/daemon/server.d.ts.map +1 -1
  147. package/dist/daemon/server.js +191 -16
  148. package/dist/daemon/server.js.map +1 -1
  149. package/dist/daemon/types.d.ts +127 -0
  150. package/dist/daemon/types.d.ts.map +1 -0
  151. package/dist/daemon/types.js +6 -0
  152. package/dist/daemon/types.js.map +1 -0
  153. package/dist/daemon/workspace-manager.d.ts +75 -0
  154. package/dist/daemon/workspace-manager.d.ts.map +1 -0
  155. package/dist/daemon/workspace-manager.js +289 -0
  156. package/dist/daemon/workspace-manager.js.map +1 -0
  157. package/dist/dashboard/out/404.html +1 -1
  158. package/dist/dashboard/out/_next/static/chunks/693-7b3301d8f6bc5014.js +1 -0
  159. package/dist/dashboard/out/_next/static/chunks/713-f78477eb185f1f4d.js +1 -0
  160. package/dist/dashboard/out/_next/static/chunks/766-e53e1cfe39b0b5b5.js +1 -0
  161. package/dist/dashboard/out/_next/static/chunks/900-037c64bfd797fb2a.js +1 -0
  162. package/dist/dashboard/out/_next/static/chunks/app/app/page-e3d9e1f4466b9bae.js +1 -0
  163. package/dist/dashboard/out/_next/static/chunks/app/history/page-b6edd4dde8d08194.js +1 -0
  164. package/dist/dashboard/out/_next/static/chunks/app/layout-2433bb48965f4333.js +1 -0
  165. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-e68825a81db67ba1.js +1 -0
  166. package/dist/dashboard/out/_next/static/chunks/app/page-cc108bf68c8a657f.js +1 -0
  167. package/dist/dashboard/out/_next/static/chunks/app/pricing/page-d80e03a5297f95b6.js +1 -0
  168. package/dist/dashboard/out/_next/static/chunks/main-app-5d692157a8eb1fd9.js +1 -0
  169. package/dist/dashboard/out/_next/static/chunks/{main-e0a1f53fe0617a63.js → main-c2f423b9c9f4591b.js} +1 -1
  170. package/dist/dashboard/out/_next/static/chunks/{webpack-c81f7fd28659d64f.js → webpack-a5acc2831d094776.js} +1 -1
  171. package/dist/dashboard/out/_next/static/css/79b80143647a07d7.css +1 -0
  172. package/dist/dashboard/out/_next/static/css/8cf277370ad48cfe.css +1 -0
  173. package/dist/dashboard/out/alt-logos/agent-relay-logo-128.png +0 -0
  174. package/dist/dashboard/out/alt-logos/agent-relay-logo-256.png +0 -0
  175. package/dist/dashboard/out/alt-logos/agent-relay-logo-32.png +0 -0
  176. package/dist/dashboard/out/alt-logos/agent-relay-logo-512.png +0 -0
  177. package/dist/dashboard/out/alt-logos/agent-relay-logo-64.png +0 -0
  178. package/dist/dashboard/out/alt-logos/agent-relay-logo.svg +45 -0
  179. package/dist/dashboard/out/alt-logos/logo.svg +38 -0
  180. package/dist/dashboard/out/alt-logos/monogram-logo-128.png +0 -0
  181. package/dist/dashboard/out/alt-logos/monogram-logo-256.png +0 -0
  182. package/dist/dashboard/out/alt-logos/monogram-logo-32.png +0 -0
  183. package/dist/dashboard/out/alt-logos/monogram-logo-512.png +0 -0
  184. package/dist/dashboard/out/alt-logos/monogram-logo-64.png +0 -0
  185. package/dist/dashboard/out/alt-logos/monogram-logo.svg +38 -0
  186. package/dist/dashboard/out/app.html +14 -0
  187. package/dist/dashboard/out/app.txt +7 -0
  188. package/dist/dashboard/out/history.html +1 -0
  189. package/dist/dashboard/out/history.txt +7 -0
  190. package/dist/dashboard/out/index.html +1 -1
  191. package/dist/dashboard/out/index.txt +2 -2
  192. package/dist/dashboard/out/metrics.html +1 -515
  193. package/dist/dashboard/out/metrics.txt +2 -2
  194. package/dist/dashboard/out/pricing.html +13 -0
  195. package/dist/dashboard/out/pricing.txt +7 -0
  196. package/dist/dashboard-server/metrics.d.ts.map +1 -1
  197. package/dist/dashboard-server/metrics.js +3 -2
  198. package/dist/dashboard-server/metrics.js.map +1 -1
  199. package/dist/dashboard-server/server.d.ts.map +1 -1
  200. package/dist/dashboard-server/server.js +1279 -56
  201. package/dist/dashboard-server/server.js.map +1 -1
  202. package/dist/protocol/types.d.ts +10 -1
  203. package/dist/protocol/types.d.ts.map +1 -1
  204. package/dist/resiliency/context-persistence.d.ts +140 -0
  205. package/dist/resiliency/context-persistence.d.ts.map +1 -0
  206. package/dist/resiliency/context-persistence.js +397 -0
  207. package/dist/resiliency/context-persistence.js.map +1 -0
  208. package/dist/resiliency/health-monitor.d.ts +97 -0
  209. package/dist/resiliency/health-monitor.d.ts.map +1 -0
  210. package/dist/resiliency/health-monitor.js +291 -0
  211. package/dist/resiliency/health-monitor.js.map +1 -0
  212. package/dist/resiliency/index.d.ts +63 -0
  213. package/dist/resiliency/index.d.ts.map +1 -0
  214. package/dist/resiliency/index.js +63 -0
  215. package/dist/resiliency/index.js.map +1 -0
  216. package/dist/resiliency/logger.d.ts +114 -0
  217. package/dist/resiliency/logger.d.ts.map +1 -0
  218. package/dist/resiliency/logger.js +250 -0
  219. package/dist/resiliency/logger.js.map +1 -0
  220. package/dist/resiliency/metrics.d.ts +115 -0
  221. package/dist/resiliency/metrics.d.ts.map +1 -0
  222. package/dist/resiliency/metrics.js +239 -0
  223. package/dist/resiliency/metrics.js.map +1 -0
  224. package/dist/resiliency/provider-context.d.ts +100 -0
  225. package/dist/resiliency/provider-context.d.ts.map +1 -0
  226. package/dist/resiliency/provider-context.js +360 -0
  227. package/dist/resiliency/provider-context.js.map +1 -0
  228. package/dist/resiliency/supervisor.d.ts +109 -0
  229. package/dist/resiliency/supervisor.d.ts.map +1 -0
  230. package/dist/resiliency/supervisor.js +337 -0
  231. package/dist/resiliency/supervisor.js.map +1 -0
  232. package/dist/storage/adapter.d.ts +2 -0
  233. package/dist/storage/adapter.d.ts.map +1 -1
  234. package/dist/storage/adapter.js +12 -2
  235. package/dist/storage/adapter.js.map +1 -1
  236. package/dist/storage/sqlite-adapter.d.ts.map +1 -1
  237. package/dist/storage/sqlite-adapter.js +18 -14
  238. package/dist/storage/sqlite-adapter.js.map +1 -1
  239. package/dist/utils/index.d.ts +1 -0
  240. package/dist/utils/index.d.ts.map +1 -1
  241. package/dist/utils/index.js +1 -0
  242. package/dist/utils/index.js.map +1 -1
  243. package/dist/utils/logger.d.ts +40 -0
  244. package/dist/utils/logger.d.ts.map +1 -0
  245. package/dist/utils/logger.js +84 -0
  246. package/dist/utils/logger.js.map +1 -0
  247. package/dist/wrapper/client.d.ts +16 -1
  248. package/dist/wrapper/client.d.ts.map +1 -1
  249. package/dist/wrapper/client.js +32 -1
  250. package/dist/wrapper/client.js.map +1 -1
  251. package/dist/wrapper/parser.d.ts +3 -0
  252. package/dist/wrapper/parser.d.ts.map +1 -1
  253. package/dist/wrapper/parser.js +121 -18
  254. package/dist/wrapper/parser.js.map +1 -1
  255. package/dist/wrapper/pty-wrapper.d.ts +28 -1
  256. package/dist/wrapper/pty-wrapper.d.ts.map +1 -1
  257. package/dist/wrapper/pty-wrapper.js +166 -30
  258. package/dist/wrapper/pty-wrapper.js.map +1 -1
  259. package/dist/wrapper/tmux-wrapper.d.ts +5 -0
  260. package/dist/wrapper/tmux-wrapper.d.ts.map +1 -1
  261. package/dist/wrapper/tmux-wrapper.js +58 -18
  262. package/dist/wrapper/tmux-wrapper.js.map +1 -1
  263. package/docs/CLOUD-ARCHITECTURE.md +652 -0
  264. package/docs/CLOUD-ONBOARDING-DESIGN.md +1983 -0
  265. package/docs/TESTING_PRESENCE_FEATURES.md +327 -0
  266. package/docs/agent-relay-snippet.md +107 -4
  267. package/docs/guides/CLOUD.md +236 -0
  268. package/docs/guides/LOCAL.md +535 -0
  269. package/docs/guides/SELF-HOSTED.md +494 -0
  270. package/docs/proposals/shadow-as-subagent.md +765 -0
  271. package/docs/proposals/slack-bot-integration.md +1457 -0
  272. package/package.json +33 -4
  273. package/dist/dashboard/out/_next/static/chunks/app/layout-c9d8c5d95e48c6bf.js +0 -1
  274. package/dist/dashboard/out/_next/static/chunks/app/metrics/page-8aa9936bc6c771ab.js +0 -1
  275. package/dist/dashboard/out/_next/static/chunks/app/page-49055e5d2b5e34ec.js +0 -1
  276. package/dist/dashboard/out/_next/static/chunks/main-app-bae2e535de00de50.js +0 -1
  277. package/dist/dashboard/out/_next/static/css/50ed6996e3df7bdd.css +0 -1
  278. /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_buildManifest.js +0 -0
  279. /package/dist/dashboard/out/_next/static/{gZXwjIKGDKJ0hiTH-HMeJ → 6HHWb2ZmnJ4OSm0zUP7h4}/_ssgManifest.js +0 -0
  280. /package/dist/dashboard/out/_next/static/chunks/{117-3bef7b19f3e60751.js → 117-b2cd8d6485aacf2b.js} +0 -0
  281. /package/dist/dashboard/out/_next/static/chunks/{648-6cf686106c891ad3.js → 648-8f3f26864ce515e5.js} +0 -0
  282. /package/dist/dashboard/out/_next/static/chunks/app/_not-found/{page-8ff6572bc7c9bc61.js → page-0b990dbb71d72a98.js} +0 -0
  283. /package/dist/dashboard/out/_next/static/chunks/{fd9d1056-26bd8d656b496dba.js → fd9d1056-bf46c09eb57e019c.js} +0 -0
@@ -0,0 +1,388 @@
1
+ /**
2
+ * Agent Relay Cloud - Billing Service
3
+ *
4
+ * Stripe integration for subscription management, payments, and webhooks.
5
+ */
6
+ import Stripe from 'stripe';
7
+ import { getConfig } from '../config.js';
8
+ import { getPlan } from './plans.js';
9
+ let stripeClient = null;
10
+ /**
11
+ * Get or create Stripe client
12
+ */
13
+ function getStripe() {
14
+ if (!stripeClient) {
15
+ const config = getConfig();
16
+ stripeClient = new Stripe(config.stripe.secretKey);
17
+ }
18
+ return stripeClient;
19
+ }
20
+ /**
21
+ * Billing Service
22
+ */
23
+ export class BillingService {
24
+ stripe;
25
+ constructor() {
26
+ this.stripe = getStripe();
27
+ }
28
+ /**
29
+ * Create or get a Stripe customer for a user
30
+ */
31
+ async getOrCreateCustomer(userId, email, name) {
32
+ // Search for existing customer by metadata
33
+ const existing = await this.stripe.customers.search({
34
+ query: `metadata['user_id']:'${userId}'`,
35
+ limit: 1,
36
+ });
37
+ if (existing.data.length > 0) {
38
+ return existing.data[0].id;
39
+ }
40
+ // Create new customer
41
+ const customer = await this.stripe.customers.create({
42
+ email,
43
+ name,
44
+ metadata: {
45
+ user_id: userId,
46
+ },
47
+ });
48
+ return customer.id;
49
+ }
50
+ /**
51
+ * Get customer details including subscription
52
+ */
53
+ async getCustomer(stripeCustomerId) {
54
+ try {
55
+ const customer = await this.stripe.customers.retrieve(stripeCustomerId, {
56
+ expand: ['subscriptions', 'invoice_settings.default_payment_method'],
57
+ });
58
+ if (customer.deleted) {
59
+ return null;
60
+ }
61
+ // Get payment methods
62
+ const paymentMethods = await this.stripe.paymentMethods.list({
63
+ customer: stripeCustomerId,
64
+ type: 'card',
65
+ });
66
+ // Get recent invoices
67
+ const invoices = await this.stripe.invoices.list({
68
+ customer: stripeCustomerId,
69
+ limit: 10,
70
+ });
71
+ const subscription = customer.subscriptions?.data[0];
72
+ return {
73
+ id: customer.metadata?.user_id || '',
74
+ stripeCustomerId,
75
+ email: customer.email || '',
76
+ name: customer.name || undefined,
77
+ subscription: subscription ? this.mapSubscription(subscription) : undefined,
78
+ paymentMethods: paymentMethods.data.map((pm) => this.mapPaymentMethod(pm)),
79
+ invoices: invoices.data.map((inv) => this.mapInvoice(inv)),
80
+ createdAt: new Date(customer.created * 1000),
81
+ updatedAt: new Date(),
82
+ };
83
+ }
84
+ catch (error) {
85
+ if (error.code === 'resource_missing') {
86
+ return null;
87
+ }
88
+ throw error;
89
+ }
90
+ }
91
+ /**
92
+ * Create a checkout session for subscription
93
+ */
94
+ async createCheckoutSession(customerId, tier, billingInterval, successUrl, cancelUrl) {
95
+ const config = getConfig();
96
+ // Validate tier exists
97
+ getPlan(tier);
98
+ // Get the appropriate price ID
99
+ let priceId;
100
+ if (billingInterval === 'month') {
101
+ priceId = config.stripe.priceIds[`${tier}Monthly`];
102
+ }
103
+ else {
104
+ priceId = config.stripe.priceIds[`${tier}Yearly`];
105
+ }
106
+ if (!priceId) {
107
+ throw new Error(`No price configured for ${tier} ${billingInterval}ly plan`);
108
+ }
109
+ const session = await this.stripe.checkout.sessions.create({
110
+ customer: customerId,
111
+ payment_method_types: ['card'],
112
+ mode: 'subscription',
113
+ line_items: [
114
+ {
115
+ price: priceId,
116
+ quantity: 1,
117
+ },
118
+ ],
119
+ success_url: successUrl,
120
+ cancel_url: cancelUrl,
121
+ subscription_data: {
122
+ metadata: {
123
+ tier,
124
+ },
125
+ },
126
+ allow_promotion_codes: true,
127
+ });
128
+ return {
129
+ sessionId: session.id,
130
+ url: session.url,
131
+ };
132
+ }
133
+ /**
134
+ * Create a billing portal session for managing subscription
135
+ */
136
+ async createPortalSession(customerId, returnUrl) {
137
+ const session = await this.stripe.billingPortal.sessions.create({
138
+ customer: customerId,
139
+ return_url: returnUrl,
140
+ });
141
+ return {
142
+ url: session.url,
143
+ };
144
+ }
145
+ /**
146
+ * Change subscription tier
147
+ */
148
+ async changeSubscription(subscriptionId, newTier, billingInterval) {
149
+ const config = getConfig();
150
+ // Get new price ID
151
+ let priceId;
152
+ if (billingInterval === 'month') {
153
+ priceId = config.stripe.priceIds[`${newTier}Monthly`];
154
+ }
155
+ else {
156
+ priceId = config.stripe.priceIds[`${newTier}Yearly`];
157
+ }
158
+ if (!priceId) {
159
+ throw new Error(`No price configured for ${newTier} ${billingInterval}ly plan`);
160
+ }
161
+ // Get current subscription
162
+ const subscription = await this.stripe.subscriptions.retrieve(subscriptionId);
163
+ const currentItem = subscription.items.data[0];
164
+ // Update subscription
165
+ const updated = await this.stripe.subscriptions.update(subscriptionId, {
166
+ items: [
167
+ {
168
+ id: currentItem.id,
169
+ price: priceId,
170
+ },
171
+ ],
172
+ metadata: {
173
+ tier: newTier,
174
+ },
175
+ proration_behavior: 'create_prorations',
176
+ });
177
+ return this.mapSubscription(updated);
178
+ }
179
+ /**
180
+ * Cancel subscription at period end
181
+ */
182
+ async cancelSubscription(subscriptionId) {
183
+ const subscription = await this.stripe.subscriptions.update(subscriptionId, {
184
+ cancel_at_period_end: true,
185
+ });
186
+ return this.mapSubscription(subscription);
187
+ }
188
+ /**
189
+ * Resume a canceled subscription
190
+ */
191
+ async resumeSubscription(subscriptionId) {
192
+ const subscription = await this.stripe.subscriptions.update(subscriptionId, {
193
+ cancel_at_period_end: false,
194
+ });
195
+ return this.mapSubscription(subscription);
196
+ }
197
+ /**
198
+ * Add a payment method to customer
199
+ */
200
+ async addPaymentMethod(customerId, paymentMethodId, setAsDefault = false) {
201
+ // Attach payment method to customer
202
+ const pm = await this.stripe.paymentMethods.attach(paymentMethodId, {
203
+ customer: customerId,
204
+ });
205
+ // Set as default if requested
206
+ if (setAsDefault) {
207
+ await this.stripe.customers.update(customerId, {
208
+ invoice_settings: {
209
+ default_payment_method: paymentMethodId,
210
+ },
211
+ });
212
+ }
213
+ return this.mapPaymentMethod(pm, setAsDefault);
214
+ }
215
+ /**
216
+ * Remove a payment method
217
+ */
218
+ async removePaymentMethod(paymentMethodId) {
219
+ await this.stripe.paymentMethods.detach(paymentMethodId);
220
+ }
221
+ /**
222
+ * Set default payment method
223
+ */
224
+ async setDefaultPaymentMethod(customerId, paymentMethodId) {
225
+ await this.stripe.customers.update(customerId, {
226
+ invoice_settings: {
227
+ default_payment_method: paymentMethodId,
228
+ },
229
+ });
230
+ }
231
+ /**
232
+ * Get upcoming invoice preview
233
+ */
234
+ async getUpcomingInvoice(customerId) {
235
+ try {
236
+ const invoice = await this.stripe.invoices.retrieveUpcoming({
237
+ customer: customerId,
238
+ });
239
+ return this.mapInvoice(invoice);
240
+ }
241
+ catch (error) {
242
+ if (error.code === 'invoice_upcoming_none') {
243
+ return null;
244
+ }
245
+ throw error;
246
+ }
247
+ }
248
+ /**
249
+ * Record usage for metered billing
250
+ */
251
+ async recordUsage(subscriptionItemId, quantity, timestamp) {
252
+ await this.stripe.subscriptionItems.createUsageRecord(subscriptionItemId, {
253
+ quantity,
254
+ timestamp: timestamp ? Math.floor(timestamp.getTime() / 1000) : undefined,
255
+ action: 'increment',
256
+ });
257
+ }
258
+ /**
259
+ * Verify webhook signature
260
+ */
261
+ verifyWebhookSignature(payload, signature) {
262
+ const config = getConfig();
263
+ return this.stripe.webhooks.constructEvent(payload, signature, config.stripe.webhookSecret);
264
+ }
265
+ /**
266
+ * Process webhook event
267
+ */
268
+ async processWebhookEvent(event) {
269
+ const billingEvent = {
270
+ id: event.id,
271
+ type: this.mapEventType(event.type),
272
+ stripeEventId: event.id,
273
+ data: event.data.object,
274
+ createdAt: new Date(event.created * 1000),
275
+ };
276
+ // Extract user ID from customer metadata if available
277
+ if ('customer' in event.data.object) {
278
+ const customerId = event.data.object.customer;
279
+ if (customerId) {
280
+ try {
281
+ const customer = await this.stripe.customers.retrieve(customerId);
282
+ if (!customer.deleted && customer.metadata?.user_id) {
283
+ billingEvent.userId = customer.metadata.user_id;
284
+ }
285
+ }
286
+ catch {
287
+ // Customer not found, continue without user ID
288
+ }
289
+ }
290
+ }
291
+ billingEvent.processedAt = new Date();
292
+ return billingEvent;
293
+ }
294
+ /**
295
+ * Get subscription tier from Stripe subscription
296
+ */
297
+ getTierFromSubscription(subscription) {
298
+ // Check metadata first
299
+ if (subscription.metadata?.tier) {
300
+ return subscription.metadata.tier;
301
+ }
302
+ // Fallback: determine from price ID
303
+ const config = getConfig();
304
+ const priceId = subscription.items.data[0]?.price.id;
305
+ for (const [key, value] of Object.entries(config.stripe.priceIds)) {
306
+ if (value === priceId) {
307
+ // Extract tier from key (e.g., 'proMonthly' -> 'pro')
308
+ return key.replace(/(Monthly|Yearly)$/, '').toLowerCase();
309
+ }
310
+ }
311
+ return 'free'; // Default fallback
312
+ }
313
+ // Helper: Map Stripe subscription to our type
314
+ mapSubscription(subscription) {
315
+ const sub = subscription;
316
+ return {
317
+ id: subscription.id,
318
+ stripeSubscriptionId: subscription.id,
319
+ tier: this.getTierFromSubscription(subscription),
320
+ status: subscription.status,
321
+ currentPeriodStart: new Date((sub.current_period_start || sub.billing_cycle_anchor) * 1000),
322
+ currentPeriodEnd: new Date((sub.current_period_end || sub.current_period_start + 30 * 24 * 60 * 60) * 1000),
323
+ cancelAtPeriodEnd: subscription.cancel_at_period_end,
324
+ billingInterval: subscription.items.data[0]?.price.recurring?.interval === 'year'
325
+ ? 'year'
326
+ : 'month',
327
+ createdAt: new Date(subscription.created * 1000),
328
+ };
329
+ }
330
+ // Helper: Map Stripe payment method to our type
331
+ mapPaymentMethod(pm, isDefault = false) {
332
+ return {
333
+ id: pm.id,
334
+ stripePaymentMethodId: pm.id,
335
+ type: pm.type,
336
+ isDefault,
337
+ card: pm.card
338
+ ? {
339
+ brand: pm.card.brand,
340
+ last4: pm.card.last4,
341
+ expMonth: pm.card.exp_month,
342
+ expYear: pm.card.exp_year,
343
+ }
344
+ : undefined,
345
+ };
346
+ }
347
+ // Helper: Map Stripe invoice to our type
348
+ mapInvoice(invoice) {
349
+ const isUpcoming = !('id' in invoice) || invoice.id === null;
350
+ return {
351
+ id: isUpcoming ? 'upcoming' : invoice.id,
352
+ stripeInvoiceId: isUpcoming ? 'upcoming' : invoice.id,
353
+ amountDue: invoice.amount_due,
354
+ amountPaid: invoice.amount_paid,
355
+ status: isUpcoming ? 'draft' : invoice.status,
356
+ invoicePdf: 'invoice_pdf' in invoice ? invoice.invoice_pdf ?? undefined : undefined,
357
+ hostedInvoiceUrl: 'hosted_invoice_url' in invoice ? invoice.hosted_invoice_url ?? undefined : undefined,
358
+ periodStart: new Date(invoice.period_start * 1000),
359
+ periodEnd: new Date(invoice.period_end * 1000),
360
+ createdAt: new Date((invoice.created || Date.now() / 1000) * 1000),
361
+ };
362
+ }
363
+ // Helper: Map Stripe event type to our type
364
+ mapEventType(stripeType) {
365
+ const mapping = {
366
+ 'customer.subscription.created': 'subscription.created',
367
+ 'customer.subscription.updated': 'subscription.updated',
368
+ 'customer.subscription.deleted': 'subscription.canceled',
369
+ 'customer.subscription.trial_will_end': 'subscription.trial_ending',
370
+ 'invoice.paid': 'invoice.paid',
371
+ 'invoice.payment_failed': 'invoice.payment_failed',
372
+ 'payment_method.attached': 'payment_method.attached',
373
+ 'payment_method.detached': 'payment_method.detached',
374
+ 'customer.created': 'customer.created',
375
+ 'customer.updated': 'customer.updated',
376
+ };
377
+ return mapping[stripeType] || 'customer.updated';
378
+ }
379
+ }
380
+ // Export singleton instance
381
+ let billingService = null;
382
+ export function getBillingService() {
383
+ if (!billingService) {
384
+ billingService = new BillingService();
385
+ }
386
+ return billingService;
387
+ }
388
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.js","sourceRoot":"","sources":["../../../src/cloud/billing/service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,135 @@
1
+ /**
2
+ * Agent Relay Cloud - Billing Types
3
+ *
4
+ * Defines subscription plans, customer data, and billing events.
5
+ */
6
+ /**
7
+ * Subscription tier levels
8
+ */
9
+ export type SubscriptionTier = 'free' | 'pro' | 'team' | 'enterprise';
10
+ /**
11
+ * Plan definitions with limits and pricing
12
+ */
13
+ export interface BillingPlan {
14
+ id: SubscriptionTier;
15
+ name: string;
16
+ description: string;
17
+ priceMonthly: number;
18
+ priceYearly: number;
19
+ stripePriceIdMonthly?: string;
20
+ stripePriceIdYearly?: string;
21
+ limits: PlanLimits;
22
+ features: string[];
23
+ }
24
+ /**
25
+ * Resource limits per plan
26
+ */
27
+ export interface PlanLimits {
28
+ maxWorkspaces: number;
29
+ maxAgentsPerWorkspace: number;
30
+ maxTeamMembers: number;
31
+ maxStorageGB: number;
32
+ maxComputeHoursPerMonth: number;
33
+ customDomains: boolean;
34
+ prioritySupport: boolean;
35
+ sla: boolean;
36
+ ssoEnabled: boolean;
37
+ auditLogs: boolean;
38
+ }
39
+ /**
40
+ * Customer billing information
41
+ */
42
+ export interface BillingCustomer {
43
+ id: string;
44
+ stripeCustomerId: string;
45
+ email: string;
46
+ name?: string;
47
+ subscription?: CustomerSubscription;
48
+ paymentMethods: PaymentMethod[];
49
+ invoices: Invoice[];
50
+ createdAt: Date;
51
+ updatedAt: Date;
52
+ }
53
+ /**
54
+ * Active subscription
55
+ */
56
+ export interface CustomerSubscription {
57
+ id: string;
58
+ stripeSubscriptionId: string;
59
+ tier: SubscriptionTier;
60
+ status: SubscriptionStatus;
61
+ currentPeriodStart: Date;
62
+ currentPeriodEnd: Date;
63
+ cancelAtPeriodEnd: boolean;
64
+ billingInterval: 'month' | 'year';
65
+ createdAt: Date;
66
+ }
67
+ export type SubscriptionStatus = 'active' | 'past_due' | 'canceled' | 'incomplete' | 'trialing' | 'unpaid';
68
+ /**
69
+ * Payment method
70
+ */
71
+ export interface PaymentMethod {
72
+ id: string;
73
+ stripePaymentMethodId: string;
74
+ type: 'card' | 'us_bank_account' | 'sepa_debit';
75
+ isDefault: boolean;
76
+ card?: {
77
+ brand: string;
78
+ last4: string;
79
+ expMonth: number;
80
+ expYear: number;
81
+ };
82
+ }
83
+ /**
84
+ * Invoice
85
+ */
86
+ export interface Invoice {
87
+ id: string;
88
+ stripeInvoiceId: string;
89
+ amountDue: number;
90
+ amountPaid: number;
91
+ status: 'draft' | 'open' | 'paid' | 'void' | 'uncollectible';
92
+ invoicePdf?: string;
93
+ hostedInvoiceUrl?: string;
94
+ periodStart: Date;
95
+ periodEnd: Date;
96
+ createdAt: Date;
97
+ }
98
+ /**
99
+ * Usage record for metered billing
100
+ */
101
+ export interface UsageRecord {
102
+ userId: string;
103
+ workspaceId: string;
104
+ metric: UsageMetric;
105
+ quantity: number;
106
+ timestamp: Date;
107
+ }
108
+ export type UsageMetric = 'compute_hours' | 'storage_gb' | 'api_calls' | 'agent_spawns';
109
+ /**
110
+ * Billing event for webhooks and audit
111
+ */
112
+ export interface BillingEvent {
113
+ id: string;
114
+ type: BillingEventType;
115
+ userId?: string;
116
+ stripeEventId?: string;
117
+ data: Record<string, unknown>;
118
+ processedAt?: Date;
119
+ createdAt: Date;
120
+ }
121
+ export type BillingEventType = 'subscription.created' | 'subscription.updated' | 'subscription.canceled' | 'subscription.trial_ending' | 'invoice.paid' | 'invoice.payment_failed' | 'payment_method.attached' | 'payment_method.detached' | 'customer.created' | 'customer.updated';
122
+ /**
123
+ * Checkout session result
124
+ */
125
+ export interface CheckoutSession {
126
+ sessionId: string;
127
+ url: string;
128
+ }
129
+ /**
130
+ * Portal session for managing subscription
131
+ */
132
+ export interface PortalSession {
133
+ url: string;
134
+ }
135
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/cloud/billing/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Agent Relay Cloud - Billing Types
3
+ *
4
+ * Defines subscription plans, customer data, and billing events.
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/cloud/billing/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Agent Relay Cloud - Configuration
3
+ */
4
+ export interface CloudConfig {
5
+ port: number;
6
+ publicUrl: string;
7
+ sessionSecret: string;
8
+ databaseUrl: string;
9
+ redisUrl: string;
10
+ github: {
11
+ clientId: string;
12
+ clientSecret: string;
13
+ appId?: string;
14
+ appPrivateKey?: string;
15
+ };
16
+ providers: {
17
+ anthropic?: {
18
+ clientId: string;
19
+ };
20
+ openai?: {
21
+ clientId: string;
22
+ };
23
+ google?: {
24
+ clientId: string;
25
+ clientSecret: string;
26
+ };
27
+ };
28
+ vault: {
29
+ masterKey: string;
30
+ };
31
+ compute: {
32
+ provider: 'fly' | 'railway' | 'docker';
33
+ fly?: {
34
+ apiToken: string;
35
+ org: string;
36
+ region?: string;
37
+ workspaceDomain?: string;
38
+ };
39
+ railway?: {
40
+ apiToken: string;
41
+ };
42
+ };
43
+ stripe: {
44
+ secretKey: string;
45
+ publishableKey: string;
46
+ webhookSecret: string;
47
+ priceIds: {
48
+ proMonthly?: string;
49
+ proYearly?: string;
50
+ teamMonthly?: string;
51
+ teamYearly?: string;
52
+ enterpriseMonthly?: string;
53
+ enterpriseYearly?: string;
54
+ };
55
+ };
56
+ }
57
+ export declare function loadConfig(): CloudConfig;
58
+ export declare function getConfig(): CloudConfig;
59
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/cloud/config.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,MAAM,WAAW,WAAW;IAE1B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IAGtB,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IAGjB,MAAM,EAAE;QACN,QAAQ,EAAE,MAAM,CAAC;QACjB,YAAY,EAAE,MAAM,CAAC;QACrB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,aAAa,CAAC,EAAE,MAAM,CAAC;KACxB,CAAC;IAIF,SAAS,EAAE;QAET,SAAS,CAAC,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAC;QAEjC,MAAM,CAAC,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAC;QAE9B,MAAM,CAAC,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,MAAM,CAAA;SAAE,CAAC;KACrD,CAAC;IAGF,KAAK,EAAE;QACL,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;IAGF,OAAO,EAAE;QACP,QAAQ,EAAE,KAAK,GAAG,SAAS,GAAG,QAAQ,CAAC;QACvC,GAAG,CAAC,EAAE;YACJ,QAAQ,EAAE,MAAM,CAAC;YACjB,GAAG,EAAE,MAAM,CAAC;YACZ,MAAM,CAAC,EAAE,MAAM,CAAC;YAChB,eAAe,CAAC,EAAE,MAAM,CAAC;SAC1B,CAAC;QACF,OAAO,CAAC,EAAE;YACR,QAAQ,EAAE,MAAM,CAAC;SAClB,CAAC;KACH,CAAC;IAGF,MAAM,EAAE;QACN,SAAS,EAAE,MAAM,CAAC;QAClB,cAAc,EAAE,MAAM,CAAC;QACvB,aAAa,EAAE,MAAM,CAAC;QACtB,QAAQ,EAAE;YACR,UAAU,CAAC,EAAE,MAAM,CAAC;YACpB,SAAS,CAAC,EAAE,MAAM,CAAC;YACnB,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,UAAU,CAAC,EAAE,MAAM,CAAC;YACpB,iBAAiB,CAAC,EAAE,MAAM,CAAC;YAC3B,gBAAgB,CAAC,EAAE,MAAM,CAAC;SAC3B,CAAC;KACH,CAAC;CACH;AAcD,wBAAgB,UAAU,IAAI,WAAW,CAmExC;AAKD,wBAAgB,SAAS,IAAI,WAAW,CAKvC"}