autumn-js 0.1.23 → 0.1.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 (115) hide show
  1. package/dist/libraries/backend/better-auth.js +1 -2
  2. package/dist/libraries/backend/better-auth.mjs +2 -2
  3. package/dist/libraries/backend/{chunk-J5U7ZXZU.mjs → chunk-7DS7ICKQ.mjs} +1 -1
  4. package/dist/libraries/backend/{chunk-FOK63UWJ.mjs → chunk-GB7SC4FJ.mjs} +1 -2
  5. package/dist/libraries/backend/convex.d.mts +15 -1
  6. package/dist/libraries/backend/convex.d.ts +15 -1
  7. package/dist/libraries/backend/convex.js +1556 -0
  8. package/dist/libraries/backend/convex.mjs +164 -0
  9. package/dist/libraries/backend/elysia.js +1 -2
  10. package/dist/libraries/backend/elysia.mjs +2 -2
  11. package/dist/libraries/backend/express.js +1 -2
  12. package/dist/libraries/backend/express.mjs +2 -2
  13. package/dist/libraries/backend/fastify.js +1 -2
  14. package/dist/libraries/backend/fastify.mjs +2 -2
  15. package/dist/libraries/backend/hono.js +1 -2
  16. package/dist/libraries/backend/hono.mjs +2 -2
  17. package/dist/libraries/backend/index.js +1 -2
  18. package/dist/libraries/backend/index.mjs +2 -2
  19. package/dist/libraries/backend/next.js +1 -2
  20. package/dist/libraries/backend/next.mjs +2 -2
  21. package/dist/libraries/backend/react-router.js +1 -2
  22. package/dist/libraries/backend/react-router.mjs +2 -2
  23. package/dist/libraries/backend/remix_dep.js +1 -2
  24. package/dist/libraries/backend/remix_dep.mjs +2 -2
  25. package/dist/libraries/backend/routes/backendRouter.js +1 -2
  26. package/dist/libraries/backend/routes/backendRouter.mjs +2 -2
  27. package/dist/libraries/backend/routes/genRoutes.js +1 -2
  28. package/dist/libraries/backend/routes/genRoutes.mjs +1 -1
  29. package/dist/libraries/backend/supabase.js +1 -2
  30. package/dist/libraries/backend/supabase.mjs +2 -2
  31. package/dist/libraries/backend/tanstack.js +1 -2
  32. package/dist/libraries/backend/tanstack.mjs +2 -2
  33. package/dist/libraries/react/AutumnContext.d.mts +1 -1
  34. package/dist/libraries/react/AutumnContext.d.ts +1 -1
  35. package/dist/libraries/react/BaseAutumnProvider.d.mts +1 -1
  36. package/dist/libraries/react/BaseAutumnProvider.d.ts +1 -1
  37. package/dist/libraries/react/BaseAutumnProvider.js +0 -2
  38. package/dist/libraries/react/BaseAutumnProvider.mjs +3 -3
  39. package/dist/libraries/react/{ReactAutumnClient--zmCg7U8.d.mts → ReactAutumnClient-BBQsSJYU.d.mts} +1 -1
  40. package/dist/libraries/react/{ReactAutumnClient-XuVllEBP.d.ts → ReactAutumnClient-VD1rcIPC.d.ts} +1 -1
  41. package/dist/libraries/react/ReactAutumnProvider.js +12 -11
  42. package/dist/libraries/react/ReactAutumnProvider.mjs +5 -5
  43. package/dist/libraries/react/{chunk-MYRJW7LW.mjs → chunk-2CP6WKDX.mjs} +1 -1
  44. package/dist/libraries/react/{chunk-6KINUP6L.mjs → chunk-7U6BZK2Q.mjs} +1 -1
  45. package/dist/libraries/react/{chunk-54IJL24F.mjs → chunk-DOC77WTB.mjs} +1 -1
  46. package/dist/libraries/react/{chunk-5KZSH7JF.mjs → chunk-F6DIQF5V.mjs} +4 -4
  47. package/dist/libraries/react/{chunk-65S4VY5K.mjs → chunk-GITYXFGP.mjs} +1 -1
  48. package/dist/libraries/react/{chunk-WRVDJJBE.mjs → chunk-IBGAE73H.mjs} +1 -1
  49. package/dist/libraries/react/{chunk-ZYTMSYY3.mjs → chunk-JLAWCM26.mjs} +444 -442
  50. package/dist/libraries/react/{chunk-WUEXMQIT.mjs → chunk-MLPVSH6P.mjs} +2 -2
  51. package/dist/libraries/react/{chunk-UYZX3KX2.mjs → chunk-MZ26ZDT3.mjs} +3 -3
  52. package/dist/libraries/react/{chunk-2PBWI3T6.mjs → chunk-PDLQNFRW.mjs} +17 -17
  53. package/dist/libraries/react/{chunk-PZVVV3LN.mjs → chunk-PE5RABEC.mjs} +2 -2
  54. package/dist/libraries/react/{chunk-COGRLJH2.mjs → chunk-R7DEST3O.mjs} +0 -2
  55. package/dist/libraries/react/{chunk-QYW6U2NR.mjs → chunk-UGHMVXB7.mjs} +1 -1
  56. package/dist/libraries/react/{chunk-VYBU4WHO.mjs → chunk-XR2XUVVC.mjs} +2 -2
  57. package/dist/libraries/react/{chunk-DAZBMK7R.mjs → chunk-YURNJN6P.mjs} +1 -1
  58. package/dist/libraries/react/{chunk-ZH7N5FIC.mjs → chunk-ZUPU2EBK.mjs} +12 -9
  59. package/dist/libraries/react/client/ConvexAutumnClient.d.mts +2 -2
  60. package/dist/libraries/react/client/ConvexAutumnClient.d.ts +2 -2
  61. package/dist/libraries/react/client/ConvexAutumnClient.js +12 -9
  62. package/dist/libraries/react/client/ConvexAutumnClient.mjs +1 -1
  63. package/dist/libraries/react/client/ReactAutumnClient.d.mts +1 -1
  64. package/dist/libraries/react/client/ReactAutumnClient.d.ts +1 -1
  65. package/dist/libraries/react/client/clientCompMethods.d.mts +1 -1
  66. package/dist/libraries/react/client/clientCompMethods.d.ts +1 -1
  67. package/dist/libraries/react/client/clientCusMethods.d.mts +1 -1
  68. package/dist/libraries/react/client/clientCusMethods.d.ts +1 -1
  69. package/dist/libraries/react/client/clientEntityMethods.d.mts +1 -1
  70. package/dist/libraries/react/client/clientEntityMethods.d.ts +1 -1
  71. package/dist/libraries/react/client/clientGenMethods.d.mts +1 -1
  72. package/dist/libraries/react/client/clientGenMethods.d.ts +1 -1
  73. package/dist/libraries/react/client/clientProdMethods.d.mts +1 -1
  74. package/dist/libraries/react/client/clientProdMethods.d.ts +1 -1
  75. package/dist/libraries/react/client/clientReferralMethods.d.mts +1 -1
  76. package/dist/libraries/react/client/clientReferralMethods.d.ts +1 -1
  77. package/dist/libraries/react/components/checkout-dialog/checkout-dialog-synced.js +0 -2
  78. package/dist/libraries/react/components/checkout-dialog/checkout-dialog-synced.mjs +21 -21
  79. package/dist/libraries/react/components/paywall-dialog/paywall-dialog-synced.mjs +21 -21
  80. package/dist/libraries/react/components/pricing-table/pricing-table-synced.js +0 -2
  81. package/dist/libraries/react/components/pricing-table/pricing-table-synced.mjs +21 -21
  82. package/dist/libraries/react/components/ui/accordion.mjs +3 -3
  83. package/dist/libraries/react/components/ui/dialog.mjs +4 -4
  84. package/dist/libraries/react/components/ui/popover.mjs +5 -5
  85. package/dist/libraries/react/components/ui/switch.mjs +3 -3
  86. package/dist/libraries/react/hooks/helpers/handleCheck.d.mts +1 -1
  87. package/dist/libraries/react/hooks/helpers/handleCheck.d.ts +1 -1
  88. package/dist/libraries/react/hooks/helpers/handleCheck.js +0 -2
  89. package/dist/libraries/react/hooks/helpers/handleCheck.mjs +1 -1
  90. package/dist/libraries/react/hooks/helpers/useAutumnBase.d.mts +1 -1
  91. package/dist/libraries/react/hooks/helpers/useAutumnBase.d.ts +1 -1
  92. package/dist/libraries/react/hooks/useCustomer.d.mts +1 -1
  93. package/dist/libraries/react/hooks/useCustomer.d.ts +1 -1
  94. package/dist/libraries/react/hooks/useCustomer.js +0 -2
  95. package/dist/libraries/react/hooks/useCustomer.mjs +3 -3
  96. package/dist/libraries/react/hooks/useCustomerBase.d.mts +1 -1
  97. package/dist/libraries/react/hooks/useCustomerBase.d.ts +1 -1
  98. package/dist/libraries/react/hooks/useCustomerBase.js +0 -2
  99. package/dist/libraries/react/hooks/useCustomerBase.mjs +2 -2
  100. package/dist/libraries/react/hooks/useEntity.js +0 -2
  101. package/dist/libraries/react/hooks/useEntity.mjs +3 -3
  102. package/dist/libraries/react/hooks/useEntityBase.d.mts +1 -1
  103. package/dist/libraries/react/hooks/useEntityBase.d.ts +1 -1
  104. package/dist/libraries/react/hooks/useEntityBase.js +0 -2
  105. package/dist/libraries/react/hooks/useEntityBase.mjs +2 -2
  106. package/dist/libraries/react/hooks/usePricingTableBase.d.mts +1 -1
  107. package/dist/libraries/react/hooks/usePricingTableBase.d.ts +1 -1
  108. package/dist/libraries/react/hooks/useProductsBase.d.mts +1 -1
  109. package/dist/libraries/react/hooks/useProductsBase.d.ts +1 -1
  110. package/dist/libraries/react/index.js +12 -11
  111. package/dist/libraries/react/index.mjs +12 -11
  112. package/dist/next/client/NextAutumnClient.d.mts +1 -1
  113. package/dist/next/client/NextAutumnClient.d.ts +1 -1
  114. package/package.json +6 -1
  115. package/dist/libraries/react/{chunk-YN67J64M.mjs → chunk-D3PGSU2Q.mjs} +11 -11
