@parsrun/payments 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,469 @@
1
+ // src/types.ts
2
+ import {
3
+ type,
4
+ currencyCode,
5
+ money,
6
+ paymentCustomer,
7
+ createCustomerRequest,
8
+ cardDetails,
9
+ paymentMethod,
10
+ paymentIntentStatus,
11
+ paymentIntent,
12
+ createPaymentIntentRequest,
13
+ subscriptionStatus,
14
+ priceInterval,
15
+ price,
16
+ subscription,
17
+ createSubscriptionRequest,
18
+ refundStatus,
19
+ refund,
20
+ createRefundRequest,
21
+ webhookEventType,
22
+ webhookEvent,
23
+ stripeConfig,
24
+ paddleConfig,
25
+ iyzicoConfig,
26
+ paymentsConfig
27
+ } from "@parsrun/types";
28
+ var PaymentError = class extends Error {
29
+ constructor(message, code, cause) {
30
+ super(message);
31
+ this.code = code;
32
+ this.cause = cause;
33
+ this.name = "PaymentError";
34
+ }
35
+ };
36
+ var PaymentErrorCodes = {
37
+ INVALID_CONFIG: "INVALID_CONFIG",
38
+ CUSTOMER_NOT_FOUND: "CUSTOMER_NOT_FOUND",
39
+ SUBSCRIPTION_NOT_FOUND: "SUBSCRIPTION_NOT_FOUND",
40
+ CHECKOUT_FAILED: "CHECKOUT_FAILED",
41
+ PAYMENT_FAILED: "PAYMENT_FAILED",
42
+ WEBHOOK_VERIFICATION_FAILED: "WEBHOOK_VERIFICATION_FAILED",
43
+ API_ERROR: "API_ERROR",
44
+ RATE_LIMITED: "RATE_LIMITED"
45
+ };
46
+
47
+ // src/providers/iyzico.ts
48
+ var IyzicoProvider = class {
49
+ type = "iyzico";
50
+ apiKey;
51
+ secretKey;
52
+ baseUrl;
53
+ constructor(config) {
54
+ this.apiKey = config.apiKey;
55
+ this.secretKey = config.secretKey;
56
+ this.baseUrl = config.baseUrl ?? (config.environment === "production" ? "https://api.iyzipay.com" : "https://sandbox-api.iyzipay.com");
57
+ }
58
+ async request(endpoint, body) {
59
+ const randomString = this.generateRandomString(8);
60
+ const authorizationString = await this.generateAuthorizationString(
61
+ body,
62
+ randomString
63
+ );
64
+ const response = await fetch(`${this.baseUrl}${endpoint}`, {
65
+ method: "POST",
66
+ headers: {
67
+ Accept: "application/json",
68
+ "Content-Type": "application/json",
69
+ Authorization: authorizationString,
70
+ "x-iyzi-rnd": randomString
71
+ },
72
+ body: JSON.stringify(body)
73
+ });
74
+ const data = await response.json();
75
+ if (data.status !== "success") {
76
+ throw new PaymentError(
77
+ `iyzico API error: ${data.errorMessage ?? "Unknown error"}`,
78
+ data.errorCode ?? PaymentErrorCodes.API_ERROR,
79
+ data
80
+ );
81
+ }
82
+ return data;
83
+ }
84
+ generateRandomString(length) {
85
+ const chars = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
86
+ let result = "";
87
+ const randomValues = new Uint8Array(length);
88
+ crypto.getRandomValues(randomValues);
89
+ for (let i = 0; i < length; i++) {
90
+ const randomValue = randomValues[i];
91
+ if (randomValue !== void 0) {
92
+ result += chars[randomValue % chars.length];
93
+ }
94
+ }
95
+ return result;
96
+ }
97
+ async generateAuthorizationString(body, randomString) {
98
+ const pkiString = this.generatePkiString(body);
99
+ const hashString = `${this.apiKey}${randomString}${this.secretKey}${pkiString}`;
100
+ const encoder = new TextEncoder();
101
+ const data = encoder.encode(hashString);
102
+ const hashBuffer = await crypto.subtle.digest("SHA-256", data);
103
+ const hashArray = new Uint8Array(hashBuffer);
104
+ const hashBase64 = btoa(String.fromCharCode(...hashArray));
105
+ const authorizationString = `${this.apiKey}:${hashBase64}`;
106
+ const authorizationBase64 = btoa(authorizationString);
107
+ return `IYZWS ${authorizationBase64}`;
108
+ }
109
+ generatePkiString(obj) {
110
+ const parts = [];
111
+ for (const [key, value] of Object.entries(obj)) {
112
+ if (value === void 0 || value === null) continue;
113
+ if (Array.isArray(value)) {
114
+ const arrayParts = value.map((item) => {
115
+ if (typeof item === "object" && item !== null) {
116
+ return this.generatePkiString(item);
117
+ }
118
+ return String(item);
119
+ });
120
+ parts.push(`${key}=[${arrayParts.join(", ")}]`);
121
+ } else if (typeof value === "object") {
122
+ parts.push(
123
+ `${key}=[${this.generatePkiString(value)}]`
124
+ );
125
+ } else {
126
+ parts.push(`${key}=${value}`);
127
+ }
128
+ }
129
+ return `[${parts.join(",")}]`;
130
+ }
131
+ // ============================================================================
132
+ // Customer - iyzico uses buyer info per transaction, not stored customers
133
+ // ============================================================================
134
+ async createCustomer(_options) {
135
+ throw new PaymentError(
136
+ "iyzico does not support stored customers. Use buyer info in checkout.",
137
+ PaymentErrorCodes.API_ERROR
138
+ );
139
+ }
140
+ async getCustomer(_customerId) {
141
+ return null;
142
+ }
143
+ async updateCustomer(_customerId, _options) {
144
+ throw new PaymentError(
145
+ "iyzico does not support stored customers",
146
+ PaymentErrorCodes.API_ERROR
147
+ );
148
+ }
149
+ async deleteCustomer(_customerId) {
150
+ throw new PaymentError(
151
+ "iyzico does not support stored customers",
152
+ PaymentErrorCodes.API_ERROR
153
+ );
154
+ }
155
+ // ============================================================================
156
+ // Checkout
157
+ // ============================================================================
158
+ async createCheckout(_options) {
159
+ throw new PaymentError(
160
+ "Use createCheckoutForm() with IyzicoCheckoutOptions for iyzico",
161
+ PaymentErrorCodes.INVALID_CONFIG
162
+ );
163
+ }
164
+ /**
165
+ * Create iyzico checkout form (iframe/popup)
166
+ */
167
+ async createCheckoutForm(options) {
168
+ const body = {
169
+ locale: "tr",
170
+ conversationId: options.conversationId ?? this.generateRandomString(16),
171
+ price: options.price,
172
+ paidPrice: options.paidPrice,
173
+ currency: options.currency,
174
+ basketId: options.metadata?.["basketId"] ?? this.generateRandomString(16),
175
+ paymentGroup: "PRODUCT",
176
+ callbackUrl: options.successUrl,
177
+ buyer: {
178
+ id: options.buyer.id,
179
+ name: options.buyer.name,
180
+ surname: options.buyer.surname,
181
+ gsmNumber: options.buyer.gsmNumber,
182
+ email: options.buyer.email,
183
+ identityNumber: options.buyer.identityNumber,
184
+ registrationAddress: options.buyer.registrationAddress,
185
+ ip: options.buyer.ip,
186
+ city: options.buyer.city,
187
+ country: options.buyer.country
188
+ },
189
+ shippingAddress: {
190
+ contactName: options.shippingAddress.contactName,
191
+ city: options.shippingAddress.city,
192
+ country: options.shippingAddress.country,
193
+ address: options.shippingAddress.address
194
+ },
195
+ billingAddress: {
196
+ contactName: options.billingAddress.contactName,
197
+ city: options.billingAddress.city,
198
+ country: options.billingAddress.country,
199
+ address: options.billingAddress.address
200
+ },
201
+ basketItems: options.basketItems.map((item) => ({
202
+ id: item.id,
203
+ name: item.name,
204
+ category1: item.category1,
205
+ category2: item.category2,
206
+ itemType: item.itemType,
207
+ price: item.price
208
+ }))
209
+ };
210
+ if (options.enabledInstallments) {
211
+ body["enabledInstallments"] = options.enabledInstallments;
212
+ }
213
+ if (options.force3ds) {
214
+ body["forceThreeDS"] = 1;
215
+ }
216
+ const result = await this.request(
217
+ "/payment/iyzi-pos/checkoutform/initialize/auth/ecom",
218
+ body
219
+ );
220
+ return {
221
+ token: result.token,
222
+ checkoutFormContent: result.checkoutFormContent,
223
+ tokenExpireTime: result.tokenExpireTime,
224
+ paymentPageUrl: result.paymentPageUrl
225
+ };
226
+ }
227
+ /**
228
+ * Retrieve checkout form result
229
+ */
230
+ async retrieveCheckoutForm(token) {
231
+ const body = {
232
+ locale: "tr",
233
+ conversationId: this.generateRandomString(16),
234
+ token
235
+ };
236
+ const result = await this.request(
237
+ "/payment/iyzi-pos/checkoutform/auth/ecom/detail",
238
+ body
239
+ );
240
+ return {
241
+ paymentId: result.paymentId,
242
+ status: result.status,
243
+ paymentStatus: result.paymentStatus,
244
+ price: result.price,
245
+ paidPrice: result.paidPrice,
246
+ currency: result.currency,
247
+ installment: result.installment,
248
+ basketId: result.basketId,
249
+ binNumber: result.binNumber,
250
+ lastFourDigits: result.lastFourDigits,
251
+ cardAssociation: result.cardAssociation,
252
+ cardFamily: result.cardFamily,
253
+ cardType: result.cardType,
254
+ fraudStatus: result.fraudStatus,
255
+ raw: result
256
+ };
257
+ }
258
+ async getCheckout(_sessionId) {
259
+ return null;
260
+ }
261
+ // ============================================================================
262
+ // 3D Secure Payment
263
+ // ============================================================================
264
+ /**
265
+ * Initialize 3D Secure payment
266
+ */
267
+ async initialize3DSPayment(options) {
268
+ const body = {
269
+ locale: "tr",
270
+ conversationId: options.conversationId ?? this.generateRandomString(16),
271
+ price: options.price,
272
+ paidPrice: options.paidPrice,
273
+ currency: options.currency,
274
+ installment: options.installment,
275
+ basketId: this.generateRandomString(16),
276
+ paymentChannel: "WEB",
277
+ paymentGroup: "PRODUCT",
278
+ paymentCard: options.paymentCard,
279
+ buyer: options.buyer,
280
+ shippingAddress: options.shippingAddress,
281
+ billingAddress: options.billingAddress,
282
+ basketItems: options.basketItems,
283
+ callbackUrl: options.callbackUrl
284
+ };
285
+ const result = await this.request(
286
+ "/payment/3dsecure/initialize",
287
+ body
288
+ );
289
+ return {
290
+ threeDSHtmlContent: result.threeDSHtmlContent,
291
+ status: result.status
292
+ };
293
+ }
294
+ /**
295
+ * Complete 3D Secure payment after callback
296
+ */
297
+ async complete3DSPayment(paymentId, conversationId) {
298
+ const body = {
299
+ locale: "tr",
300
+ conversationId: conversationId ?? this.generateRandomString(16),
301
+ paymentId
302
+ };
303
+ const result = await this.request(
304
+ "/payment/3dsecure/auth",
305
+ body
306
+ );
307
+ return {
308
+ paymentId: result.paymentId,
309
+ status: result.status,
310
+ paymentStatus: result.paymentStatus,
311
+ price: result.price,
312
+ paidPrice: result.paidPrice,
313
+ currency: result.currency,
314
+ installment: result.installment,
315
+ basketId: result.basketId,
316
+ binNumber: result.binNumber,
317
+ lastFourDigits: result.lastFourDigits,
318
+ cardAssociation: result.cardAssociation,
319
+ cardFamily: result.cardFamily,
320
+ cardType: result.cardType,
321
+ fraudStatus: result.fraudStatus,
322
+ raw: result
323
+ };
324
+ }
325
+ // ============================================================================
326
+ // Refund
327
+ // ============================================================================
328
+ /**
329
+ * Create a refund
330
+ */
331
+ async createRefund(options) {
332
+ const body = {
333
+ locale: "tr",
334
+ conversationId: options.conversationId ?? this.generateRandomString(16),
335
+ paymentTransactionId: options.paymentTransactionId,
336
+ price: options.price,
337
+ currency: options.currency,
338
+ ip: options.ip
339
+ };
340
+ const result = await this.request(
341
+ "/payment/refund",
342
+ body
343
+ );
344
+ return {
345
+ paymentId: result.paymentId,
346
+ paymentTransactionId: result.paymentTransactionId,
347
+ price: result.price,
348
+ status: result.status
349
+ };
350
+ }
351
+ /**
352
+ * Cancel a payment (full refund before settlement)
353
+ */
354
+ async cancelPayment(options) {
355
+ const body = {
356
+ locale: "tr",
357
+ conversationId: options.conversationId ?? this.generateRandomString(16),
358
+ paymentId: options.paymentId,
359
+ ip: options.ip
360
+ };
361
+ const result = await this.request(
362
+ "/payment/cancel",
363
+ body
364
+ );
365
+ return {
366
+ paymentId: result.paymentId,
367
+ price: result.price,
368
+ currency: result.currency,
369
+ status: result.status
370
+ };
371
+ }
372
+ // ============================================================================
373
+ // Installment
374
+ // ============================================================================
375
+ /**
376
+ * Get installment info for a BIN number
377
+ */
378
+ async getInstallmentInfo(binNumber, price2) {
379
+ const body = {
380
+ locale: "tr",
381
+ conversationId: this.generateRandomString(16),
382
+ binNumber: binNumber.substring(0, 6),
383
+ price: price2
384
+ };
385
+ const result = await this.request(
386
+ "/payment/iyzi-pos/installment",
387
+ body
388
+ );
389
+ return {
390
+ installmentDetails: result.installmentDetails ?? []
391
+ };
392
+ }
393
+ // ============================================================================
394
+ // Subscriptions - iyzico has separate subscription API
395
+ // ============================================================================
396
+ async createSubscription(_options) {
397
+ throw new PaymentError(
398
+ "Use iyzico subscription API methods directly",
399
+ PaymentErrorCodes.API_ERROR
400
+ );
401
+ }
402
+ async getSubscription(_subscriptionId) {
403
+ return null;
404
+ }
405
+ async updateSubscription(_subscriptionId, _options) {
406
+ throw new PaymentError(
407
+ "Use iyzico subscription API methods directly",
408
+ PaymentErrorCodes.API_ERROR
409
+ );
410
+ }
411
+ async cancelSubscription(_subscriptionId, _cancelAtPeriodEnd) {
412
+ throw new PaymentError(
413
+ "Use iyzico subscription API methods directly",
414
+ PaymentErrorCodes.API_ERROR
415
+ );
416
+ }
417
+ async listSubscriptions(_customerId) {
418
+ return [];
419
+ }
420
+ // ============================================================================
421
+ // Portal - not supported
422
+ // ============================================================================
423
+ async createPortalSession(_options) {
424
+ throw new PaymentError(
425
+ "iyzico does not support customer portal",
426
+ PaymentErrorCodes.API_ERROR
427
+ );
428
+ }
429
+ // ============================================================================
430
+ // Webhooks
431
+ // ============================================================================
432
+ async verifyWebhook(payload, _signature) {
433
+ const payloadString = typeof payload === "string" ? payload : new TextDecoder().decode(payload);
434
+ try {
435
+ const data = JSON.parse(payloadString);
436
+ if (data.token) {
437
+ const result = await this.retrieveCheckoutForm(data.token);
438
+ return {
439
+ id: result.paymentId ?? data.token,
440
+ type: this.mapEventType(data.status ?? result.status),
441
+ data: result,
442
+ created: /* @__PURE__ */ new Date(),
443
+ provider: "iyzico",
444
+ raw: data
445
+ };
446
+ }
447
+ return null;
448
+ } catch {
449
+ return null;
450
+ }
451
+ }
452
+ mapEventType(status) {
453
+ const mapping = {
454
+ success: "payment.succeeded",
455
+ failure: "payment.failed",
456
+ INIT_THREEDS: "payment.succeeded",
457
+ CALLBACK_THREEDS: "payment.succeeded"
458
+ };
459
+ return mapping[status] ?? "payment.succeeded";
460
+ }
461
+ };
462
+ function createIyzicoProvider(config) {
463
+ return new IyzicoProvider(config);
464
+ }
465
+ export {
466
+ IyzicoProvider,
467
+ createIyzicoProvider
468
+ };
469
+ //# sourceMappingURL=iyzico.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/types.ts","../../src/providers/iyzico.ts"],"sourcesContent":["/**\n * @parsrun/payments - Type Definitions\n * Payment types and interfaces\n */\n\n// Re-export types from @parsrun/types for convenience\nexport {\n type,\n currencyCode,\n money,\n paymentCustomer,\n createCustomerRequest,\n cardDetails,\n paymentMethod,\n paymentIntentStatus,\n paymentIntent as parsPaymentIntent,\n createPaymentIntentRequest,\n subscriptionStatus as parsSubscriptionStatus,\n priceInterval,\n price as parsPrice,\n subscription as parsSubscription,\n createSubscriptionRequest,\n refundStatus,\n refund,\n createRefundRequest,\n webhookEventType,\n webhookEvent,\n stripeConfig,\n paddleConfig,\n iyzicoConfig,\n paymentsConfig,\n type CurrencyCode as ParsCurrencyCode,\n type Money,\n type PaymentCustomer,\n type CreateCustomerRequest as ParsCreateCustomerRequest,\n type CardDetails,\n type PaymentMethod as ParsPaymentMethod,\n type PaymentIntentStatus,\n type PaymentIntent as ParsPaymentIntentType,\n type CreatePaymentIntentRequest,\n type SubscriptionStatus as ParsSubscriptionStatus,\n type PriceInterval,\n type Price as ParsPrice,\n type Subscription as ParsSubscription,\n type CreateSubscriptionRequest as ParsCreateSubscriptionRequest,\n type RefundStatus,\n type Refund,\n type CreateRefundRequest,\n type WebhookEventType as ParsWebhookEventType,\n type WebhookEvent as ParsWebhookEvent,\n type StripeConfig,\n type PaddleConfig,\n type IyzicoConfig,\n type PaymentsConfig,\n} from \"@parsrun/types\";\n\n/**\n * Payment provider type\n */\nexport type PaymentProviderType = \"stripe\" | \"paddle\" | \"iyzico\";\n\n/**\n * Currency code (ISO 4217)\n */\nexport type CurrencyCode = \"USD\" | \"EUR\" | \"GBP\" | \"TRY\" | \"JPY\" | \"CAD\" | \"AUD\" | string;\n\n/**\n * Payment status\n */\nexport type PaymentStatus =\n | \"pending\"\n | \"processing\"\n | \"succeeded\"\n | \"failed\"\n | \"canceled\"\n | \"refunded\"\n | \"partially_refunded\";\n\n/**\n * Subscription status\n */\nexport type SubscriptionStatus =\n | \"active\"\n | \"past_due\"\n | \"unpaid\"\n | \"canceled\"\n | \"incomplete\"\n | \"incomplete_expired\"\n | \"trialing\"\n | \"paused\";\n\n/**\n * Billing interval\n */\nexport type BillingInterval = \"day\" | \"week\" | \"month\" | \"year\";\n\n// ============================================================================\n// Customer\n// ============================================================================\n\n/**\n * Customer data\n */\nexport interface Customer {\n /** Provider customer ID */\n id: string;\n /** Customer email */\n email: string;\n /** Customer name */\n name?: string | undefined;\n /** Phone number */\n phone?: string | undefined;\n /** Billing address */\n address?: Address | undefined;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n/**\n * Address\n */\nexport interface Address {\n line1?: string | undefined;\n line2?: string | undefined;\n city?: string | undefined;\n state?: string | undefined;\n postalCode?: string | undefined;\n country?: string | undefined;\n}\n\n/**\n * Create customer options\n */\nexport interface CreateCustomerOptions {\n email: string;\n name?: string | undefined;\n phone?: string | undefined;\n address?: Address | undefined;\n metadata?: Record<string, string> | undefined;\n}\n\n// ============================================================================\n// Products & Prices\n// ============================================================================\n\n/**\n * Product\n */\nexport interface Product {\n /** Provider product ID */\n id: string;\n /** Product name */\n name: string;\n /** Description */\n description?: string | undefined;\n /** Active status */\n active: boolean;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n/**\n * Price\n */\nexport interface Price {\n /** Provider price ID */\n id: string;\n /** Product ID */\n productId: string;\n /** Price in smallest currency unit (cents) */\n unitAmount: number;\n /** Currency */\n currency: CurrencyCode;\n /** Recurring billing details */\n recurring?: {\n interval: BillingInterval;\n intervalCount: number;\n } | undefined;\n /** Active status */\n active: boolean;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n// ============================================================================\n// Checkout\n// ============================================================================\n\n/**\n * Checkout line item\n */\nexport interface CheckoutLineItem {\n /** Price ID */\n priceId: string;\n /** Quantity */\n quantity: number;\n}\n\n/**\n * Create checkout options\n */\nexport interface CreateCheckoutOptions {\n /** Customer ID (optional, creates new if not provided) */\n customerId?: string | undefined;\n /** Customer email (for new customers) */\n customerEmail?: string | undefined;\n /** Line items */\n lineItems: CheckoutLineItem[];\n /** Success redirect URL */\n successUrl: string;\n /** Cancel redirect URL */\n cancelUrl: string;\n /** Checkout mode */\n mode: \"payment\" | \"subscription\" | \"setup\";\n /** Allow promotion codes */\n allowPromotionCodes?: boolean | undefined;\n /** Trial period days (subscription only) */\n trialDays?: number | undefined;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Tenant ID for multi-tenant */\n tenantId?: string | undefined;\n}\n\n/**\n * Checkout session\n */\nexport interface CheckoutSession {\n /** Provider session ID */\n id: string;\n /** Checkout URL */\n url: string;\n /** Customer ID */\n customerId?: string | undefined;\n /** Payment status */\n status: \"open\" | \"complete\" | \"expired\";\n /** Mode */\n mode: \"payment\" | \"subscription\" | \"setup\";\n /** Amount total */\n amountTotal?: number | undefined;\n /** Currency */\n currency?: CurrencyCode | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n// ============================================================================\n// Subscriptions\n// ============================================================================\n\n/**\n * Subscription\n */\nexport interface Subscription {\n /** Provider subscription ID */\n id: string;\n /** Customer ID */\n customerId: string;\n /** Status */\n status: SubscriptionStatus;\n /** Price ID */\n priceId: string;\n /** Product ID */\n productId?: string | undefined;\n /** Current period start */\n currentPeriodStart: Date;\n /** Current period end */\n currentPeriodEnd: Date;\n /** Cancel at period end */\n cancelAtPeriodEnd: boolean;\n /** Canceled at */\n canceledAt?: Date | undefined;\n /** Trial start */\n trialStart?: Date | undefined;\n /** Trial end */\n trialEnd?: Date | undefined;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n/**\n * Create subscription options\n */\nexport interface CreateSubscriptionOptions {\n /** Customer ID */\n customerId: string;\n /** Price ID */\n priceId: string;\n /** Trial period days */\n trialDays?: number | undefined;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Payment behavior */\n paymentBehavior?: \"default_incomplete\" | \"error_if_incomplete\" | \"allow_incomplete\" | undefined;\n}\n\n/**\n * Update subscription options\n */\nexport interface UpdateSubscriptionOptions {\n /** New price ID */\n priceId?: string | undefined;\n /** Cancel at period end */\n cancelAtPeriodEnd?: boolean | undefined;\n /** Custom metadata */\n metadata?: Record<string, string> | undefined;\n /** Proration behavior */\n prorationBehavior?: \"create_prorations\" | \"none\" | \"always_invoice\" | undefined;\n}\n\n// ============================================================================\n// Payments & Invoices\n// ============================================================================\n\n/**\n * Payment intent\n */\nexport interface PaymentIntent {\n /** Provider payment ID */\n id: string;\n /** Amount */\n amount: number;\n /** Currency */\n currency: CurrencyCode;\n /** Status */\n status: PaymentStatus;\n /** Customer ID */\n customerId?: string | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n/**\n * Invoice\n */\nexport interface Invoice {\n /** Provider invoice ID */\n id: string;\n /** Customer ID */\n customerId: string;\n /** Subscription ID */\n subscriptionId?: string | undefined;\n /** Status */\n status: \"draft\" | \"open\" | \"paid\" | \"void\" | \"uncollectible\";\n /** Amount due */\n amountDue: number;\n /** Amount paid */\n amountPaid: number;\n /** Currency */\n currency: CurrencyCode;\n /** Invoice URL */\n hostedInvoiceUrl?: string | undefined;\n /** PDF URL */\n invoicePdf?: string | undefined;\n /** Due date */\n dueDate?: Date | undefined;\n /** Provider-specific data */\n providerData?: unknown;\n}\n\n// ============================================================================\n// Portal\n// ============================================================================\n\n/**\n * Customer portal session\n */\nexport interface PortalSession {\n /** Portal URL */\n url: string;\n /** Return URL */\n returnUrl: string;\n}\n\n/**\n * Create portal options\n */\nexport interface CreatePortalOptions {\n /** Customer ID */\n customerId: string;\n /** Return URL */\n returnUrl: string;\n}\n\n// ============================================================================\n// Webhooks\n// ============================================================================\n\n/**\n * Webhook event types\n */\nexport type WebhookEventType =\n // Checkout\n | \"checkout.session.completed\"\n | \"checkout.session.expired\"\n // Customer\n | \"customer.created\"\n | \"customer.updated\"\n | \"customer.deleted\"\n // Subscription\n | \"subscription.created\"\n | \"subscription.updated\"\n | \"subscription.deleted\"\n | \"subscription.trial_will_end\"\n // Payment\n | \"payment.succeeded\"\n | \"payment.failed\"\n // Invoice\n | \"invoice.created\"\n | \"invoice.paid\"\n | \"invoice.payment_failed\"\n | \"invoice.upcoming\"\n // Refund\n | \"refund.created\"\n | \"refund.updated\";\n\n/**\n * Webhook event\n */\nexport interface WebhookEvent<T = unknown> {\n /** Event ID */\n id: string;\n /** Event type */\n type: WebhookEventType;\n /** Event data */\n data: T;\n /** Created timestamp */\n created: Date;\n /** Provider type */\n provider: PaymentProviderType;\n /** Raw event data */\n raw: unknown;\n}\n\n/**\n * Webhook handler\n */\nexport type WebhookHandler<T = unknown> = (\n event: WebhookEvent<T>\n) => void | Promise<void>;\n\n// ============================================================================\n// Provider Interface\n// ============================================================================\n\n/**\n * Payment provider interface\n */\nexport interface PaymentProvider {\n /** Provider type */\n readonly type: PaymentProviderType;\n\n // Customer\n createCustomer(options: CreateCustomerOptions): Promise<Customer>;\n getCustomer(customerId: string): Promise<Customer | null>;\n updateCustomer(customerId: string, options: Partial<CreateCustomerOptions>): Promise<Customer>;\n deleteCustomer(customerId: string): Promise<void>;\n\n // Checkout\n createCheckout(options: CreateCheckoutOptions): Promise<CheckoutSession>;\n getCheckout(sessionId: string): Promise<CheckoutSession | null>;\n\n // Subscriptions\n createSubscription(options: CreateSubscriptionOptions): Promise<Subscription>;\n getSubscription(subscriptionId: string): Promise<Subscription | null>;\n updateSubscription(subscriptionId: string, options: UpdateSubscriptionOptions): Promise<Subscription>;\n cancelSubscription(subscriptionId: string, cancelAtPeriodEnd?: boolean): Promise<Subscription>;\n listSubscriptions(customerId: string): Promise<Subscription[]>;\n\n // Portal\n createPortalSession(options: CreatePortalOptions): Promise<PortalSession>;\n\n // Webhooks\n verifyWebhook(payload: string | Uint8Array, signature: string): Promise<WebhookEvent | null>;\n\n // Products & Prices (optional)\n getProduct?(productId: string): Promise<Product | null>;\n getPrice?(priceId: string): Promise<Price | null>;\n listPrices?(productId?: string): Promise<Price[]>;\n}\n\n// ============================================================================\n// Provider Config\n// ============================================================================\n\n/**\n * Stripe provider config\n */\nexport interface StripeProviderConfig {\n /** Stripe secret key */\n secretKey: string;\n /** Webhook signing secret */\n webhookSecret?: string | undefined;\n /** API version */\n apiVersion?: string | undefined;\n}\n\n/**\n * Paddle provider config\n */\nexport interface PaddleProviderConfig {\n /** Paddle API key */\n apiKey: string;\n /** Paddle environment */\n environment?: \"sandbox\" | \"production\" | undefined;\n /** Webhook secret key */\n webhookSecret?: string | undefined;\n /** Seller ID */\n sellerId?: string | undefined;\n}\n\n// ============================================================================\n// Service Config\n// ============================================================================\n\n/**\n * Payment service config\n */\nexport interface PaymentServiceConfig {\n /** Payment provider */\n provider: PaymentProvider;\n /** Enable debug logging */\n debug?: boolean | undefined;\n}\n\n// ============================================================================\n// Errors\n// ============================================================================\n\n/**\n * Payment error\n */\nexport class PaymentError extends Error {\n constructor(\n message: string,\n public readonly code: string,\n public readonly cause?: unknown\n ) {\n super(message);\n this.name = \"PaymentError\";\n }\n}\n\n/**\n * Common payment error codes\n */\nexport const PaymentErrorCodes = {\n INVALID_CONFIG: \"INVALID_CONFIG\",\n CUSTOMER_NOT_FOUND: \"CUSTOMER_NOT_FOUND\",\n SUBSCRIPTION_NOT_FOUND: \"SUBSCRIPTION_NOT_FOUND\",\n CHECKOUT_FAILED: \"CHECKOUT_FAILED\",\n PAYMENT_FAILED: \"PAYMENT_FAILED\",\n WEBHOOK_VERIFICATION_FAILED: \"WEBHOOK_VERIFICATION_FAILED\",\n API_ERROR: \"API_ERROR\",\n RATE_LIMITED: \"RATE_LIMITED\",\n} as const;\n","/**\n * @parsrun/payments - iyzico Provider\n * Edge-compatible iyzico provider using fetch API\n */\n\nimport type {\n CheckoutSession,\n CreateCheckoutOptions,\n CreateCustomerOptions,\n CreatePortalOptions,\n CreateSubscriptionOptions,\n Customer,\n PaymentProvider,\n PortalSession,\n Subscription,\n UpdateSubscriptionOptions,\n WebhookEvent,\n WebhookEventType,\n} from \"../types.js\";\nimport { PaymentError, PaymentErrorCodes } from \"../types.js\";\n\n/**\n * iyzico provider config\n */\nexport interface IyzicoProviderConfig {\n /** iyzico API key */\n apiKey: string;\n /** iyzico secret key */\n secretKey: string;\n /** Environment */\n environment?: \"sandbox\" | \"production\" | undefined;\n /** Base URL override */\n baseUrl?: string | undefined;\n}\n\n/**\n * iyzico basket item\n */\nexport interface IyzicoBasketItem {\n id: string;\n name: string;\n category1: string;\n category2?: string | undefined;\n itemType: \"PHYSICAL\" | \"VIRTUAL\";\n price: string; // Decimal string like \"1.0\"\n}\n\n/**\n * iyzico buyer info\n */\nexport interface IyzicoBuyer {\n id: string;\n name: string;\n surname: string;\n email: string;\n gsmNumber?: string | undefined;\n identityNumber: string;\n registrationAddress: string;\n city: string;\n country: string;\n ip: string;\n}\n\n/**\n * iyzico address\n */\nexport interface IyzicoAddress {\n contactName: string;\n city: string;\n country: string;\n address: string;\n}\n\n/**\n * Extended checkout options for iyzico\n */\nexport interface IyzicoCheckoutOptions extends CreateCheckoutOptions {\n /** Buyer information (required for iyzico) */\n buyer: IyzicoBuyer;\n /** Billing address */\n billingAddress: IyzicoAddress;\n /** Shipping address */\n shippingAddress: IyzicoAddress;\n /** Basket items */\n basketItems: IyzicoBasketItem[];\n /** Price (total amount as decimal string) */\n price: string;\n /** Paid price (can include installment fees) */\n paidPrice: string;\n /** Currency (TRY, USD, EUR, GBP, IRR) */\n currency: \"TRY\" | \"USD\" | \"EUR\" | \"GBP\" | \"IRR\";\n /** Installment options */\n enabledInstallments?: number[] | undefined;\n /** Force 3D Secure */\n force3ds?: boolean | undefined;\n /** Conversation ID for tracking */\n conversationId?: string | undefined;\n}\n\n/**\n * iyzico Payment Provider\n * Edge-compatible using fetch API\n *\n * @example\n * ```typescript\n * const iyzico = new IyzicoProvider({\n * apiKey: process.env.IYZICO_API_KEY,\n * secretKey: process.env.IYZICO_SECRET_KEY,\n * environment: 'sandbox',\n * });\n *\n * const checkout = await iyzico.createCheckoutForm({\n * price: '100.00',\n * paidPrice: '100.00',\n * currency: 'TRY',\n * basketItems: [...],\n * buyer: {...},\n * billingAddress: {...},\n * shippingAddress: {...},\n * callbackUrl: 'https://example.com/callback',\n * });\n * ```\n */\nexport class IyzicoProvider implements PaymentProvider {\n readonly type = \"iyzico\" as const;\n\n private apiKey: string;\n private secretKey: string;\n private baseUrl: string;\n\n constructor(config: IyzicoProviderConfig) {\n this.apiKey = config.apiKey;\n this.secretKey = config.secretKey;\n this.baseUrl =\n config.baseUrl ??\n (config.environment === \"production\"\n ? \"https://api.iyzipay.com\"\n : \"https://sandbox-api.iyzipay.com\");\n }\n\n private async request<T>(\n endpoint: string,\n body: Record<string, unknown>\n ): Promise<T> {\n const randomString = this.generateRandomString(8);\n\n // Generate authorization header\n const authorizationString = await this.generateAuthorizationString(\n body,\n randomString\n );\n\n const response = await fetch(`${this.baseUrl}${endpoint}`, {\n method: \"POST\",\n headers: {\n Accept: \"application/json\",\n \"Content-Type\": \"application/json\",\n Authorization: authorizationString,\n \"x-iyzi-rnd\": randomString,\n },\n body: JSON.stringify(body),\n });\n\n const data = (await response.json()) as IyzicoResponse & T;\n\n if (data.status !== \"success\") {\n throw new PaymentError(\n `iyzico API error: ${data.errorMessage ?? \"Unknown error\"}`,\n data.errorCode ?? PaymentErrorCodes.API_ERROR,\n data\n );\n }\n\n return data as T;\n }\n\n private generateRandomString(length: number): string {\n const chars = \"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\";\n let result = \"\";\n const randomValues = new Uint8Array(length);\n crypto.getRandomValues(randomValues);\n for (let i = 0; i < length; i++) {\n const randomValue = randomValues[i];\n if (randomValue !== undefined) {\n result += chars[randomValue % chars.length];\n }\n }\n return result;\n }\n\n private async generateAuthorizationString(\n body: Record<string, unknown>,\n randomString: string\n ): Promise<string> {\n // Sort and flatten the body for PKI string\n const pkiString = this.generatePkiString(body);\n\n // Create hash string\n const hashString = `${this.apiKey}${randomString}${this.secretKey}${pkiString}`;\n\n // SHA256 hash\n const encoder = new TextEncoder();\n const data = encoder.encode(hashString);\n const hashBuffer = await crypto.subtle.digest(\"SHA-256\", data);\n const hashArray = new Uint8Array(hashBuffer);\n const hashBase64 = btoa(String.fromCharCode(...hashArray));\n\n // Create authorization\n const authorizationString = `${this.apiKey}:${hashBase64}`;\n const authorizationBase64 = btoa(authorizationString);\n\n return `IYZWS ${authorizationBase64}`;\n }\n\n private generatePkiString(obj: Record<string, unknown>): string {\n const parts: string[] = [];\n\n for (const [key, value] of Object.entries(obj)) {\n if (value === undefined || value === null) continue;\n\n if (Array.isArray(value)) {\n const arrayParts = value.map((item) => {\n if (typeof item === \"object\" && item !== null) {\n return this.generatePkiString(item as Record<string, unknown>);\n }\n return String(item);\n });\n parts.push(`${key}=[${arrayParts.join(\", \")}]`);\n } else if (typeof value === \"object\") {\n parts.push(\n `${key}=[${this.generatePkiString(value as Record<string, unknown>)}]`\n );\n } else {\n parts.push(`${key}=${value}`);\n }\n }\n\n return `[${parts.join(\",\")}]`;\n }\n\n // ============================================================================\n // Customer - iyzico uses buyer info per transaction, not stored customers\n // ============================================================================\n\n async createCustomer(_options: CreateCustomerOptions): Promise<Customer> {\n // iyzico doesn't have a separate customer API\n // Customers are identified by buyer info in each transaction\n throw new PaymentError(\n \"iyzico does not support stored customers. Use buyer info in checkout.\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n async getCustomer(_customerId: string): Promise<Customer | null> {\n return null;\n }\n\n async updateCustomer(\n _customerId: string,\n _options: Partial<CreateCustomerOptions>\n ): Promise<Customer> {\n throw new PaymentError(\n \"iyzico does not support stored customers\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n async deleteCustomer(_customerId: string): Promise<void> {\n throw new PaymentError(\n \"iyzico does not support stored customers\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n // ============================================================================\n // Checkout\n // ============================================================================\n\n async createCheckout(_options: CreateCheckoutOptions): Promise<CheckoutSession> {\n // For standard createCheckout, we need extended options\n throw new PaymentError(\n \"Use createCheckoutForm() with IyzicoCheckoutOptions for iyzico\",\n PaymentErrorCodes.INVALID_CONFIG\n );\n }\n\n /**\n * Create iyzico checkout form (iframe/popup)\n */\n async createCheckoutForm(options: IyzicoCheckoutOptions): Promise<IyzicoCheckoutResult> {\n const body: Record<string, unknown> = {\n locale: \"tr\",\n conversationId: options.conversationId ?? this.generateRandomString(16),\n price: options.price,\n paidPrice: options.paidPrice,\n currency: options.currency,\n basketId: options.metadata?.[\"basketId\"] ?? this.generateRandomString(16),\n paymentGroup: \"PRODUCT\",\n callbackUrl: options.successUrl,\n buyer: {\n id: options.buyer.id,\n name: options.buyer.name,\n surname: options.buyer.surname,\n gsmNumber: options.buyer.gsmNumber,\n email: options.buyer.email,\n identityNumber: options.buyer.identityNumber,\n registrationAddress: options.buyer.registrationAddress,\n ip: options.buyer.ip,\n city: options.buyer.city,\n country: options.buyer.country,\n },\n shippingAddress: {\n contactName: options.shippingAddress.contactName,\n city: options.shippingAddress.city,\n country: options.shippingAddress.country,\n address: options.shippingAddress.address,\n },\n billingAddress: {\n contactName: options.billingAddress.contactName,\n city: options.billingAddress.city,\n country: options.billingAddress.country,\n address: options.billingAddress.address,\n },\n basketItems: options.basketItems.map((item) => ({\n id: item.id,\n name: item.name,\n category1: item.category1,\n category2: item.category2,\n itemType: item.itemType,\n price: item.price,\n })),\n };\n\n if (options.enabledInstallments) {\n body[\"enabledInstallments\"] = options.enabledInstallments;\n }\n\n if (options.force3ds) {\n body[\"forceThreeDS\"] = 1;\n }\n\n const result = await this.request<IyzicoCheckoutFormResponse>(\n \"/payment/iyzi-pos/checkoutform/initialize/auth/ecom\",\n body\n );\n\n return {\n token: result.token,\n checkoutFormContent: result.checkoutFormContent,\n tokenExpireTime: result.tokenExpireTime,\n paymentPageUrl: result.paymentPageUrl,\n };\n }\n\n /**\n * Retrieve checkout form result\n */\n async retrieveCheckoutForm(token: string): Promise<IyzicoPaymentResult> {\n const body = {\n locale: \"tr\",\n conversationId: this.generateRandomString(16),\n token,\n };\n\n const result = await this.request<IyzicoPaymentResponse>(\n \"/payment/iyzi-pos/checkoutform/auth/ecom/detail\",\n body\n );\n\n return {\n paymentId: result.paymentId,\n status: result.status,\n paymentStatus: result.paymentStatus,\n price: result.price,\n paidPrice: result.paidPrice,\n currency: result.currency,\n installment: result.installment,\n basketId: result.basketId,\n binNumber: result.binNumber,\n lastFourDigits: result.lastFourDigits,\n cardAssociation: result.cardAssociation,\n cardFamily: result.cardFamily,\n cardType: result.cardType,\n fraudStatus: result.fraudStatus,\n raw: result,\n };\n }\n\n async getCheckout(_sessionId: string): Promise<CheckoutSession | null> {\n // Use retrieveCheckoutForm instead\n return null;\n }\n\n // ============================================================================\n // 3D Secure Payment\n // ============================================================================\n\n /**\n * Initialize 3D Secure payment\n */\n async initialize3DSPayment(options: {\n price: string;\n paidPrice: string;\n currency: \"TRY\" | \"USD\" | \"EUR\" | \"GBP\" | \"IRR\";\n installment: number;\n paymentCard: {\n cardHolderName: string;\n cardNumber: string;\n expireMonth: string;\n expireYear: string;\n cvc: string;\n registerCard?: 0 | 1;\n };\n buyer: IyzicoBuyer;\n billingAddress: IyzicoAddress;\n shippingAddress: IyzicoAddress;\n basketItems: IyzicoBasketItem[];\n callbackUrl: string;\n conversationId?: string;\n }): Promise<IyzicoThreeDSInitResult> {\n const body: Record<string, unknown> = {\n locale: \"tr\",\n conversationId: options.conversationId ?? this.generateRandomString(16),\n price: options.price,\n paidPrice: options.paidPrice,\n currency: options.currency,\n installment: options.installment,\n basketId: this.generateRandomString(16),\n paymentChannel: \"WEB\",\n paymentGroup: \"PRODUCT\",\n paymentCard: options.paymentCard,\n buyer: options.buyer,\n shippingAddress: options.shippingAddress,\n billingAddress: options.billingAddress,\n basketItems: options.basketItems,\n callbackUrl: options.callbackUrl,\n };\n\n const result = await this.request<IyzicoThreeDSResponse>(\n \"/payment/3dsecure/initialize\",\n body\n );\n\n return {\n threeDSHtmlContent: result.threeDSHtmlContent,\n status: result.status,\n };\n }\n\n /**\n * Complete 3D Secure payment after callback\n */\n async complete3DSPayment(paymentId: string, conversationId?: string): Promise<IyzicoPaymentResult> {\n const body = {\n locale: \"tr\",\n conversationId: conversationId ?? this.generateRandomString(16),\n paymentId,\n };\n\n const result = await this.request<IyzicoPaymentResponse>(\n \"/payment/3dsecure/auth\",\n body\n );\n\n return {\n paymentId: result.paymentId,\n status: result.status,\n paymentStatus: result.paymentStatus,\n price: result.price,\n paidPrice: result.paidPrice,\n currency: result.currency,\n installment: result.installment,\n basketId: result.basketId,\n binNumber: result.binNumber,\n lastFourDigits: result.lastFourDigits,\n cardAssociation: result.cardAssociation,\n cardFamily: result.cardFamily,\n cardType: result.cardType,\n fraudStatus: result.fraudStatus,\n raw: result,\n };\n }\n\n // ============================================================================\n // Refund\n // ============================================================================\n\n /**\n * Create a refund\n */\n async createRefund(options: {\n paymentTransactionId: string;\n price: string;\n currency: \"TRY\" | \"USD\" | \"EUR\" | \"GBP\" | \"IRR\";\n ip: string;\n conversationId?: string;\n }): Promise<IyzicoRefundResult> {\n const body = {\n locale: \"tr\",\n conversationId: options.conversationId ?? this.generateRandomString(16),\n paymentTransactionId: options.paymentTransactionId,\n price: options.price,\n currency: options.currency,\n ip: options.ip,\n };\n\n const result = await this.request<IyzicoRefundResponse>(\n \"/payment/refund\",\n body\n );\n\n return {\n paymentId: result.paymentId,\n paymentTransactionId: result.paymentTransactionId,\n price: result.price,\n status: result.status,\n };\n }\n\n /**\n * Cancel a payment (full refund before settlement)\n */\n async cancelPayment(options: {\n paymentId: string;\n ip: string;\n conversationId?: string;\n }): Promise<IyzicoCancelResult> {\n const body = {\n locale: \"tr\",\n conversationId: options.conversationId ?? this.generateRandomString(16),\n paymentId: options.paymentId,\n ip: options.ip,\n };\n\n const result = await this.request<IyzicoCancelResponse>(\n \"/payment/cancel\",\n body\n );\n\n return {\n paymentId: result.paymentId,\n price: result.price,\n currency: result.currency,\n status: result.status,\n };\n }\n\n // ============================================================================\n // Installment\n // ============================================================================\n\n /**\n * Get installment info for a BIN number\n */\n async getInstallmentInfo(\n binNumber: string,\n price: string\n ): Promise<IyzicoInstallmentResult> {\n const body = {\n locale: \"tr\",\n conversationId: this.generateRandomString(16),\n binNumber: binNumber.substring(0, 6),\n price,\n };\n\n const result = await this.request<IyzicoInstallmentResponse>(\n \"/payment/iyzi-pos/installment\",\n body\n );\n\n return {\n installmentDetails: result.installmentDetails ?? [],\n };\n }\n\n // ============================================================================\n // Subscriptions - iyzico has separate subscription API\n // ============================================================================\n\n async createSubscription(_options: CreateSubscriptionOptions): Promise<Subscription> {\n throw new PaymentError(\n \"Use iyzico subscription API methods directly\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n async getSubscription(_subscriptionId: string): Promise<Subscription | null> {\n return null;\n }\n\n async updateSubscription(\n _subscriptionId: string,\n _options: UpdateSubscriptionOptions\n ): Promise<Subscription> {\n throw new PaymentError(\n \"Use iyzico subscription API methods directly\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n async cancelSubscription(\n _subscriptionId: string,\n _cancelAtPeriodEnd?: boolean\n ): Promise<Subscription> {\n throw new PaymentError(\n \"Use iyzico subscription API methods directly\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n async listSubscriptions(_customerId: string): Promise<Subscription[]> {\n return [];\n }\n\n // ============================================================================\n // Portal - not supported\n // ============================================================================\n\n async createPortalSession(_options: CreatePortalOptions): Promise<PortalSession> {\n throw new PaymentError(\n \"iyzico does not support customer portal\",\n PaymentErrorCodes.API_ERROR\n );\n }\n\n // ============================================================================\n // Webhooks\n // ============================================================================\n\n async verifyWebhook(\n payload: string | Uint8Array,\n _signature: string\n ): Promise<WebhookEvent | null> {\n // iyzico uses IPN (Instant Payment Notification) system\n // The callback includes payment data that should be verified by retrieving the payment\n\n const payloadString = typeof payload === \"string\" ? payload : new TextDecoder().decode(payload);\n\n try {\n const data = JSON.parse(payloadString) as {\n token?: string;\n paymentId?: string;\n status?: string;\n iyziEventType?: string;\n };\n\n // Verify by retrieving the payment\n if (data.token) {\n const result = await this.retrieveCheckoutForm(data.token);\n\n return {\n id: result.paymentId ?? data.token,\n type: this.mapEventType(data.status ?? result.status),\n data: result,\n created: new Date(),\n provider: \"iyzico\",\n raw: data,\n };\n }\n\n return null;\n } catch {\n return null;\n }\n }\n\n private mapEventType(status: string): WebhookEventType {\n const mapping: Record<string, WebhookEventType> = {\n success: \"payment.succeeded\",\n failure: \"payment.failed\",\n INIT_THREEDS: \"payment.succeeded\",\n CALLBACK_THREEDS: \"payment.succeeded\",\n };\n\n return mapping[status] ?? \"payment.succeeded\";\n }\n}\n\n// ============================================================================\n// iyzico Response Types\n// ============================================================================\n\ninterface IyzicoResponse {\n status: \"success\" | \"failure\";\n errorCode?: string;\n errorMessage?: string;\n locale?: string;\n systemTime?: number;\n conversationId?: string;\n}\n\ninterface IyzicoCheckoutFormResponse extends IyzicoResponse {\n token: string;\n checkoutFormContent: string;\n tokenExpireTime: number;\n paymentPageUrl: string;\n}\n\ninterface IyzicoPaymentResponse extends IyzicoResponse {\n paymentId: string;\n paymentStatus: string;\n price: string;\n paidPrice: string;\n currency: string;\n installment: number;\n basketId: string;\n binNumber: string;\n lastFourDigits: string;\n cardAssociation: string;\n cardFamily: string;\n cardType: string;\n fraudStatus: number;\n itemTransactions?: Array<{\n itemId: string;\n paymentTransactionId: string;\n transactionStatus: number;\n price: string;\n paidPrice: string;\n }>;\n}\n\ninterface IyzicoThreeDSResponse extends IyzicoResponse {\n threeDSHtmlContent: string;\n}\n\ninterface IyzicoRefundResponse extends IyzicoResponse {\n paymentId: string;\n paymentTransactionId: string;\n price: string;\n}\n\ninterface IyzicoCancelResponse extends IyzicoResponse {\n paymentId: string;\n price: string;\n currency: string;\n}\n\ninterface IyzicoInstallmentResponse extends IyzicoResponse {\n installmentDetails?: Array<{\n binNumber: string;\n price: string;\n cardType: string;\n cardAssociation: string;\n cardFamilyName: string;\n force3ds: number;\n bankCode: number;\n bankName: string;\n forceCvc: number;\n installmentPrices: Array<{\n installmentNumber: number;\n totalPrice: string;\n installmentPrice: string;\n }>;\n }>;\n}\n\n// ============================================================================\n// Result Types\n// ============================================================================\n\nexport interface IyzicoCheckoutResult {\n token: string;\n checkoutFormContent: string;\n tokenExpireTime: number;\n paymentPageUrl: string;\n}\n\nexport interface IyzicoPaymentResult {\n paymentId: string;\n status: string;\n paymentStatus: string;\n price: string;\n paidPrice: string;\n currency: string;\n installment: number;\n basketId: string;\n binNumber: string;\n lastFourDigits: string;\n cardAssociation: string;\n cardFamily: string;\n cardType: string;\n fraudStatus: number;\n raw: unknown;\n}\n\nexport interface IyzicoThreeDSInitResult {\n threeDSHtmlContent: string;\n status: string;\n}\n\nexport interface IyzicoRefundResult {\n paymentId: string;\n paymentTransactionId: string;\n price: string;\n status: string;\n}\n\nexport interface IyzicoCancelResult {\n paymentId: string;\n price: string;\n currency: string;\n status: string;\n}\n\nexport interface IyzicoInstallmentResult {\n installmentDetails: Array<{\n binNumber: string;\n price: string;\n cardType: string;\n cardAssociation: string;\n cardFamilyName: string;\n force3ds: number;\n bankCode: number;\n bankName: string;\n forceCvc: number;\n installmentPrices: Array<{\n installmentNumber: number;\n totalPrice: string;\n installmentPrice: string;\n }>;\n }>;\n}\n\n/**\n * Create an iyzico provider\n */\nexport function createIyzicoProvider(config: IyzicoProviderConfig): IyzicoProvider {\n return new IyzicoProvider(config);\n}\n"],"mappings":";AAMA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACiB;AAAA,EACjB;AAAA,EACsB;AAAA,EACtB;AAAA,EACS;AAAA,EACO;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OAwBK;AAseA,IAAM,eAAN,cAA2B,MAAM;AAAA,EACtC,YACE,SACgB,MACA,OAChB;AACA,UAAM,OAAO;AAHG;AACA;AAGhB,SAAK,OAAO;AAAA,EACd;AACF;AAKO,IAAM,oBAAoB;AAAA,EAC/B,gBAAgB;AAAA,EAChB,oBAAoB;AAAA,EACpB,wBAAwB;AAAA,EACxB,iBAAiB;AAAA,EACjB,gBAAgB;AAAA,EAChB,6BAA6B;AAAA,EAC7B,WAAW;AAAA,EACX,cAAc;AAChB;;;ACxbO,IAAM,iBAAN,MAAgD;AAAA,EAC5C,OAAO;AAAA,EAER;AAAA,EACA;AAAA,EACA;AAAA,EAER,YAAY,QAA8B;AACxC,SAAK,SAAS,OAAO;AACrB,SAAK,YAAY,OAAO;AACxB,SAAK,UACH,OAAO,YACN,OAAO,gBAAgB,eACpB,4BACA;AAAA,EACR;AAAA,EAEA,MAAc,QACZ,UACA,MACY;AACZ,UAAM,eAAe,KAAK,qBAAqB,CAAC;AAGhD,UAAM,sBAAsB,MAAM,KAAK;AAAA,MACrC;AAAA,MACA;AAAA,IACF;AAEA,UAAM,WAAW,MAAM,MAAM,GAAG,KAAK,OAAO,GAAG,QAAQ,IAAI;AAAA,MACzD,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,QAAQ;AAAA,QACR,gBAAgB;AAAA,QAChB,eAAe;AAAA,QACf,cAAc;AAAA,MAChB;AAAA,MACA,MAAM,KAAK,UAAU,IAAI;AAAA,IAC3B,CAAC;AAED,UAAM,OAAQ,MAAM,SAAS,KAAK;AAElC,QAAI,KAAK,WAAW,WAAW;AAC7B,YAAM,IAAI;AAAA,QACR,qBAAqB,KAAK,gBAAgB,eAAe;AAAA,QACzD,KAAK,aAAa,kBAAkB;AAAA,QACpC;AAAA,MACF;AAAA,IACF;AAEA,WAAO;AAAA,EACT;AAAA,EAEQ,qBAAqB,QAAwB;AACnD,UAAM,QAAQ;AACd,QAAI,SAAS;AACb,UAAM,eAAe,IAAI,WAAW,MAAM;AAC1C,WAAO,gBAAgB,YAAY;AACnC,aAAS,IAAI,GAAG,IAAI,QAAQ,KAAK;AAC/B,YAAM,cAAc,aAAa,CAAC;AAClC,UAAI,gBAAgB,QAAW;AAC7B,kBAAU,MAAM,cAAc,MAAM,MAAM;AAAA,MAC5C;AAAA,IACF;AACA,WAAO;AAAA,EACT;AAAA,EAEA,MAAc,4BACZ,MACA,cACiB;AAEjB,UAAM,YAAY,KAAK,kBAAkB,IAAI;AAG7C,UAAM,aAAa,GAAG,KAAK,MAAM,GAAG,YAAY,GAAG,KAAK,SAAS,GAAG,SAAS;AAG7E,UAAM,UAAU,IAAI,YAAY;AAChC,UAAM,OAAO,QAAQ,OAAO,UAAU;AACtC,UAAM,aAAa,MAAM,OAAO,OAAO,OAAO,WAAW,IAAI;AAC7D,UAAM,YAAY,IAAI,WAAW,UAAU;AAC3C,UAAM,aAAa,KAAK,OAAO,aAAa,GAAG,SAAS,CAAC;AAGzD,UAAM,sBAAsB,GAAG,KAAK,MAAM,IAAI,UAAU;AACxD,UAAM,sBAAsB,KAAK,mBAAmB;AAEpD,WAAO,SAAS,mBAAmB;AAAA,EACrC;AAAA,EAEQ,kBAAkB,KAAsC;AAC9D,UAAM,QAAkB,CAAC;AAEzB,eAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,GAAG,GAAG;AAC9C,UAAI,UAAU,UAAa,UAAU,KAAM;AAE3C,UAAI,MAAM,QAAQ,KAAK,GAAG;AACxB,cAAM,aAAa,MAAM,IAAI,CAAC,SAAS;AACrC,cAAI,OAAO,SAAS,YAAY,SAAS,MAAM;AAC7C,mBAAO,KAAK,kBAAkB,IAA+B;AAAA,UAC/D;AACA,iBAAO,OAAO,IAAI;AAAA,QACpB,CAAC;AACD,cAAM,KAAK,GAAG,GAAG,KAAK,WAAW,KAAK,IAAI,CAAC,GAAG;AAAA,MAChD,WAAW,OAAO,UAAU,UAAU;AACpC,cAAM;AAAA,UACJ,GAAG,GAAG,KAAK,KAAK,kBAAkB,KAAgC,CAAC;AAAA,QACrE;AAAA,MACF,OAAO;AACL,cAAM,KAAK,GAAG,GAAG,IAAI,KAAK,EAAE;AAAA,MAC9B;AAAA,IACF;AAEA,WAAO,IAAI,MAAM,KAAK,GAAG,CAAC;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,eAAe,UAAoD;AAGvE,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,MAAM,YAAY,aAA+C;AAC/D,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,eACJ,aACA,UACmB;AACnB,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,MAAM,eAAe,aAAoC;AACvD,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,eAAe,UAA2D;AAE9E,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,mBAAmB,SAA+D;AACtF,UAAM,OAAgC;AAAA,MACpC,QAAQ;AAAA,MACR,gBAAgB,QAAQ,kBAAkB,KAAK,qBAAqB,EAAE;AAAA,MACtE,OAAO,QAAQ;AAAA,MACf,WAAW,QAAQ;AAAA,MACnB,UAAU,QAAQ;AAAA,MAClB,UAAU,QAAQ,WAAW,UAAU,KAAK,KAAK,qBAAqB,EAAE;AAAA,MACxE,cAAc;AAAA,MACd,aAAa,QAAQ;AAAA,MACrB,OAAO;AAAA,QACL,IAAI,QAAQ,MAAM;AAAA,QAClB,MAAM,QAAQ,MAAM;AAAA,QACpB,SAAS,QAAQ,MAAM;AAAA,QACvB,WAAW,QAAQ,MAAM;AAAA,QACzB,OAAO,QAAQ,MAAM;AAAA,QACrB,gBAAgB,QAAQ,MAAM;AAAA,QAC9B,qBAAqB,QAAQ,MAAM;AAAA,QACnC,IAAI,QAAQ,MAAM;AAAA,QAClB,MAAM,QAAQ,MAAM;AAAA,QACpB,SAAS,QAAQ,MAAM;AAAA,MACzB;AAAA,MACA,iBAAiB;AAAA,QACf,aAAa,QAAQ,gBAAgB;AAAA,QACrC,MAAM,QAAQ,gBAAgB;AAAA,QAC9B,SAAS,QAAQ,gBAAgB;AAAA,QACjC,SAAS,QAAQ,gBAAgB;AAAA,MACnC;AAAA,MACA,gBAAgB;AAAA,QACd,aAAa,QAAQ,eAAe;AAAA,QACpC,MAAM,QAAQ,eAAe;AAAA,QAC7B,SAAS,QAAQ,eAAe;AAAA,QAChC,SAAS,QAAQ,eAAe;AAAA,MAClC;AAAA,MACA,aAAa,QAAQ,YAAY,IAAI,CAAC,UAAU;AAAA,QAC9C,IAAI,KAAK;AAAA,QACT,MAAM,KAAK;AAAA,QACX,WAAW,KAAK;AAAA,QAChB,WAAW,KAAK;AAAA,QAChB,UAAU,KAAK;AAAA,QACf,OAAO,KAAK;AAAA,MACd,EAAE;AAAA,IACJ;AAEA,QAAI,QAAQ,qBAAqB;AAC/B,WAAK,qBAAqB,IAAI,QAAQ;AAAA,IACxC;AAEA,QAAI,QAAQ,UAAU;AACpB,WAAK,cAAc,IAAI;AAAA,IACzB;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,OAAO,OAAO;AAAA,MACd,qBAAqB,OAAO;AAAA,MAC5B,iBAAiB,OAAO;AAAA,MACxB,gBAAgB,OAAO;AAAA,IACzB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,qBAAqB,OAA6C;AACtE,UAAM,OAAO;AAAA,MACX,QAAQ;AAAA,MACR,gBAAgB,KAAK,qBAAqB,EAAE;AAAA,MAC5C;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,WAAW,OAAO;AAAA,MAClB,QAAQ,OAAO;AAAA,MACf,eAAe,OAAO;AAAA,MACtB,OAAO,OAAO;AAAA,MACd,WAAW,OAAO;AAAA,MAClB,UAAU,OAAO;AAAA,MACjB,aAAa,OAAO;AAAA,MACpB,UAAU,OAAO;AAAA,MACjB,WAAW,OAAO;AAAA,MAClB,gBAAgB,OAAO;AAAA,MACvB,iBAAiB,OAAO;AAAA,MACxB,YAAY,OAAO;AAAA,MACnB,UAAU,OAAO;AAAA,MACjB,aAAa,OAAO;AAAA,MACpB,KAAK;AAAA,IACP;AAAA,EACF;AAAA,EAEA,MAAM,YAAY,YAAqD;AAErE,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,qBAAqB,SAmBU;AACnC,UAAM,OAAgC;AAAA,MACpC,QAAQ;AAAA,MACR,gBAAgB,QAAQ,kBAAkB,KAAK,qBAAqB,EAAE;AAAA,MACtE,OAAO,QAAQ;AAAA,MACf,WAAW,QAAQ;AAAA,MACnB,UAAU,QAAQ;AAAA,MAClB,aAAa,QAAQ;AAAA,MACrB,UAAU,KAAK,qBAAqB,EAAE;AAAA,MACtC,gBAAgB;AAAA,MAChB,cAAc;AAAA,MACd,aAAa,QAAQ;AAAA,MACrB,OAAO,QAAQ;AAAA,MACf,iBAAiB,QAAQ;AAAA,MACzB,gBAAgB,QAAQ;AAAA,MACxB,aAAa,QAAQ;AAAA,MACrB,aAAa,QAAQ;AAAA,IACvB;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,oBAAoB,OAAO;AAAA,MAC3B,QAAQ,OAAO;AAAA,IACjB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,mBAAmB,WAAmB,gBAAuD;AACjG,UAAM,OAAO;AAAA,MACX,QAAQ;AAAA,MACR,gBAAgB,kBAAkB,KAAK,qBAAqB,EAAE;AAAA,MAC9D;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,WAAW,OAAO;AAAA,MAClB,QAAQ,OAAO;AAAA,MACf,eAAe,OAAO;AAAA,MACtB,OAAO,OAAO;AAAA,MACd,WAAW,OAAO;AAAA,MAClB,UAAU,OAAO;AAAA,MACjB,aAAa,OAAO;AAAA,MACpB,UAAU,OAAO;AAAA,MACjB,WAAW,OAAO;AAAA,MAClB,gBAAgB,OAAO;AAAA,MACvB,iBAAiB,OAAO;AAAA,MACxB,YAAY,OAAO;AAAA,MACnB,UAAU,OAAO;AAAA,MACjB,aAAa,OAAO;AAAA,MACpB,KAAK;AAAA,IACP;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,aAAa,SAMa;AAC9B,UAAM,OAAO;AAAA,MACX,QAAQ;AAAA,MACR,gBAAgB,QAAQ,kBAAkB,KAAK,qBAAqB,EAAE;AAAA,MACtE,sBAAsB,QAAQ;AAAA,MAC9B,OAAO,QAAQ;AAAA,MACf,UAAU,QAAQ;AAAA,MAClB,IAAI,QAAQ;AAAA,IACd;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,WAAW,OAAO;AAAA,MAClB,sBAAsB,OAAO;AAAA,MAC7B,OAAO,OAAO;AAAA,MACd,QAAQ,OAAO;AAAA,IACjB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAM,cAAc,SAIY;AAC9B,UAAM,OAAO;AAAA,MACX,QAAQ;AAAA,MACR,gBAAgB,QAAQ,kBAAkB,KAAK,qBAAqB,EAAE;AAAA,MACtE,WAAW,QAAQ;AAAA,MACnB,IAAI,QAAQ;AAAA,IACd;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,WAAW,OAAO;AAAA,MAClB,OAAO,OAAO;AAAA,MACd,UAAU,OAAO;AAAA,MACjB,QAAQ,OAAO;AAAA,IACjB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAM,mBACJ,WACAA,QACkC;AAClC,UAAM,OAAO;AAAA,MACX,QAAQ;AAAA,MACR,gBAAgB,KAAK,qBAAqB,EAAE;AAAA,MAC5C,WAAW,UAAU,UAAU,GAAG,CAAC;AAAA,MACnC,OAAAA;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,KAAK;AAAA,MACxB;AAAA,MACA;AAAA,IACF;AAEA,WAAO;AAAA,MACL,oBAAoB,OAAO,sBAAsB,CAAC;AAAA,IACpD;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,mBAAmB,UAA4D;AACnF,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,MAAM,gBAAgB,iBAAuD;AAC3E,WAAO;AAAA,EACT;AAAA,EAEA,MAAM,mBACJ,iBACA,UACuB;AACvB,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,MAAM,mBACJ,iBACA,oBACuB;AACvB,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,MAAM,kBAAkB,aAA8C;AACpE,WAAO,CAAC;AAAA,EACV;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,oBAAoB,UAAuD;AAC/E,UAAM,IAAI;AAAA,MACR;AAAA,MACA,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,cACJ,SACA,YAC8B;AAI9B,UAAM,gBAAgB,OAAO,YAAY,WAAW,UAAU,IAAI,YAAY,EAAE,OAAO,OAAO;AAE9F,QAAI;AACF,YAAM,OAAO,KAAK,MAAM,aAAa;AAQrC,UAAI,KAAK,OAAO;AACd,cAAM,SAAS,MAAM,KAAK,qBAAqB,KAAK,KAAK;AAEzD,eAAO;AAAA,UACL,IAAI,OAAO,aAAa,KAAK;AAAA,UAC7B,MAAM,KAAK,aAAa,KAAK,UAAU,OAAO,MAAM;AAAA,UACpD,MAAM;AAAA,UACN,SAAS,oBAAI,KAAK;AAAA,UAClB,UAAU;AAAA,UACV,KAAK;AAAA,QACP;AAAA,MACF;AAEA,aAAO;AAAA,IACT,QAAQ;AACN,aAAO;AAAA,IACT;AAAA,EACF;AAAA,EAEQ,aAAa,QAAkC;AACrD,UAAM,UAA4C;AAAA,MAChD,SAAS;AAAA,MACT,SAAS;AAAA,MACT,cAAc;AAAA,MACd,kBAAkB;AAAA,IACpB;AAEA,WAAO,QAAQ,MAAM,KAAK;AAAA,EAC5B;AACF;AAsJO,SAAS,qBAAqB,QAA8C;AACjF,SAAO,IAAI,eAAe,MAAM;AAClC;","names":["price"]}
@@ -0,0 +1,66 @@
1
+ import { PaymentProvider, PaddleProviderConfig, CreateCustomerOptions, Customer, CreateCheckoutOptions, CheckoutSession, CreateSubscriptionOptions, Subscription, UpdateSubscriptionOptions, CreatePortalOptions, PortalSession, Product, Price, WebhookEvent } from '../types.js';
2
+ import '@parsrun/types';
3
+
4
+ /**
5
+ * @parsrun/payments - Paddle Provider
6
+ * Edge-compatible Paddle provider using fetch API (Paddle Billing API v2)
7
+ */
8
+
9
+ /**
10
+ * Paddle Payment Provider
11
+ * Edge-compatible using fetch API (Paddle Billing API v2)
12
+ *
13
+ * @example
14
+ * ```typescript
15
+ * const paddle = new PaddleProvider({
16
+ * apiKey: process.env.PADDLE_API_KEY,
17
+ * environment: 'sandbox', // or 'production'
18
+ * webhookSecret: process.env.PADDLE_WEBHOOK_SECRET,
19
+ * });
20
+ *
21
+ * const checkout = await paddle.createCheckout({
22
+ * lineItems: [{ priceId: 'pri_xxx', quantity: 1 }],
23
+ * successUrl: 'https://example.com/success',
24
+ * cancelUrl: 'https://example.com/cancel',
25
+ * mode: 'subscription',
26
+ * });
27
+ * ```
28
+ */
29
+ declare class PaddleProvider implements PaymentProvider {
30
+ readonly type: "paddle";
31
+ private apiKey;
32
+ private webhookSecret;
33
+ private baseUrl;
34
+ constructor(config: PaddleProviderConfig);
35
+ private request;
36
+ createCustomer(options: CreateCustomerOptions): Promise<Customer>;
37
+ getCustomer(customerId: string): Promise<Customer | null>;
38
+ updateCustomer(customerId: string, options: Partial<CreateCustomerOptions>): Promise<Customer>;
39
+ deleteCustomer(_customerId: string): Promise<void>;
40
+ private mapCustomer;
41
+ createCheckout(options: CreateCheckoutOptions): Promise<CheckoutSession>;
42
+ getCheckout(sessionId: string): Promise<CheckoutSession | null>;
43
+ createSubscription(_options: CreateSubscriptionOptions): Promise<Subscription>;
44
+ getSubscription(subscriptionId: string): Promise<Subscription | null>;
45
+ updateSubscription(subscriptionId: string, options: UpdateSubscriptionOptions): Promise<Subscription>;
46
+ cancelSubscription(subscriptionId: string, cancelAtPeriodEnd?: boolean): Promise<Subscription>;
47
+ listSubscriptions(customerId: string): Promise<Subscription[]>;
48
+ private mapSubscription;
49
+ createPortalSession(options: CreatePortalOptions): Promise<PortalSession>;
50
+ getProduct(productId: string): Promise<Product | null>;
51
+ getPrice(priceId: string): Promise<Price | null>;
52
+ listPrices(productId?: string): Promise<Price[]>;
53
+ private mapProduct;
54
+ private mapPrice;
55
+ private parsePaddleAmount;
56
+ verifyWebhook(payload: string | Uint8Array, signature: string): Promise<WebhookEvent | null>;
57
+ private computeHmacSignature;
58
+ private secureCompare;
59
+ private mapEventType;
60
+ }
61
+ /**
62
+ * Create a Paddle provider
63
+ */
64
+ declare function createPaddleProvider(config: PaddleProviderConfig): PaddleProvider;
65
+
66
+ export { PaddleProvider, createPaddleProvider };