@nordsym/apiclaw 1.7.11 → 1.7.13

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 (153) hide show
  1. package/convex/adminActivate.d.ts +3 -0
  2. package/convex/adminActivate.d.ts.map +1 -0
  3. package/convex/adminActivate.js +47 -0
  4. package/convex/adminActivate.js.map +1 -0
  5. package/convex/adminStats.d.ts +4 -0
  6. package/convex/adminStats.d.ts.map +1 -0
  7. package/convex/adminStats.js +101 -0
  8. package/convex/adminStats.js.map +1 -0
  9. package/convex/agents.d.ts +76 -0
  10. package/convex/agents.d.ts.map +1 -0
  11. package/convex/agents.js +699 -0
  12. package/convex/agents.js.map +1 -0
  13. package/convex/analytics.d.ts +5 -0
  14. package/convex/analytics.d.ts.map +1 -0
  15. package/convex/analytics.js +166 -0
  16. package/convex/analytics.js.map +1 -0
  17. package/convex/billing.d.ts +88 -0
  18. package/convex/billing.d.ts.map +1 -0
  19. package/convex/billing.js +655 -0
  20. package/convex/billing.js.map +1 -0
  21. package/convex/capabilities.d.ts +9 -0
  22. package/convex/capabilities.d.ts.map +1 -0
  23. package/convex/capabilities.js +145 -0
  24. package/convex/capabilities.js.map +1 -0
  25. package/convex/chains.d.ts +68 -0
  26. package/convex/chains.d.ts.map +1 -0
  27. package/convex/chains.js +1105 -0
  28. package/convex/chains.js.map +1 -0
  29. package/convex/credits.d.ts +25 -0
  30. package/convex/credits.d.ts.map +1 -0
  31. package/convex/credits.js +186 -0
  32. package/convex/credits.js.map +1 -0
  33. package/convex/crons.d.ts +3 -0
  34. package/convex/crons.d.ts.map +1 -0
  35. package/convex/crons.js +17 -0
  36. package/convex/crons.js.map +1 -0
  37. package/convex/directCall.d.ts +72 -0
  38. package/convex/directCall.d.ts.map +1 -0
  39. package/convex/directCall.js +627 -0
  40. package/convex/directCall.js.map +1 -0
  41. package/convex/earnProgress.d.ts +58 -0
  42. package/convex/earnProgress.d.ts.map +1 -0
  43. package/convex/earnProgress.js +649 -0
  44. package/convex/earnProgress.js.map +1 -0
  45. package/convex/email.d.ts +14 -0
  46. package/convex/email.d.ts.map +1 -0
  47. package/convex/email.js +300 -0
  48. package/convex/email.js.map +1 -0
  49. package/convex/feedback.d.ts +7 -0
  50. package/convex/feedback.d.ts.map +1 -0
  51. package/convex/feedback.js +227 -0
  52. package/convex/feedback.js.map +1 -0
  53. package/convex/http.d.ts +3 -0
  54. package/convex/http.d.ts.map +1 -0
  55. package/convex/http.js +1405 -0
  56. package/convex/http.js.map +1 -0
  57. package/convex/inbound.d.ts +2 -0
  58. package/convex/inbound.d.ts.map +1 -0
  59. package/convex/inbound.js +32 -0
  60. package/convex/inbound.js.map +1 -0
  61. package/convex/logs.d.ts +48 -0
  62. package/convex/logs.d.ts.map +1 -0
  63. package/convex/logs.js +605 -0
  64. package/convex/logs.js.map +1 -0
  65. package/convex/mou.d.ts +6 -0
  66. package/convex/mou.d.ts.map +1 -0
  67. package/convex/mou.js +82 -0
  68. package/convex/mou.js.map +1 -0
  69. package/convex/providerKeys.d.ts +31 -0
  70. package/convex/providerKeys.d.ts.map +1 -0
  71. package/convex/providerKeys.js +257 -0
  72. package/convex/providerKeys.js.map +1 -0
  73. package/convex/providers.d.ts +34 -0
  74. package/convex/providers.d.ts.map +1 -0
  75. package/convex/providers.js +898 -0
  76. package/convex/providers.js.map +1 -0
  77. package/convex/providers.ts +57 -2
  78. package/convex/purchases.d.ts +7 -0
  79. package/convex/purchases.d.ts.map +1 -0
  80. package/convex/purchases.js +157 -0
  81. package/convex/purchases.js.map +1 -0
  82. package/convex/ratelimit.d.ts +4 -0
  83. package/convex/ratelimit.d.ts.map +1 -0
  84. package/convex/ratelimit.js +91 -0
  85. package/convex/ratelimit.js.map +1 -0
  86. package/convex/searchLogs.d.ts +4 -0
  87. package/convex/searchLogs.d.ts.map +1 -0
  88. package/convex/searchLogs.js +129 -0
  89. package/convex/searchLogs.js.map +1 -0
  90. package/convex/seedAPILayerAPIs.d.ts +7 -0
  91. package/convex/seedAPILayerAPIs.d.ts.map +1 -0
  92. package/convex/seedAPILayerAPIs.js +177 -0
  93. package/convex/seedAPILayerAPIs.js.map +1 -0
  94. package/convex/seedDirectCallConfigs.d.ts +2 -0
  95. package/convex/seedDirectCallConfigs.d.ts.map +1 -0
  96. package/convex/seedDirectCallConfigs.js +324 -0
  97. package/convex/seedDirectCallConfigs.js.map +1 -0
  98. package/convex/seedPratham.d.ts +6 -0
  99. package/convex/seedPratham.d.ts.map +1 -0
  100. package/convex/seedPratham.js +150 -0
  101. package/convex/seedPratham.js.map +1 -0
  102. package/convex/spendAlerts.d.ts +36 -0
  103. package/convex/spendAlerts.d.ts.map +1 -0
  104. package/convex/spendAlerts.js +380 -0
  105. package/convex/spendAlerts.js.map +1 -0
  106. package/convex/stripeActions.d.ts +19 -0
  107. package/convex/stripeActions.d.ts.map +1 -0
  108. package/convex/stripeActions.js +411 -0
  109. package/convex/stripeActions.js.map +1 -0
  110. package/convex/teams.d.ts +21 -0
  111. package/convex/teams.d.ts.map +1 -0
  112. package/convex/teams.js +215 -0
  113. package/convex/teams.js.map +1 -0
  114. package/convex/telemetry.d.ts +4 -0
  115. package/convex/telemetry.d.ts.map +1 -0
  116. package/convex/telemetry.js +74 -0
  117. package/convex/telemetry.js.map +1 -0
  118. package/convex/updateAPIStatus.d.ts +6 -0
  119. package/convex/updateAPIStatus.d.ts.map +1 -0
  120. package/convex/updateAPIStatus.js +40 -0
  121. package/convex/updateAPIStatus.js.map +1 -0
  122. package/convex/usage.d.ts +27 -0
  123. package/convex/usage.d.ts.map +1 -0
  124. package/convex/usage.js +229 -0
  125. package/convex/usage.js.map +1 -0
  126. package/convex/waitlist.d.ts +4 -0
  127. package/convex/waitlist.d.ts.map +1 -0
  128. package/convex/waitlist.js +49 -0
  129. package/convex/waitlist.js.map +1 -0
  130. package/convex/webhooks.d.ts +12 -0
  131. package/convex/webhooks.d.ts.map +1 -0
  132. package/convex/webhooks.js +410 -0
  133. package/convex/webhooks.js.map +1 -0
  134. package/convex/workspaces.d.ts +31 -0
  135. package/convex/workspaces.d.ts.map +1 -0
  136. package/convex/workspaces.js +975 -0
  137. package/convex/workspaces.js.map +1 -0
  138. package/dist/capability-router.js +1 -1
  139. package/dist/capability-router.js.map +1 -1
  140. package/dist/cli.js +1 -1
  141. package/dist/cli.js.map +1 -1
  142. package/dist/hivr-whitelist.js +1 -1
  143. package/dist/hivr-whitelist.js.map +1 -1
  144. package/dist/index.js +53 -30
  145. package/dist/index.js.map +1 -1
  146. package/dist/product-whitelist.js +1 -1
  147. package/dist/product-whitelist.js.map +1 -1
  148. package/dist/proxy.js +1 -1
  149. package/dist/proxy.js.map +1 -1
  150. package/dist/telemetry.js +1 -1
  151. package/dist/telemetry.js.map +1 -1
  152. package/package.json +1 -1
  153. package/src/index.ts +5 -18