@@ -1 +1,1557 @@
1
1
  "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/libraries/backend/convex.ts
21
+ var convex_exports = {};
22
+ __export(convex_exports, {
23
+ autumnHandler: () => autumnHandler,
24
+ convexHandler: () => convexHandler
25
+ });
26
+ module.exports = __toCommonJS(convex_exports);
27
+
28
+ // src/sdk/error.ts
29
+ var AutumnError = class _AutumnError extends Error {
30
+ message;
31
+ code;
32
+ constructor(response) {
33
+ super(response.message);
34
+ this.message = response.message;
35
+ this.code = response.code;
36
+ }
37
+ static fromError(error) {
38
+ return new _AutumnError({
39
+ message: error.message || "Unknown error",
40
+ code: error.code || "unknown_error"
41
+ });
42
+ }
43
+ toString() {
44
+ return `${this.message} (code: ${this.code})`;
45
+ }
46
+ toJSON() {
47
+ return {
48
+ message: this.message,
49
+ code: this.code
50
+ };
51
+ }
52
+ };
53
+
54
+ // src/sdk/general/genMethods.ts
55
+ var handleCheckout = async ({
56
+ instance,
57
+ params
58
+ }) => {
59
+ return instance.post("/checkout", params);
60
+ };
61
+ var handleAttach = async ({
62
+ instance,
63
+ params
64
+ }) => {
65
+ return instance.post("/attach", params);
66
+ };
67
+ var handleSetupPayment = async ({
68
+ instance,
69
+ params
70
+ }) => {
71
+ return instance.post("/setup_payment", params);
72
+ };
73
+ var handleCancel = async ({
74
+ instance,
75
+ params
76
+ }) => {
77
+ return instance.post("/cancel", params);
78
+ };
79
+ var handleTrack = async ({
80
+ instance,
81
+ params
82
+ }) => {
83
+ return instance.post("/track", params);
84
+ };
85
+ var handleUsage = async ({
86
+ instance,
87
+ params
88
+ }) => {
89
+ return instance.post("/usage", params);
90
+ };
91
+ var handleCheck = async ({
92
+ instance,
93
+ params
94
+ }) => {
95
+ return instance.post("/check", params);
96
+ };
97
+ var handleQuery = async ({
98
+ instance,
99
+ params
100
+ }) => {
101
+ return instance.post("/query", params);
102
+ };
103
+
104
+ // src/libraries/backend/constants.ts
105
+ var autumnApiUrl = "https://api.useautumn.com/v1";
106
+ var BASE_PATH = "/api/autumn";
107
+
108
+ // src/sdk/utils.ts
109
+ var staticWrapper = (callback, instance, args) => {
110
+ if (!instance) {
111
+ instance = new Autumn();
112
+ }
113
+ return callback({ instance, ...args });
114
+ };
115
+
116
+ // src/sdk/customers/cusMethods.ts
117
+ var customerMethods = (instance) => {
118
+ return {
119
+ get: (id, params) => staticWrapper(getCustomer, instance, { id, params }),
120
+ create: (params) => staticWrapper(createCustomer, instance, { params }),
121
+ update: (id, params) => staticWrapper(updateCustomer, instance, { id, params }),
122
+ delete: (id) => staticWrapper(deleteCustomer, instance, { id }),
123
+ billingPortal: (id, params) => staticWrapper(billingPortal, instance, { id, params }),
124
+ updateBalances: (id, params) => staticWrapper(updateBalances, instance, { id, params })
125
+ };
126
+ };
127
+ var getExpandStr = (expand) => {
128
+ if (!expand) {
129
+ return "";
130
+ }
131
+ return `expand=${expand.join(",")}`;
132
+ };
133
+ var getCustomer = async ({
134
+ instance,
135
+ id,
136
+ params
137
+ }) => {
138
+ if (!id) {
139
+ return {
140
+ data: null,
141
+ error: new AutumnError({
142
+ message: "Customer ID is required",
143
+ code: "CUSTOMER_ID_REQUIRED"
144
+ })
145
+ };
146
+ }
147
+ return instance.get(`/customers/${id}?${getExpandStr(params?.expand)}`);
148
+ };
149
+ var createCustomer = async ({
150
+ instance,
151
+ params
152
+ }) => {
153
+ return instance.post(`/customers?${getExpandStr(params?.expand)}`, params);
154
+ };
155
+ var updateCustomer = async ({
156
+ instance,
157
+ id,
158
+ params
159
+ }) => {
160
+ return instance.post(`/customers/${id}`, params);
161
+ };
162
+ var deleteCustomer = async ({
163
+ instance,
164
+ id
165
+ }) => {
166
+ return instance.delete(`/customers/${id}`);
167
+ };
168
+ var billingPortal = async ({
169
+ instance,
170
+ id,
171
+ params
172
+ }) => {
173
+ return instance.post(`/customers/${id}/billing_portal`, params);
174
+ };
175
+ var updateBalances = async ({
176
+ instance,
177
+ id,
178
+ params
179
+ }) => {
180
+ return instance.post(`/customers/${id}/balances`, {
181
+ balances: Array.isArray(params) ? params : [params]
182
+ });
183
+ };
184
+
185
+ // src/sdk/customers/entities/entMethods.ts
186
+ var entityMethods = (instance) => {
187
+ return {
188
+ get: (customer_id, entity_id, params) => staticWrapper(getEntity, instance, {
189
+ customer_id,
190
+ entity_id,
191
+ params
192
+ }),
193
+ create: (customer_id, params) => staticWrapper(createEntity, instance, { customer_id, params }),
194
+ transfer: (customer_id, params) => staticWrapper(transferProduct, instance, { customer_id, params }),
195
+ delete: (customer_id, entity_id) => staticWrapper(deleteEntity, instance, { customer_id, entity_id })
196
+ };
197
+ };
198
+ var getExpandStr2 = (expand) => {
199
+ if (!expand) {
200
+ return "";
201
+ }
202
+ return `expand=${expand.join(",")}`;
203
+ };
204
+ var getEntity = async ({
205
+ instance,
206
+ customer_id,
207
+ entity_id,
208
+ params
209
+ }) => {
210
+ return instance.get(
211
+ `/customers/${customer_id}/entities/${entity_id}?${getExpandStr2(
212
+ params?.expand
213
+ )}`
214
+ );
215
+ };
216
+ var createEntity = async ({
217
+ instance,
218
+ customer_id,
219
+ params
220
+ }) => {
221
+ return instance.post(`/customers/${customer_id}/entities`, params);
222
+ };
223
+ var deleteEntity = async ({
224
+ instance,
225
+ customer_id,
226
+ entity_id
227
+ }) => {
228
+ return instance.delete(`/customers/${customer_id}/entities/${entity_id}`);
229
+ };
230
+ var transferProduct = async ({
231
+ instance,
232
+ customer_id,
233
+ params
234
+ }) => {
235
+ return instance.post(`/customers/${customer_id}/transfer`, params);
236
+ };
237
+
238
+ // src/sdk/products/prodMethods.ts
239
+ var productMethods = (instance) => {
240
+ return {
241
+ get: (id) => staticWrapper(getProduct, instance, { id }),
242
+ create: (params) => staticWrapper(createProduct, instance, { params }),
243
+ list: (params) => staticWrapper(listProducts, instance, { params })
244
+ };
245
+ };
246
+ var listProducts = async ({
247
+ instance,
248
+ params
249
+ }) => {
250
+ let path = "/products_beta";
251
+ if (params) {
252
+ const queryParams = new URLSearchParams();
253
+ for (const [key, value] of Object.entries(params)) {
254
+ if (value !== void 0) {
255
+ queryParams.append(key, String(value));
256
+ }
257
+ }
258
+ const queryString = queryParams.toString();
259
+ if (queryString) {
260
+ path += `?${queryString}`;
261
+ }
262
+ }
263
+ return instance.get(path);
264
+ };
265
+ var getProduct = async ({
266
+ instance,
267
+ id
268
+ }) => {
269
+ return instance.get(`/products/${id}`);
270
+ };
271
+ var createProduct = async ({
272
+ instance,
273
+ params
274
+ }) => {
275
+ return instance.post("/products", params);
276
+ };
277
+
278
+ // src/sdk/referrals/referralMethods.ts
279
+ var referralMethods = (instance) => {
280
+ return {
281
+ createCode: (params) => staticWrapper(createReferralCode, instance, { params }),
282
+ redeemCode: (params) => staticWrapper(redeemReferralCode, instance, { params })
283
+ };
284
+ };
285
+ var createReferralCode = async ({
286
+ instance,
287
+ params
288
+ }) => {
289
+ return instance.post("/referrals/code", params);
290
+ };
291
+ var redeemReferralCode = async ({
292
+ instance,
293
+ params
294
+ }) => {
295
+ return instance.post("/referrals/redeem", params);
296
+ };
297
+
298
+ // src/sdk/response.ts
299
+ var toContainerResult = async ({
300
+ response,
301
+ logger: logger2,
302
+ logError = true
303
+ }) => {
304
+ if (response.status < 200 || response.status >= 300) {
305
+ let error;
306
+ try {
307
+ error = await response.json();
308
+ if (logError) {
309
+ logger2.error(`[Autumn] ${error.message}`);
310
+ }
311
+ } catch (error2) {
312
+ throw error2;
313
+ return {
314
+ data: null,
315
+ error: new AutumnError({
316
+ message: "Failed to parse JSON response from Autumn",
317
+ code: "internal_error"
318
+ }),
319
+ statusCode: response.status
320
+ };
321
+ }
322
+ return {
323
+ data: null,
324
+ error: new AutumnError({
325
+ message: error.message,
326
+ code: error.code
327
+ }),
328
+ statusCode: response.status
329
+ };
330
+ }
331
+ try {
332
+ let data = await response.json();
333
+ return {
334
+ data,
335
+ error: null,
336
+ statusCode: response?.status
337
+ };
338
+ } catch (error) {
339
+ throw error;
340
+ return {
341
+ data: null,
342
+ error: new AutumnError({
343
+ message: "Failed to parse Autumn API response",
344
+ code: "internal_error"
345
+ }),
346
+ statusCode: response?.status
347
+ };
348
+ }
349
+ };
350
+
351
+ // src/utils/logger.ts
352
+ var getTime = () => {
353
+ let timeString = (/* @__PURE__ */ new Date()).toISOString();
354
+ return `[${timeString.split("T")[1].split(".")[0]}]`;
355
+ };
356
+ var greaterThanLevel = (level) => {
357
+ return levels.indexOf(level) >= levels.indexOf(logger.level);
358
+ };
359
+ var levels = ["debug", "info", "warn", "error", "fatal"];
360
+ var logger = {
361
+ ...console,
362
+ level: "info",
363
+ debug: (...args) => {
364
+ if (greaterThanLevel("debug")) {
365
+ console.log(getTime(), "DEBUG", ...args);
366
+ }
367
+ },
368
+ log: (...args) => {
369
+ console.log(getTime(), "INFO", ...args);
370
+ },
371
+ info: (...args) => {
372
+ if (greaterThanLevel("info")) {
373
+ console.log(getTime(), "INFO", ...args);
374
+ }
375
+ },
376
+ warn: (...args) => {
377
+ if (greaterThanLevel("warn")) {
378
+ console.log(getTime(), "WARN", ...args);
379
+ }
380
+ },
381
+ error: (...args) => {
382
+ if (greaterThanLevel("error")) {
383
+ console.log(getTime(), "ERROR", ...args);
384
+ }
385
+ }
386
+ };
387
+
388
+ // src/sdk/features/featureMethods.ts
389
+ var featureMethods = (instance) => {
390
+ return {
391
+ list: () => staticWrapper(listFeatures, instance, {})
392
+ };
393
+ };
394
+ var listFeatures = async ({
395
+ instance,
396
+ params
397
+ }) => {
398
+ let path = "/features";
399
+ if (params) {
400
+ const queryParams = new URLSearchParams();
401
+ for (const [key, value] of Object.entries(params)) {
402
+ if (value !== void 0) {
403
+ queryParams.append(key, String(value));
404
+ }
405
+ }
406
+ const queryString = queryParams.toString();
407
+ if (queryString) {
408
+ path += `?${queryString}`;
409
+ }
410
+ }
411
+ return instance.get(path);
412
+ };
413
+
414
+ // src/sdk/client.ts
415
+ var LATEST_API_VERSION = "1.2";
416
+ var Autumn = class {
417
+ secretKey;
418
+ publishableKey;
419
+ headers;
420
+ url;
421
+ logger = console;
422
+ constructor(options) {
423
+ try {
424
+ this.secretKey = options?.secretKey || process.env.AUTUMN_SECRET_KEY;
425
+ this.publishableKey = options?.publishableKey || process.env.AUTUMN_PUBLISHABLE_KEY;
426
+ } catch (error) {
427
+ }
428
+ if (!this.secretKey && !this.publishableKey && !options?.headers) {
429
+ throw new Error("Autumn secret key or publishable key is required");
430
+ }
431
+ this.headers = options?.headers || {
432
+ Authorization: `Bearer ${this.secretKey || this.publishableKey}`,
433
+ "Content-Type": "application/json"
434
+ };
435
+ let version = options?.version || LATEST_API_VERSION;
436
+ this.headers["x-api-version"] = version;
437
+ this.url = options?.url || autumnApiUrl;
438
+ this.logger = logger;
439
+ this.logger.level = options?.logLevel || "info";
440
+ }
441
+ async get(path) {
442
+ const response = await fetch(`${this.url}${path}`, {
443
+ headers: this.headers
444
+ });
445
+ return toContainerResult({ response, logger: this.logger });
446
+ }
447
+ async post(path, body) {
448
+ try {
449
+ const response = await fetch(`${this.url}${path}`, {
450
+ method: "POST",
451
+ headers: this.headers,
452
+ body: JSON.stringify(body)
453
+ });
454
+ return toContainerResult({ response, logger: this.logger });
455
+ } catch (error) {
456
+ console.error("Error sending request:", error);
457
+ throw error;
458
+ }
459
+ }
460
+ async delete(path) {
461
+ const response = await fetch(`${this.url}${path}`, {
462
+ method: "DELETE",
463
+ headers: this.headers
464
+ });
465
+ return toContainerResult({ response, logger: this.logger });
466
+ }
467
+ static customers = customerMethods();
468
+ static products = productMethods();
469
+ static entities = entityMethods();
470
+ static referrals = referralMethods();
471
+ static features = featureMethods();
472
+ customers = customerMethods(this);
473
+ products = productMethods(this);
474
+ entities = entityMethods(this);
475
+ referrals = referralMethods(this);
476
+ features = featureMethods(this);
477
+ /**
478
+ * Initiates a checkout flow for a product purchase.
479
+ *
480
+ * The checkout function handles the purchase process for products with pricing.
481
+ * It determines whether to show a dialog for user input or redirect directly
482
+ * to Stripe based on the customer's state and product requirements.
483
+ *
484
+ * @param params - Checkout parameters including product ID, customer data, and options
485
+ * @returns Promise resolving to checkout details including pricing, prorations, and URLs
486
+ *
487
+ * @example
488
+ * ```typescript
489
+ * const result = await autumn.checkout({
490
+ * customer_id: "user_123",
491
+ * product_id: "pro",
492
+ * success_url: "https://myapp.com/success"
493
+ * });
494
+ *
495
+ * if (result.url) {
496
+ * // Redirect to Stripe checkout
497
+ * window.location.href = result.url;
498
+ * }
499
+ * ```
500
+ */
501
+ async checkout(params) {
502
+ return handleCheckout({
503
+ instance: this,
504
+ params
505
+ });
506
+ }
507
+ static checkout = (params) => staticWrapper(handleCheckout, void 0, { params });
508
+ static usage = (params) => staticWrapper(handleUsage, void 0, { params });
509
+ /**
510
+ * Attaches a product to a customer, enabling access and handling billing.
511
+ *
512
+ * The attach function activates a product for a customer and applies all product items.
513
+ * When you attach a product:
514
+ * - The customer gains access to all features in the product
515
+ * - If the product has prices, the customer will be billed accordingly
516
+ * - If there's no existing payment method, a checkout URL will be generated
517
+ *
518
+ * @param params - Attach parameters including customer ID, product ID, and options
519
+ * @returns Promise resolving to attachment result with checkout URL if needed
520
+ *
521
+ * @example
522
+ * ```typescript
523
+ * const result = await autumn.attach({
524
+ * customer_id: "user_123",
525
+ * product_id: "pro",
526
+ * success_url: "https://myapp.com/success"
527
+ * });
528
+ *
529
+ * if (result.checkout_url) {
530
+ * // Payment required - redirect to checkout
531
+ * window.location.href = result.checkout_url;
532
+ * } else {
533
+ * // Product successfully attached
534
+ * console.log("Access granted:", result.message);
535
+ * }
536
+ * ```
537
+ */
538
+ async attach(params) {
539
+ return handleAttach({
540
+ instance: this,
541
+ params
542
+ });
543
+ }
544
+ static attach = (params) => staticWrapper(handleAttach, void 0, { params });
545
+ static setupPayment = (params) => staticWrapper(handleSetupPayment, void 0, { params });
546
+ /**
547
+ * Sets up a payment method for a customer.
548
+ *
549
+ * This method allows you to set up payment methods for customers without
550
+ * immediately charging them. Useful for collecting payment information
551
+ * before product attachment or for updating existing payment methods.
552
+ *
553
+ * @param params - Setup payment parameters including customer information
554
+ * @returns Promise resolving to setup payment result
555
+ *
556
+ * @example
557
+ * ```typescript
558
+ * const result = await autumn.setupPayment({
559
+ * customer_id: "user_123"
560
+ * });
561
+ * ```
562
+ */
563
+ async setupPayment(params) {
564
+ return handleSetupPayment({
565
+ instance: this,
566
+ params
567
+ });
568
+ }
569
+ static cancel = (params) => staticWrapper(handleCancel, void 0, { params });
570
+ /**
571
+ * Cancels a customer's subscription or product attachment.
572
+ *
573
+ * This method allows you to cancel a customer's subscription to a specific product.
574
+ * You can choose to cancel immediately or at the end of the billing cycle.
575
+ *
576
+ * @param params - Cancel parameters including customer ID and product ID
577
+ * @returns Promise resolving to cancellation result
578
+ *
579
+ * @example
580
+ * ```typescript
581
+ * const result = await autumn.cancel({
582
+ * customer_id: "user_123",
583
+ * product_id: "pro",
584
+ * cancel_immediately: false // Cancel at end of billing cycle
585
+ * });
586
+ * ```
587
+ */
588
+ async cancel(params) {
589
+ return handleCancel({
590
+ instance: this,
591
+ params
592
+ });
593
+ }
594
+ static check = (params) => staticWrapper(handleCheck, void 0, { params });
595
+ /**
596
+ * Checks if a customer has access to a specific feature.
597
+ *
598
+ * This method verifies whether a customer has permission to use a feature
599
+ * and checks their remaining balance/usage limits. It can be used to gate
600
+ * features and determine when to show upgrade prompts.
601
+ *
602
+ * @param params - Check parameters including customer ID and feature ID
603
+ * @returns Promise resolving to access check result with allowed status and balance info
604
+ *
605
+ * @example
606
+ * ```typescript
607
+ * const result = await autumn.check({
608
+ * customer_id: "user_123",
609
+ * feature_id: "messages",
610
+ * required_balance: 1
611
+ * });
612
+ *
613
+ * if (!result.allowed) {
614
+ * console.log("Feature access denied - upgrade required");
615
+ * }
616
+ * ```
617
+ */
618
+ async check(params) {
619
+ return handleCheck({
620
+ instance: this,
621
+ params
622
+ });
623
+ }
624
+ static track = (params) => staticWrapper(handleTrack, void 0, { params });
625
+ /**
626
+ * Tracks usage events for features or analytics.
627
+ *
628
+ * This method records usage events for metered features, updating the customer's
629
+ * balance and usage statistics. It's typically used server-side to ensure
630
+ * accurate tracking that cannot be manipulated by users.
631
+ *
632
+ * @param params - Track parameters including customer ID, feature ID, and usage value
633
+ * @returns Promise resolving to tracking result
634
+ *
635
+ * @example
636
+ * ```typescript
637
+ * const result = await autumn.track({
638
+ * customer_id: "user_123",
639
+ * feature_id: "messages",
640
+ * value: 1 // Track 1 message sent
641
+ * });
642
+ * ```
643
+ */
644
+ async track(params) {
645
+ return handleTrack({
646
+ instance: this,
647
+ params
648
+ });
649
+ }
650
+ /**
651
+ * Retrieves usage statistics and analytics for a customer.
652
+ *
653
+ * This method fetches detailed usage information for a customer's features,
654
+ * including current balances, usage history, and analytics data. Useful
655
+ * for displaying usage dashboards or generating reports.
656
+ *
657
+ * @param params - Usage parameters including customer ID and optional filters
658
+ * @returns Promise resolving to usage statistics and analytics data
659
+ *
660
+ * @example
661
+ * ```typescript
662
+ * const result = await autumn.usage({
663
+ * customer_id: "user_123",
664
+ * feature_id: "messages"
665
+ * value: 20 // Usage value
666
+ * });
667
+ * ```
668
+ */
669
+ async usage(params) {
670
+ return handleUsage({
671
+ instance: this,
672
+ params
673
+ });
674
+ }
675
+ static query = (params) => staticWrapper(handleQuery, void 0, { params });
676
+ /**
677
+ * Performs advanced queries on customer data and analytics.
678
+ *
679
+ * This method allows you to run complex queries against customer data,
680
+ * usage patterns, and billing information. Useful for generating reports,
681
+ * analytics, and custom data insights.
682
+ *
683
+ * @param params - Query parameters including customer ID and query specifications
684
+ * @returns Promise resolving to query results with requested data
685
+ *
686
+ * @example
687
+ * ```typescript
688
+ * const result = await autumn.query({
689
+ * customer_id: "user_123",
690
+ * feature_id: "messages" // feature id to fetch for query, can also be an array
691
+ * });
692
+ *
693
+ * ```
694
+ */
695
+ async query(params) {
696
+ return handleQuery({
697
+ instance: this,
698
+ params
699
+ });
700
+ }
701
+ };
702
+
703
+ // src/sdk/products/prodEnums.ts
704
+ var ProductItemInterval = /* @__PURE__ */ ((ProductItemInterval2) => {
705
+ ProductItemInterval2["Minute"] = "minute";
706
+ ProductItemInterval2["Hour"] = "hour";
707
+ ProductItemInterval2["Day"] = "day";
708
+ ProductItemInterval2["Week"] = "week";
709
+ ProductItemInterval2["Month"] = "month";
710
+ ProductItemInterval2["Quarter"] = "quarter";
711
+ ProductItemInterval2["SemiAnnual"] = "semi_annual";
712
+ ProductItemInterval2["Year"] = "year";
713
+ ProductItemInterval2["Multiple"] = "multiple";
714
+ return ProductItemInterval2;
715
+ })(ProductItemInterval || {});
716
+
717
+ // src/sdk/customers/cusEnums.ts
718
+ var import_v4 = require("zod/v4");
719
+ var CustomerExpandEnum = import_v4.z.enum([
720
+ "invoices",
721
+ "rewards",
722
+ "trials_used",
723
+ "entities",
724
+ "referrals",
725
+ "payment_method"
726
+ ]);
727
+
728
+ // src/sdk/customers/cusTypes.ts
729
+ var import_v42 = require("zod/v4");
730
+ var CoreCusFeatureSchema = import_v42.z.object({
731
+ unlimited: import_v42.z.boolean().optional(),
732
+ interval: import_v42.z.enum(ProductItemInterval).optional(),
733
+ balance: import_v42.z.number().nullish(),
734
+ usage: import_v42.z.number().optional(),
735
+ included_usage: import_v42.z.number().optional(),
736
+ next_reset_at: import_v42.z.number().nullish(),
737
+ overage_allowed: import_v42.z.boolean().optional(),
738
+ usage_limit: import_v42.z.number().optional(),
739
+ rollovers: import_v42.z.object({
740
+ balance: import_v42.z.number(),
741
+ expires_at: import_v42.z.number()
742
+ }).optional(),
743
+ breakdown: import_v42.z.array(
744
+ import_v42.z.object({
745
+ interval: import_v42.z.enum(ProductItemInterval),
746
+ balance: import_v42.z.number().optional(),
747
+ usage: import_v42.z.number().optional(),
748
+ included_usage: import_v42.z.number().optional(),
749
+ next_reset_at: import_v42.z.number().optional()
750
+ })
751
+ ).optional(),
752
+ credit_schema: import_v42.z.array(
753
+ import_v42.z.object({
754
+ feature_id: import_v42.z.string(),
755
+ credit_amount: import_v42.z.number()
756
+ })
757
+ ).optional()
758
+ });
759
+ var CustomerDataSchema = import_v42.z.object({
760
+ name: import_v42.z.string().nullish(),
761
+ email: import_v42.z.string().nullish(),
762
+ fingerprint: import_v42.z.string().nullish()
763
+ });
764
+ var CreateCustomerParamsSchema = import_v42.z.object({
765
+ id: import_v42.z.string().nullish(),
766
+ email: import_v42.z.string().nullish(),
767
+ name: import_v42.z.string().nullish(),
768
+ fingerprint: import_v42.z.string().nullish(),
769
+ metadata: import_v42.z.record(import_v42.z.string(), import_v42.z.any()).optional(),
770
+ expand: import_v42.z.array(CustomerExpandEnum).optional(),
771
+ stripe_id: import_v42.z.string().nullish()
772
+ });
773
+ var BillingPortalParamsSchema = import_v42.z.object({
774
+ return_url: import_v42.z.string().optional()
775
+ });
776
+ var UpdateBalancesParamsSchema = import_v42.z.object({
777
+ feature_id: import_v42.z.string(),
778
+ balance: import_v42.z.number()
779
+ }).or(
780
+ import_v42.z.array(
781
+ import_v42.z.object({
782
+ feature_id: import_v42.z.string(),
783
+ balance: import_v42.z.number()
784
+ })
785
+ )
786
+ );
787
+
788
+ // src/sdk/general/checkTypes.ts
789
+ var import_v43 = require("zod/v4");
790
+ var CheckFeatureResultSchema = import_v43.z.object({
791
+ allowed: import_v43.z.boolean(),
792
+ feature_id: import_v43.z.string(),
793
+ customer_id: import_v43.z.string(),
794
+ entity_id: import_v43.z.string().optional(),
795
+ required_balance: import_v43.z.number()
796
+ }).extend(CoreCusFeatureSchema.shape);
797
+
798
+ // src/sdk/customers/entities/entTypes.ts
799
+ var import_v44 = require("zod/v4");
800
+ var EntityDataSchema = import_v44.z.object({
801
+ name: import_v44.z.string().optional(),
802
+ feature_id: import_v44.z.string()
803
+ });
804
+ var TransferProductParamsSchema = import_v44.z.object({
805
+ from_entity_id: import_v44.z.string(),
806
+ to_entity_id: import_v44.z.string(),
807
+ product_id: import_v44.z.string()
808
+ });
809
+
810
+ // src/sdk/general/genTypes.ts
811
+ var import_v45 = require("zod/v4");
812
+ var CancelParamsSchema = import_v45.z.object({
813
+ customer_id: import_v45.z.string(),
814
+ product_id: import_v45.z.string(),
815
+ entity_id: import_v45.z.string().optional(),
816
+ cancel_immediately: import_v45.z.boolean().optional()
817
+ });
818
+ var CancelResultSchema = import_v45.z.object({
819
+ success: import_v45.z.boolean(),
820
+ customer_id: import_v45.z.string(),
821
+ product_id: import_v45.z.string()
822
+ });
823
+ var TrackParamsSchema = import_v45.z.object({
824
+ customer_id: import_v45.z.string(),
825
+ value: import_v45.z.number().optional(),
826
+ feature_id: import_v45.z.string().optional(),
827
+ event_name: import_v45.z.string().optional(),
828
+ entity_id: import_v45.z.string().optional(),
829
+ customer_data: import_v45.z.any().optional(),
830
+ idempotency_key: import_v45.z.string().optional(),
831
+ entity_data: import_v45.z.any().optional()
832
+ });
833
+ var TrackResultSchema = import_v45.z.object({
834
+ id: import_v45.z.string(),
835
+ code: import_v45.z.string(),
836
+ customer_id: import_v45.z.string(),
837
+ feature_id: import_v45.z.string().optional(),
838
+ event_name: import_v45.z.string().optional()
839
+ });
840
+ var CheckParamsSchema = import_v45.z.object({
841
+ customer_id: import_v45.z.string(),
842
+ feature_id: import_v45.z.string().optional(),
843
+ product_id: import_v45.z.string().optional(),
844
+ entity_id: import_v45.z.string().optional(),
845
+ customer_data: import_v45.z.any().optional(),
846
+ required_balance: import_v45.z.number().optional(),
847
+ send_event: import_v45.z.boolean().optional(),
848
+ with_preview: import_v45.z.boolean().optional(),
849
+ entity_data: EntityDataSchema.optional()
850
+ });
851
+ var QueryRangeEnum = import_v45.z.enum(["24h", "7d", "30d", "90d", "last_cycle"]);
852
+ var QueryParamsSchema = import_v45.z.object({
853
+ customer_id: import_v45.z.string(),
854
+ feature_id: import_v45.z.string().or(import_v45.z.array(import_v45.z.string())),
855
+ range: QueryRangeEnum.optional()
856
+ });
857
+
858
+ // src/sdk/components/componentMethods.ts
859
+ var fetchPricingTable = async ({
860
+ instance,
861
+ params
862
+ }) => {
863
+ let path = "/components/pricing_table";
864
+ if (params) {
865
+ const queryParams = new URLSearchParams();
866
+ for (const [key, value] of Object.entries(params)) {
867
+ if (key === "products") {
868
+ continue;
869
+ }
870
+ if (value !== void 0) {
871
+ queryParams.append(key, String(value));
872
+ }
873
+ }
874
+ const queryString = queryParams.toString();
875
+ if (queryString) {
876
+ path += `?${queryString}`;
877
+ }
878
+ }
879
+ return await instance.get(path);
880
+ };
881
+
882
+ // src/sdk/referrals/referralTypes.ts
883
+ var import_v46 = require("zod/v4");
884
+ var CreateReferralCodeParamsSchema = import_v46.z.object({
885
+ customer_id: import_v46.z.string(),
886
+ program_id: import_v46.z.string()
887
+ });
888
+ var RedeemReferralCodeParamsSchema = import_v46.z.object({
889
+ code: import_v46.z.string(),
890
+ customer_id: import_v46.z.string()
891
+ });
892
+
893
+ // src/sdk/general/attachTypes.ts
894
+ var import_v47 = require("zod/v4");
895
+ var AttachFeatureOptionsSchema = import_v47.z.object({
896
+ feature_id: import_v47.z.string(),
897
+ quantity: import_v47.z.number()
898
+ });
899
+ var AttachParamsSchema = import_v47.z.object({
900
+ customer_id: import_v47.z.string(),
901
+ product_id: import_v47.z.string().optional(),
902
+ entity_id: import_v47.z.string().optional(),
903
+ options: import_v47.z.array(AttachFeatureOptionsSchema).optional(),
904
+ product_ids: import_v47.z.array(import_v47.z.string()).optional(),
905
+ free_trial: import_v47.z.boolean().optional(),
906
+ success_url: import_v47.z.string().optional(),
907
+ metadata: import_v47.z.record(import_v47.z.string(), import_v47.z.string()).optional(),
908
+ force_checkout: import_v47.z.boolean().optional(),
909
+ customer_data: CustomerDataSchema.optional(),
910
+ entity_data: import_v47.z.any().optional(),
911
+ checkout_session_params: import_v47.z.record(import_v47.z.string(), import_v47.z.any()).optional(),
912
+ reward: import_v47.z.string().optional(),
913
+ invoice: import_v47.z.boolean().optional()
914
+ });
915
+ var AttachResultSchema = import_v47.z.object({
916
+ checkout_url: import_v47.z.string().optional(),
917
+ customer_id: import_v47.z.string(),
918
+ product_ids: import_v47.z.array(import_v47.z.string()),
919
+ code: import_v47.z.string(),
920
+ message: import_v47.z.string(),
921
+ customer_data: import_v47.z.any().optional(),
922
+ invoice: import_v47.z.object({
923
+ status: import_v47.z.string(),
924
+ stripe_id: import_v47.z.string(),
925
+ hosted_invoice_url: import_v47.z.string().nullable(),
926
+ total: import_v47.z.number(),
927
+ currency: import_v47.z.string()
928
+ }).optional()
929
+ });
930
+ var CheckoutParamsSchema = import_v47.z.object({
931
+ customer_id: import_v47.z.string(),
932
+ product_id: import_v47.z.string(),
933
+ product_ids: import_v47.z.array(import_v47.z.string()).optional(),
934
+ entity_id: import_v47.z.string().optional(),
935
+ options: import_v47.z.array(AttachFeatureOptionsSchema).optional(),
936
+ force_checkout: import_v47.z.boolean().optional(),
937
+ invoice: import_v47.z.boolean().optional(),
938
+ success_url: import_v47.z.string().optional(),
939
+ customer_data: CustomerDataSchema.optional(),
940
+ entity_data: import_v47.z.any().optional(),
941
+ checkout_session_params: import_v47.z.record(import_v47.z.string(), import_v47.z.any()).optional(),
942
+ reward: import_v47.z.string().optional()
943
+ });
944
+
945
+ // src/sdk/features/featureTypes.ts
946
+ var import_zod = require("zod");
947
+ var FeatureType = /* @__PURE__ */ ((FeatureType2) => {
948
+ FeatureType2["Boolean"] = "boolean";
949
+ FeatureType2["SingleUse"] = "single_use";
950
+ FeatureType2["ContinuousUse"] = "continuous_use";
951
+ FeatureType2["CreditSystem"] = "credit_system";
952
+ return FeatureType2;
953
+ })(FeatureType || {});
954
+ var FeatureSchema = import_zod.z.object({
955
+ id: import_zod.z.string(),
956
+ name: import_zod.z.string().nullish(),
957
+ type: import_zod.z.nativeEnum(FeatureType),
958
+ display: import_zod.z.object({
959
+ singular: import_zod.z.string(),
960
+ plural: import_zod.z.string()
961
+ }).nullish(),
962
+ credit_schema: import_zod.z.array(
963
+ import_zod.z.object({
964
+ metered_feature_id: import_zod.z.string(),
965
+ credit_cost: import_zod.z.number()
966
+ })
967
+ ).nullish()
968
+ });
969
+
970
+ // src/libraries/backend/utils/backendRes.ts
971
+ var toBackendRes = ({ res }) => {
972
+ let statusCode = res.statusCode ? res.statusCode : res.error ? 500 : 200;
973
+ return {
974
+ body: res.data ? res.data : res.error,
975
+ statusCode
976
+ };
977
+ };
978
+ var toBackendError = ({
979
+ path,
980
+ message,
981
+ code,
982
+ statusCode = 500
983
+ }) => {
984
+ return {
985
+ statusCode,
986
+ body: new AutumnError({
987
+ message: message || "Internal server error",
988
+ code: code || "internal_server_error"
989
+ })
990
+ };
991
+ };
992
+
993
+ // src/libraries/backend/utils/withAuth.ts
994
+ var withAuth = ({
995
+ fn,
996
+ requireCustomer = true
997
+ }) => {
998
+ return async ({
999
+ autumn,
1000
+ body,
1001
+ path,
1002
+ getCustomer: getCustomer2,
1003
+ pathParams,
1004
+ searchParams
1005
+ }) => {
1006
+ let authResult = await getCustomer2();
1007
+ let customerId = authResult?.customerId;
1008
+ if (!customerId && requireCustomer) {
1009
+ if (body?.errorOnNotFound === false) {
1010
+ return {
1011
+ statusCode: 202,
1012
+ body: null
1013
+ };
1014
+ } else {
1015
+ logger.error(
1016
+ `[Autumn]: customerId returned from identify function is ${customerId}`
1017
+ );
1018
+ return toBackendError({
1019
+ path,
1020
+ message: `customerId returned from identify function is ${customerId}`,
1021
+ code: "no_customer_id",
1022
+ statusCode: 401
1023
+ });
1024
+ }
1025
+ }
1026
+ let cusData = authResult?.customerData || body?.customer_data;
1027
+ try {
1028
+ let res = await fn({
1029
+ body,
1030
+ autumn,
1031
+ customer_id: customerId,
1032
+ customer_data: cusData,
1033
+ pathParams,
1034
+ searchParams
1035
+ });
1036
+ return toBackendRes({ res });
1037
+ } catch (error) {
1038
+ logger.error(`${error.message}`);
1039
+ return toBackendError({
1040
+ path,
1041
+ message: error.message || "unknown error",
1042
+ code: "internal_error"
1043
+ });
1044
+ }
1045
+ };
1046
+ };
1047
+
1048
+ // src/libraries/backend/routes/genRoutes.ts
1049
+ var import_rou3 = require("rou3");
1050
+
1051
+ // src/libraries/react/utils/toSnakeCase.ts
1052
+ function stringToSnakeCase(str) {
1053
+ return str.replace(/([a-z])([A-Z])/g, "$1_$2").replace(/[-\s]+/g, "_").toLowerCase();
1054
+ }
1055
+ var toSnakeCase = (obj, excludeKeys) => {
1056
+ if (Array.isArray(obj)) {
1057
+ return obj.map((item) => toSnakeCase(item, excludeKeys));
1058
+ } else if (obj !== null && typeof obj === "object") {
1059
+ return Object.fromEntries(
1060
+ Object.entries(obj).map(([key, value]) => {
1061
+ const snakeKey = stringToSnakeCase(key);
1062
+ if (excludeKeys && excludeKeys.includes(key)) {
1063
+ return [snakeKey, value];
1064
+ }
1065
+ return [snakeKey, toSnakeCase(value, excludeKeys)];
1066
+ })
1067
+ );
1068
+ }
1069
+ return obj;
1070
+ };
1071
+
1072
+ // src/libraries/backend/routes/genRoutes.ts
1073
+ var sanitizeBody = (body) => {
1074
+ let bodyCopy = { ...body };
1075
+ delete bodyCopy.customer_id;
1076
+ delete bodyCopy.customer_data;
1077
+ return bodyCopy;
1078
+ };
1079
+ var checkoutHandler = withAuth({
1080
+ fn: async ({
1081
+ autumn,
1082
+ customer_id,
1083
+ customer_data,
1084
+ body
1085
+ }) => {
1086
+ return await autumn.checkout({
1087
+ ...sanitizeBody(body),
1088
+ customer_id,
1089
+ customer_data
1090
+ });
1091
+ }
1092
+ });
1093
+ var attachHandler = withAuth({
1094
+ fn: async ({
1095
+ autumn,
1096
+ customer_id,
1097
+ customer_data,
1098
+ body
1099
+ }) => {
1100
+ return await autumn.attach({
1101
+ ...sanitizeBody(body),
1102
+ customer_id,
1103
+ customer_data
1104
+ });
1105
+ }
1106
+ });
1107
+ var setupPaymentHandler = withAuth({
1108
+ fn: async ({
1109
+ autumn,
1110
+ customer_id,
1111
+ customer_data,
1112
+ body
1113
+ }) => {
1114
+ return await autumn.setupPayment({
1115
+ ...sanitizeBody(body),
1116
+ customer_id,
1117
+ customer_data
1118
+ });
1119
+ }
1120
+ });
1121
+ var cancelHandler = withAuth({
1122
+ fn: async ({
1123
+ autumn,
1124
+ customer_id,
1125
+ body
1126
+ }) => {
1127
+ return await autumn.cancel({
1128
+ ...sanitizeBody(body),
1129
+ customer_id
1130
+ });
1131
+ }
1132
+ });
1133
+ var checkHandler = withAuth({
1134
+ fn: async ({
1135
+ autumn,
1136
+ customer_id,
1137
+ customer_data,
1138
+ body
1139
+ }) => {
1140
+ const result = await autumn.check({
1141
+ ...sanitizeBody(body),
1142
+ customer_id,
1143
+ customer_data
1144
+ });
1145
+ return result;
1146
+ }
1147
+ });
1148
+ var trackHandler = withAuth({
1149
+ fn: async ({
1150
+ autumn,
1151
+ customer_id,
1152
+ customer_data,
1153
+ body
1154
+ }) => {
1155
+ return await autumn.track({
1156
+ ...sanitizeBody(body),
1157
+ customer_id,
1158
+ customer_data
1159
+ });
1160
+ }
1161
+ });
1162
+ var openBillingPortalHandler = withAuth({
1163
+ fn: async ({
1164
+ autumn,
1165
+ customer_id,
1166
+ body
1167
+ }) => {
1168
+ return await autumn.customers.billingPortal(customer_id, body);
1169
+ }
1170
+ });
1171
+ var queryHandler = withAuth({
1172
+ fn: async ({
1173
+ autumn,
1174
+ customer_id,
1175
+ body
1176
+ }) => {
1177
+ return await autumn.query({ customer_id, ...toSnakeCase(body) });
1178
+ }
1179
+ });
1180
+ var addGenRoutes = (router) => {
1181
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/checkout`, {
1182
+ handler: checkoutHandler
1183
+ });
1184
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/attach`, {
1185
+ handler: attachHandler
1186
+ });
1187
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/cancel`, {
1188
+ handler: cancelHandler
1189
+ });
1190
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/check`, {
1191
+ handler: checkHandler
1192
+ });
1193
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/track`, {
1194
+ handler: trackHandler
1195
+ });
1196
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/billing_portal`, {
1197
+ handler: openBillingPortalHandler
1198
+ });
1199
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/setup_payment`, {
1200
+ handler: setupPaymentHandler
1201
+ });
1202
+ (0, import_rou3.addRoute)(router, "POST", `${BASE_PATH}/query`, {
1203
+ handler: queryHandler
1204
+ });
1205
+ };
1206
+
1207
+ // src/libraries/backend/routes/backendRouter.ts
1208
+ var import_rou35 = require("rou3");
1209
+
1210
+ // src/libraries/backend/routes/entityRoutes.ts
1211
+ var import_rou32 = require("rou3");
1212
+ var createEntityHandler = withAuth({
1213
+ fn: async ({
1214
+ autumn,
1215
+ customer_id,
1216
+ body
1217
+ }) => {
1218
+ return await autumn.entities.create(customer_id, body);
1219
+ }
1220
+ });
1221
+ var getEntityHandler = withAuth({
1222
+ fn: async ({
1223
+ autumn,
1224
+ customer_id,
1225
+ pathParams,
1226
+ searchParams
1227
+ }) => {
1228
+ if (!pathParams?.entityId) {
1229
+ return {
1230
+ statusCode: 400,
1231
+ body: {
1232
+ error: "no_entity_id",
1233
+ message: "Entity ID is required"
1234
+ }
1235
+ };
1236
+ }
1237
+ let params = {
1238
+ expand: searchParams?.expand?.split(",")
1239
+ };
1240
+ let res = await autumn.entities.get(
1241
+ customer_id,
1242
+ pathParams.entityId,
1243
+ params
1244
+ );
1245
+ return res;
1246
+ }
1247
+ });
1248
+ var deleteEntityHandler = withAuth({
1249
+ fn: async ({
1250
+ autumn,
1251
+ customer_id,
1252
+ pathParams
1253
+ }) => {
1254
+ if (!pathParams?.entityId) {
1255
+ return {
1256
+ statusCode: 400,
1257
+ body: {
1258
+ error: "no_entity_id",
1259
+ message: "Entity ID is required"
1260
+ }
1261
+ };
1262
+ }
1263
+ return await autumn.entities.delete(customer_id, pathParams.entityId);
1264
+ }
1265
+ });
1266
+ var addEntityRoutes = async (router) => {
1267
+ (0, import_rou32.addRoute)(router, "POST", "/api/autumn/entities", {
1268
+ handler: createEntityHandler
1269
+ });
1270
+ (0, import_rou32.addRoute)(router, "GET", "/api/autumn/entities/:entityId", {
1271
+ handler: getEntityHandler
1272
+ });
1273
+ (0, import_rou32.addRoute)(router, "DELETE", "/api/autumn/entities/:entityId", {
1274
+ handler: deleteEntityHandler
1275
+ });
1276
+ };
1277
+
1278
+ // src/libraries/backend/routes/referralRoutes.ts
1279
+ var import_rou33 = require("rou3");
1280
+ var createReferralCodeHandler = withAuth({
1281
+ fn: async ({
1282
+ autumn,
1283
+ customer_id,
1284
+ body
1285
+ }) => {
1286
+ return await autumn.referrals.createCode({
1287
+ ...body,
1288
+ customer_id
1289
+ });
1290
+ }
1291
+ });
1292
+ var redeemReferralCodeHandler = withAuth({
1293
+ fn: async ({
1294
+ autumn,
1295
+ customer_id,
1296
+ body
1297
+ }) => {
1298
+ return await autumn.referrals.redeemCode({
1299
+ ...body,
1300
+ customer_id
1301
+ });
1302
+ }
1303
+ });
1304
+ var addReferralRoutes = async (router) => {
1305
+ (0, import_rou33.addRoute)(router, "POST", `${BASE_PATH}/referrals/code`, {
1306
+ handler: createReferralCodeHandler
1307
+ });
1308
+ (0, import_rou33.addRoute)(router, "POST", `${BASE_PATH}/referrals/redeem`, {
1309
+ handler: redeemReferralCodeHandler
1310
+ });
1311
+ };
1312
+
1313
+ // src/libraries/backend/routes/productRoutes.ts
1314
+ var import_rou34 = require("rou3");
1315
+ var listProductsHandler = withAuth({
1316
+ fn: async ({
1317
+ autumn,
1318
+ customer_id
1319
+ }) => {
1320
+ return await autumn.products.list({
1321
+ customer_id
1322
+ });
1323
+ },
1324
+ requireCustomer: false
1325
+ });
1326
+ var addProductRoutes = async (router) => {
1327
+ (0, import_rou34.addRoute)(router, "GET", `${BASE_PATH}/products`, {
1328
+ handler: listProductsHandler
1329
+ });
1330
+ };
1331
+
1332
+ // src/libraries/backend/routes/backendRouter.ts
1333
+ var sanitizeCustomerBody = (body) => {
1334
+ let bodyCopy = { ...body };
1335
+ delete bodyCopy.id;
1336
+ delete bodyCopy.name;
1337
+ delete bodyCopy.email;
1338
+ return bodyCopy;
1339
+ };
1340
+ var createCustomerHandler = withAuth({
1341
+ fn: async ({
1342
+ autumn,
1343
+ customer_id,
1344
+ customer_data = {},
1345
+ body
1346
+ }) => {
1347
+ let res = await autumn.customers.create({
1348
+ id: customer_id,
1349
+ ...customer_data,
1350
+ ...sanitizeCustomerBody(body)
1351
+ });
1352
+ return res;
1353
+ }
1354
+ });
1355
+ var getPricingTableHandler = withAuth({
1356
+ fn: async ({
1357
+ autumn,
1358
+ customer_id
1359
+ }) => {
1360
+ return await fetchPricingTable({
1361
+ instance: autumn,
1362
+ params: {
1363
+ customer_id: customer_id || void 0
1364
+ }
1365
+ });
1366
+ },
1367
+ requireCustomer: false
1368
+ });
1369
+ var createRouterWithOptions = () => {
1370
+ const router = (0, import_rou35.createRouter)();
1371
+ (0, import_rou35.addRoute)(router, "POST", `${BASE_PATH}/cors`, {
1372
+ handler: () => {
1373
+ return {
1374
+ body: {
1375
+ message: "OK"
1376
+ },
1377
+ statusCode: 200
1378
+ };
1379
+ }
1380
+ });
1381
+ (0, import_rou35.addRoute)(router, "POST", `${BASE_PATH}/customers`, {
1382
+ handler: createCustomerHandler
1383
+ });
1384
+ (0, import_rou35.addRoute)(router, "GET", `${BASE_PATH}/components/pricing_table`, {
1385
+ handler: getPricingTableHandler,
1386
+ requireCustomer: false
1387
+ });
1388
+ addGenRoutes(router);
1389
+ addEntityRoutes(router);
1390
+ addReferralRoutes(router);
1391
+ addProductRoutes(router);
1392
+ return router;
1393
+ };
1394
+
1395
+ // src/libraries/backend/utils/secretKeyCheck.ts
1396
+ var secretKeyCheck = (secretKey) => {
1397
+ if (!secretKey && !process.env.AUTUMN_SECRET_KEY) {
1398
+ return {
1399
+ found: false,
1400
+ error: {
1401
+ statusCode: 500,
1402
+ message: `Autumn secret key not found in ENV variables or passed into autumnHandler`,
1403
+ code: "no_secret_key"
1404
+ }
1405
+ };
1406
+ }
1407
+ return { found: true, error: null };
1408
+ };
1409
+
1410
+ // src/libraries/backend/convex.ts
1411
+ var import_rou36 = require("rou3");
1412
+ function autumnHandler(options) {
1413
+ const router = createRouterWithOptions();
1414
+ return options.httpAction(async (ctx, request) => {
1415
+ const headers = request.headers;
1416
+ if (headers.get("Origin") !== null && headers.get("Access-Control-Request-Method") !== null && headers.get("Access-Control-Request-Headers") !== null) {
1417
+ return new Response(null, {
1418
+ headers: new Headers({
1419
+ // e.g. https://mywebsite.com, configured on your Convex dashboard, or passed in as an option
1420
+ "Access-Control-Allow-Origin": process.env.CLIENT_ORIGIN ?? "http://localhost:3000",
1421
+ "Access-Control-Allow-Methods": "POST, GET, PATCH, DELETE, OPTIONS",
1422
+ "Access-Control-Allow-Headers": "Content-Type, Digest, Authorization, Cookie",
1423
+ "Access-Control-Allow-Credentials": "true",
1424
+ "Access-Control-Max-Age": "86400"
1425
+ })
1426
+ });
1427
+ }
1428
+ let { found, error: resError } = secretKeyCheck(options.secretKey);
1429
+ if (!found && !options.secretKey) {
1430
+ return Response.json(resError, { status: resError.statusCode });
1431
+ }
1432
+ const method = request.method;
1433
+ const url = new URL(request.url);
1434
+ const searchParams = Object.fromEntries(url.searchParams);
1435
+ const pathname = url.pathname;
1436
+ const match = (0, import_rou36.findRoute)(router, method, pathname);
1437
+ if (!match) {
1438
+ return Response.json({ error: "Not found" }, { status: 404 });
1439
+ }
1440
+ const { data, params: pathParams } = match;
1441
+ const { handler } = data;
1442
+ const autumn = new Autumn({
1443
+ secretKey: options.secretKey || void 0,
1444
+ url: options.url
1445
+ });
1446
+ let body = null;
1447
+ if (method === "POST" || method === "PUT" || method === "PATCH") {
1448
+ try {
1449
+ body = await request.json();
1450
+ } catch (error) {
1451
+ }
1452
+ }
1453
+ const result = await handler({
1454
+ autumn,
1455
+ body,
1456
+ path: url.pathname,
1457
+ getCustomer: async () => await options.identify(ctx, request),
1458
+ pathParams,
1459
+ searchParams
1460
+ });
1461
+ return Response.json(result.body, {
1462
+ status: result.statusCode,
1463
+ headers: new Headers({
1464
+ "Access-Control-Allow-Origin": process.env.CLIENT_ORIGIN ?? "http://localhost:3000",
1465
+ "Access-Control-Allow-Credentials": "true",
1466
+ Vary: "origin"
1467
+ })
1468
+ });
1469
+ });
1470
+ }
1471
+ function convexHandler(options) {
1472
+ const router = createRouterWithOptions();
1473
+ const corsHeaders = {
1474
+ "Access-Control-Allow-Origin": options.corsOrigin ?? process.env.CLIENT_ORIGIN ?? "http://localhost:3000",
1475
+ "Access-Control-Allow-Methods": "POST, GET, PATCH, DELETE, OPTIONS",
1476
+ "Access-Control-Allow-Headers": "*",
1477
+ "Access-Control-Allow-Credentials": "true",
1478
+ "Access-Control-Max-Age": "86400",
1479
+ "Vary": "Origin"
1480
+ };
1481
+ return async (ctx, request) => {
1482
+ const headers = request.headers;
1483
+ if (request.method === "OPTIONS") {
1484
+ return new Response(null, {
1485
+ headers: new Headers(corsHeaders)
1486
+ });
1487
+ }
1488
+ let { found, error: resError } = secretKeyCheck(options.secretKey);
1489
+ if (!found && !options.secretKey) {
1490
+ return new Response(JSON.stringify(resError), {
1491
+ status: resError.statusCode,
1492
+ headers: {
1493
+ "Content-Type": "application/json",
1494
+ ...corsHeaders
1495
+ }
1496
+ });
1497
+ }
1498
+ const method = request.method;
1499
+ const url = new URL(request.url);
1500
+ const searchParams = Object.fromEntries(url.searchParams);
1501
+ const pathname = url.pathname;
1502
+ const match = (0, import_rou36.findRoute)(router, method, pathname);
1503
+ if (!match) {
1504
+ return new Response(JSON.stringify({ error: "Not found" }), {
1505
+ status: 404,
1506
+ headers: {
1507
+ "Content-Type": "application/json",
1508
+ ...corsHeaders
1509
+ }
1510
+ });
1511
+ }
1512
+ const { data, params: pathParams } = match;
1513
+ const { handler } = data;
1514
+ const autumn = new Autumn({
1515
+ secretKey: options.secretKey || void 0,
1516
+ url: options.url
1517
+ });
1518
+ let body = null;
1519
+ if (method === "POST" || method === "PUT" || method === "PATCH") {
1520
+ try {
1521
+ body = await request.json();
1522
+ } catch (error) {
1523
+ }
1524
+ }
1525
+ try {
1526
+ console.log("Identity in convex.ts:", options.identity);
1527
+ const result = await handler({
1528
+ autumn,
1529
+ body,
1530
+ path: url.pathname,
1531
+ getCustomer: async () => options.identity,
1532
+ pathParams,
1533
+ searchParams
1534
+ });
1535
+ return new Response(JSON.stringify(result.body), {
1536
+ status: result.statusCode,
1537
+ headers: {
1538
+ "Content-Type": "application/json",
1539
+ ...corsHeaders
1540
+ }
1541
+ });
1542
+ } catch (error) {
1543
+ return new Response(JSON.stringify({ error: "Internal server error" }), {
1544
+ status: 500,
1545
+ headers: {
1546
+ "Content-Type": "application/json",
1547
+ ...corsHeaders
1548
+ }
1549
+ });
1550
+ }
1551
+ };
1552
+ }
1553
+ // Annotate the CommonJS export names for ESM import in node:
1554
+ 0 && (module.exports = {
1555
+ autumnHandler,
1556
+ convexHandler
1557
+ });