@dodopayments/convex 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lib.js","sources":["../../src/component/lib.ts"],"sourcesContent":["import { action } from \"../component/_generated/server\";\nimport { v } from \"convex/values\";\nimport { \n buildCheckoutUrl, \n type CheckoutSessionPayload\n} from \"@dodopayments/core/checkout\";\nimport DodoPayments from \"dodopayments\";\n\nconst checkoutSessionPayloadValidator = v.object({\n product_cart: v.array(v.object({\n product_id: v.string(),\n quantity: v.number(),\n })),\n customer: v.optional(v.object({\n email: v.optional(v.string()),\n name: v.optional(v.string()),\n phone_number: v.optional(v.string()),\n })),\n billing_address: v.optional(v.object({\n street: v.optional(v.string()),\n city: v.optional(v.string()),\n state: v.optional(v.string()),\n country: v.string(),\n zipcode: v.optional(v.string()),\n })),\n return_url: v.optional(v.string()),\n allowed_payment_method_types: v.optional(v.array(v.string())),\n billing_currency: v.optional(v.string()),\n show_saved_payment_methods: v.optional(v.boolean()),\n confirm: v.optional(v.boolean()),\n discount_code: v.optional(v.string()),\n metadata: v.optional(v.record(v.string(), v.string())),\n customization: v.optional(v.object({\n theme: v.optional(v.string()),\n show_order_details: v.optional(v.boolean()),\n show_on_demand_tag: v.optional(v.boolean()),\n })),\n feature_flags: v.optional(v.object({\n allow_currency_selection: v.optional(v.boolean()),\n allow_discount_code: v.optional(v.boolean()),\n allow_phone_number_collection: v.optional(v.boolean()),\n allow_tax_id: v.optional(v.boolean()),\n always_create_new_customer: v.optional(v.boolean()),\n })),\n subscription_data: v.optional(v.object({\n trial_period_days: v.optional(v.number()),\n })),\n});\n\nexport const checkout = action({\n args: {\n payload: checkoutSessionPayloadValidator,\n apiKey: v.string(),\n environment: v.union(v.literal(\"test_mode\"), v.literal(\"live_mode\")),\n },\n returns: v.object({ checkout_url: v.string() }),\n handler: async (_, { payload, apiKey, environment }): Promise<{ checkout_url: string }> => {\n const checkoutUrl = await buildCheckoutUrl({\n sessionPayload: payload as CheckoutSessionPayload,\n bearerToken: apiKey,\n environment,\n type: \"session\",\n });\n return { checkout_url: checkoutUrl };\n },\n});\n\nexport const customerPortal = action({\n args: {\n dodoCustomerId: v.string(),\n send_email: v.optional(v.boolean()),\n apiKey: v.string(),\n environment: v.union(v.literal(\"test_mode\"), v.literal(\"live_mode\")),\n },\n returns: v.object({ portal_url: v.string() }),\n handler: async (_, { dodoCustomerId, send_email, apiKey, environment }): Promise<{ portal_url: string }> => {\n if (!dodoCustomerId) {\n throw new Error(\"dodoCustomerId is required for customerPortal.\");\n }\n\n const dodopayments = new DodoPayments({\n bearerToken: apiKey,\n environment,\n });\n \n const params = {\n send_email: Boolean(send_email),\n };\n\n const session = await dodopayments.customers.customerPortal.create(dodoCustomerId, params);\n return { portal_url: session.link };\n },\n});"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ declare const _default: import("convex/server").SchemaDefinition<{}, true>;
2
+ export default _default;
@@ -0,0 +1,6 @@
1
+ import { defineSchema } from 'convex/server';
2
+
3
+ var schema = defineSchema({});
4
+
5
+ export { schema as default };
6
+ //# sourceMappingURL=schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema.js","sources":["../../src/component/schema.ts"],"sourcesContent":["import { defineSchema } from \"convex/server\";\n\nexport default defineSchema({});\n"],"names":[],"mappings":";;AAEA,aAAe,YAAY,CAAC,EAAE,CAAC;;;;"}
@@ -0,0 +1,543 @@
1
+ import { z } from 'zod';
2
+ import DodoPayments from 'dodopayments';
3
+
4
+ var __assign = (undefined && undefined.__assign) || function () {
5
+ __assign = Object.assign || function(t) {
6
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
7
+ s = arguments[i];
8
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
9
+ t[p] = s[p];
10
+ }
11
+ return t;
12
+ };
13
+ return __assign.apply(this, arguments);
14
+ };
15
+ var __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {
16
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
17
+ return new (P || (P = Promise))(function (resolve, reject) {
18
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
19
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
20
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
21
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
22
+ });
23
+ };
24
+ var __generator = (undefined && undefined.__generator) || function (thisArg, body) {
25
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
26
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
27
+ function verb(n) { return function (v) { return step([n, v]); }; }
28
+ function step(op) {
29
+ if (f) throw new TypeError("Generator is already executing.");
30
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
31
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
32
+ if (y = 0, t) op = [op[0] & 2, t.value];
33
+ switch (op[0]) {
34
+ case 0: case 1: t = op; break;
35
+ case 4: _.label++; return { value: op[1], done: false };
36
+ case 5: _.label++; y = op[1]; op = [0]; continue;
37
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
38
+ default:
39
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
40
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
41
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
42
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
43
+ if (t[2]) _.ops.pop();
44
+ _.trys.pop(); continue;
45
+ }
46
+ op = body.call(thisArg, _);
47
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
48
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
49
+ }
50
+ };
51
+ var checkoutQuerySchema = z
52
+ .object({
53
+ productId: z.string(),
54
+ quantity: z.string().optional(),
55
+ // Customer fields
56
+ fullName: z.string().optional(),
57
+ firstName: z.string().optional(),
58
+ lastName: z.string().optional(),
59
+ email: z.string().optional(),
60
+ country: z.string().optional(),
61
+ addressLine: z.string().optional(),
62
+ city: z.string().optional(),
63
+ state: z.string().optional(),
64
+ zipCode: z.string().optional(),
65
+ // Disable flags
66
+ disableFullName: z.string().optional(),
67
+ disableFirstName: z.string().optional(),
68
+ disableLastName: z.string().optional(),
69
+ disableEmail: z.string().optional(),
70
+ disableCountry: z.string().optional(),
71
+ disableAddressLine: z.string().optional(),
72
+ disableCity: z.string().optional(),
73
+ disableState: z.string().optional(),
74
+ disableZipCode: z.string().optional(),
75
+ // Advanced controls
76
+ paymentCurrency: z.string().optional(),
77
+ showCurrencySelector: z.string().optional(),
78
+ paymentAmount: z.string().optional(),
79
+ showDiscounts: z.string().optional(),
80
+ // Metadata (allow any key starting with metadata_)
81
+ // We'll handle metadata separately in the handler
82
+ })
83
+ .catchall(z.unknown());
84
+ // Add Zod schema for dynamic checkout body
85
+ var dynamicCheckoutBodySchema = z
86
+ .object({
87
+ // For subscription
88
+ product_id: z.string().optional(),
89
+ quantity: z.number().optional(),
90
+ // For one-time payment
91
+ product_cart: z
92
+ .array(z.object({
93
+ product_id: z.string(),
94
+ quantity: z.number(),
95
+ }))
96
+ .optional(),
97
+ // Common fields
98
+ billing: z.object({
99
+ city: z.string(),
100
+ country: z.string(),
101
+ state: z.string(),
102
+ street: z.string(),
103
+ zipcode: z.string(),
104
+ }),
105
+ customer: z.object({
106
+ customer_id: z.string().optional(),
107
+ email: z.string().optional(),
108
+ name: z.string().optional(),
109
+ }),
110
+ discount_id: z.string().optional(),
111
+ addons: z
112
+ .array(z.object({
113
+ addon_id: z.string(),
114
+ quantity: z.number(),
115
+ }))
116
+ .optional(),
117
+ metadata: z.record(z.string(), z.string()).optional(),
118
+ currency: z.string().optional(),
119
+ // Allow any additional fields (for future compatibility)
120
+ })
121
+ .catchall(z.unknown());
122
+ // ========================================
123
+ // CHECKOUT SESSIONS SCHEMAS & TYPES
124
+ // ========================================
125
+ // Product cart item schema for checkout sessions
126
+ var checkoutSessionProductCartItemSchema = z.object({
127
+ product_id: z.string().min(1, "Product ID is required"),
128
+ quantity: z.number().int().positive("Quantity must be a positive integer"),
129
+ });
130
+ // Customer information schema for checkout sessions
131
+ var checkoutSessionCustomerSchema = z
132
+ .object({
133
+ email: z.string().email().optional(),
134
+ name: z.string().min(1).optional(),
135
+ phone_number: z.string().optional(),
136
+ })
137
+ .optional();
138
+ // Billing address schema for checkout sessions
139
+ var checkoutSessionBillingAddressSchema = z
140
+ .object({
141
+ street: z.string().optional(),
142
+ city: z.string().optional(),
143
+ state: z.string().optional(),
144
+ country: z.string().length(2, "Country must be a 2-letter ISO code"),
145
+ zipcode: z.string().optional(),
146
+ })
147
+ .optional();
148
+ // Payment method types enum based on Dodo Payments documentation
149
+ var paymentMethodTypeSchema = z.enum([
150
+ "credit",
151
+ "debit",
152
+ "upi_collect",
153
+ "upi_intent",
154
+ "apple_pay",
155
+ "google_pay",
156
+ "amazon_pay",
157
+ "klarna",
158
+ "affirm",
159
+ "afterpay_clearpay",
160
+ "sepa",
161
+ "ach",
162
+ ]);
163
+ // Customization options schema
164
+ var checkoutSessionCustomizationSchema = z
165
+ .object({
166
+ theme: z.enum(["light", "dark", "system"]).optional(),
167
+ show_order_details: z.boolean().optional(),
168
+ show_on_demand_tag: z.boolean().optional(),
169
+ })
170
+ .optional();
171
+ // Feature flags schema
172
+ var checkoutSessionFeatureFlagsSchema = z
173
+ .object({
174
+ allow_currency_selection: z.boolean().optional(),
175
+ allow_discount_code: z.boolean().optional(),
176
+ allow_phone_number_collection: z.boolean().optional(),
177
+ allow_tax_id: z.boolean().optional(),
178
+ always_create_new_customer: z.boolean().optional(),
179
+ })
180
+ .optional();
181
+ // Subscription data schema
182
+ var checkoutSessionSubscriptionDataSchema = z
183
+ .object({
184
+ trial_period_days: z.number().int().nonnegative().optional(),
185
+ })
186
+ .optional();
187
+ // Main checkout session payload schema
188
+ var checkoutSessionPayloadSchema = z.object({
189
+ // Required fields
190
+ product_cart: z
191
+ .array(checkoutSessionProductCartItemSchema)
192
+ .min(1, "At least one product is required"),
193
+ // Optional fields
194
+ customer: checkoutSessionCustomerSchema,
195
+ billing_address: checkoutSessionBillingAddressSchema,
196
+ return_url: z.string().url().optional(),
197
+ allowed_payment_method_types: z.array(paymentMethodTypeSchema).optional(),
198
+ billing_currency: z
199
+ .string()
200
+ .length(3, "Currency must be a 3-letter ISO code")
201
+ .optional(),
202
+ show_saved_payment_methods: z.boolean().optional(),
203
+ confirm: z.boolean().optional(),
204
+ discount_code: z.string().optional(),
205
+ metadata: z.record(z.string(), z.string()).optional(),
206
+ customization: checkoutSessionCustomizationSchema,
207
+ feature_flags: checkoutSessionFeatureFlagsSchema,
208
+ subscription_data: checkoutSessionSubscriptionDataSchema,
209
+ });
210
+ // Checkout session response schema
211
+ var checkoutSessionResponseSchema = z.object({
212
+ session_id: z.string().min(1, "Session ID is required"),
213
+ checkout_url: z.string().url("Invalid checkout URL"),
214
+ });
215
+ /**
216
+ * Creates a new Dodo Payments Checkout Session using the modern /checkouts endpoint.
217
+ * This function provides a clean, type-safe interface to the Checkout Sessions API.
218
+ *
219
+ * @param payload - The checkout session data, validated against CheckoutSessionPayloadSchema
220
+ * @param config - Dodo Payments client configuration (bearerToken, environment)
221
+ * @returns Promise<CheckoutSessionResponse> - The checkout session with session_id and checkout_url
222
+ *
223
+ * @throws {Error} When payload validation fails or API request fails
224
+ *
225
+ * @example
226
+ * ```typescript
227
+ * const session = await createCheckoutSession({
228
+ * product_cart: [{ product_id: 'prod_123', quantity: 1 }],
229
+ * customer: { email: 'customer@example.com' },
230
+ * return_url: 'https://yoursite.com/success'
231
+ * }, {
232
+ * bearerToken: process.env.DODO_PAYMENTS_API_KEY,
233
+ * environment: 'test_mode'
234
+ * });
235
+ *
236
+ * ```
237
+ */
238
+ var createCheckoutSession = function (payload, config) { return __awaiter(void 0, void 0, void 0, function () {
239
+ var validation, dodopayments, sdkPayload, session, responseValidation, error_1;
240
+ return __generator(this, function (_a) {
241
+ switch (_a.label) {
242
+ case 0:
243
+ validation = checkoutSessionPayloadSchema.safeParse(payload);
244
+ if (!validation.success) {
245
+ throw new Error("Invalid checkout session payload: ".concat(validation.error.issues
246
+ .map(function (issue) { return "".concat(issue.path.join("."), ": ").concat(issue.message); })
247
+ .join(", ")));
248
+ }
249
+ dodopayments = new DodoPayments({
250
+ bearerToken: config.bearerToken,
251
+ environment: config.environment,
252
+ });
253
+ _a.label = 1;
254
+ case 1:
255
+ _a.trys.push([1, 3, , 4]);
256
+ sdkPayload = __assign(__assign({}, validation.data), (validation.data.billing_address && {
257
+ billing_address: __assign(__assign({}, validation.data.billing_address), { country: validation.data.billing_address.country }),
258
+ }));
259
+ return [4 /*yield*/, dodopayments.checkoutSessions.create(sdkPayload)];
260
+ case 2:
261
+ session = _a.sent();
262
+ responseValidation = checkoutSessionResponseSchema.safeParse(session);
263
+ if (!responseValidation.success) {
264
+ throw new Error("Invalid checkout session response from API: ".concat(responseValidation.error.issues
265
+ .map(function (issue) { return "".concat(issue.path.join("."), ": ").concat(issue.message); })
266
+ .join(", ")));
267
+ }
268
+ return [2 /*return*/, responseValidation.data];
269
+ case 3:
270
+ error_1 = _a.sent();
271
+ if (error_1 instanceof Error) {
272
+ console.error("Dodo Payments Checkout Session API Error:", {
273
+ message: error_1.message,
274
+ payload: validation.data,
275
+ config: {
276
+ environment: config.environment,
277
+ hasBearerToken: !!config.bearerToken,
278
+ },
279
+ });
280
+ // Re-throw with a more user-friendly message
281
+ throw new Error("Failed to create checkout session: ".concat(error_1.message));
282
+ }
283
+ // Handle non-Error objects
284
+ console.error("Unknown error creating checkout session:", error_1);
285
+ throw new Error("Failed to create checkout session due to an unknown error");
286
+ case 4: return [2 /*return*/];
287
+ }
288
+ });
289
+ }); };
290
+ var buildCheckoutUrl = function (_a) { return __awaiter(void 0, [_a], void 0, function (_b) {
291
+ var session, inputData, parseResult, success, data, error, _c, productId, quantity_1, fullName, firstName, lastName, email, country, addressLine, city, state, zipCode, disableFullName, disableFirstName, disableLastName, disableEmail, disableCountry, disableAddressLine, disableCity, disableState, disableZipCode, paymentCurrency, showCurrencySelector, paymentAmount, showDiscounts, dodopayments_1, err_1, url, _i, _d, _e, key, value, dyn, product_id, product_cart, quantity, billing, customer, addons, metadata, allowed_payment_method_types, billing_currency, discount_code, on_demand, bodyReturnUrl, show_saved_payment_methods, tax_id, trial_period_days, dodopayments, isSubscription, productIdToFetch, product, err_2, subscriptionPayload, subscription, err_3, cart, paymentPayload, payment, err_4;
292
+ var queryParams = _b.queryParams, body = _b.body, sessionPayload = _b.sessionPayload, returnUrl = _b.returnUrl, bearerToken = _b.bearerToken, environment = _b.environment, _f = _b.type, type = _f === void 0 ? "static" : _f;
293
+ return __generator(this, function (_g) {
294
+ switch (_g.label) {
295
+ case 0:
296
+ if (!(type === "session")) return [3 /*break*/, 2];
297
+ if (!sessionPayload) {
298
+ throw new Error("sessionPayload is required when type is 'session'");
299
+ }
300
+ return [4 /*yield*/, createCheckoutSession(sessionPayload, {
301
+ bearerToken: bearerToken,
302
+ environment: environment,
303
+ })];
304
+ case 1:
305
+ session = _g.sent();
306
+ return [2 /*return*/, session.checkout_url];
307
+ case 2:
308
+ inputData = type === "dynamic" ? body : queryParams;
309
+ if (type === "dynamic") {
310
+ parseResult = dynamicCheckoutBodySchema.safeParse(inputData);
311
+ }
312
+ else {
313
+ parseResult = checkoutQuerySchema.safeParse(inputData);
314
+ }
315
+ success = parseResult.success, data = parseResult.data, error = parseResult.error;
316
+ if (!success) {
317
+ throw new Error("Invalid ".concat(type === "dynamic" ? "body" : "query parameters", ".\n ").concat(error.message));
318
+ }
319
+ if (!(type !== "dynamic")) return [3 /*break*/, 7];
320
+ _c = data, productId = _c.productId, quantity_1 = _c.quantity, fullName = _c.fullName, firstName = _c.firstName, lastName = _c.lastName, email = _c.email, country = _c.country, addressLine = _c.addressLine, city = _c.city, state = _c.state, zipCode = _c.zipCode, disableFullName = _c.disableFullName, disableFirstName = _c.disableFirstName, disableLastName = _c.disableLastName, disableEmail = _c.disableEmail, disableCountry = _c.disableCountry, disableAddressLine = _c.disableAddressLine, disableCity = _c.disableCity, disableState = _c.disableState, disableZipCode = _c.disableZipCode, paymentCurrency = _c.paymentCurrency, showCurrencySelector = _c.showCurrencySelector, paymentAmount = _c.paymentAmount, showDiscounts = _c.showDiscounts;
321
+ dodopayments_1 = new DodoPayments({
322
+ bearerToken: bearerToken,
323
+ environment: environment,
324
+ });
325
+ // Check that the product exists for this merchant
326
+ if (!productId)
327
+ throw new Error("Missing required field: productId");
328
+ _g.label = 3;
329
+ case 3:
330
+ _g.trys.push([3, 5, , 6]);
331
+ return [4 /*yield*/, dodopayments_1.products.retrieve(productId)];
332
+ case 4:
333
+ _g.sent();
334
+ return [3 /*break*/, 6];
335
+ case 5:
336
+ err_1 = _g.sent();
337
+ console.error(err_1);
338
+ throw new Error("Product not found");
339
+ case 6:
340
+ url = new URL("".concat(environment === "test_mode" ? "https://test.checkout.dodopayments.com" : "https://checkout.dodopayments.com", "/buy/").concat(productId));
341
+ url.searchParams.set("quantity", quantity_1 ? String(quantity_1) : "1");
342
+ if (returnUrl)
343
+ url.searchParams.set("redirect_url", returnUrl);
344
+ // Customer/billing fields
345
+ if (fullName)
346
+ url.searchParams.set("fullName", String(fullName));
347
+ if (firstName)
348
+ url.searchParams.set("firstName", String(firstName));
349
+ if (lastName)
350
+ url.searchParams.set("lastName", String(lastName));
351
+ if (email)
352
+ url.searchParams.set("email", String(email));
353
+ if (country)
354
+ url.searchParams.set("country", String(country));
355
+ if (addressLine)
356
+ url.searchParams.set("addressLine", String(addressLine));
357
+ if (city)
358
+ url.searchParams.set("city", String(city));
359
+ if (state)
360
+ url.searchParams.set("state", String(state));
361
+ if (zipCode)
362
+ url.searchParams.set("zipCode", String(zipCode));
363
+ // Disable flags (must be set to 'true' to disable)
364
+ if (disableFullName === "true")
365
+ url.searchParams.set("disableFullName", "true");
366
+ if (disableFirstName === "true")
367
+ url.searchParams.set("disableFirstName", "true");
368
+ if (disableLastName === "true")
369
+ url.searchParams.set("disableLastName", "true");
370
+ if (disableEmail === "true")
371
+ url.searchParams.set("disableEmail", "true");
372
+ if (disableCountry === "true")
373
+ url.searchParams.set("disableCountry", "true");
374
+ if (disableAddressLine === "true")
375
+ url.searchParams.set("disableAddressLine", "true");
376
+ if (disableCity === "true")
377
+ url.searchParams.set("disableCity", "true");
378
+ if (disableState === "true")
379
+ url.searchParams.set("disableState", "true");
380
+ if (disableZipCode === "true")
381
+ url.searchParams.set("disableZipCode", "true");
382
+ // Advanced controls
383
+ if (paymentCurrency)
384
+ url.searchParams.set("paymentCurrency", String(paymentCurrency));
385
+ if (showCurrencySelector)
386
+ url.searchParams.set("showCurrencySelector", String(showCurrencySelector));
387
+ if (paymentAmount)
388
+ url.searchParams.set("paymentAmount", String(paymentAmount));
389
+ if (showDiscounts)
390
+ url.searchParams.set("showDiscounts", String(showDiscounts));
391
+ // Metadata: add all query params starting with metadata_
392
+ for (_i = 0, _d = Object.entries(queryParams || {}); _i < _d.length; _i++) {
393
+ _e = _d[_i], key = _e[0], value = _e[1];
394
+ if (key.startsWith("metadata_") && value && typeof value !== "object") {
395
+ url.searchParams.set(key, String(value));
396
+ }
397
+ }
398
+ return [2 /*return*/, url.toString()];
399
+ case 7:
400
+ dyn = data;
401
+ product_id = dyn.product_id, product_cart = dyn.product_cart, quantity = dyn.quantity, billing = dyn.billing, customer = dyn.customer, addons = dyn.addons, metadata = dyn.metadata, allowed_payment_method_types = dyn.allowed_payment_method_types, billing_currency = dyn.billing_currency, discount_code = dyn.discount_code, on_demand = dyn.on_demand, bodyReturnUrl = dyn.return_url, show_saved_payment_methods = dyn.show_saved_payment_methods, tax_id = dyn.tax_id, trial_period_days = dyn.trial_period_days;
402
+ dodopayments = new DodoPayments({
403
+ bearerToken: bearerToken,
404
+ environment: environment,
405
+ });
406
+ isSubscription = false;
407
+ productIdToFetch = product_id;
408
+ if (!product_id && product_cart && product_cart.length > 0) {
409
+ productIdToFetch = product_cart[0].product_id;
410
+ }
411
+ if (!productIdToFetch)
412
+ throw new Error("Missing required field: product_id or product_cart[0].product_id");
413
+ _g.label = 8;
414
+ case 8:
415
+ _g.trys.push([8, 10, , 11]);
416
+ return [4 /*yield*/, dodopayments.products.retrieve(productIdToFetch)];
417
+ case 9:
418
+ product = _g.sent();
419
+ return [3 /*break*/, 11];
420
+ case 10:
421
+ err_2 = _g.sent();
422
+ console.error(err_2);
423
+ throw new Error("Product not found");
424
+ case 11:
425
+ isSubscription = Boolean(product.is_recurring);
426
+ // Required field validation
427
+ if (isSubscription && !product_id)
428
+ throw new Error("Missing required field: product_id for subscription");
429
+ if (!billing)
430
+ throw new Error("Missing required field: billing");
431
+ if (!customer)
432
+ throw new Error("Missing required field: customer");
433
+ if (!isSubscription) return [3 /*break*/, 16];
434
+ subscriptionPayload = {
435
+ billing: billing,
436
+ customer: customer,
437
+ product_id: product_id,
438
+ quantity: quantity ? Number(quantity) : 1,
439
+ };
440
+ if (metadata)
441
+ subscriptionPayload.metadata = metadata;
442
+ if (discount_code)
443
+ subscriptionPayload.discount_code = discount_code;
444
+ if (addons)
445
+ subscriptionPayload.addons = addons;
446
+ if (allowed_payment_method_types)
447
+ subscriptionPayload.allowed_payment_method_types =
448
+ allowed_payment_method_types;
449
+ if (billing_currency)
450
+ subscriptionPayload.billing_currency = billing_currency;
451
+ if (on_demand)
452
+ subscriptionPayload.on_demand = on_demand;
453
+ subscriptionPayload.payment_link = true;
454
+ // Use bodyReturnUrl if present, otherwise use top-level returnUrl
455
+ if (bodyReturnUrl) {
456
+ subscriptionPayload.return_url = bodyReturnUrl;
457
+ }
458
+ else if (returnUrl) {
459
+ subscriptionPayload.return_url = returnUrl;
460
+ }
461
+ if (show_saved_payment_methods)
462
+ subscriptionPayload.show_saved_payment_methods =
463
+ show_saved_payment_methods;
464
+ if (tax_id)
465
+ subscriptionPayload.tax_id = tax_id;
466
+ if (trial_period_days)
467
+ subscriptionPayload.trial_period_days = trial_period_days;
468
+ subscription = void 0;
469
+ _g.label = 12;
470
+ case 12:
471
+ _g.trys.push([12, 14, , 15]);
472
+ return [4 /*yield*/, dodopayments.subscriptions.create(subscriptionPayload)];
473
+ case 13:
474
+ subscription =
475
+ _g.sent();
476
+ return [3 /*break*/, 15];
477
+ case 14:
478
+ err_3 = _g.sent();
479
+ console.error("Error when creating subscription", err_3);
480
+ throw new Error(err_3 instanceof Error ? err_3.message : String(err_3));
481
+ case 15:
482
+ if (!subscription || !subscription.payment_link) {
483
+ throw new Error("No payment link returned from Dodo Payments API (subscription). Make sure to set payment_link as true in payload");
484
+ }
485
+ return [2 /*return*/, subscription.payment_link];
486
+ case 16:
487
+ cart = product_cart;
488
+ if (!cart && product_id) {
489
+ cart = [
490
+ { product_id: product_id, quantity: quantity ? Number(quantity) : 1 },
491
+ ];
492
+ }
493
+ if (!cart || cart.length === 0)
494
+ throw new Error("Missing required field: product_cart or product_id");
495
+ paymentPayload = {
496
+ billing: billing,
497
+ customer: customer,
498
+ product_cart: cart,
499
+ };
500
+ if (metadata)
501
+ paymentPayload.metadata = metadata;
502
+ paymentPayload.payment_link = true;
503
+ if (allowed_payment_method_types)
504
+ paymentPayload.allowed_payment_method_types =
505
+ allowed_payment_method_types;
506
+ if (billing_currency)
507
+ paymentPayload.billing_currency = billing_currency;
508
+ if (discount_code)
509
+ paymentPayload.discount_code = discount_code;
510
+ // Use bodyReturnUrl if present, otherwise use top-level returnUrl
511
+ if (bodyReturnUrl) {
512
+ paymentPayload.return_url = bodyReturnUrl;
513
+ }
514
+ else if (returnUrl) {
515
+ paymentPayload.return_url = returnUrl;
516
+ }
517
+ if (show_saved_payment_methods)
518
+ paymentPayload.show_saved_payment_methods = show_saved_payment_methods;
519
+ if (tax_id)
520
+ paymentPayload.tax_id = tax_id;
521
+ payment = void 0;
522
+ _g.label = 17;
523
+ case 17:
524
+ _g.trys.push([17, 19, , 20]);
525
+ return [4 /*yield*/, dodopayments.payments.create(paymentPayload)];
526
+ case 18:
527
+ payment = _g.sent();
528
+ return [3 /*break*/, 20];
529
+ case 19:
530
+ err_4 = _g.sent();
531
+ console.error("Error when creating payment link", err_4);
532
+ throw new Error(err_4 instanceof Error ? err_4.message : String(err_4));
533
+ case 20:
534
+ if (!payment || !payment.payment_link) {
535
+ throw new Error("No payment link returned from Dodo Payments API. Make sure to set payment_link as true in payload.");
536
+ }
537
+ return [2 /*return*/, payment.payment_link];
538
+ }
539
+ });
540
+ }); };
541
+
542
+ export { buildCheckoutUrl, checkoutQuerySchema, checkoutSessionBillingAddressSchema, checkoutSessionCustomerSchema, checkoutSessionCustomizationSchema, checkoutSessionFeatureFlagsSchema, checkoutSessionPayloadSchema, checkoutSessionProductCartItemSchema, checkoutSessionResponseSchema, checkoutSessionSubscriptionDataSchema, createCheckoutSession, dynamicCheckoutBodySchema, paymentMethodTypeSchema };
543
+ //# sourceMappingURL=checkout.js.map