@@ -0,0 +1,411 @@
1
+ import Stripe from "stripe";
2
+ import { httpAction } from "./_generated/server";
3
+ import { api } from "./_generated/api";
4
+ // Initialize Stripe (will use env var at runtime)
5
+ function getStripe() {
6
+ const key = process.env.STRIPE_SECRET_KEY;
7
+ if (!key) {
8
+ throw new Error("STRIPE_SECRET_KEY not configured");
9
+ }
10
+ return new Stripe(key);
11
+ }
12
+ // CORS headers
13
+ const corsHeaders = {
14
+ "Access-Control-Allow-Origin": "*",
15
+ "Access-Control-Allow-Methods": "GET, POST, OPTIONS",
16
+ "Access-Control-Allow-Headers": "Content-Type, Authorization, stripe-signature",
17
+ };
18
+ function jsonResponse(data, status = 200) {
19
+ return new Response(JSON.stringify(data), {
20
+ status,
21
+ headers: { "Content-Type": "application/json", ...corsHeaders },
22
+ });
23
+ }
24
+ /**
25
+ * Create Stripe Checkout Session
26
+ * POST /api/billing/checkout
27
+ */
28
+ export const createCheckoutSession = httpAction(async (ctx, request) => {
29
+ try {
30
+ const body = await request.json();
31
+ const { workspaceId, returnUrl, mode = "setup" } = body;
32
+ if (!workspaceId) {
33
+ return jsonResponse({ error: "workspaceId required" }, 400);
34
+ }
35
+ const stripe = getStripe();
36
+ // Get workspace
37
+ const workspace = await ctx.runQuery(api.billing.getWorkspace, {
38
+ id: workspaceId,
39
+ });
40
+ if (!workspace) {
41
+ return jsonResponse({ error: "Workspace not found" }, 404);
42
+ }
43
+ let customerId = workspace.stripeCustomerId;
44
+ // Create Stripe customer if doesn't exist
45
+ if (!customerId) {
46
+ const customer = await stripe.customers.create({
47
+ email: workspace.email,
48
+ metadata: {
49
+ workspaceId: workspaceId,
50
+ source: "apiclaw",
51
+ },
52
+ });
53
+ customerId = customer.id;
54
+ // Link customer to workspace
55
+ await ctx.runMutation(api.billing.linkCustomer, {
56
+ workspaceId: workspaceId,
57
+ stripeCustomerId: customerId,
58
+ });
59
+ }
60
+ const baseUrl = returnUrl || "https://apiclaw.nordsym.com";
61
+ // Create checkout session
62
+ if (mode === "setup") {
63
+ // Setup mode - just save card for future billing
64
+ const session = await stripe.checkout.sessions.create({
65
+ customer: customerId,
66
+ mode: "setup",
67
+ payment_method_types: ["card"],
68
+ success_url: `${baseUrl}/billing?session_id={CHECKOUT_SESSION_ID}&success=true`,
69
+ cancel_url: `${baseUrl}/billing?canceled=true`,
70
+ metadata: {
71
+ workspaceId: workspaceId,
72
+ },
73
+ });
74
+ return jsonResponse({
75
+ checkoutUrl: session.url,
76
+ sessionId: session.id,
77
+ });
78
+ }
79
+ else if (mode === "subscription") {
80
+ // Create metered subscription
81
+ const priceId = process.env.STRIPE_PRICE_ID_USAGE;
82
+ if (!priceId) {
83
+ return jsonResponse({ error: "Usage price not configured" }, 500);
84
+ }
85
+ const session = await stripe.checkout.sessions.create({
86
+ customer: customerId,
87
+ mode: "subscription",
88
+ line_items: [
89
+ {
90
+ price: priceId,
91
+ },
92
+ ],
93
+ success_url: `${baseUrl}/billing?session_id={CHECKOUT_SESSION_ID}&success=true`,
94
+ cancel_url: `${baseUrl}/billing?canceled=true`,
95
+ metadata: {
96
+ workspaceId: workspaceId,
97
+ },
98
+ });
99
+ return jsonResponse({
100
+ checkoutUrl: session.url,
101
+ sessionId: session.id,
102
+ });
103
+ }
104
+ else {
105
+ return jsonResponse({ error: "Invalid mode. Use 'setup' or 'subscription'" }, 400);
106
+ }
107
+ }
108
+ catch (e) {
109
+ console.error("Checkout error:", e);
110
+ return jsonResponse({ error: e.message || "Failed to create checkout" }, 500);
111
+ }
112
+ });
113
+ /**
114
+ * Create Stripe Billing Portal Session
115
+ * POST /api/billing/portal
116
+ */
117
+ export const createPortalSession = httpAction(async (ctx, request) => {
118
+ try {
119
+ const body = await request.json();
120
+ const { workspaceId, returnUrl } = body;
121
+ if (!workspaceId) {
122
+ return jsonResponse({ error: "workspaceId required" }, 400);
123
+ }
124
+ const stripe = getStripe();
125
+ // Get workspace
126
+ const workspace = await ctx.runQuery(api.billing.getWorkspace, {
127
+ id: workspaceId,
128
+ });
129
+ if (!workspace) {
130
+ return jsonResponse({ error: "Workspace not found" }, 404);
131
+ }
132
+ if (!workspace.stripeCustomerId) {
133
+ return jsonResponse({ error: "No billing account. Add a payment method first." }, 400);
134
+ }
135
+ const session = await stripe.billingPortal.sessions.create({
136
+ customer: workspace.stripeCustomerId,
137
+ return_url: returnUrl || "https://apiclaw.com/workspace?tab=settings&portal=success",
138
+ });
139
+ return jsonResponse({
140
+ portalUrl: session.url,
141
+ });
142
+ }
143
+ catch (e) {
144
+ console.error("Portal error:", e);
145
+ return jsonResponse({ error: e.message || "Failed to create portal session" }, 500);
146
+ }
147
+ });
148
+ /**
149
+ * Stripe Webhook Handler
150
+ * POST /api/webhooks/stripe
151
+ */
152
+ export const handleStripeWebhook = httpAction(async (ctx, request) => {
153
+ const webhookSecret = process.env.STRIPE_WEBHOOK_SECRET;
154
+ if (!webhookSecret) {
155
+ console.error("STRIPE_WEBHOOK_SECRET not configured");
156
+ return jsonResponse({ error: "Webhook not configured" }, 500);
157
+ }
158
+ const stripe = getStripe();
159
+ const signature = request.headers.get("stripe-signature");
160
+ if (!signature) {
161
+ return jsonResponse({ error: "Missing stripe-signature header" }, 400);
162
+ }
163
+ let event;
164
+ try {
165
+ const body = await request.text();
166
+ event = stripe.webhooks.constructEvent(body, signature, webhookSecret);
167
+ }
168
+ catch (err) {
169
+ console.error("Webhook signature verification failed:", err.message);
170
+ return jsonResponse({ error: `Webhook Error: ${err.message}` }, 400);
171
+ }
172
+ // Handle the event
173
+ try {
174
+ switch (event.type) {
175
+ case "checkout.session.completed": {
176
+ const session = event.data.object;
177
+ await handleCheckoutComplete(ctx, session);
178
+ break;
179
+ }
180
+ case "customer.subscription.created":
181
+ case "customer.subscription.updated": {
182
+ const subscription = event.data.object;
183
+ await handleSubscriptionUpdate(ctx, subscription);
184
+ break;
185
+ }
186
+ case "customer.subscription.deleted": {
187
+ const subscription = event.data.object;
188
+ await handleSubscriptionCanceled(ctx, subscription);
189
+ break;
190
+ }
191
+ case "invoice.paid": {
192
+ const invoice = event.data.object;
193
+ await handleInvoicePaid(ctx, invoice);
194
+ break;
195
+ }
196
+ case "invoice.payment_failed": {
197
+ const invoice = event.data.object;
198
+ await handlePaymentFailed(ctx, invoice);
199
+ break;
200
+ }
201
+ case "setup_intent.succeeded": {
202
+ const setupIntent = event.data.object;
203
+ await handleSetupSuccess(ctx, setupIntent);
204
+ break;
205
+ }
206
+ case "payment_method.attached": {
207
+ const paymentMethod = event.data.object;
208
+ await handlePaymentMethodAttached(ctx, paymentMethod);
209
+ break;
210
+ }
211
+ case "payment_method.detached": {
212
+ const paymentMethod = event.data.object;
213
+ await handlePaymentMethodDetached(ctx, paymentMethod);
214
+ break;
215
+ }
216
+ default:
217
+ console.log(`Unhandled event type: ${event.type}`);
218
+ }
219
+ return jsonResponse({ received: true, type: event.type });
220
+ }
221
+ catch (e) {
222
+ console.error(`Error handling ${event.type}:`, e);
223
+ // Return 200 to prevent Stripe retries for business logic errors
224
+ return jsonResponse({ received: true, error: e.message });
225
+ }
226
+ });
227
+ // ============================================
228
+ // Webhook Event Handlers
229
+ // ============================================
230
+ async function handleCheckoutComplete(ctx, session) {
231
+ const workspaceId = session.metadata?.workspaceId;
232
+ if (!workspaceId) {
233
+ console.log("No workspaceId in checkout session metadata");
234
+ return;
235
+ }
236
+ // If subscription mode, the subscription webhook will handle it
237
+ if (session.mode === "subscription" && session.subscription) {
238
+ console.log("Subscription checkout completed, waiting for subscription webhook");
239
+ return;
240
+ }
241
+ // If setup mode, upgrade to usage-based billing
242
+ if (session.mode === "setup") {
243
+ await ctx.runMutation(api.billing.updateSubscription, {
244
+ workspaceId: workspaceId,
245
+ billingPlan: "usage_based",
246
+ });
247
+ console.log(`Workspace ${workspaceId} upgraded to usage-based billing`);
248
+ }
249
+ }
250
+ async function handleSubscriptionUpdate(ctx, subscription) {
251
+ const customerId = typeof subscription.customer === "string"
252
+ ? subscription.customer
253
+ : subscription.customer.id;
254
+ // Get workspace by customer ID
255
+ const workspace = await ctx.runQuery(api.billing.getByStripeCustomerId, {
256
+ stripeCustomerId: customerId,
257
+ });
258
+ if (!workspace) {
259
+ console.log(`No workspace found for customer ${customerId}`);
260
+ return;
261
+ }
262
+ // Determine plan from subscription
263
+ const plan = subscription.status === "active" ? "usage_based" : "free";
264
+ await ctx.runMutation(api.billing.updateSubscription, {
265
+ workspaceId: workspace._id,
266
+ stripeSubscriptionId: subscription.id,
267
+ billingPlan: plan,
268
+ });
269
+ console.log(`Subscription ${subscription.id} updated for workspace ${workspace._id}`);
270
+ }
271
+ async function handleSubscriptionCanceled(ctx, subscription) {
272
+ const customerId = typeof subscription.customer === "string"
273
+ ? subscription.customer
274
+ : subscription.customer.id;
275
+ const workspace = await ctx.runQuery(api.billing.getByStripeCustomerId, {
276
+ stripeCustomerId: customerId,
277
+ });
278
+ if (!workspace) {
279
+ console.log(`No workspace found for customer ${customerId}`);
280
+ return;
281
+ }
282
+ // Downgrade to free and reset usage
283
+ await ctx.runMutation(api.billing.updateSubscription, {
284
+ workspaceId: workspace._id,
285
+ stripeSubscriptionId: undefined,
286
+ billingPlan: "free",
287
+ });
288
+ // Reset usage count to 0 for clean slate on free tier
289
+ await ctx.runMutation(api.billing.resetUsageOnCancellation, {
290
+ workspaceId: workspace._id,
291
+ });
292
+ console.log(`Workspace ${workspace._id} downgraded to free (subscription canceled)`);
293
+ }
294
+ async function handleInvoicePaid(ctx, invoice) {
295
+ const customerId = typeof invoice.customer === "string"
296
+ ? invoice.customer
297
+ : invoice.customer?.id;
298
+ if (!customerId)
299
+ return;
300
+ const workspace = await ctx.runQuery(api.billing.getByStripeCustomerId, {
301
+ stripeCustomerId: customerId,
302
+ });
303
+ if (!workspace) {
304
+ console.log(`No workspace found for customer ${customerId}`);
305
+ return;
306
+ }
307
+ // Calculate call count from line items (for metered billing)
308
+ let callCount = 0;
309
+ if (invoice.lines?.data) {
310
+ for (const line of invoice.lines.data) {
311
+ if (line.quantity) {
312
+ callCount += line.quantity;
313
+ }
314
+ }
315
+ }
316
+ await ctx.runMutation(api.billing.processPayment, {
317
+ stripeInvoiceId: invoice.id,
318
+ workspaceId: workspace._id,
319
+ amount: invoice.amount_paid,
320
+ periodStart: invoice.period_start * 1000,
321
+ periodEnd: invoice.period_end * 1000,
322
+ callCount,
323
+ pdfUrl: invoice.invoice_pdf || undefined,
324
+ });
325
+ console.log(`Invoice ${invoice.id} processed for workspace ${workspace._id}`);
326
+ }
327
+ async function handlePaymentFailed(ctx, invoice) {
328
+ const customerId = typeof invoice.customer === "string"
329
+ ? invoice.customer
330
+ : invoice.customer?.id;
331
+ if (!customerId)
332
+ return;
333
+ // Update invoice status to failed
334
+ await ctx.runMutation(api.billing.updateInvoiceStatus, {
335
+ stripeInvoiceId: invoice.id,
336
+ status: "failed",
337
+ });
338
+ console.log(`Payment failed for invoice ${invoice.id}`);
339
+ // TODO: Send notification to user about failed payment
340
+ }
341
+ async function handleSetupSuccess(ctx, setupIntent) {
342
+ // Card saved successfully
343
+ const customerId = typeof setupIntent.customer === "string"
344
+ ? setupIntent.customer
345
+ : setupIntent.customer?.id;
346
+ if (!customerId)
347
+ return;
348
+ const workspace = await ctx.runQuery(api.billing.getByStripeCustomerId, {
349
+ stripeCustomerId: customerId,
350
+ });
351
+ if (!workspace) {
352
+ console.log(`No workspace found for customer ${customerId}`);
353
+ return;
354
+ }
355
+ // Upgrade to usage-based if still on free
356
+ if (!workspace.billingPlan || workspace.billingPlan === "free") {
357
+ await ctx.runMutation(api.billing.updateSubscription, {
358
+ workspaceId: workspace._id,
359
+ billingPlan: "usage_based",
360
+ });
361
+ console.log(`Workspace ${workspace._id} upgraded after setup intent`);
362
+ }
363
+ }
364
+ async function handlePaymentMethodAttached(ctx, paymentMethod) {
365
+ // Payment method attached to customer
366
+ const customerId = typeof paymentMethod.customer === "string"
367
+ ? paymentMethod.customer
368
+ : paymentMethod.customer?.id;
369
+ if (!customerId) {
370
+ console.log("Payment method attached but no customer ID");
371
+ return;
372
+ }
373
+ const workspace = await ctx.runQuery(api.billing.getByStripeCustomerId, {
374
+ stripeCustomerId: customerId,
375
+ });
376
+ if (!workspace) {
377
+ console.log(`No workspace found for customer ${customerId}`);
378
+ return;
379
+ }
380
+ // Sync payment method info
381
+ await ctx.runMutation(api.billing.updatePaymentMethodInfo, {
382
+ workspaceId: workspace._id,
383
+ hasPaymentMethod: true,
384
+ paymentMethodType: paymentMethod.type,
385
+ cardBrand: paymentMethod.card?.brand,
386
+ cardLast4: paymentMethod.card?.last4,
387
+ });
388
+ console.log(`Payment method attached for workspace ${workspace._id}`);
389
+ }
390
+ async function handlePaymentMethodDetached(ctx, paymentMethod) {
391
+ // When a payment method is detached, we need to check if customer still has payment methods
392
+ // Since customer info isn't available on detached event, we log it
393
+ console.log(`Payment method ${paymentMethod.id} detached`);
394
+ // Note: In a production system, you might want to:
395
+ // 1. Query Stripe for remaining payment methods
396
+ // 2. If no payment methods remain, downgrade the workspace
397
+ // For now, we rely on subscription cancellation to handle downgrades
398
+ }
399
+ // ============================================
400
+ // OPTIONS handlers for CORS
401
+ // ============================================
402
+ export const checkoutOptions = httpAction(async () => {
403
+ return new Response(null, { headers: corsHeaders });
404
+ });
405
+ export const portalOptions = httpAction(async () => {
406
+ return new Response(null, { headers: corsHeaders });
407
+ });
408
+ export const webhookOptions = httpAction(async () => {
409
+ return new Response(null, { headers: corsHeaders });
410
+ });
411
+ //# sourceMappingURL=stripeActions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stripeActions.js","sourceRoot":"","sources":["stripeActions.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Get team members for a workspace
3
+ */
4
+ export declare const getMembers: any;
5
+ /**
6
+ * Invite a member to the workspace (creates pending invite)
7
+ */
8
+ export declare const inviteMember: any;
9
+ /**
10
+ * Accept an invite
11
+ */
12
+ export declare const acceptInvite: any;
13
+ /**
14
+ * Remove a member from the workspace
15
+ */
16
+ export declare const removeMember: any;
17
+ /**
18
+ * Get invite details (public, for invite acceptance page)
19
+ */
20
+ export declare const getInviteDetails: any;
21
+ //# sourceMappingURL=teams.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"teams.d.ts","sourceRoot":"","sources":["teams.ts"],"names":[],"mappings":"AAoBA;;GAEG;AACH,eAAO,MAAM,UAAU,KAuCrB,CAAC;AAMH;;GAEG;AACH,eAAO,MAAM,YAAY,KAoEvB,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,YAAY,KA2BvB,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,YAAY,KAwCvB,CAAC;AAEH;;GAEG;AACH,eAAO,MAAM,gBAAgB,KAqB3B,CAAC"}
@@ -0,0 +1,215 @@
1
+ import { v } from "convex/values";
2
+ import { mutation, query } from "./_generated/server";
3
+ // ============================================
4
+ // HELPER FUNCTIONS
5
+ // ============================================
6
+ function generateToken() {
7
+ const chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
8
+ let result = "";
9
+ for (let i = 0; i < 32; i++) {
10
+ result += chars.charAt(Math.floor(Math.random() * chars.length));
11
+ }
12
+ return result;
13
+ }
14
+ // ============================================
15
+ // TEAM QUERIES
16
+ // ============================================
17
+ /**
18
+ * Get team members for a workspace
19
+ */
20
+ export const getMembers = query({
21
+ args: { token: v.string() },
22
+ handler: async (ctx, { token }) => {
23
+ const session = await ctx.db
24
+ .query("agentSessions")
25
+ .withIndex("by_sessionToken", (q) => q.eq("sessionToken", token))
26
+ .first();
27
+ if (!session)
28
+ return [];
29
+ const workspace = await ctx.db.get(session.workspaceId);
30
+ if (!workspace)
31
+ return [];
32
+ const members = await ctx.db
33
+ .query("workspaceMembers")
34
+ .withIndex("by_workspaceId", (q) => q.eq("workspaceId", session.workspaceId))
35
+ .collect();
36
+ // Add owner as first member
37
+ return [
38
+ {
39
+ email: workspace.email,
40
+ role: "owner",
41
+ status: "active",
42
+ isOwner: true,
43
+ createdAt: workspace.createdAt,
44
+ },
45
+ ...members.map((m) => ({
46
+ id: m._id,
47
+ email: m.email,
48
+ role: m.role,
49
+ status: m.status,
50
+ isOwner: false,
51
+ invitedBy: m.invitedBy,
52
+ createdAt: m.createdAt,
53
+ acceptedAt: m.acceptedAt,
54
+ })),
55
+ ];
56
+ },
57
+ });
58
+ // ============================================
59
+ // TEAM MUTATIONS
60
+ // ============================================
61
+ /**
62
+ * Invite a member to the workspace (creates pending invite)
63
+ */
64
+ export const inviteMember = mutation({
65
+ args: {
66
+ token: v.string(),
67
+ email: v.string(),
68
+ role: v.union(v.literal("admin"), v.literal("member")),
69
+ },
70
+ handler: async (ctx, { token, email, role }) => {
71
+ const session = await ctx.db
72
+ .query("agentSessions")
73
+ .withIndex("by_sessionToken", (q) => q.eq("sessionToken", token))
74
+ .first();
75
+ if (!session)
76
+ throw new Error("Invalid session");
77
+ const workspace = await ctx.db.get(session.workspaceId);
78
+ if (!workspace)
79
+ throw new Error("Workspace not found");
80
+ // Normalize email
81
+ const normalizedEmail = email.toLowerCase().trim();
82
+ // Can't invite yourself
83
+ if (normalizedEmail === workspace.email.toLowerCase()) {
84
+ throw new Error("Cannot invite yourself");
85
+ }
86
+ // Check if already member
87
+ const existing = await ctx.db
88
+ .query("workspaceMembers")
89
+ .withIndex("by_workspaceId_email", (q) => q.eq("workspaceId", session.workspaceId).eq("email", normalizedEmail))
90
+ .first();
91
+ if (existing) {
92
+ if (existing.status === "active") {
93
+ throw new Error("Already a team member");
94
+ }
95
+ if (existing.status === "pending") {
96
+ throw new Error("Invite already pending");
97
+ }
98
+ // If revoked, we can re-invite - update existing record
99
+ const inviteToken = generateToken();
100
+ await ctx.db.patch(existing._id, {
101
+ role,
102
+ invitedBy: workspace.email,
103
+ inviteToken,
104
+ status: "pending",
105
+ createdAt: Date.now(),
106
+ acceptedAt: undefined,
107
+ });
108
+ return { id: existing._id, inviteToken };
109
+ }
110
+ // Generate invite token
111
+ const inviteToken = generateToken();
112
+ const id = await ctx.db.insert("workspaceMembers", {
113
+ workspaceId: session.workspaceId,
114
+ email: normalizedEmail,
115
+ role,
116
+ invitedBy: workspace.email,
117
+ inviteToken,
118
+ status: "pending",
119
+ createdAt: Date.now(),
120
+ });
121
+ return { id, inviteToken };
122
+ },
123
+ });
124
+ /**
125
+ * Accept an invite
126
+ */
127
+ export const acceptInvite = mutation({
128
+ args: { inviteToken: v.string() },
129
+ handler: async (ctx, { inviteToken }) => {
130
+ const member = await ctx.db
131
+ .query("workspaceMembers")
132
+ .withIndex("by_inviteToken", (q) => q.eq("inviteToken", inviteToken))
133
+ .first();
134
+ if (!member)
135
+ throw new Error("Invalid invite token");
136
+ if (member.status !== "pending")
137
+ throw new Error("Invite already used or revoked");
138
+ await ctx.db.patch(member._id, {
139
+ status: "active",
140
+ acceptedAt: Date.now(),
141
+ inviteToken: undefined, // Clear token after use
142
+ });
143
+ // Get workspace info for response
144
+ const workspace = await ctx.db.get(member.workspaceId);
145
+ return {
146
+ success: true,
147
+ workspaceId: member.workspaceId,
148
+ workspaceEmail: workspace?.email,
149
+ role: member.role,
150
+ };
151
+ },
152
+ });
153
+ /**
154
+ * Remove a member from the workspace
155
+ */
156
+ export const removeMember = mutation({
157
+ args: {
158
+ token: v.string(),
159
+ memberEmail: v.string(),
160
+ },
161
+ handler: async (ctx, { token, memberEmail }) => {
162
+ const session = await ctx.db
163
+ .query("agentSessions")
164
+ .withIndex("by_sessionToken", (q) => q.eq("sessionToken", token))
165
+ .first();
166
+ if (!session)
167
+ throw new Error("Invalid session");
168
+ const workspace = await ctx.db.get(session.workspaceId);
169
+ if (!workspace)
170
+ throw new Error("Workspace not found");
171
+ const normalizedEmail = memberEmail.toLowerCase().trim();
172
+ // Cannot remove owner
173
+ if (normalizedEmail === workspace.email.toLowerCase()) {
174
+ throw new Error("Cannot remove workspace owner");
175
+ }
176
+ const member = await ctx.db
177
+ .query("workspaceMembers")
178
+ .withIndex("by_workspaceId_email", (q) => q.eq("workspaceId", session.workspaceId).eq("email", normalizedEmail))
179
+ .first();
180
+ if (!member)
181
+ throw new Error("Member not found");
182
+ // Set status to revoked instead of deleting
183
+ await ctx.db.patch(member._id, {
184
+ status: "revoked",
185
+ inviteToken: undefined,
186
+ });
187
+ return { success: true };
188
+ },
189
+ });
190
+ /**
191
+ * Get invite details (public, for invite acceptance page)
192
+ */
193
+ export const getInviteDetails = query({
194
+ args: { inviteToken: v.string() },
195
+ handler: async (ctx, { inviteToken }) => {
196
+ const member = await ctx.db
197
+ .query("workspaceMembers")
198
+ .withIndex("by_inviteToken", (q) => q.eq("inviteToken", inviteToken))
199
+ .first();
200
+ if (!member)
201
+ return null;
202
+ if (member.status !== "pending")
203
+ return null;
204
+ const workspace = await ctx.db.get(member.workspaceId);
205
+ if (!workspace)
206
+ return null;
207
+ return {
208
+ email: member.email,
209
+ role: member.role,
210
+ invitedBy: member.invitedBy,
211
+ workspaceEmail: workspace.email,
212
+ };
213
+ },
214
+ });
215
+ //# sourceMappingURL=teams.js.map