@verapay/verapay-js 1.3.0 → 2.0.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.
- package/README.md +70 -3
- package/dist/index.cjs +2 -2
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +17 -3
- package/dist/index.d.ts +17 -3
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -9,6 +9,7 @@ A simple, PCI-compliant TypeScript SDK for Stripe payment processing.
|
|
|
9
9
|
- **Customizable**: Flexible styling and layout options
|
|
10
10
|
- **Validation**: Built-in card validation and error handling
|
|
11
11
|
- **3D Secure**: Automatic 3D Secure (SCA) support
|
|
12
|
+
- **Card on File**: Save a card with `saveCard` and charge it later off-session
|
|
12
13
|
- **Extensible**: Plugin architecture for pre/post payment hooks
|
|
13
14
|
- **Tree-shakable**: ES Module format for optimal bundle sizes
|
|
14
15
|
|
|
@@ -84,13 +85,13 @@ const verapay = new VerapayClient({
|
|
|
84
85
|
});
|
|
85
86
|
```
|
|
86
87
|
|
|
87
|
-
If your Merchant account is associated with a Partner, include `
|
|
88
|
+
If your Merchant account is associated with a Partner, include `platformFee` — the partner's margin taken from the payment, which you are responsible for calculating. It must not exceed the payment `amount`. VeraPay's own fee is computed server-side from your partner pricing config and must not be passed here:
|
|
88
89
|
|
|
89
90
|
```typescript
|
|
90
91
|
const verapay = new VerapayClient({
|
|
91
92
|
apiKey: 'vpy_pk_test_...',
|
|
92
93
|
merchantId: 'your-merchant-id',
|
|
93
|
-
paymentData: { amount: 5000, currency: 'gbp',
|
|
94
|
+
paymentData: { amount: 5000, currency: 'gbp', platformFee: 250 },
|
|
94
95
|
});
|
|
95
96
|
|
|
96
97
|
await verapay.mountPaymentForm('#payment-form');
|
|
@@ -110,6 +111,57 @@ try {
|
|
|
110
111
|
}
|
|
111
112
|
```
|
|
112
113
|
|
|
114
|
+
## Saving Cards (Card on File)
|
|
115
|
+
|
|
116
|
+
Save a customer's card without charging it, then charge it later off-session from your backend. The card is collected and saved entirely through the SDK — your servers never touch raw card data.
|
|
117
|
+
|
|
118
|
+
### 1. Create a setup intent on your backend
|
|
119
|
+
|
|
120
|
+
Call `POST /v1/setup_intents` from your server (using your secret key) for a customer, and return the **wrapped** `clientSecret` (`vpy_cs_..._seti_..._secret_...`) to your frontend.
|
|
121
|
+
|
|
122
|
+
### 2. Collect and save the card
|
|
123
|
+
|
|
124
|
+
```typescript
|
|
125
|
+
import { VerapayClient, PaymentError } from '@verapay/verapay-js';
|
|
126
|
+
|
|
127
|
+
const verapay = new VerapayClient({
|
|
128
|
+
clientSecret: 'vpy_cs_test_seti_...', // from your backend
|
|
129
|
+
});
|
|
130
|
+
|
|
131
|
+
await verapay.initialize();
|
|
132
|
+
await verapay.mountPaymentForm('#card-form');
|
|
133
|
+
|
|
134
|
+
const result = await verapay.saveCard();
|
|
135
|
+
|
|
136
|
+
if (result.status === 'succeeded') {
|
|
137
|
+
// result.savedPaymentMethodId can be charged later, off-session
|
|
138
|
+
console.log('Card saved:', result.savedPaymentMethodId);
|
|
139
|
+
} else if (result.status === 'requires_action') {
|
|
140
|
+
// Non-terminal: the bank requires authentication. Re-mount on-session,
|
|
141
|
+
// or poll verapay.retrieveSetupIntent() after the customer completes 3-D Secure.
|
|
142
|
+
}
|
|
143
|
+
```
|
|
144
|
+
|
|
145
|
+
`saveCard()` returns a `SetupResult`:
|
|
146
|
+
|
|
147
|
+
```typescript
|
|
148
|
+
interface SetupResult {
|
|
149
|
+
success: boolean;
|
|
150
|
+
savedPaymentMethodId?: string;
|
|
151
|
+
setupIntentId: string;
|
|
152
|
+
status: 'succeeded' | 'processing' | 'requires_action' | 'failed';
|
|
153
|
+
error?: string;
|
|
154
|
+
}
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
> Unlike `PaymentResult`, `requires_action` is **not** collapsed into `processing` — it is returned as a distinct, non-terminal status so you can branch on it and poll `retrieveSetupIntent()`.
|
|
158
|
+
|
|
159
|
+
> **The saved card is persisted asynchronously.** Once `saveCard()` returns `succeeded`, the card is written by a `setup_intent.succeeded` webhook on the backend. It therefore appears in the customer's payment methods (`GET /v1/customers/{customerId}/payment_methods`) shortly after — not necessarily instantly. Make sure your webhook endpoint is configured, and treat the payment-methods list as eventually consistent.
|
|
160
|
+
|
|
161
|
+
### 3. Charge the saved card later (backend, off-session)
|
|
162
|
+
|
|
163
|
+
From your server, call `POST /v1/payment_intents` with `offSession: true` and the saved `customerId` (and optionally `paymentMethodId`). See the Verapay API reference for details.
|
|
164
|
+
|
|
113
165
|
## Test Mode
|
|
114
166
|
|
|
115
167
|
The SDK automatically detects the environment from your API key prefix — no flags needed:
|
|
@@ -475,7 +527,7 @@ new VerapayClient(config: VerapayConfig)
|
|
|
475
527
|
|---|---|---|---|
|
|
476
528
|
| `amount` | `number` | Yes | Amount in the smallest currency unit (e.g., pence for GBP) |
|
|
477
529
|
| `currency` | `string` | Yes | ISO 4217 currency code (e.g., `'gbp'`) |
|
|
478
|
-
| `
|
|
530
|
+
| `platformFee` | `number` | No | The partner's margin in the smallest currency unit, taken from the payment amount. Only applicable if your Merchant account is associated with a Partner — ignored otherwise. You are responsible for calculating this value. Must not exceed `amount`. VeraPay's own fee is computed server-side from your partner pricing config and must not be passed here. |
|
|
479
531
|
|
|
480
532
|
#### Methods
|
|
481
533
|
|
|
@@ -490,6 +542,9 @@ new VerapayClient(config: VerapayConfig)
|
|
|
490
542
|
| `confirmPayment()` | `Promise<PaymentResult>` | Confirm a backend-initialized payment |
|
|
491
543
|
| `retrievePaymentIntent()` | `Promise<PaymentResult>` | Retrieve the current status of the payment intent |
|
|
492
544
|
| `processPayment(request)` | `Promise<PaymentResult>` | Process the payment (works for both flow types) |
|
|
545
|
+
| `saveCard()` | `Promise<SetupResult>` | Save the entered card against a setup intent (no charge). Requires a setup-intent `clientSecret` |
|
|
546
|
+
| `retrieveSetupIntent()` | `Promise<SetupResult>` | Retrieve the current status of the setup intent (e.g. poll after `requires_action`) |
|
|
547
|
+
| `teardown()` | `void` | Unmount all elements and reset the client for re-initialization |
|
|
493
548
|
| `addExtension(extension)` | `void` | Register a payment lifecycle extension |
|
|
494
549
|
|
|
495
550
|
|
|
@@ -512,6 +567,18 @@ new VerapayClient(config: VerapayConfig)
|
|
|
512
567
|
| `paymentIntentId` | `string` | Stripe PaymentIntent ID |
|
|
513
568
|
| `error` | `string` | Error message if the payment failed |
|
|
514
569
|
|
|
570
|
+
#### SetupResult
|
|
571
|
+
|
|
572
|
+
Returned by `saveCard()` and `retrieveSetupIntent()`.
|
|
573
|
+
|
|
574
|
+
| Property | Type | Description |
|
|
575
|
+
|---|---|---|
|
|
576
|
+
| `success` | `boolean` | Whether the card was saved (`status === 'succeeded'`) |
|
|
577
|
+
| `status` | `'succeeded' \| 'processing' \| 'requires_action' \| 'failed'` | Setup status. `requires_action` is non-terminal — the customer must complete 3-D Secure |
|
|
578
|
+
| `savedPaymentMethodId` | `string` | ID of the saved payment method, chargeable off-session |
|
|
579
|
+
| `setupIntentId` | `string` | Stripe SetupIntent ID |
|
|
580
|
+
| `error` | `string` | Error message if the setup failed |
|
|
581
|
+
|
|
515
582
|
## License
|
|
516
583
|
|
|
517
584
|
Copyright © Lopay Ltd. All rights reserved.
|
package/dist/index.cjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';var stripeJs=require('@stripe/stripe-js'),tsMoney=require('ts-money');var a=class s extends Error{constructor(e,t="PAYMENT_FAILED",n){super(e),this.name="VerapayError",this.code=t,this.details={code:t,message:e,formattedMessage:this.formatMessage(e,t),...n},Error.captureStackTrace&&Error.captureStackTrace(this,s);}formatMessage(e,t){return {VALIDATION_ERROR:"Please check your payment information and try again.",PAYMENT_FAILED:"Your payment could not be processed. Please try again.",AUTHENTICATION_FAILED:"Payment authentication failed. Please try again.",NETWORK_ERROR:"Network error. Please check your connection and try again.",STRIPE_ERROR:"Payment service error. Please try again later.",CONFIGURATION_ERROR:"Configuration error. Please contact support.",CARD_DECLINED:"Your card was declined. Please use a different payment method.",INSUFFICIENT_FUNDS:"Insufficient funds. Please use a different payment method.",EXPIRED_CARD:"Your card has expired. Please use a different payment method."}[t]||e}toJSON(){return {name:this.name,code:this.code,message:this.message,details:this.details}}};var c=class extends a{constructor(e,t,n){super(e,"VALIDATION_ERROR",{field:t,metadata:n}),this.name="ValidationError";}};var m=class s extends a{constructor(e,t,n){let i=s.mapStripeCode(t);super(e,i,{stripeCode:t,metadata:n}),this.name="PaymentError";}static mapStripeCode(e){return e?{card_declined:"CARD_DECLINED",insufficient_funds:"INSUFFICIENT_FUNDS",expired_card:"EXPIRED_CARD",incorrect_cvc:"VALIDATION_ERROR",processing_error:"PAYMENT_FAILED",authentication_failed:"AUTHENTICATION_FAILED"}[e]||"PAYMENT_FAILED":"PAYMENT_FAILED"}};var y=class{static formatForUser(e){return "formattedMessage"in e?e.formattedMessage:"details"in e&&e.details&&typeof e.details=="object"&&"formattedMessage"in e.details&&typeof e.details.formattedMessage=="string"?e.details.formattedMessage:"An unexpected error occurred. Please try again."}static formatForDeveloper(e){return "code"in e&&"message"in e?`[${e.code}] ${e.message}`:e.message||"Unknown error"}static toJSON(e){return "toJSON"in e&&typeof e.toJSON=="function"?e.toJSON():{name:e.name||"Error",message:e.message,..."code"in e&&{code:e.code},..."details"in e&&{details:e.details}}}};var u=class{constructor(e){this.stripe=e;}async confirmPayment(e,t){let n=await this.stripe.confirmPayment({clientSecret:t,confirmParams:{payment_method:e,return_url:window.location.href},redirect:"if_required"});if(n.error)throw new m(n.error.message||"Payment failed",n.error.code);return n}async confirmCardPayment(e,t){let n=await this.stripe.confirmCardPayment(t,{payment_method:e});if(n.error)throw new m(n.error.message||"Payment failed",n.error.code);return n}async createPaymentMethod(e,t=false){let n;if(!t)n=await this.stripe.createPaymentMethod({elements:e});else {let r=(await e.getElement("address",{mode:"billing"}).getValue()).value;n=await this.stripe.createPaymentMethod({type:"card",card:e.getElement("cardNumber"),billing_details:{name:r.name,address:{...r.address,line2:r.address.line2??void 0}}});}if(n.error||!n.paymentMethod)throw new m(n.error?.message||"Failed to create payment method",n.error?.code);return n.paymentMethod.id}async retrievePaymentIntent(e){let t=await this.stripe.retrievePaymentIntent(e);if(t.error)throw new m(t.error.message||"Failed to retrieve payment intent",t.error.code);return t}};var d={showIcon:true,iconStyle:"solid",placeholders:{cardNumber:"1234 1234 1234 1234",cardExpiry:"MM / YY - TESTING",cardCvc:"CVC"},style:{base:{color:"#333333",fontFamily:"system-ui, -apple-system, sans-serif",fontSize:"16px","::placeholder":{color:"#aab7c4"}},complete:{color:"#333333"},empty:{},invalid:{color:"#df1b41"}}},w={cardNumber:"Card number",cardExpiry:"Expiry date",cardCvc:"CVC",address:"Address"},h=class{constructor(e,t,n){this.stripe=e;this.config=t;this.clientSecret=n;this.elements=null;this.mountedElements=new Map;this.elementStates=new Map;if(!n)throw new a("Client secret not initialized","CONFIGURATION_ERROR")}mountPaymentElement(e){if(!this.elements){let i={clientSecret:this.clientSecret,appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"};this.elements=this.stripe.elements(i);}if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let n=this.elements.create("payment",{layout:"tabs",wallets:{link:"never"}});n.mount(e),this.mountedElements.set("payment",n);}mountCardNumberElement(e){this.mountIndividualFormElement(e,"cardNumber",this.cardElementOptions("cardNumber"));}mountCardExpiryElement(e){this.mountIndividualFormElement(e,"cardExpiry",this.cardElementOptions("cardExpiry"));}mountCardCvcElement(e){this.mountIndividualFormElement(e,"cardCvc",this.cardElementOptions("cardCvc"));}mountAddressElement(e,t){this.mountIndividualFormElement(e,"address",{mode:t});}cardElementOptions(e){let{elementsConfig:t}=this.config,n={placeholder:t?.placeholders?.[e]??d.placeholders[e],style:{base:{...d.style.base,...t?.style?.base},complete:{...d.style.complete,...t?.style?.complete},empty:{...d.style.empty,...t?.style?.empty},invalid:{...d.style.invalid,...t?.style?.invalid}}};return e==="cardNumber"&&(n.showIcon=t?.showIcon??d.showIcon,n.iconStyle=t?.iconStyle??d.iconStyle),n}mountIndividualFormElement(e,t,n){if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let r=this.createIndividualFormElement(t,n);r.mount(e),this.mountedElements.set(t,r),this.trackElementState(t,r);}createIndividualFormElement(e,t){return this.elements||(this.elements=this.stripe.elements({appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"})),this.elements.create(e,t)}async validate(){let e=[];for(let[t,n]of this.elementStates.entries())n.complete||e.push({field:t,message:n.error??`${w[t]??t} failed validation`});return {isValid:e.length===0,errors:e}}getElements(){return this.elements}unmountAll(){for(let e of this.mountedElements.values())e.unmount();this.mountedElements.clear(),this.elementStates.clear();}trackElementState(e,t){this.elementStates.set(e,{complete:false});let n=i=>{this.elementStates.set(e,{complete:i.complete,error:i.error?.message});};t.on("change",n);}};var g=class{constructor(){this.extensions=[];}add(e){this.extensions.push(e);}async runBeforePayment(e){let t=e;for(let n of this.extensions)n.beforePayment&&(t=await n.beforePayment(t));return t}async runAfterPayment(e){await Promise.all(this.extensions.filter(t=>t.afterPayment).map(t=>t.afterPayment(e)));}async runOnError(e){await Promise.all(this.extensions.filter(t=>t.onPaymentError).map(t=>t.onPaymentError(e)));}};var f=class{constructor(e,t,n){this.stripeAdapter=e;this.elementsManager=t;this.verapayService=n;}async process(e,t){let n=this.elementsManager.getElements();await this.validatePaymentCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements);return await this.verapayService.processPrePayment({merchantId:t.merchantId,paymentIntentId:t.paymentIntentId,paymentMethodId:i,amount:t.amount,currency:t.currency,customerData:{email:e.customerEmail,firstName:e.customerFirstName,lastName:e.customerLastName},description:e.description,metadata:e.metadata}),this.confirm(t.clientSecret,{paymentMethodId:i,isUsingStripePaymentElement:t.isUsingStripePaymentElement,isUsingIndividualFormElements:t.isUsingIndividualFormElements})}async validatePaymentCanProceed(e,t){if(!e)throw new a("Payment form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of payment form in use");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}async confirm(e,t={}){let n;return t.isUsingStripePaymentElement?n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e):t.isUsingIndividualFormElements?n=await this.stripeAdapter.confirmCardPayment(t.paymentMethodId||"",e):n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e),this.formatPaymentResult(n)}async retrievePaymentIntent(e){let t=await this.stripeAdapter.retrievePaymentIntent(e);return this.formatPaymentResult(t)}formatPaymentResult(e){let t=e.paymentIntent,n="failed";return t.status==="succeeded"?n="succeeded":["processing","requires_action","requires_confirmation"].includes(t.status)&&(n="processing"),{success:t.status==="succeeded",paymentIntentId:t.id,status:n}}};var p=class{constructor(e,t){this.baseUrl=e,this.apiKey=t;}setApiKey(e){this.apiKey=e;}async getPaymentIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch provider config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async initialisePayment(e){let{merchantId:t,paymentData:n}=e;try{let i=await fetch(`${this.baseUrl}/api/initialise-payment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:t,paymentData:{...n,paymentMethodType:"card"}})});if(!i.ok){let o=await i.json().catch(()=>({}));throw new a(this.extractErrorMessage(o,i.status),"CONFIGURATION_ERROR")}let r=await i.json();if(!r.clientSecret||!r.paymentIntentId)throw new a("Missing clientSecret or paymentIntentId in server response","CONFIGURATION_ERROR");return {paymentIntentId:r.paymentIntentId,clientSecret:r.clientSecret,connectAccountId:r.connectAccountId,stripePublishableKey:r.stripePublishableKey}}catch(i){throw i instanceof a?i:new a(i instanceof Error?i.message:"Unknown error occurred","CONFIGURATION_ERROR")}}async processPrePayment(e){try{let t=await fetch(`${this.baseUrl}/api/process-prepayment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:e.merchantId,paymentIntentId:e.paymentIntentId,paymentMethodId:e.paymentMethodId,amount:e.amount,currency:e.currency,customerData:e.customerData,description:e.description,metadata:e.metadata})});if(!t.ok){let n=await t.json().catch(()=>({}));throw new a(this.extractErrorMessage(n,t.status),"CONFIGURATION_ERROR")}}catch(t){throw t instanceof a?t:new a(t instanceof Error?t.message:"Unknown error occurred","CONFIGURATION_ERROR")}}extractErrorMessage(e,t){if(!e||typeof e!="object")return `HTTP error! status: ${t}`;let n=e,i=[n.error,n.message,n.details];for(let r of i){if(typeof r=="string"&&r.trim().length>0)return r;if(r&&typeof r=="object")try{return JSON.stringify(r)}catch{}}return `HTTP error! status: ${t}`}};function R(s){return s.startsWith("vpy_cs_test_")?s.replace("vpy_cs_test_",""):s.startsWith("vpy_cs_live_")?s.replace("vpy_cs_live_",""):s}var E=class E{constructor(e){this.stripeAdapter=null;this.elementsManager=null;this.paymentService=null;this.initializationPromise=null;this.isUsingStripePaymentElement=false;this.isUsingIndividualFormElements=false;this.rawSecret=null;this.paymentIntentId=null;this.amount=null;this.currency=null;this.merchantId=null;if(!e.apiKey&&!e.clientSecret)throw new a("Either apiKey or clientSecret is required.","CONFIGURATION_ERROR");if(e.apiKey&&e.clientSecret)throw new a("Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.","CONFIGURATION_ERROR");e.apiKey&&!e.apiKey.includes("_pk_")&&typeof window<"u"&&console.warn("Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead."),this.config=e;let t=this.config.apiUrlOverride||E.BACKEND_URL;this.verapayService=new p(t,this.config.apiKey||""),this.extensionsManager=new g;}async initialize(){return this.initializationPromise?this.initializationPromise:(this.initializationPromise=(async()=>{let e,t,n;if(this.config.clientSecret){let r=await this.verapayService.getPaymentIntentConfig(this.config.clientSecret);e=this.config.clientSecret,t=r.paymentIntentId,n=r.publishableKey,this.amount=r.amount,this.currency=r.currency,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {this.validatePaymentInitialisation();let r=await this.verapayService.initialisePayment({merchantId:this.config.merchantId??"",paymentData:this.config.paymentData});e=r.clientSecret,t=r.paymentIntentId,n=r.stripePublishableKey,this.amount=this.config.paymentData.amount,this.currency=this.config.paymentData.currency,this.merchantId=this.config.merchantId??"";}this.rawSecret=R(e),this.paymentIntentId=t;let i=await stripeJs.loadStripe(n);if(!i)throw new a("Failed to load Stripe","CONFIGURATION_ERROR");this.stripeAdapter=new u(i),this.elementsManager=new h(i,this.config,this.rawSecret),this.paymentService=new f(this.stripeAdapter,this.elementsManager,this.verapayService);})().catch(e=>{throw this.initializationPromise=null,e}),this.initializationPromise)}async confirmPayment(){return await this.ensureInitialized(),this.paymentService.confirm(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}async retrievePaymentIntent(){return await this.ensureInitialized(),this.paymentService.retrievePaymentIntent(this.rawSecret)}async processPayment(e){await this.ensureInitialized();let t=await this.extensionsManager.runBeforePayment(e);try{let n=await this.paymentService.process(t,{merchantId:this.merchantId,paymentIntentId:this.paymentIntentId,clientSecret:this.rawSecret,amount:this.amount,currency:this.currency,isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements});return await this.extensionsManager.runAfterPayment(n),n}catch(n){throw await this.extensionsManager.runOnError(n),this.handlePaymentError(n)}}async mountPaymentForm(e){await this.ensureInitialized(),this.elementsManager.mountPaymentElement(e),this.isUsingStripePaymentElement=true;}async mountCardNumber(e){await this.ensureInitialized(),this.elementsManager.mountCardNumberElement(e),this.isUsingIndividualFormElements=true;}async mountCardExpiry(e){await this.ensureInitialized(),this.elementsManager.mountCardExpiryElement(e),this.isUsingIndividualFormElements=true;}async mountCardCvc(e){await this.ensureInitialized(),this.elementsManager.mountCardCvcElement(e),this.isUsingIndividualFormElements=true;}async mountAddress(e,t){await this.ensureInitialized(),this.elementsManager.mountAddressElement(e,t),this.isUsingIndividualFormElements=true;}addExtension(e){this.extensionsManager.add(e);}async ensureInitialized(){this.stripeAdapter||await this.initialize();}validatePaymentInitialisation(){if(!this.config.paymentData)throw new a("paymentData is required for frontend-initialized flows.","CONFIGURATION_ERROR");let{amount:e,currency:t,partnerFee:n}=this.config.paymentData;if(!t)throw new c("Currency is required","currency");let i=t.toUpperCase(),r=this.toMoney(e,i,"amount");if(r.isZero()||r.isNegative())throw new c("Amount must be greater than 0","amount");if(n!==void 0){let o=this.toMoney(n,i,"partnerFee");if(o.isNegative())throw new c("partnerFee cannot be negative","partnerFee");if(o.greaterThan(r))throw new c("partnerFee cannot exceed the payment amount","partnerFee")}}toMoney(e,t,n){try{return tsMoney.Money.fromInteger(e,t)}catch{throw new c(`${n} must be an integer in the smallest currency unit (e.g., cents for USD)`,n)}}handlePaymentError(e){if(e instanceof a)return e;let t=e instanceof Error?e.message:"Payment failed",n=e?.code;return new m(t,n)}};E.BACKEND_URL="https://api.verapay.app";var v=E;var I=class{validateCardNumber(e){let t=e.replace(/\D/g,"");if(t.length<13||t.length>19)return false;let n=0,i=false;for(let r=t.length-1;r>=0;r--){let o=parseInt(t[r],10);i&&(o*=2,o>9&&(o-=9)),n+=o,i=!i;}return n%10===0}detectCardType(e){let t=e.replace(/\D/g,"");return /^4/.test(t)?"visa":/^5[1-5]/.test(t)?"mastercard":/^3[47]/.test(t)?"amex":/^6(?:011|5)/.test(t)?"discover":"unknown"}validateExpiry(e,t){let n=new Date,i=n.getFullYear(),r=n.getMonth()+1;if(e<1||e>12)return false;let o=t<100?2e3+t:t;return !(o<i||o===i&&e<r)}validateCVC(e,t="unknown"){let n=e.replace(/\D/g,"");return t==="amex"?n.length===4:n.length===3||n.length===4}validateAll(e,t,n,i){let r=this.detectCardType(e);return {number:{isValid:this.validateCardNumber(e),cardType:r},expiry:{isValid:this.validateExpiry(t,n),month:t,year:n},cvc:{isValid:this.validateCVC(i,r),length:i.replace(/\D/g,"").length}}}};var P=class{static sanitizeCardNumber(e){return e.replace(/\D/g,"")}static formatCardNumber(e){return this.sanitizeCardNumber(e).replace(/(\d{4})/g,"$1 ").trim()}static sanitizeCVC(e){return e.replace(/\D/g,"").slice(0,4)}static sanitizeExpiry(e){let t=e.replace(/\D/g,"");return t.length===4?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,4),10)}:t.length===6?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,6),10)}:null}};var fe="1.1.0";
|
|
2
|
-
exports.CardValidator=
|
|
1
|
+
'use strict';var stripeJs=require('@stripe/stripe-js'),tsMoney=require('ts-money');var a=class s extends Error{constructor(e,t="PAYMENT_FAILED",n){super(e),this.name="VerapayError",this.code=t,this.details={code:t,message:e,formattedMessage:this.formatMessage(e,t),...n},Error.captureStackTrace&&Error.captureStackTrace(this,s);}formatMessage(e,t){return {VALIDATION_ERROR:"Please check your payment information and try again.",PAYMENT_FAILED:"Your payment could not be processed. Please try again.",AUTHENTICATION_FAILED:"Payment authentication failed. Please try again.",NETWORK_ERROR:"Network error. Please check your connection and try again.",STRIPE_ERROR:"Payment service error. Please try again later.",CONFIGURATION_ERROR:"Configuration error. Please contact support.",CARD_DECLINED:"Your card was declined. Please use a different payment method.",INSUFFICIENT_FUNDS:"Insufficient funds. Please use a different payment method.",EXPIRED_CARD:"Your card has expired. Please use a different payment method."}[t]||e}toJSON(){return {name:this.name,code:this.code,message:this.message,details:this.details}}};var l=class extends a{constructor(e,t,n){super(e,"VALIDATION_ERROR",{field:t,metadata:n}),this.name="ValidationError";}};var o=class s extends a{constructor(e,t,n){let i=s.mapStripeCode(t);super(e,i,{stripeCode:t,metadata:n}),this.name="PaymentError";}static mapStripeCode(e){return e?{card_declined:"CARD_DECLINED",insufficient_funds:"INSUFFICIENT_FUNDS",expired_card:"EXPIRED_CARD",incorrect_cvc:"VALIDATION_ERROR",processing_error:"PAYMENT_FAILED",authentication_failed:"AUTHENTICATION_FAILED"}[e]||"PAYMENT_FAILED":"PAYMENT_FAILED"}};var u=class{static formatForUser(e){return "formattedMessage"in e?e.formattedMessage:"details"in e&&e.details&&typeof e.details=="object"&&"formattedMessage"in e.details&&typeof e.details.formattedMessage=="string"?e.details.formattedMessage:"An unexpected error occurred. Please try again."}static formatForDeveloper(e){return "code"in e&&"message"in e?`[${e.code}] ${e.message}`:e.message||"Unknown error"}static toJSON(e){return "toJSON"in e&&typeof e.toJSON=="function"?e.toJSON():{name:e.name||"Error",message:e.message,..."code"in e&&{code:e.code},..."details"in e&&{details:e.details}}}};var y=class{constructor(e){this.stripe=e;}async confirmPayment(e,t){let n=await this.stripe.confirmPayment({clientSecret:t,confirmParams:{payment_method:e,return_url:window.location.href},redirect:"if_required"});if(n.error)throw new o(n.error.message||"Payment failed",n.error.code);return n}async confirmCardPayment(e,t){let n=await this.stripe.confirmCardPayment(t,{payment_method:e});if(n.error)throw new o(n.error.message||"Payment failed",n.error.code);return n}async createPaymentMethod(e,t=false){let n;if(!t)n=await this.stripe.createPaymentMethod({elements:e});else {let r=(await e.getElement("address",{mode:"billing"}).getValue()).value;n=await this.stripe.createPaymentMethod({type:"card",card:e.getElement("cardNumber"),billing_details:{name:r.name,address:{...r.address,line2:r.address.line2??void 0}}});}if(n.error||!n.paymentMethod)throw new o(n.error?.message||"Failed to create payment method",n.error?.code);return n.paymentMethod.id}async retrievePaymentIntent(e){let t=await this.stripe.retrievePaymentIntent(e);if(t.error)throw new o(t.error.message||"Failed to retrieve payment intent",t.error.code);return t}async confirmCardSetup(e,t){let n=await this.stripe.confirmCardSetup(t,{payment_method:e});if(n.error)throw new o(n.error.message||"Card setup failed",n.error.code);return n}async retrieveSetupIntent(e){let t=await this.stripe.retrieveSetupIntent(e);if(t.error)throw new o(t.error.message||"Failed to retrieve setup intent",t.error.code);return t}};var p={showIcon:true,iconStyle:"solid",placeholders:{cardNumber:"1234 1234 1234 1234",cardExpiry:"MM / YY - TESTING",cardCvc:"CVC"},style:{base:{color:"#333333",fontFamily:"system-ui, -apple-system, sans-serif",fontSize:"16px","::placeholder":{color:"#aab7c4"}},complete:{color:"#333333"},empty:{},invalid:{color:"#df1b41"}}},S={cardNumber:"Card number",cardExpiry:"Expiry date",cardCvc:"CVC",address:"Address"},h=class{constructor(e,t,n){this.stripe=e;this.config=t;this.clientSecret=n;this.elements=null;this.mountedElements=new Map;this.elementStates=new Map;if(!n)throw new a("Client secret not initialized","CONFIGURATION_ERROR")}mountPaymentElement(e){if(!this.elements){let i={clientSecret:this.clientSecret,appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"};this.elements=this.stripe.elements(i);}if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let n=this.elements.create("payment",{layout:"tabs",wallets:{link:"never"}});n.mount(e),this.mountedElements.set("payment",n);}mountCardNumberElement(e){this.mountIndividualFormElement(e,"cardNumber",this.cardElementOptions("cardNumber"));}mountCardExpiryElement(e){this.mountIndividualFormElement(e,"cardExpiry",this.cardElementOptions("cardExpiry"));}mountCardCvcElement(e){this.mountIndividualFormElement(e,"cardCvc",this.cardElementOptions("cardCvc"));}mountAddressElement(e,t){this.mountIndividualFormElement(e,"address",{mode:t});}cardElementOptions(e){let{elementsConfig:t}=this.config,n={placeholder:t?.placeholders?.[e]??p.placeholders[e],style:{base:{...p.style.base,...t?.style?.base},complete:{...p.style.complete,...t?.style?.complete},empty:{...p.style.empty,...t?.style?.empty},invalid:{...p.style.invalid,...t?.style?.invalid}}};return e==="cardNumber"&&(n.showIcon=t?.showIcon??p.showIcon,n.iconStyle=t?.iconStyle??p.iconStyle),n}mountIndividualFormElement(e,t,n){if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let r=this.createIndividualFormElement(t,n);r.mount(e),this.mountedElements.set(t,r),this.trackElementState(t,r);}createIndividualFormElement(e,t){return this.elements||(this.elements=this.stripe.elements({appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"})),this.elements.create(e,t)}async validate(){let e=[];for(let[t,n]of this.elementStates.entries())n.complete||e.push({field:t,message:n.error??`${S[t]??t} failed validation`});return {isValid:e.length===0,errors:e}}getElements(){return this.elements}unmountAll(){for(let e of this.mountedElements.values())e.unmount();this.mountedElements.clear(),this.elementStates.clear();}trackElementState(e,t){this.elementStates.set(e,{complete:false});let n=i=>{this.elementStates.set(e,{complete:i.complete,error:i.error?.message});};t.on("change",n);}};var f=class{constructor(){this.extensions=[];}add(e){this.extensions.push(e);}async runBeforePayment(e){let t=e;for(let n of this.extensions)n.beforePayment&&(t=await n.beforePayment(t));return t}async runAfterPayment(e){await Promise.all(this.extensions.filter(t=>t.afterPayment).map(t=>t.afterPayment(e)));}async runOnError(e){await Promise.all(this.extensions.filter(t=>t.onPaymentError).map(t=>t.onPaymentError(e)));}};var g=class{constructor(e,t,n){this.stripeAdapter=e;this.elementsManager=t;this.verapayService=n;}async process(e,t){let n=this.elementsManager.getElements();await this.validatePaymentCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements);return await this.verapayService.processPrePayment({merchantId:t.merchantId,paymentIntentId:t.paymentIntentId,paymentMethodId:i,amount:t.amount,currency:t.currency,customerData:{email:e.customerEmail,firstName:e.customerFirstName,lastName:e.customerLastName},description:e.description,metadata:e.metadata}),this.confirm(t.clientSecret,{paymentMethodId:i,isUsingStripePaymentElement:t.isUsingStripePaymentElement,isUsingIndividualFormElements:t.isUsingIndividualFormElements})}async validatePaymentCanProceed(e,t){if(!e)throw new a("Payment form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of payment form in use");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}async confirm(e,t={}){let n;return t.isUsingStripePaymentElement?n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e):t.isUsingIndividualFormElements?n=await this.stripeAdapter.confirmCardPayment(t.paymentMethodId||"",e):n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e),this.formatPaymentResult(n)}async retrievePaymentIntent(e){let t=await this.stripeAdapter.retrievePaymentIntent(e);return this.formatPaymentResult(t)}formatPaymentResult(e){let t=e.paymentIntent,n="failed";return t.status==="succeeded"?n="succeeded":["processing","requires_action","requires_confirmation"].includes(t.status)&&(n="processing"),{success:t.status==="succeeded",paymentIntentId:t.id,status:n}}};var I=class{constructor(e,t){this.stripeAdapter=e;this.elementsManager=t;}async save(e,t){let n=this.elementsManager.getElements();await this.validateSetupCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements),r=await this.stripeAdapter.confirmCardSetup(i,e);return this.formatSetupResult(r)}async retrieve(e){let t=await this.stripeAdapter.retrieveSetupIntent(e);return this.formatSetupResult(t)}async validateSetupCanProceed(e,t){if(!e)throw new a("Card form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of card form in use","CONFIGURATION_ERROR");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}formatSetupResult(e){let t=e.setupIntent,n="failed";t.status==="succeeded"?n="succeeded":t.status==="processing"?n="processing":(t.status==="requires_action"||t.status==="requires_confirmation")&&(n="requires_action");let i=t.payment_method,r=typeof i=="string"?i:i?.id;return {success:t.status==="succeeded",savedPaymentMethodId:r,setupIntentId:t.id,status:n}}};var d=class{constructor(e,t){this.baseUrl=e,this.apiKey=t;}setApiKey(e){this.apiKey=e;}async getPaymentIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch provider config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async getSetupIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/setup_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch setup config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async initialisePayment(e){let{merchantId:t,paymentData:n}=e;try{let i=await fetch(`${this.baseUrl}/api/initialise-payment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:t,paymentData:{...n,paymentMethodType:"card"}})});if(!i.ok){let m=await i.json().catch(()=>({}));throw new a(this.extractErrorMessage(m,i.status),"CONFIGURATION_ERROR")}let r=await i.json();if(!r.clientSecret||!r.paymentIntentId)throw new a("Missing clientSecret or paymentIntentId in server response","CONFIGURATION_ERROR");return {paymentIntentId:r.paymentIntentId,clientSecret:r.clientSecret,connectAccountId:r.connectAccountId,stripePublishableKey:r.stripePublishableKey}}catch(i){throw i instanceof a?i:new a(i instanceof Error?i.message:"Unknown error occurred","CONFIGURATION_ERROR")}}async processPrePayment(e){try{let t=await fetch(`${this.baseUrl}/api/process-prepayment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:e.merchantId,paymentIntentId:e.paymentIntentId,paymentMethodId:e.paymentMethodId,amount:e.amount,currency:e.currency,customerData:e.customerData,description:e.description,metadata:e.metadata})});if(!t.ok){let n=await t.json().catch(()=>({}));throw new a(this.extractErrorMessage(n,t.status),"CONFIGURATION_ERROR")}}catch(t){throw t instanceof a?t:new a(t instanceof Error?t.message:"Unknown error occurred","CONFIGURATION_ERROR")}}extractErrorMessage(e,t){if(!e||typeof e!="object")return `HTTP error! status: ${t}`;let n=e,i=[n.error,n.message,n.details];for(let r of i){if(typeof r=="string"&&r.trim().length>0)return r;if(r&&typeof r=="object")try{return JSON.stringify(r)}catch{}}return `HTTP error! status: ${t}`}};function R(s){return s.startsWith("vpy_cs_test_")?s.replace("vpy_cs_test_",""):s.startsWith("vpy_cs_live_")?s.replace("vpy_cs_live_",""):s}var E=class E{constructor(e){this.stripeAdapter=null;this.elementsManager=null;this.paymentService=null;this.setupService=null;this.initializationPromise=null;this.isUsingStripePaymentElement=false;this.isUsingIndividualFormElements=false;this.intentKind="payment";this.rawSecret=null;this.paymentIntentId=null;this.amount=null;this.currency=null;this.merchantId=null;if(!e.apiKey&&!e.clientSecret)throw new a("Either apiKey or clientSecret is required.","CONFIGURATION_ERROR");if(e.apiKey&&e.clientSecret)throw new a("Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.","CONFIGURATION_ERROR");e.apiKey&&!e.apiKey.includes("_pk_")&&typeof window<"u"&&console.warn("Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead."),this.config=e;let t=this.config.apiUrlOverride||E.BACKEND_URL;this.verapayService=new d(t,this.config.apiKey||""),this.extensionsManager=new f;}async initialize(){return this.initializationPromise?this.initializationPromise:(this.initializationPromise=(async()=>{let e,t,n;if(this.config.clientSecret)if(this.intentKind=R(this.config.clientSecret).startsWith("seti_")?"setup":"payment",this.intentKind==="setup"){let r=await this.verapayService.getSetupIntentConfig(this.config.clientSecret);if(r.object!=="setup_intent_config")throw new a("Unexpected configuration returned for setup intent","CONFIGURATION_ERROR");e=this.config.clientSecret,t="",n=r.publishableKey,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {let r=await this.verapayService.getPaymentIntentConfig(this.config.clientSecret);e=this.config.clientSecret,t=r.paymentIntentId,n=r.publishableKey,this.amount=r.amount,this.currency=r.currency,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {this.validatePaymentInitialisation();let r=await this.verapayService.initialisePayment({merchantId:this.config.merchantId??"",paymentData:this.config.paymentData});e=r.clientSecret,t=r.paymentIntentId,n=r.stripePublishableKey,this.amount=this.config.paymentData.amount,this.currency=this.config.paymentData.currency,this.merchantId=this.config.merchantId??"";}this.rawSecret=R(e),this.paymentIntentId=t;let i=await stripeJs.loadStripe(n);if(!i)throw new a("Failed to load Stripe","CONFIGURATION_ERROR");this.stripeAdapter=new y(i),this.elementsManager=new h(i,this.config,this.rawSecret),this.paymentService=new g(this.stripeAdapter,this.elementsManager,this.verapayService),this.setupService=new I(this.stripeAdapter,this.elementsManager);})().catch(e=>{throw this.initializationPromise=null,e}),this.initializationPromise)}async confirmPayment(){return await this.ensureInitialized(),this.assertIntentKind("payment","confirmPayment"),this.paymentService.confirm(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}async saveCard(){await this.ensureInitialized(),this.assertIntentKind("setup","saveCard");try{return await this.setupService.save(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}catch(e){throw this.handlePaymentError(e)}}async retrieveSetupIntent(){return await this.ensureInitialized(),this.assertIntentKind("setup","retrieveSetupIntent"),this.setupService.retrieve(this.rawSecret)}teardown(){this.elementsManager?.unmountAll(),this.stripeAdapter=null,this.elementsManager=null,this.paymentService=null,this.setupService=null,this.initializationPromise=null,this.isUsingStripePaymentElement=false,this.isUsingIndividualFormElements=false,this.intentKind="payment",this.rawSecret=null,this.paymentIntentId=null,this.amount=null,this.currency=null,this.merchantId=null;}async retrievePaymentIntent(){return await this.ensureInitialized(),this.paymentService.retrievePaymentIntent(this.rawSecret)}async processPayment(e){await this.ensureInitialized(),this.assertIntentKind("payment","processPayment");let t=await this.extensionsManager.runBeforePayment(e);try{let n=await this.paymentService.process(t,{merchantId:this.merchantId,paymentIntentId:this.paymentIntentId,clientSecret:this.rawSecret,amount:this.amount,currency:this.currency,isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements});return await this.extensionsManager.runAfterPayment(n),n}catch(n){throw await this.extensionsManager.runOnError(n),this.handlePaymentError(n)}}async mountPaymentForm(e){await this.ensureInitialized(),this.elementsManager.mountPaymentElement(e),this.isUsingStripePaymentElement=true;}async mountCardNumber(e){await this.ensureInitialized(),this.elementsManager.mountCardNumberElement(e),this.isUsingIndividualFormElements=true;}async mountCardExpiry(e){await this.ensureInitialized(),this.elementsManager.mountCardExpiryElement(e),this.isUsingIndividualFormElements=true;}async mountCardCvc(e){await this.ensureInitialized(),this.elementsManager.mountCardCvcElement(e),this.isUsingIndividualFormElements=true;}async mountAddress(e,t){await this.ensureInitialized(),this.elementsManager.mountAddressElement(e,t),this.isUsingIndividualFormElements=true;}addExtension(e){this.extensionsManager.add(e);}async ensureInitialized(){this.stripeAdapter||await this.initialize();}assertIntentKind(e,t){if(this.intentKind!==e)throw new a(`${t} requires a ${e} intent client secret`,"CONFIGURATION_ERROR")}validatePaymentInitialisation(){if(!this.config.paymentData)throw new a("paymentData is required for frontend-initialized flows.","CONFIGURATION_ERROR");let{amount:e,currency:t,platformFee:n}=this.config.paymentData;if(!t)throw new l("Currency is required","currency");let i=t.toUpperCase(),r=this.toMoney(e,i,"amount");if(r.isZero()||r.isNegative())throw new l("Amount must be greater than 0","amount");if(n!==void 0){let m=this.toMoney(n,i,"platformFee");if(m.isNegative())throw new l("platformFee cannot be negative","platformFee");if(m.greaterThan(r))throw new l("platformFee cannot exceed the payment amount","platformFee")}}toMoney(e,t,n){try{return tsMoney.Money.fromInteger(e,t)}catch{throw new l(`${n} must be an integer in the smallest currency unit (e.g., cents for USD)`,n)}}handlePaymentError(e){if(e instanceof a)return e;let t=e instanceof Error?e.message:"Payment failed",n=e?.code;return new o(t,n)}};E.BACKEND_URL="https://api.verapay.app";var w=E;var P=class{validateCardNumber(e){let t=e.replace(/\D/g,"");if(t.length<13||t.length>19)return false;let n=0,i=false;for(let r=t.length-1;r>=0;r--){let m=parseInt(t[r],10);i&&(m*=2,m>9&&(m-=9)),n+=m,i=!i;}return n%10===0}detectCardType(e){let t=e.replace(/\D/g,"");return /^4/.test(t)?"visa":/^5[1-5]/.test(t)?"mastercard":/^3[47]/.test(t)?"amex":/^6(?:011|5)/.test(t)?"discover":"unknown"}validateExpiry(e,t){let n=new Date,i=n.getFullYear(),r=n.getMonth()+1;if(e<1||e>12)return false;let m=t<100?2e3+t:t;return !(m<i||m===i&&e<r)}validateCVC(e,t="unknown"){let n=e.replace(/\D/g,"");return t==="amex"?n.length===4:n.length===3||n.length===4}validateAll(e,t,n,i){let r=this.detectCardType(e);return {number:{isValid:this.validateCardNumber(e),cardType:r},expiry:{isValid:this.validateExpiry(t,n),month:t,year:n},cvc:{isValid:this.validateCVC(i,r),length:i.replace(/\D/g,"").length}}}};var v=class{static sanitizeCardNumber(e){return e.replace(/\D/g,"")}static formatCardNumber(e){return this.sanitizeCardNumber(e).replace(/(\d{4})/g,"$1 ").trim()}static sanitizeCVC(e){return e.replace(/\D/g,"").slice(0,4)}static sanitizeExpiry(e){let t=e.replace(/\D/g,"");return t.length===4?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,4),10)}:t.length===6?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,6),10)}:null}};var ve="1.4.0";
|
|
2
|
+
exports.CardValidator=P;exports.ErrorFormatter=u;exports.InputSanitizer=v;exports.PaymentError=o;exports.VERSION=ve;exports.ValidationError=l;exports.VerapayClient=w;exports.VerapayError=a;exports.VerapayService=d;//# sourceMappingURL=index.cjs.map
|
|
3
3
|
//# sourceMappingURL=index.cjs.map
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/errors/verapay-error.ts","../src/errors/validation-error.ts","../src/errors/payment-error.ts","../src/errors/error-formatter.ts","../src/client/stripe-adapter.ts","../src/client/elements-manager.ts","../src/client/payment-extensions-manager.ts","../src/services/payment-service.ts","../src/services/verapay-service.ts","../src/utils/secret.util.ts","../src/client/verapay-client.ts","../src/validation/card-validator.ts","../src/validation/input-sanitizer.ts","../src/index.ts"],"names":["VerapayError","_VerapayError","message","code","details","ValidationError","field","metadata","PaymentError","_PaymentError","stripeCode","ErrorFormatter","error","StripeAdapter","stripe","paymentMethodId","clientSecret","result","elements","isUsingIndividualFormElements","address","DEFAULT_CARD_ELEMENT_CONFIG","FIELD_LABELS","ElementsManager","config","selector","elementsConfig","element","mode","fieldType","options","formFieldType","elementType","errors","state","handleElementChange","event","PaymentExtensionsManager","extension","request","modifiedRequest","ext","PaymentService","stripeAdapter","elementsManager","verapayService","context","validation","paymentIntent","status","VerapayService","baseUrl","apiKey","response","merchantId","paymentData","errorData","data","record","candidates","candidate","unwrapClientSecret","wrappedSecret","_VerapayClient","backendUrl","paymentIntentId","stripePublishableKey","loadStripe","paymentResult","amount","currency","partnerFee","uppercaseCurrency","paymentAmount","partnerFeeAmount","value","fieldName","Money","VerapayClient","CardValidator","cardNumber","cleaned","sum","isEven","i","digit","month","year","now","currentYear","currentMonth","fullYear","cvc","cardType","expiryMonth","expiryYear","InputSanitizer","input","VERSION"],"mappings":"mFAGO,IAAMA,CAAAA,CAAN,MAAMC,UAAqB,KAAM,CAItC,YACEC,CAAAA,CACAC,CAAAA,CAAAA,gBAAAA,CACAC,EACA,CACA,KAAA,CAAMF,CAAO,CAAA,CACb,KAAK,IAAA,CAAO,cAAA,CACZ,IAAA,CAAK,IAAA,CAAOC,EACZ,IAAA,CAAK,OAAA,CAAU,CACb,IAAA,CAAAA,EACA,OAAA,CAAAD,CAAAA,CACA,iBAAkB,IAAA,CAAK,aAAA,CAAcA,EAASC,CAAI,CAAA,CAClD,GAAGC,CACL,EAEI,KAAA,CAAM,iBAAA,EACR,KAAA,CAAM,iBAAA,CAAkB,KAAMH,CAAY,EAE9C,CAEQ,aAAA,CAAcC,EAAiBC,CAAAA,CAAyB,CAsB9D,OArB8C,CAC3C,gBAAA,CACC,uDACD,cAAA,CACC,wDAAA,CACD,qBAAA,CACC,kDAAA,CACD,cACC,4DAAA,CACD,YAAA,CACC,gDAAA,CACD,mBAAA,CACC,+CACD,aAAA,CACC,gEAAA,CACD,kBAAA,CACC,4DAAA,CACD,aACC,+DACJ,CAAA,CAEkBA,CAAI,CAAA,EAAKD,CAC7B,CAEA,MAAA,EAAS,CACP,OAAO,CACL,KAAM,IAAA,CAAK,IAAA,CACX,IAAA,CAAM,IAAA,CAAK,KACX,OAAA,CAAS,IAAA,CAAK,OAAA,CACd,OAAA,CAAS,KAAK,OAChB,CACF,CACF,ECzDO,IAAMG,EAAN,cAA8BL,CAAa,CAChD,WAAA,CAAYE,EAAiBI,CAAAA,CAAgBC,CAAAA,CAAoC,CAE/E,KAAA,CAAML,qBAAqC,CACzC,KAAA,CAAAI,CAAAA,CACA,QAAA,CAAAC,CACF,CAAC,CAAA,CACD,KAAK,IAAA,CAAO,kBACd,CACF,ECTO,IAAMC,CAAAA,CAAN,MAAMC,UAAqBT,CAAa,CAC7C,WAAA,CACEE,CAAAA,CACAQ,EACAH,CAAAA,CACA,CACA,IAAMJ,CAAAA,CAAOM,EAAa,aAAA,CAAcC,CAAU,EAClD,KAAA,CAAMR,CAAAA,CAASC,EAAM,CACnB,UAAA,CAAAO,CAAAA,CACA,QAAA,CAAAH,CACF,CAAC,CAAA,CACD,IAAA,CAAK,IAAA,CAAO,eACd,CAEA,OAAe,aAAA,CAAcG,CAAAA,CAAgC,CAC3D,OAAKA,CAAAA,CAEsC,CACzC,aAAA,CAAA,eAAA,CACA,kBAAA,CAAA,oBAAA,CACA,4BACA,aAAA,CAAA,kBAAA,CACA,gBAAA,CAAA,gBAAA,CACA,qBAAA,CAAA,uBACF,CAAA,CAEeA,CAAU,CAAA,EAAK,gBAAA,CAAA,gBAChC,CACF,MC7BaC,CAAAA,CAAN,KAAqB,CAC1B,OAAO,cAAcC,CAAAA,CAAqC,CACxD,OAAI,kBAAA,GAAsBA,CAAAA,CACjBA,EAAM,gBAAA,CAGb,SAAA,GAAaA,CAAAA,EACbA,CAAAA,CAAM,SACN,OAAOA,CAAAA,CAAM,OAAA,EAAY,QAAA,EACzB,qBAAsBA,CAAAA,CAAM,OAAA,EAC5B,OAAOA,CAAAA,CAAM,QAAQ,gBAAA,EAAqB,QAAA,CAEnCA,EAAM,OAAA,CAAQ,gBAAA,CAEhB,iDACT,CAEA,OAAO,kBAAA,CAAmBA,CAAAA,CAAqC,CAC7D,OAAI,MAAA,GAAUA,CAAAA,EAAS,SAAA,GAAaA,EAC3B,CAAA,CAAA,EAAIA,CAAAA,CAAM,IAAI,CAAA,EAAA,EAAKA,EAAM,OAAO,CAAA,CAAA,CAElCA,EAAM,OAAA,EAAW,eAC1B,CAEA,OAAO,MAAA,CAAOA,CAAAA,CAAsD,CAElE,OAAI,QAAA,GAAYA,CAAAA,EAAS,OAAOA,CAAAA,CAAM,QAAW,UAAA,CACxCA,CAAAA,CAAM,MAAA,EAAO,CAGf,CACL,IAAA,CAAOA,CAAAA,CAAgB,MAAQ,OAAA,CAC/B,OAAA,CAASA,EAAM,OAAA,CACf,GAAI,MAAA,GAAUA,CAAAA,EAAS,CAAE,IAAA,CAAMA,CAAAA,CAAM,IAAK,CAAA,CAC1C,GAAI,SAAA,GAAaA,CAAAA,EAAS,CAAE,OAAA,CAASA,EAAM,OAAQ,CACrD,CACF,CACF,ECpCO,IAAMC,CAAAA,CAAN,KAAoB,CACzB,WAAA,CAAoBC,EAAgB,CAAhB,IAAA,CAAA,MAAA,CAAAA,EAAiB,CAErC,MAAM,cAAA,CACJC,CAAAA,CACAC,CAAAA,CAC2C,CAC3C,IAAMC,CAAAA,CAAS,MAAM,KAAK,MAAA,CAAO,cAAA,CAAe,CAC9C,YAAA,CAAAD,CAAAA,CACA,aAAA,CAAe,CACb,eAAgBD,CAAAA,CAChB,UAAA,CAAY,MAAA,CAAO,QAAA,CAAS,IAC9B,CAAA,CACA,QAAA,CAAU,aACZ,CAAC,EAED,GAAIE,CAAAA,CAAO,MACT,MAAM,IAAIT,EACRS,CAAAA,CAAO,KAAA,CAAM,OAAA,EAAW,gBAAA,CACxBA,EAAO,KAAA,CAAM,IACf,CAAA,CAGF,OAAOA,CACT,CAEA,MAAM,kBAAA,CACJF,CAAAA,CACAC,EAC2C,CAC3C,IAAMC,EAAS,MAAM,IAAA,CAAK,OAAO,kBAAA,CAAmBD,CAAAA,CAAc,CAChE,cAAA,CAAgBD,CAClB,CAAC,CAAA,CAED,GAAIE,CAAAA,CAAO,MACT,MAAM,IAAIT,CAAAA,CACRS,CAAAA,CAAO,MAAM,OAAA,EAAW,gBAAA,CACxBA,EAAO,KAAA,CAAM,IACf,EAGF,OAAOA,CACT,CAEA,MAAM,oBACJC,CAAAA,CACAC,CAAAA,CAAyC,KAAA,CACxB,CACjB,IAAIF,CAAAA,CAEJ,GAAI,CAACE,CAAAA,CACHF,EAAS,MAAM,IAAA,CAAK,OAAO,mBAAA,CAAoB,CAC7C,SAAAC,CACF,CAAC,CAAA,CAAA,KACI,CAIL,IAAME,CAAAA,CAAAA,CAFiB,MAAMF,CAAAA,CAAS,UAAA,CAAW,UAAW,CAAE,IAAA,CAAM,SAAU,CAAC,EAAG,QAAA,EAAS,EAE3D,MAEhCD,CAAAA,CAAS,MAAM,KAAK,MAAA,CAAO,mBAAA,CAAoB,CAC7C,IAAA,CAAM,OACN,IAAA,CAAMC,CAAAA,CAAS,UAAA,CAAW,YAAY,EACtC,eAAA,CAAiB,CACf,IAAA,CAAME,CAAAA,CAAQ,KACd,OAAA,CAAS,CACP,GAAGA,CAAAA,CAAQ,OAAA,CACX,MAAOA,CAAAA,CAAQ,OAAA,CAAQ,KAAA,EAAS,MAClC,CACF,CACF,CAAC,EACH,CAEA,GAAIH,CAAAA,CAAO,KAAA,EAAS,CAACA,CAAAA,CAAO,cAC1B,MAAM,IAAIT,EACRS,CAAAA,CAAO,KAAA,EAAO,SAAW,iCAAA,CACzBA,CAAAA,CAAO,KAAA,EAAO,IAChB,EAGF,OAAOA,CAAAA,CAAO,aAAA,CAAc,EAC9B,CAEA,MAAM,qBAAA,CACJD,CAAAA,CAC2C,CAC3C,IAAMC,CAAAA,CAAS,MAAM,KAAK,MAAA,CAAO,qBAAA,CAAsBD,CAAY,CAAA,CAEnE,GAAIC,CAAAA,CAAO,KAAA,CACT,MAAM,IAAIT,CAAAA,CACRS,CAAAA,CAAO,KAAA,CAAM,SAAW,mCAAA,CACxBA,CAAAA,CAAO,KAAA,CAAM,IACf,EAGF,OAAOA,CACT,CACF,CAAA,CCvFA,IAAMI,EAA8B,CAClC,QAAA,CAAU,IAAA,CACV,SAAA,CAAW,QACX,YAAA,CAAc,CACZ,UAAA,CAAY,qBAAA,CACZ,WAAY,mBAAA,CACZ,OAAA,CAAS,KACX,CAAA,CACA,MAAO,CACL,IAAA,CAAM,CACJ,KAAA,CAAO,SAAA,CACP,WAAY,sCAAA,CACZ,QAAA,CAAU,MAAA,CACV,eAAA,CAAiB,CAAE,KAAA,CAAO,SAAU,CACtC,CAAA,CACA,SAAU,CACR,KAAA,CAAO,SACT,CAAA,CACA,MAAO,EAAC,CACR,QAAS,CACP,KAAA,CAAO,SACT,CACF,CACF,CAAA,CAEMC,CAAAA,CAAuC,CAC3C,UAAA,CAAY,aAAA,CACZ,UAAA,CAAY,aAAA,CACZ,QAAS,KAAA,CACT,OAAA,CAAS,SACX,CAAA,CAEaC,EAAN,KAAsB,CAK3B,YACUT,CAAAA,CACAU,CAAAA,CACAR,EACR,CAHQ,IAAA,CAAA,MAAA,CAAAF,CAAAA,CACA,IAAA,CAAA,MAAA,CAAAU,EACA,IAAA,CAAA,YAAA,CAAAR,CAAAA,CAPV,IAAA,CAAQ,QAAA,CAAkC,KAC1C,IAAA,CAAQ,eAAA,CAA8C,IAAI,GAAA,CAC1D,KAAQ,aAAA,CAA2C,IAAI,IAOrD,GAAI,CAACA,EACH,MAAM,IAAIhB,CAAAA,CACR,+BAAA,CAAA,qBAEF,CAEJ,CAGA,mBAAA,CAAoByB,CAAAA,CAAwB,CAC1C,GAAI,CAAC,IAAA,CAAK,QAAA,CAAU,CAClB,IAAMC,CAAAA,CAAiB,CACrB,aAAc,IAAA,CAAK,YAAA,CACnB,WAAY,IAAA,CAAK,MAAA,CAAO,UAAA,CACxB,MAAA,CAAQ,KAAK,MAAA,CAAO,MAAA,CACpB,KAAA,CAAO,IAAA,CAAK,OAAO,KAAA,CACnB,qBAAA,CAAuB,QACzB,CAAA,CAEA,KAAK,QAAA,CAAW,IAAA,CAAK,OAAO,QAAA,CAASA,CAAc,EACrD,CAIA,GAAI,CAFc,QAAA,CAAS,cAAcD,CAAQ,CAAA,CAG/C,MAAM,IAAIzB,EACR,CAAA,mBAAA,EAAsByB,CAAQ,CAAA,CAAA,CAAA,qBAEhC,CAAA,CAGF,IAAME,CAAAA,CAAU,IAAA,CAAK,SAAS,MAAA,CAAO,SAAA,CAAW,CAC9C,MAAA,CAAQ,MAAA,CACR,OAAA,CAAS,CAAE,KAAM,OAAQ,CAC3B,CAAC,CAAA,CAEDA,EAAQ,KAAA,CAAMF,CAAQ,CAAA,CACtB,IAAA,CAAK,gBAAgB,GAAA,CAAI,SAAA,CAAWE,CAAO,EAC7C,CAEA,uBAAuBF,CAAAA,CAAwB,CAC7C,IAAA,CAAK,0BAAA,CAA2BA,EAAU,YAAA,CAAc,IAAA,CAAK,kBAAA,CAAmB,YAAY,CAAC,EAC/F,CAEA,sBAAA,CAAuBA,CAAAA,CAAwB,CAC7C,IAAA,CAAK,0BAAA,CAA2BA,EAAU,YAAA,CAAc,IAAA,CAAK,mBAAmB,YAAY,CAAC,EAC/F,CAEA,oBAAoBA,CAAAA,CAAwB,CAC1C,IAAA,CAAK,0BAAA,CAA2BA,EAAU,SAAA,CAAW,IAAA,CAAK,kBAAA,CAAmB,SAAS,CAAC,EACzF,CAEA,oBAAoBA,CAAAA,CAAkBG,CAAAA,CAAoC,CACxE,IAAA,CAAK,0BAAA,CAA2BH,CAAAA,CAAU,SAAA,CAAW,CAAE,IAAA,CAAAG,CAAK,CAAC,EAC/D,CAEQ,kBAAA,CAAmBC,CAAAA,CAA6E,CACtG,GAAM,CAAE,cAAA,CAAAH,CAAe,EAAI,IAAA,CAAK,MAAA,CAC1BI,EAAmC,CACvC,WAAA,CAAaJ,CAAAA,EAAgB,YAAA,GAAeG,CAAS,CAAA,EAAKR,CAAAA,CAA4B,YAAA,CAAaQ,CAAS,EAC5G,KAAA,CAAO,CACL,IAAA,CAAM,CAAE,GAAGR,CAAAA,CAA4B,KAAA,CAAM,KAAM,GAAGK,CAAAA,EAAgB,OAAO,IAAK,CAAA,CAClF,QAAA,CAAU,CAAE,GAAGL,CAAAA,CAA4B,KAAA,CAAM,QAAA,CAAU,GAAGK,GAAgB,KAAA,EAAO,QAAS,CAAA,CAC9F,KAAA,CAAO,CAAE,GAAGL,CAAAA,CAA4B,MAAM,KAAA,CAAO,GAAGK,GAAgB,KAAA,EAAO,KAAM,CAAA,CACrF,OAAA,CAAS,CAAE,GAAGL,CAAAA,CAA4B,KAAA,CAAM,OAAA,CAAS,GAAGK,CAAAA,EAAgB,KAAA,EAAO,OAAQ,CAC7F,CACF,CAAA,CAEA,OAAIG,IAAc,YAAA,GAChBC,CAAAA,CAAQ,SAAWJ,CAAAA,EAAgB,QAAA,EAAYL,CAAAA,CAA4B,QAAA,CAC3ES,EAAQ,SAAA,CAAYJ,CAAAA,EAAgB,SAAA,EAAaL,CAAAA,CAA4B,WAGxES,CACT,CAEQ,0BAAA,CAA2BL,CAAAA,CAAkBM,EAAoED,CAAAA,CAAoC,CAG3J,GAAI,CAFc,QAAA,CAAS,cAAcL,CAAQ,CAAA,CAG/C,MAAM,IAAIzB,EACR,CAAA,mBAAA,EAAsByB,CAAQ,CAAA,CAAA,CAAA,qBAEhC,CAAA,CAGF,IAAME,CAAAA,CAAU,IAAA,CAAK,2BAAA,CAA4BI,CAAAA,CAAeD,CAAO,CAAA,CACvEH,CAAAA,CAAQ,MAAMF,CAAQ,CAAA,CAEtB,KAAK,eAAA,CAAgB,GAAA,CAAIM,CAAAA,CAAeJ,CAAO,EAC/C,IAAA,CAAK,iBAAA,CAAkBI,CAAAA,CAAeJ,CAAO,EAC/C,CAEQ,2BAAA,CACNK,CAAAA,CACAF,CAAAA,CACe,CACf,OAAK,IAAA,CAAK,WACR,IAAA,CAAK,QAAA,CAAW,KAAK,MAAA,CAAO,QAAA,CAAS,CACnC,UAAA,CAAY,KAAK,MAAA,CAAO,UAAA,CACxB,MAAA,CAAQ,IAAA,CAAK,OAAO,MAAA,CACpB,KAAA,CAAO,IAAA,CAAK,MAAA,CAAO,MACnB,qBAAA,CAAuB,QACzB,CAAC,CAAA,CAAA,CAGI,IAAA,CAAK,SAAS,MAAA,CAAOE,CAAAA,CAA6BF,CAAO,CAClE,CAIA,MAAM,QAAA,EAAsC,CAC1C,IAAMG,EAA4B,EAAC,CAEnC,IAAA,GAAW,CAAC3B,EAAO4B,CAAK,CAAA,GAAK,KAAK,aAAA,CAAc,OAAA,GACzCA,CAAAA,CAAM,QAAA,EACTD,CAAAA,CAAO,IAAA,CAAK,CACV,KAAA,CAAA3B,CAAAA,CACA,OAAA,CAAS4B,CAAAA,CAAM,OAAS,CAAA,EAAGZ,CAAAA,CAAahB,CAAK,CAAA,EAAKA,CAAK,CAAA,kBAAA,CACzD,CAAC,EAIL,OAAO,CAAE,QAAS2B,CAAAA,CAAO,MAAA,GAAW,CAAA,CAAG,MAAA,CAAAA,CAAO,CAChD,CAEA,WAAA,EAAqC,CACnC,OAAO,IAAA,CAAK,QACd,CAEA,UAAA,EAAmB,CACjB,IAAA,IAAWN,CAAAA,IAAW,KAAK,eAAA,CAAgB,MAAA,GACzCA,CAAAA,CAAQ,OAAA,EAAQ,CAElB,IAAA,CAAK,gBAAgB,KAAA,EAAM,CAC3B,IAAA,CAAK,aAAA,CAAc,QACrB,CAEQ,iBAAA,CAAkBrB,CAAAA,CAAeqB,EAA8B,CACrE,IAAA,CAAK,cAAc,GAAA,CAAIrB,CAAAA,CAAO,CAAE,QAAA,CAAU,KAAM,CAAC,CAAA,CAEjD,IAAM6B,CAAAA,CAAuBC,CAAAA,EAA8D,CACzF,IAAA,CAAK,cAAc,GAAA,CAAI9B,CAAAA,CAAO,CAAE,QAAA,CAAU8B,EAAM,QAAA,CAAU,KAAA,CAAOA,EAAM,KAAA,EAAO,OAAQ,CAAC,EACzF,CAAA,CAECT,CAAAA,CAAsF,EAAA,CACrF,SACAQ,CACF,EACF,CACF,CAAA,CC1MO,IAAME,CAAAA,CAAN,KAA+B,CAA/B,WAAA,EAAA,CACL,KAAQ,UAAA,CAAiC,IAEzC,GAAA,CAAIC,CAAAA,CAAmC,CACrC,IAAA,CAAK,UAAA,CAAW,IAAA,CAAKA,CAAS,EAChC,CAEA,MAAM,gBAAA,CAAiBC,CAAAA,CAAgE,CACrF,IAAIC,CAAAA,CAAkBD,CAAAA,CACtB,IAAA,IAAWE,KAAO,IAAA,CAAK,UAAA,CACjBA,EAAI,aAAA,GACND,CAAAA,CAAkB,MAAMC,CAAAA,CAAI,aAAA,CAAcD,CAAe,CAAA,CAAA,CAG7D,OAAOA,CACT,CAEA,MAAM,eAAA,CAAgBvB,EAAsC,CAC1D,MAAM,OAAA,CAAQ,GAAA,CACZ,KAAK,UAAA,CACF,MAAA,CAAQwB,GAAQA,CAAAA,CAAI,YAAY,EAChC,GAAA,CAAKA,CAAAA,EAAQA,CAAAA,CAAI,YAAA,CAAcxB,CAAM,CAAC,CAC3C,EACF,CAEA,MAAM,UAAA,CAAWL,CAAAA,CAA6B,CAC5C,MAAM,QAAQ,GAAA,CACZ,IAAA,CAAK,WACF,MAAA,CAAQ6B,CAAAA,EAAQA,EAAI,cAAc,CAAA,CAClC,GAAA,CAAKA,CAAAA,EAAQA,EAAI,cAAA,CAAgB7B,CAAK,CAAC,CAC5C,EACF,CACF,CAAA,CClBO,IAAM8B,CAAAA,CAAN,KAAqB,CAC1B,WAAA,CACUC,EACAC,CAAAA,CACAC,CAAAA,CACR,CAHQ,IAAA,CAAA,aAAA,CAAAF,CAAAA,CACA,IAAA,CAAA,eAAA,CAAAC,CAAAA,CACA,oBAAAC,EACP,CAEH,MAAM,OAAA,CAAQN,EAAgCO,CAAAA,CAAwD,CACpG,IAAM5B,CAAAA,CAAW,KAAK,eAAA,CAAgB,WAAA,GAEtC,MAAM,IAAA,CAAK,0BAA0BA,CAAAA,CAAU4B,CAAO,CAAA,CAEtD,MAAM5B,EAAU,MAAA,EAAO,CAEvB,IAAMH,CAAAA,CAAkB,MAAM,IAAA,CAAK,aAAA,CAAc,mBAAA,CAC/CG,CAAAA,CACA4B,EAAQ,6BACV,CAAA,CAEA,aAAM,IAAA,CAAK,cAAA,CAAe,kBAAkB,CAC1C,UAAA,CAAYA,CAAAA,CAAQ,UAAA,CACpB,gBAAiBA,CAAAA,CAAQ,eAAA,CACzB,eAAA,CAAA/B,CAAAA,CACA,OAAQ+B,CAAAA,CAAQ,MAAA,CAChB,QAAA,CAAUA,CAAAA,CAAQ,SAClB,YAAA,CAAc,CACZ,MAAOP,CAAAA,CAAQ,aAAA,CACf,UAAWA,CAAAA,CAAQ,iBAAA,CACnB,QAAA,CAAUA,CAAAA,CAAQ,gBACpB,CAAA,CACA,WAAA,CAAaA,CAAAA,CAAQ,WAAA,CACrB,SAAUA,CAAAA,CAAQ,QACpB,CAAC,CAAA,CAEM,KAAK,OAAA,CAAQO,CAAAA,CAAQ,aAAc,CACxC,eAAA,CAAA/B,EACA,2BAAA,CAA6B+B,CAAAA,CAAQ,2BAAA,CACrC,6BAAA,CAA+BA,EAAQ,6BACzC,CAAC,CACH,CAEA,MAAc,yBAAA,CACZ5B,CAAAA,CACA4B,CAAAA,CACA,CACA,GAAI,CAAC5B,CAAAA,CACH,MAAM,IAAIlB,CAAAA,CAAa,gDAAyD,CAAA,CAGlF,GAAI8C,CAAAA,CAAQ,2BAAA,EAA+BA,EAAQ,6BAAA,CACjD,MAAM,IAAI9C,CAAAA,CAAa,mCAAmC,CAAA,CAG5D,GAAI8C,CAAAA,CAAQ,6BAAA,CAA+B,CACzC,IAAMC,CAAAA,CAAa,MAAM,IAAA,CAAK,eAAA,CAAgB,UAAS,CACvD,GAAI,CAACA,CAAAA,CAAW,QACd,MAAM,IAAI/C,CAAAA,CAAa+C,CAAAA,CAAW,OAAO,CAAC,CAAA,CAAE,OAAA,CAAA,kBAAmC,CAEnF,CACF,CAEA,MAAM,QACJ/B,CAAAA,CACAc,CAAAA,CAII,EAAC,CACmB,CACxB,IAAIb,CAAAA,CAEJ,OAAIa,CAAAA,CAAQ,2BAAA,CACVb,CAAAA,CAAS,MAAM,KAAK,aAAA,CAAc,cAAA,CAAea,CAAAA,CAAQ,eAAA,EAAmB,GAAId,CAAY,CAAA,CACnFc,EAAQ,6BAAA,CACjBb,CAAAA,CAAS,MAAM,IAAA,CAAK,aAAA,CAAc,kBAAA,CAChCa,CAAAA,CAAQ,iBAAmB,EAAA,CAC3Bd,CACF,CAAA,CAEAC,CAAAA,CAAS,MAAM,IAAA,CAAK,aAAA,CAAc,cAAA,CAAea,CAAAA,CAAQ,iBAAmB,EAAA,CAAId,CAAY,EAGvF,IAAA,CAAK,mBAAA,CAAoBC,CAAM,CACxC,CAEA,MAAM,qBAAA,CAAsBD,EAA8C,CACxE,IAAMC,CAAAA,CAAS,MAAM,KAAK,aAAA,CAAc,qBAAA,CAAsBD,CAAY,CAAA,CAC1E,OAAO,IAAA,CAAK,mBAAA,CAAoBC,CAAM,CACxC,CAEQ,oBAAoBA,CAAAA,CAAgC,CAC1D,IAAM+B,CAAAA,CAAiB/B,EACpB,aAAA,CAECgC,CAAAA,CAAgD,QAAA,CACpD,OAAID,EAAc,MAAA,GAAW,WAAA,CAC3BC,CAAAA,CAAS,WAAA,CAET,CAAC,YAAA,CAAc,iBAAA,CAAmB,uBAAuB,CAAA,CAAE,QAAA,CACzDD,EAAc,MAChB,CAAA,GAEAC,CAAAA,CAAS,YAAA,CAAA,CAGJ,CACL,OAAA,CAASD,CAAAA,CAAc,MAAA,GAAW,WAAA,CAClC,gBAAiBA,CAAAA,CAAc,EAAA,CAC/B,MAAA,CAAAC,CACF,CACF,CAEF,CAAA,KCtGaC,CAAAA,CAAN,KAAqB,CAI1B,WAAA,CAAYC,CAAAA,CAAiBC,CAAAA,CAAiB,CAC5C,KAAK,OAAA,CAAUD,CAAAA,CACf,KAAK,MAAA,CAASC,EAChB,CAEA,SAAA,CAAUA,CAAAA,CAAsB,CAC9B,IAAA,CAAK,OAASA,EAChB,CAGA,MAAM,sBAAA,CAAuBpC,CAAAA,CAAwD,CAEnF,GAAI,CACF,IAAMqC,CAAAA,CAAW,MAAM,KAAA,CACrB,CAAA,EAAG,IAAA,CAAK,OAAO,4CAA4C,kBAAA,CACzDrC,CACF,CAAC,CAAA,CAAA,CACD,CACE,MAAA,CAAQ,KAAA,CACR,QAAS,CACP,cAAA,CAAgB,kBAClB,CACF,CACF,CAAA,CAEA,GAAI,CAACqC,CAAAA,CAAS,EAAA,CACZ,MAAM,IAAIrD,EAAa,iCAAA,CAAA,qBAAgE,CAAA,CAGzF,OAAOqD,CAAAA,CAAS,MAClB,CAAA,MAASzC,EAAO,CACd,MAAIA,aAAiBZ,CAAAA,CAAoBY,CAAAA,CACnC,IAAIZ,CAAAA,CAAa,iDAA0D,CACnF,CACF,CAGA,MAAM,kBACJuC,CAAAA,CACoC,CACpC,GAAM,CAAE,WAAAe,CAAAA,CAAY,WAAA,CAAAC,CAAY,CAAA,CAAIhB,CAAAA,CAEpC,GAAI,CACF,IAAMc,CAAAA,CAAW,MAAM,MAAM,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,uBAAA,CAAA,CAA2B,CACrE,MAAA,CAAQ,MAAA,CACR,OAAA,CAAS,CACP,eAAgB,kBAAA,CAChB,GAAI,KAAK,MAAA,CAAS,CAAE,YAAa,IAAA,CAAK,MAAO,CAAA,CAAI,EACnD,CAAA,CAEA,IAAA,CAAM,IAAA,CAAK,SAAA,CAAU,CACnB,UAAA,CAAAC,CAAAA,CACA,WAAA,CAAa,CAAE,GAAGC,CAAAA,CAAa,iBAAA,CAAmB,MAAO,CAC3D,CAAC,CACH,CAAC,CAAA,CAED,GAAI,CAACF,EAAS,EAAA,CAAI,CAChB,IAAMG,CAAAA,CAAY,MAAMH,CAAAA,CAAS,IAAA,EAAK,CAAE,KAAA,CAAM,KAAO,EAAC,CAAE,EACxD,MAAM,IAAIrD,EACR,IAAA,CAAK,mBAAA,CAAoBwD,CAAAA,CAAWH,CAAAA,CAAS,MAAM,CAAA,CAAA,qBAErD,CACF,CAEA,IAAMI,EAAO,MAAMJ,CAAAA,CAAS,IAAA,EAAK,CAEjC,GAAI,CAACI,CAAAA,CAAK,cAAgB,CAACA,CAAAA,CAAK,gBAC9B,MAAM,IAAIzD,CAAAA,CACR,4DAAA,CAAA,qBAEF,EAGF,OAAO,CACL,eAAA,CAAiByD,CAAAA,CAAK,gBACtB,YAAA,CAAcA,CAAAA,CAAK,YAAA,CACnB,gBAAA,CAAkBA,EAAK,gBAAA,CACvB,oBAAA,CAAsBA,EAAK,oBAC7B,CACF,OAAS7C,CAAAA,CAAO,CACd,MAAIA,CAAAA,YAAiBZ,EACbY,CAAAA,CAEF,IAAIZ,CAAAA,CACRY,CAAAA,YAAiB,MAAQA,CAAAA,CAAM,OAAA,CAAU,wBAAA,CAAA,qBAE3C,CACF,CACF,CAEA,MAAM,kBAAkB2B,CAAAA,CAAkD,CACxE,GAAI,CACF,IAAMc,CAAAA,CAAW,MAAM,MAAM,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,uBAAA,CAAA,CAA2B,CACrE,MAAA,CAAQ,MAAA,CACR,OAAA,CAAS,CACP,eAAgB,kBAAA,CAChB,GAAI,KAAK,MAAA,CAAS,CAAE,YAAa,IAAA,CAAK,MAAO,CAAA,CAAI,EACnD,CAAA,CAEA,IAAA,CAAM,IAAA,CAAK,SAAA,CAAU,CACnB,UAAA,CAAYd,CAAAA,CAAQ,UAAA,CACpB,eAAA,CAAiBA,EAAQ,eAAA,CACzB,eAAA,CAAiBA,EAAQ,eAAA,CACzB,MAAA,CAAQA,EAAQ,MAAA,CAChB,QAAA,CAAUA,CAAAA,CAAQ,QAAA,CAClB,aAAcA,CAAAA,CAAQ,YAAA,CACtB,WAAA,CAAaA,CAAAA,CAAQ,YACrB,QAAA,CAAUA,CAAAA,CAAQ,QACpB,CAAC,CACH,CAAC,CAAA,CAED,GAAI,CAACc,CAAAA,CAAS,GAAI,CAChB,IAAMG,CAAAA,CAAY,MAAMH,EAAS,IAAA,EAAK,CAAE,KAAA,CAAM,KAAO,EAAC,CAAE,CAAA,CACxD,MAAM,IAAIrD,EACR,IAAA,CAAK,mBAAA,CAAoBwD,EAAWH,CAAAA,CAAS,MAAM,uBAErD,CACF,CACF,CAAA,MAASzC,CAAAA,CAAO,CACd,MAAIA,CAAAA,YAAiBZ,CAAAA,CACbY,CAAAA,CAEF,IAAIZ,CAAAA,CACRY,CAAAA,YAAiB,KAAA,CAAQA,CAAAA,CAAM,QAAU,wBAAA,CAAA,qBAE3C,CACF,CACF,CAEQ,mBAAA,CAAoB4C,EAAoBP,CAAAA,CAAwB,CACtE,GAAI,CAACO,GAAa,OAAOA,CAAAA,EAAc,QAAA,CACrC,OAAO,uBAAuBP,CAAM,CAAA,CAAA,CAGtC,IAAMS,CAAAA,CAASF,EACTG,CAAAA,CAAa,CAACD,EAAO,KAAA,CAAOA,CAAAA,CAAO,QAASA,CAAAA,CAAO,OAAO,CAAA,CAEhE,IAAA,IAAWE,KAAaD,CAAAA,CAAY,CAClC,GAAI,OAAOC,GAAc,QAAA,EAAYA,CAAAA,CAAU,IAAA,EAAK,CAAE,OAAS,CAAA,CAC7D,OAAOA,EAGT,GAAIA,CAAAA,EAAa,OAAOA,CAAAA,EAAc,QAAA,CACpC,GAAI,CACF,OAAO,IAAA,CAAK,SAAA,CAAUA,CAAS,CACjC,MAAQ,CAER,CAEJ,CAEA,OAAO,uBAAuBX,CAAM,CAAA,CACtC,CACF,ECxLO,SAASY,EAAmBC,CAAAA,CAA+B,CAChE,OAAIA,CAAAA,CAAc,WAAW,cAAc,CAAA,CAClCA,CAAAA,CAAc,OAAA,CAAQ,eAAgB,EAAE,CAAA,CAE7CA,CAAAA,CAAc,UAAA,CAAW,cAAc,CAAA,CAClCA,CAAAA,CAAc,QAAQ,cAAA,CAAgB,EAAE,EAE1CA,CACT,CCaO,IAAMC,CAAAA,CAAN,MAAMA,CAAc,CAqBzB,WAAA,CAAYvC,CAAAA,CAAuB,CAdnC,IAAA,CAAQ,aAAA,CAAsC,IAAA,CAC9C,IAAA,CAAQ,gBAA0C,IAAA,CAClD,IAAA,CAAQ,eAAwC,IAAA,CAChD,IAAA,CAAQ,sBAA8C,IAAA,CAEtD,IAAA,CAAQ,2BAAA,CAAuC,KAAA,CAC/C,KAAQ,6BAAA,CAAyC,KAAA,CAEjD,IAAA,CAAQ,SAAA,CAA2B,KACnC,IAAA,CAAQ,eAAA,CAAiC,IAAA,CACzC,IAAA,CAAQ,OAAwB,IAAA,CAChC,IAAA,CAAQ,SAA0B,IAAA,CAClC,IAAA,CAAQ,WAA4B,IAAA,CAGlC,GAAI,CAACA,CAAAA,CAAO,QAAU,CAACA,CAAAA,CAAO,YAAA,CAC5B,MAAM,IAAIxB,CAAAA,CACR,4CAAA,CAAA,qBAEF,CAAA,CAGF,GAAIwB,EAAO,MAAA,EAAUA,CAAAA,CAAO,aAC1B,MAAM,IAAIxB,EACR,uIAAA,CAAA,qBAEF,CAAA,CAGEwB,CAAAA,CAAO,MAAA,EAAU,CAACA,CAAAA,CAAO,MAAA,CAAO,QAAA,CAAS,MAAM,GAAK,OAAO,MAAA,CAAW,GAAA,EACxE,OAAA,CAAQ,KACN,oIACF,CAAA,CAGF,KAAK,MAAA,CAASA,CAAAA,CAEd,IAAMwC,CAAAA,CAAa,IAAA,CAAK,MAAA,CAAO,cAAA,EAAkBD,EAAc,WAAA,CAE/D,IAAA,CAAK,cAAA,CAAiB,IAAIb,EAAec,CAAAA,CAAY,IAAA,CAAK,MAAA,CAAO,MAAA,EAAU,EAAE,CAAA,CAC7E,IAAA,CAAK,kBAAoB,IAAI3B,EAC/B,CAEA,MAAM,UAAA,EAA4B,CAChC,OAAI,KAAK,qBAAA,CACA,IAAA,CAAK,qBAAA,EAGd,IAAA,CAAK,uBAAyB,SAAY,CACxC,IAAIrB,CAAAA,CACAiD,EACAC,CAAAA,CAGN,GAAI,KAAK,MAAA,CAAO,YAAA,CAAc,CAC5B,IAAM1C,CAAAA,CAAU,MAAM,IAAA,CAAK,eAAe,sBAAA,CACxC,IAAA,CAAK,MAAA,CAAO,YACd,EACAR,CAAAA,CAAe,IAAA,CAAK,MAAA,CAAO,YAAA,CAC3BiD,EAAkBzC,CAAAA,CAAO,eAAA,CACzB0C,EAAuB1C,CAAAA,CAAO,cAAA,CAC9B,KAAK,MAAA,CAASA,CAAAA,CAAO,MAAA,CACrB,IAAA,CAAK,SAAWA,CAAAA,CAAO,QAAA,CACvB,IAAA,CAAK,UAAA,CAAaA,EAAO,UAAA,CAErBA,CAAAA,CAAO,qBAAA,EACT,IAAA,CAAK,eAAe,SAAA,CAAUA,CAAAA,CAAO,qBAAqB,EAG9D,CAAA,KAAO,CACL,IAAA,CAAK,6BAAA,EAA8B,CAEnC,IAAM6B,EAAW,MAAM,IAAA,CAAK,cAAA,CAAe,iBAAA,CAAkB,CAC3D,UAAA,CAAY,IAAA,CAAK,MAAA,CAAO,UAAA,EAAc,GACtC,WAAA,CAAa,IAAA,CAAK,OAAO,WAC3B,CAAC,EACDrC,CAAAA,CAAeqC,CAAAA,CAAS,YAAA,CACxBY,CAAAA,CAAkBZ,EAAS,eAAA,CAC3Ba,CAAAA,CAAuBb,CAAAA,CAAS,oBAAA,CAChC,KAAK,MAAA,CAAS,IAAA,CAAK,MAAA,CAAO,WAAA,CAAa,OACvC,IAAA,CAAK,QAAA,CAAW,KAAK,MAAA,CAAO,WAAA,CAAa,SACzC,IAAA,CAAK,UAAA,CAAa,IAAA,CAAK,MAAA,CAAO,YAAc,GAC9C,CAEA,IAAA,CAAK,SAAA,CAAYQ,EAAmB7C,CAAY,CAAA,CAChD,IAAA,CAAK,eAAA,CAAkBiD,EAEvB,IAAMnD,CAAAA,CAAS,MAAMqD,mBAAAA,CAAWD,CAAoB,EAEpD,GAAI,CAACpD,CAAAA,CACH,MAAM,IAAId,CAAAA,CACR,uBAAA,CAAA,qBAEF,CAAA,CAGF,IAAA,CAAK,cAAgB,IAAIa,CAAAA,CAAcC,CAAM,CAAA,CAC7C,KAAK,eAAA,CAAkB,IAAIS,EAAgBT,CAAAA,CAAQ,IAAA,CAAK,OAAQ,IAAA,CAAK,SAAU,CAAA,CAC/E,IAAA,CAAK,eAAiB,IAAI4B,CAAAA,CACxB,IAAA,CAAK,aAAA,CACL,KAAK,eAAA,CACL,IAAA,CAAK,cACP,EACA,IAAG,CAAE,KAAA,CAAO9B,GAAU,CACpB,MAAA,IAAA,CAAK,sBAAwB,IAAA,CACvBA,CACR,CAAC,CAAA,CAEM,KAAK,qBAAA,CACd,CAEA,MAAM,cAAA,EAAyC,CAC7C,aAAM,IAAA,CAAK,iBAAA,EAAkB,CACtB,IAAA,CAAK,eAAgB,OAAA,CAAQ,IAAA,CAAK,UAAY,CACnD,2BAAA,CAA6B,KAAK,2BAAA,CAClC,6BAAA,CAA+B,IAAA,CAAK,6BACtC,CAAC,CACH,CAEA,MAAM,qBAAA,EAAgD,CACpD,OAAA,MAAM,IAAA,CAAK,iBAAA,EAAkB,CACtB,KAAK,cAAA,CAAgB,qBAAA,CAAsB,KAAK,SAAU,CACnE,CAEA,MAAM,cAAA,CAAe2B,CAAAA,CAAwD,CAC3E,MAAM,IAAA,CAAK,iBAAA,EAAkB,CAE7B,IAAMC,EACJ,MAAM,IAAA,CAAK,iBAAA,CAAkB,gBAAA,CAAiBD,CAAO,CAAA,CAEvD,GAAI,CACF,IAAM6B,CAAAA,CAAgB,MAAM,IAAA,CAAK,cAAA,CAAgB,OAAA,CAAQ5B,CAAAA,CAAiB,CACxE,UAAA,CAAY,IAAA,CAAK,UAAA,CACjB,eAAA,CAAiB,KAAK,eAAA,CACtB,YAAA,CAAc,IAAA,CAAK,SAAA,CACnB,OAAQ,IAAA,CAAK,MAAA,CACb,SAAU,IAAA,CAAK,QAAA,CACf,4BAA6B,IAAA,CAAK,2BAAA,CAClC,6BAAA,CAA+B,IAAA,CAAK,6BACtC,CAAC,CAAA,CAGD,OAAA,MAAM,IAAA,CAAK,kBAAkB,eAAA,CAAgB4B,CAAa,CAAA,CAEnDA,CACT,OAASxD,CAAAA,CAAO,CACd,YAAM,IAAA,CAAK,iBAAA,CAAkB,WAAWA,CAAc,CAAA,CAChD,IAAA,CAAK,kBAAA,CAAmBA,CAAK,CACrC,CACF,CAEA,MAAM,iBAAiBa,CAAAA,CAAiC,CACtD,MAAM,IAAA,CAAK,mBAAkB,CAC7B,IAAA,CAAK,gBAAiB,mBAAA,CAAoBA,CAAQ,EAClD,IAAA,CAAK,2BAAA,CAA8B,KACrC,CAEA,MAAM,eAAA,CAAgBA,CAAAA,CAAiC,CACrD,MAAM,KAAK,iBAAA,EAAkB,CAC7B,IAAA,CAAK,eAAA,CAAiB,uBAAuBA,CAAQ,CAAA,CACrD,KAAK,6BAAA,CAAgC,KACvC,CAEA,MAAM,eAAA,CAAgBA,CAAAA,CAAiC,CACrD,MAAM,IAAA,CAAK,iBAAA,EAAkB,CAC7B,IAAA,CAAK,gBAAiB,sBAAA,CAAuBA,CAAQ,CAAA,CACrD,IAAA,CAAK,8BAAgC,KACvC,CAEA,MAAM,YAAA,CAAaA,CAAAA,CAAiC,CAClD,MAAM,IAAA,CAAK,iBAAA,EAAkB,CAC7B,KAAK,eAAA,CAAiB,mBAAA,CAAoBA,CAAQ,CAAA,CAClD,KAAK,6BAAA,CAAgC,KACvC,CAEA,MAAM,aACJA,CAAAA,CACAG,CAAAA,CACe,CACf,MAAM,IAAA,CAAK,mBAAkB,CAC7B,IAAA,CAAK,eAAA,CAAiB,mBAAA,CAAoBH,EAAUG,CAAI,CAAA,CACxD,IAAA,CAAK,6BAAA,CAAgC,KACvC,CAEA,YAAA,CAAaU,CAAAA,CAAmC,CAC9C,KAAK,iBAAA,CAAkB,GAAA,CAAIA,CAAS,EACtC,CAEA,MAAc,iBAAA,EAAmC,CAC1C,IAAA,CAAK,aAAA,EACR,MAAM,IAAA,CAAK,UAAA,GAEf,CAEQ,+BAAsC,CAC5C,GAAI,CAAC,IAAA,CAAK,OAAO,WAAA,CACf,MAAM,IAAItC,CAAAA,CACR,yDAAA,CAAA,qBAEF,EAGF,GAAM,CAAE,MAAA,CAAAqE,CAAAA,CAAQ,SAAAC,CAAAA,CAAU,UAAA,CAAAC,CAAW,CAAA,CAAI,KAAK,MAAA,CAAO,WAAA,CAGrD,GAAI,CAACD,EACH,MAAM,IAAIjE,EAAgB,sBAAA,CAAwB,UAAU,EAG9D,IAAMmE,CAAAA,CAAoBF,CAAAA,CAAS,WAAA,GAE7BG,CAAAA,CAAgB,IAAA,CAAK,OAAA,CAAQJ,CAAAA,CAAQG,EAAmB,QAAQ,CAAA,CAEtE,GAAIC,CAAAA,CAAc,QAAO,EAAKA,CAAAA,CAAc,YAAW,CACrD,MAAM,IAAIpE,CAAAA,CAAgB,+BAAA,CAAiC,QAAQ,CAAA,CAGrE,GAAIkE,CAAAA,GAAe,MAAA,CAAW,CAC5B,IAAMG,EAAmB,IAAA,CAAK,OAAA,CAAQH,CAAAA,CAAYC,CAAAA,CAAmB,YAAY,CAAA,CAEjF,GAAIE,EAAiB,UAAA,EAAW,CAC9B,MAAM,IAAIrE,CAAAA,CAAgB,+BAAA,CAAiC,YAAY,EAGzE,GAAIqE,CAAAA,CAAiB,WAAA,CAAYD,CAAa,EAC5C,MAAM,IAAIpE,CAAAA,CAAgB,6CAAA,CAA+C,YAAY,CAEzF,CACF,CAEQ,OAAA,CAAQsE,CAAAA,CAAeL,EAAkBM,CAAAA,CAA0B,CACzE,GAAI,CACF,OAAOC,aAAAA,CAAM,WAAA,CAAYF,CAAAA,CAAOL,CAAQ,CAC1C,CAAA,KAAQ,CACN,MAAM,IAAIjE,EACR,CAAA,EAAGuE,CAAS,0EACZA,CACF,CACF,CACF,CAGQ,kBAAA,CAAmBhE,CAAAA,CAAuB,CAChD,GAAIA,CAAAA,YAAiBZ,CAAAA,CACnB,OAAOY,CAAAA,CAET,IAAMV,CAAAA,CAAUU,CAAAA,YAAiB,KAAA,CAAQA,CAAAA,CAAM,QAAU,gBAAA,CACnDT,CAAAA,CAAQS,GAAmC,IAAA,CAEjD,OAAO,IAAIJ,CAAAA,CAAaN,CAAAA,CAASC,CAAI,CACvC,CACF,CAAA,CAlQa4D,CAAAA,CACa,WAAA,CAAc,yBAAA,KAD3Be,CAAAA,CAANf,ECnBA,IAAMgB,CAAAA,CAAN,KAAoB,CACzB,kBAAA,CAAmBC,EAA6B,CAC9C,IAAMC,EAAUD,CAAAA,CAAW,OAAA,CAAQ,KAAA,CAAO,EAAE,EAE5C,GAAIC,CAAAA,CAAQ,MAAA,CAAS,EAAA,EAAMA,EAAQ,MAAA,CAAS,EAAA,CAC1C,OAAO,MAAA,CAGT,IAAIC,CAAAA,CAAM,CAAA,CACNC,EAAS,KAAA,CAEb,IAAA,IAASC,EAAIH,CAAAA,CAAQ,MAAA,CAAS,CAAA,CAAGG,CAAAA,EAAK,EAAGA,CAAAA,EAAAA,CAAK,CAC5C,IAAIC,CAAAA,CAAQ,SAASJ,CAAAA,CAAQG,CAAC,CAAA,CAAG,EAAE,EAE/BD,CAAAA,GACFE,CAAAA,EAAS,EACLA,CAAAA,CAAQ,CAAA,GACVA,GAAS,CAAA,CAAA,CAAA,CAIbH,CAAAA,EAAOG,CAAAA,CACPF,CAAAA,CAAS,CAACA,EACZ,CAEA,OAAOD,CAAAA,CAAM,KAAO,CACtB,CAEA,cAAA,CAAeF,CAAAA,CAA4B,CACzC,IAAMC,CAAAA,CAAUD,EAAW,OAAA,CAAQ,KAAA,CAAO,EAAE,CAAA,CAE5C,OAAI,IAAA,CAAK,IAAA,CAAKC,CAAO,CAAA,CAAU,MAAA,CAC3B,SAAA,CAAU,IAAA,CAAKA,CAAO,CAAA,CAAU,YAAA,CAChC,QAAA,CAAS,IAAA,CAAKA,CAAO,CAAA,CAAU,MAAA,CAC/B,cAAc,IAAA,CAAKA,CAAO,EAAU,UAAA,CAEjC,SACT,CAEA,cAAA,CAAeK,EAAeC,CAAAA,CAAuB,CACnD,IAAMC,CAAAA,CAAM,IAAI,IAAA,CACVC,CAAAA,CAAcD,CAAAA,CAAI,WAAA,GAClBE,CAAAA,CAAeF,CAAAA,CAAI,UAAS,CAAI,CAAA,CAEtC,GAAIF,CAAAA,CAAQ,CAAA,EAAKA,CAAAA,CAAQ,EAAA,CACvB,OAAO,MAAA,CAGT,IAAMK,CAAAA,CAAWJ,CAAAA,CAAO,IAAM,GAAA,CAAOA,CAAAA,CAAOA,CAAAA,CAM5C,OAJI,EAAAI,CAAAA,CAAWF,CAAAA,EAIXE,IAAaF,CAAAA,EAAeH,CAAAA,CAAQI,EAK1C,CAEA,WAAA,CAAYE,CAAAA,CAAaC,CAAAA,CAAmB,UAAoB,CAC9D,IAAMZ,CAAAA,CAAUW,CAAAA,CAAI,QAAQ,KAAA,CAAO,EAAE,CAAA,CAErC,OAAIC,IAAa,MAAA,CACRZ,CAAAA,CAAQ,SAAW,CAAA,CAGrBA,CAAAA,CAAQ,SAAW,CAAA,EAAKA,CAAAA,CAAQ,MAAA,GAAW,CACpD,CAEA,WAAA,CACED,CAAAA,CACAc,CAAAA,CACAC,CAAAA,CACAH,EACgB,CAChB,IAAMC,CAAAA,CAAW,IAAA,CAAK,eAAeb,CAAU,CAAA,CAE/C,OAAO,CACL,MAAA,CAAQ,CACN,OAAA,CAAS,IAAA,CAAK,kBAAA,CAAmBA,CAAU,EAC3C,QAAA,CAAUa,CAEZ,CAAA,CACA,MAAA,CAAQ,CACN,OAAA,CAAS,IAAA,CAAK,cAAA,CAAeC,CAAAA,CAAaC,CAAU,CAAA,CACpD,KAAA,CAAOD,EACP,IAAA,CAAMC,CACR,EACA,GAAA,CAAK,CACH,OAAA,CAAS,IAAA,CAAK,YAAYH,CAAAA,CAAKC,CAAQ,CAAA,CACvC,MAAA,CAAQD,EAAI,OAAA,CAAQ,KAAA,CAAO,EAAE,CAAA,CAAE,MACjC,CACF,CACF,CACF,EClGO,IAAMI,EAAN,KAAqB,CAC1B,OAAO,kBAAA,CAAmBC,EAAuB,CAC/C,OAAOA,CAAAA,CAAM,OAAA,CAAQ,MAAO,EAAE,CAChC,CAEA,OAAO,iBAAiBA,CAAAA,CAAuB,CAE7C,OADgB,IAAA,CAAK,kBAAA,CAAmBA,CAAK,CAAA,CAC9B,OAAA,CAAQ,UAAA,CAAY,KAAK,EAAE,IAAA,EAC5C,CAEA,OAAO,YAAYA,CAAAA,CAAuB,CACxC,OAAOA,CAAAA,CAAM,QAAQ,KAAA,CAAO,EAAE,EAAE,KAAA,CAAM,CAAA,CAAG,CAAC,CAC5C,CAEA,OAAO,cAAA,CAAeA,EAAuD,CAC3E,IAAMhB,CAAAA,CAAUgB,CAAAA,CAAM,QAAQ,KAAA,CAAO,EAAE,CAAA,CAEvC,OAAIhB,EAAQ,MAAA,GAAW,CAAA,CACd,CACL,KAAA,CAAO,QAAA,CAASA,EAAQ,KAAA,CAAM,CAAA,CAAG,CAAC,CAAA,CAAG,EAAE,CAAA,CACvC,IAAA,CAAM,QAAA,CAASA,CAAAA,CAAQ,MAAM,CAAA,CAAG,CAAC,CAAA,CAAG,EAAE,CACxC,CAAA,CACSA,CAAAA,CAAQ,SAAW,CAAA,CACrB,CACL,MAAO,QAAA,CAASA,CAAAA,CAAQ,KAAA,CAAM,CAAA,CAAG,CAAC,CAAA,CAAG,EAAE,EACvC,IAAA,CAAM,QAAA,CAASA,EAAQ,KAAA,CAAM,CAAA,CAAG,CAAC,CAAA,CAAG,EAAE,CACxC,CAAA,CAGK,IACT,CACF,MCGaiB,EAAAA,CAAU","file":"index.cjs","sourcesContent":["import type { ErrorDetails } from '../types';\nimport { ErrorCode } from '../types';\n\nexport class VerapayError extends Error {\n public readonly code: ErrorCode;\n public readonly details: ErrorDetails;\n\n constructor(\n message: string,\n code: ErrorCode = ErrorCode.PAYMENT_FAILED,\n details?: Partial<ErrorDetails>\n ) {\n super(message);\n this.name = 'VerapayError';\n this.code = code;\n this.details = {\n code,\n message,\n formattedMessage: this.formatMessage(message, code),\n ...details,\n };\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, VerapayError);\n }\n }\n\n private formatMessage(message: string, code: ErrorCode): string {\n const messageMap: Record<ErrorCode, string> = {\n [ErrorCode.VALIDATION_ERROR]:\n 'Please check your payment information and try again.',\n [ErrorCode.PAYMENT_FAILED]:\n 'Your payment could not be processed. Please try again.',\n [ErrorCode.AUTHENTICATION_FAILED]:\n 'Payment authentication failed. Please try again.',\n [ErrorCode.NETWORK_ERROR]:\n 'Network error. Please check your connection and try again.',\n [ErrorCode.STRIPE_ERROR]:\n 'Payment service error. Please try again later.',\n [ErrorCode.CONFIGURATION_ERROR]:\n 'Configuration error. Please contact support.',\n [ErrorCode.CARD_DECLINED]:\n 'Your card was declined. Please use a different payment method.',\n [ErrorCode.INSUFFICIENT_FUNDS]:\n 'Insufficient funds. Please use a different payment method.',\n [ErrorCode.EXPIRED_CARD]:\n 'Your card has expired. Please use a different payment method.',\n };\n\n return messageMap[code] || message;\n }\n\n toJSON() {\n return {\n name: this.name,\n code: this.code,\n message: this.message,\n details: this.details,\n };\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class ValidationError extends VerapayError {\n constructor(message: string, field?: string, metadata?: Record<string, unknown>) {\n\n super(message, ErrorCode.VALIDATION_ERROR, {\n field,\n metadata,\n });\n this.name = 'ValidationError';\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class PaymentError extends VerapayError {\n constructor(\n message: string,\n stripeCode?: string,\n metadata?: Record<string, unknown>\n ) {\n const code = PaymentError.mapStripeCode(stripeCode);\n super(message, code, {\n stripeCode,\n metadata,\n });\n this.name = 'PaymentError';\n }\n\n private static mapStripeCode(stripeCode?: string): ErrorCode {\n if (!stripeCode) return ErrorCode.PAYMENT_FAILED;\n\n const codeMap: Record<string, ErrorCode> = {\n card_declined: ErrorCode.CARD_DECLINED,\n insufficient_funds: ErrorCode.INSUFFICIENT_FUNDS,\n expired_card: ErrorCode.EXPIRED_CARD,\n incorrect_cvc: ErrorCode.VALIDATION_ERROR,\n processing_error: ErrorCode.PAYMENT_FAILED,\n authentication_failed: ErrorCode.AUTHENTICATION_FAILED,\n };\n\n return codeMap[stripeCode] || ErrorCode.PAYMENT_FAILED;\n }\n}\n","import type { ErrorDetails } from '../types';\n\nexport class ErrorFormatter {\n static formatForUser(error: Error | ErrorDetails): string {\n if ('formattedMessage' in error) {\n return error.formattedMessage;\n }\n if (\n 'details' in error &&\n error.details &&\n typeof error.details === 'object' &&\n 'formattedMessage' in error.details &&\n typeof error.details.formattedMessage === 'string'\n ) {\n return error.details.formattedMessage;\n }\n return 'An unexpected error occurred. Please try again.';\n }\n\n static formatForDeveloper(error: Error | ErrorDetails): string {\n if ('code' in error && 'message' in error) {\n return `[${error.code}] ${error.message}`;\n }\n return error.message || 'Unknown error';\n }\n\n static toJSON(error: Error | ErrorDetails): Record<string, unknown> {\n\n if ('toJSON' in error && typeof error.toJSON === 'function') {\n return error.toJSON();\n }\n\n return {\n name: (error as Error).name || 'Error',\n message: error.message,\n ...('code' in error && { code: error.code }),\n ...('details' in error && { details: error.details }),\n };\n }\n}\n","import type { PaymentIntent, Stripe, StripeElements } from '@stripe/stripe-js';\nimport { PaymentError } from '../errors';\n\nexport class StripeAdapter {\n constructor(private stripe: Stripe) {}\n\n async confirmPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmPayment({\n clientSecret,\n confirmParams: {\n payment_method: paymentMethodId,\n return_url: window.location.href,\n },\n redirect: 'if_required',\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmCardPayment(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async createPaymentMethod(\n elements: StripeElements,\n isUsingIndividualFormElements: boolean = false\n ): Promise<string> {\n let result;\n\n if (!isUsingIndividualFormElements) {\n result = await this.stripe.createPaymentMethod({\n elements,\n });\n } else {\n // @ts-expect-error - Stripe types don't include mode parameter for getElement\n const addressElement = await elements.getElement('address', { mode: 'billing' })!.getValue();\n\n const address = addressElement!.value;\n\n result = await this.stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement('cardNumber')!,\n billing_details: {\n name: address.name,\n address: {\n ...address.address,\n line2: address.address.line2 ?? undefined,\n },\n },\n });\n }\n\n if (result.error || !result.paymentMethod) {\n throw new PaymentError(\n result.error?.message || 'Failed to create payment method',\n result.error?.code\n );\n }\n\n return result.paymentMethod.id;\n }\n\n async retrievePaymentIntent(\n clientSecret: string,\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.retrievePaymentIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve payment intent',\n result.error.code,\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n}\n\n","import type {\n Stripe,\n StripeElements,\n StripeElement,\n StripePaymentElement,\n StripeCardNumberElement,\n PaymentWalletsOption,\n} from '@stripe/stripe-js';\nimport type { VerapayConfig, ValidationError, ValidationResult } from '../types';\nimport { VerapayError, ErrorCode } from '../errors';\n\ntype ElementState = { complete: boolean; error?: string }\n\nconst DEFAULT_CARD_ELEMENT_CONFIG = {\n showIcon: true,\n iconStyle: 'solid' as const,\n placeholders: {\n cardNumber: '1234 1234 1234 1234',\n cardExpiry: 'MM / YY - TESTING',\n cardCvc: 'CVC',\n },\n style: {\n base: {\n color: '#333333',\n fontFamily: 'system-ui, -apple-system, sans-serif',\n fontSize: '16px',\n '::placeholder': { color: '#aab7c4' },\n },\n complete: {\n color: '#333333',\n },\n empty: {},\n invalid: {\n color: '#df1b41',\n },\n },\n}\n\nconst FIELD_LABELS: Record<string, string> = {\n cardNumber: 'Card number',\n cardExpiry: 'Expiry date',\n cardCvc: 'CVC',\n address: 'Address',\n}\n\nexport class ElementsManager {\n private elements: StripeElements | null = null;\n private mountedElements: Map<string, StripeElement> = new Map();\n private elementStates: Map<string, ElementState> = new Map();\n\n constructor(\n private stripe: Stripe,\n private config: VerapayConfig,\n private clientSecret: string,\n ) {\n if (!clientSecret) {\n throw new VerapayError(\n 'Client secret not initialized',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n\n mountPaymentElement(selector: string): void {\n if (!this.elements) {\n const elementsConfig = {\n clientSecret: this.clientSecret,\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n };\n\n this.elements = this.stripe.elements(elementsConfig);\n }\n\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.elements.create('payment', {\n layout: 'tabs',\n wallets: { link: 'never' } as unknown as PaymentWalletsOption,\n }) as StripePaymentElement;\n\n element.mount(selector);\n this.mountedElements.set('payment', element);\n }\n\n mountCardNumberElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardNumber', this.cardElementOptions('cardNumber'));\n }\n\n mountCardExpiryElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardExpiry', this.cardElementOptions('cardExpiry'));\n }\n\n mountCardCvcElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardCvc', this.cardElementOptions('cardCvc'));\n }\n\n mountAddressElement(selector: string, mode: 'billing' | 'shipping'): void {\n this.mountIndividualFormElement(selector, 'address', { mode });\n }\n\n private cardElementOptions(fieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc'): Record<string, unknown> {\n const { elementsConfig } = this.config;\n const options: Record<string, unknown> = {\n placeholder: elementsConfig?.placeholders?.[fieldType] ?? DEFAULT_CARD_ELEMENT_CONFIG.placeholders[fieldType],\n style: {\n base: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.base, ...elementsConfig?.style?.base },\n complete: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.complete, ...elementsConfig?.style?.complete },\n empty: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.empty, ...elementsConfig?.style?.empty },\n invalid: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.invalid, ...elementsConfig?.style?.invalid },\n },\n };\n\n if (fieldType === 'cardNumber') {\n options.showIcon = elementsConfig?.showIcon ?? DEFAULT_CARD_ELEMENT_CONFIG.showIcon;\n options.iconStyle = elementsConfig?.iconStyle ?? DEFAULT_CARD_ELEMENT_CONFIG.iconStyle;\n }\n\n return options;\n }\n\n private mountIndividualFormElement(selector: string, formFieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address', options?: Record<string, unknown>) {\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.createIndividualFormElement(formFieldType, options) as StripeCardNumberElement;\n element.mount(selector);\n\n this.mountedElements.set(formFieldType, element);\n this.trackElementState(formFieldType, element);\n }\n\n private createIndividualFormElement(\n elementType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address',\n options?: Record<string, unknown>,\n ): StripeElement {\n if (!this.elements) {\n this.elements = this.stripe.elements({\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n });\n }\n\n return this.elements.create(elementType as 'cardNumber', options);\n }\n\n\n\n async validate(): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n\n for (const [field, state] of this.elementStates.entries()) {\n if (!state.complete) {\n errors.push({\n field,\n message: state.error ?? `${FIELD_LABELS[field] ?? field} failed validation`,\n })\n }\n }\n\n return { isValid: errors.length === 0, errors }\n }\n\n getElements(): StripeElements | null {\n return this.elements;\n }\n\n unmountAll(): void {\n for (const element of this.mountedElements.values()) {\n element.unmount();\n }\n this.mountedElements.clear();\n this.elementStates.clear();\n }\n\n private trackElementState(field: string, element: StripeElement): void {\n this.elementStates.set(field, { complete: false })\n\n const handleElementChange = (event: { complete: boolean; error?: { message: string } }) => {\n this.elementStates.set(field, { complete: event.complete, error: event.error?.message })\n };\n\n (element as unknown as { on: (event: string, handler: (e: unknown) => void) => void }).on(\n 'change',\n handleElementChange as (e: unknown) => void,\n );\n }\n}\n\n\n","import type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport type { PaymentExtension } from '../extensions'\n\nexport class PaymentExtensionsManager {\n private extensions: PaymentExtension[] = []\n\n add(extension: PaymentExtension): void {\n this.extensions.push(extension)\n }\n\n async runBeforePayment(request: ProcessPaymentRequest): Promise<ProcessPaymentRequest> {\n let modifiedRequest = request\n for (const ext of this.extensions) {\n if (ext.beforePayment) {\n modifiedRequest = await ext.beforePayment(modifiedRequest)\n }\n }\n return modifiedRequest\n }\n\n async runAfterPayment(result: PaymentResult): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.afterPayment)\n .map((ext) => ext.afterPayment!(result)),\n )\n }\n\n async runOnError(error: Error): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.onPaymentError)\n .map((ext) => ext.onPaymentError!(error)),\n )\n }\n}\n","import { StripeAdapter } from '../client/stripe-adapter'\nimport { ElementsManager } from '../client/elements-manager'\nimport { ErrorCode, VerapayError } from '../errors'\nimport { VerapayService } from './verapay-service'\nimport type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface ProcessPaymentContext {\n merchantId: string\n paymentIntentId: string\n clientSecret: string\n amount: number\n currency: string\n isUsingStripePaymentElement: boolean\n isUsingIndividualFormElements: boolean\n}\n\nexport class PaymentService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n private verapayService: VerapayService,\n ) {}\n\n async process(request: ProcessPaymentRequest, context: ProcessPaymentContext): Promise<PaymentResult> {\n const elements = this.elementsManager.getElements()\n\n await this.validatePaymentCanProceed(elements, context);\n\n await elements!.submit()\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n )\n\n await this.verapayService.processPrePayment({\n merchantId: context.merchantId,\n paymentIntentId: context.paymentIntentId,\n paymentMethodId,\n amount: context.amount,\n currency: context.currency,\n customerData: {\n email: request.customerEmail,\n firstName: request.customerFirstName,\n lastName: request.customerLastName,\n },\n description: request.description,\n metadata: request.metadata,\n })\n\n return this.confirm(context.clientSecret, {\n paymentMethodId,\n isUsingStripePaymentElement: context.isUsingStripePaymentElement,\n isUsingIndividualFormElements: context.isUsingIndividualFormElements,\n });\n }\n\n private async validatePaymentCanProceed(\n elements: StripeElements | null,\n context: ProcessPaymentContext,\n ) {\n if (!elements) {\n throw new VerapayError('Payment form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of payment form in use');\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n async confirm(\n clientSecret: string,\n options: {\n isUsingStripePaymentElement?: boolean;\n isUsingIndividualFormElements?: boolean;\n paymentMethodId?: string;\n } = {},\n ): Promise<PaymentResult> {\n let result;\n\n if (options.isUsingStripePaymentElement) {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n } else if (options.isUsingIndividualFormElements) {\n result = await this.stripeAdapter.confirmCardPayment(\n options.paymentMethodId || '',\n clientSecret,\n );\n } else {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n }\n\n return this.formatPaymentResult(result);\n }\n\n async retrievePaymentIntent(clientSecret: string): Promise<PaymentResult> {\n const result = await this.stripeAdapter.retrievePaymentIntent(clientSecret);\n return this.formatPaymentResult(result);\n }\n\n private formatPaymentResult(result: unknown): PaymentResult {\n const paymentIntent = (result as { paymentIntent: { status: string; id: string } })\n .paymentIntent\n\n let status: 'succeeded' | 'processing' | 'failed' = 'failed'\n if (paymentIntent.status === 'succeeded') {\n status = 'succeeded'\n } else if (\n ['processing', 'requires_action', 'requires_confirmation'].includes(\n paymentIntent.status,\n )\n ) {\n status = 'processing'\n }\n\n return {\n success: paymentIntent.status === 'succeeded',\n paymentIntentId: paymentIntent.id,\n status,\n }\n }\n\n}\n\n\n","import { ErrorCode, VerapayError } from '../errors';\nimport { PaymentData } from '../types';\n\nexport interface InitialisePaymentRequest {\n merchantId: string;\n paymentData: PaymentData;\n}\n\nexport interface InitialisePaymentResponse {\n paymentIntentId: string;\n clientSecret: string;\n connectAccountId: string;\n stripePublishableKey: string;\n}\n\nexport interface ProcessPrePaymentRequest {\n merchantId: string;\n paymentIntentId: string;\n paymentMethodId: string;\n amount: number;\n currency: string;\n customerData: Record<string, unknown>;\n\n description?: string;\n metadata?: Record<string, string>;\n}\n\nexport class VerapayService {\n private readonly baseUrl: string;\n private apiKey?: string;\n\n constructor(baseUrl: string, apiKey?: string) {\n this.baseUrl = baseUrl;\n this.apiKey = apiKey;\n }\n\n setApiKey(apiKey: string): void {\n this.apiKey = apiKey;\n }\n\n\n async getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch provider config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n\n async initialisePayment(\n request: InitialisePaymentRequest\n ): Promise<InitialisePaymentResponse> {\n const { merchantId, paymentData } = request;\n\n try {\n const response = await fetch(`${this.baseUrl}/api/initialise-payment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId,\n paymentData: { ...paymentData, paymentMethodType: 'card' },\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const data = await response.json();\n\n if (!data.clientSecret || !data.paymentIntentId) {\n throw new VerapayError(\n 'Missing clientSecret or paymentIntentId in server response',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n return {\n paymentIntentId: data.paymentIntentId,\n clientSecret: data.clientSecret,\n connectAccountId: data.connectAccountId,\n stripePublishableKey: data.stripePublishableKey,\n };\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n async processPrePayment(request: ProcessPrePaymentRequest): Promise<void> {\n try {\n const response = await fetch(`${this.baseUrl}/api/process-prepayment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId: request.merchantId,\n paymentIntentId: request.paymentIntentId,\n paymentMethodId: request.paymentMethodId,\n amount: request.amount,\n currency: request.currency,\n customerData: request.customerData,\n description: request.description,\n metadata: request.metadata,\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n private extractErrorMessage(errorData: unknown, status: number): string {\n if (!errorData || typeof errorData !== 'object') {\n return `HTTP error! status: ${status}`;\n }\n\n const record = errorData as Record<string, unknown>;\n const candidates = [record.error, record.message, record.details];\n\n for (const candidate of candidates) {\n if (typeof candidate === 'string' && candidate.trim().length > 0) {\n return candidate;\n }\n\n if (candidate && typeof candidate === 'object') {\n try {\n return JSON.stringify(candidate);\n } catch {\n // Ignore serialization issues and continue trying fallback messages.\n }\n }\n }\n\n return `HTTP error! status: ${status}`;\n }\n}\n","export function unwrapClientSecret(wrappedSecret: string): string {\n if (wrappedSecret.startsWith('vpy_cs_test_')) {\n return wrappedSecret.replace('vpy_cs_test_', '');\n }\n if (wrappedSecret.startsWith('vpy_cs_live_')) {\n return wrappedSecret.replace('vpy_cs_live_', '');\n }\n return wrappedSecret;\n}\n","import { loadStripe } from '@stripe/stripe-js';\nimport { Money } from 'ts-money';\nimport { StripeAdapter } from './stripe-adapter';\nimport { ElementsManager } from './elements-manager';\nimport type { PaymentExtension } from '../extensions';\nimport { PaymentExtensionsManager } from './payment-extensions-manager';\nimport { PaymentService } from '../services/payment-service';\nimport {\n ErrorCode,\n VerapayError,\n PaymentError,\n ValidationError,\n} from '../errors';\nimport { VerapayService } from '../services/verapay-service';\nimport { unwrapClientSecret } from '../utils/secret.util';\nimport type {\n VerapayConfig,\n ProcessPaymentRequest,\n PaymentResult,\n} from '../types';\n\nexport class VerapayClient {\n private static readonly BACKEND_URL = 'https://api.verapay.app';\n\n private config: VerapayConfig;\n private verapayService: VerapayService;\n private extensionsManager: PaymentExtensionsManager;\n\n private stripeAdapter: StripeAdapter | null = null;\n private elementsManager: ElementsManager | null = null;\n private paymentService: PaymentService | null = null;\n private initializationPromise: Promise<void> | null = null;\n\n private isUsingStripePaymentElement: boolean = false;\n private isUsingIndividualFormElements: boolean = false;\n\n private rawSecret: string | null = null;\n private paymentIntentId: string | null = null;\n private amount: number | null = null;\n private currency: string | null = null;\n private merchantId: string | null = null;\n\n constructor(config: VerapayConfig) {\n if (!config.apiKey && !config.clientSecret) {\n throw new VerapayError(\n 'Either apiKey or clientSecret is required.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && config.clientSecret) {\n throw new VerapayError(\n 'Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && !config.apiKey.includes(\"_pk_\") && typeof window !== \"undefined\") {\n console.warn(\n \"Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead.\"\n );\n }\n\n this.config = config;\n\n const backendUrl = this.config.apiUrlOverride || VerapayClient.BACKEND_URL;\n\n this.verapayService = new VerapayService(backendUrl, this.config.apiKey || '');\n this.extensionsManager = new PaymentExtensionsManager();\n }\n\n async initialize(): Promise<void> {\n if (this.initializationPromise) {\n return this.initializationPromise;\n }\n\n this.initializationPromise = (async () => {\n let clientSecret: string;\n let paymentIntentId: string;\n let stripePublishableKey: string;\n\n\n if (this.config.clientSecret) {\n const config = (await this.verapayService.getPaymentIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n clientSecret = this.config.clientSecret;\n paymentIntentId = config.paymentIntentId;\n stripePublishableKey = config.publishableKey;\n this.amount = config.amount;\n this.currency = config.currency;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n\n } else {\n this.validatePaymentInitialisation();\n\n const response = await this.verapayService.initialisePayment({\n merchantId: this.config.merchantId ?? '',\n paymentData: this.config.paymentData!,\n });\n clientSecret = response.clientSecret;\n paymentIntentId = response.paymentIntentId;\n stripePublishableKey = response.stripePublishableKey;\n this.amount = this.config.paymentData!.amount;\n this.currency = this.config.paymentData!.currency;\n this.merchantId = this.config.merchantId ?? '';\n }\n\n this.rawSecret = unwrapClientSecret(clientSecret);\n this.paymentIntentId = paymentIntentId;\n\n const stripe = await loadStripe(stripePublishableKey);\n\n if (!stripe) {\n throw new VerapayError(\n 'Failed to load Stripe',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n this.stripeAdapter = new StripeAdapter(stripe);\n this.elementsManager = new ElementsManager(stripe, this.config, this.rawSecret!);\n this.paymentService = new PaymentService(\n this.stripeAdapter,\n this.elementsManager,\n this.verapayService,\n );\n })().catch((error) => {\n this.initializationPromise = null;\n throw error;\n });\n\n return this.initializationPromise;\n }\n\n async confirmPayment(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.confirm(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n }\n\n async retrievePaymentIntent(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.retrievePaymentIntent(this.rawSecret!);\n }\n\n async processPayment(request: ProcessPaymentRequest): Promise<PaymentResult> {\n await this.ensureInitialized();\n\n const modifiedRequest =\n await this.extensionsManager.runBeforePayment(request);\n\n try {\n const paymentResult = await this.paymentService!.process(modifiedRequest, {\n merchantId: this.merchantId!,\n paymentIntentId: this.paymentIntentId!,\n clientSecret: this.rawSecret!,\n amount: this.amount!,\n currency: this.currency!,\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n\n\n await this.extensionsManager.runAfterPayment(paymentResult);\n\n return paymentResult;\n } catch (error) {\n await this.extensionsManager.runOnError(error as Error);\n throw this.handlePaymentError(error);\n }\n }\n\n async mountPaymentForm(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountPaymentElement(selector);\n this.isUsingStripePaymentElement = true;\n }\n\n async mountCardNumber(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardNumberElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardExpiry(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardExpiryElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardCvc(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardCvcElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountAddress(\n selector: string,\n mode: 'billing' | 'shipping'\n ): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountAddressElement(selector, mode);\n this.isUsingIndividualFormElements = true;\n }\n\n addExtension(extension: PaymentExtension): void {\n this.extensionsManager.add(extension);\n }\n\n private async ensureInitialized(): Promise<void> {\n if (!this.stripeAdapter) {\n await this.initialize();\n }\n }\n\n private validatePaymentInitialisation(): void {\n if (!this.config.paymentData) {\n throw new VerapayError(\n 'paymentData is required for frontend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n const { amount, currency, partnerFee } = this.config.paymentData;\n\n\n if (!currency) {\n throw new ValidationError('Currency is required', 'currency');\n }\n\n const uppercaseCurrency = currency.toUpperCase();\n\n const paymentAmount = this.toMoney(amount, uppercaseCurrency, 'amount');\n\n if (paymentAmount.isZero() || paymentAmount.isNegative()) {\n throw new ValidationError('Amount must be greater than 0', 'amount');\n }\n\n if (partnerFee !== undefined) {\n const partnerFeeAmount = this.toMoney(partnerFee, uppercaseCurrency, 'partnerFee');\n\n if (partnerFeeAmount.isNegative()) {\n throw new ValidationError('partnerFee cannot be negative', 'partnerFee');\n }\n\n if (partnerFeeAmount.greaterThan(paymentAmount)) {\n throw new ValidationError('partnerFee cannot exceed the payment amount', 'partnerFee');\n }\n }\n }\n\n private toMoney(value: number, currency: string, fieldName: string): Money {\n try {\n return Money.fromInteger(value, currency);\n } catch {\n throw new ValidationError(\n `${fieldName} must be an integer in the smallest currency unit (e.g., cents for USD)`,\n fieldName\n );\n }\n }\n\n\n private handlePaymentError(error: unknown): Error {\n if (error instanceof VerapayError) {\n return error;\n }\n const message = error instanceof Error ? error.message : 'Payment failed';\n const code = (error as Record<string, unknown>)?.code as string | undefined;\n\n return new PaymentError(message, code);\n }\n}\n\n","import type { CardValidation } from '../types';\n\nexport class CardValidator {\n validateCardNumber(cardNumber: string): boolean {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (cleaned.length < 13 || cleaned.length > 19) {\n return false;\n }\n\n let sum = 0;\n let isEven = false;\n\n for (let i = cleaned.length - 1; i >= 0; i--) {\n let digit = parseInt(cleaned[i], 10);\n\n if (isEven) {\n digit *= 2;\n if (digit > 9) {\n digit -= 9;\n }\n }\n\n sum += digit;\n isEven = !isEven;\n }\n\n return sum % 10 === 0;\n }\n\n detectCardType(cardNumber: string): string {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (/^4/.test(cleaned)) return 'visa';\n if (/^5[1-5]/.test(cleaned)) return 'mastercard';\n if (/^3[47]/.test(cleaned)) return 'amex';\n if (/^6(?:011|5)/.test(cleaned)) return 'discover';\n\n return 'unknown';\n }\n\n validateExpiry(month: number, year: number): boolean {\n const now = new Date();\n const currentYear = now.getFullYear();\n const currentMonth = now.getMonth() + 1;\n\n if (month < 1 || month > 12) {\n return false;\n }\n\n const fullYear = year < 100 ? 2000 + year : year;\n\n if (fullYear < currentYear) {\n return false;\n }\n\n if (fullYear === currentYear && month < currentMonth) {\n return false;\n }\n\n return true;\n }\n\n validateCVC(cvc: string, cardType: string = 'unknown'): boolean {\n const cleaned = cvc.replace(/\\D/g, '');\n\n if (cardType === 'amex') {\n return cleaned.length === 4;\n }\n\n return cleaned.length === 3 || cleaned.length === 4;\n }\n\n validateAll(\n cardNumber: string,\n expiryMonth: number,\n expiryYear: number,\n cvc: string\n ): CardValidation {\n const cardType = this.detectCardType(cardNumber);\n\n return {\n number: {\n isValid: this.validateCardNumber(cardNumber),\n cardType: cardType as 'visa' | 'mastercard' | 'amex' | 'discover' | 'unknown',\n\n },\n expiry: {\n isValid: this.validateExpiry(expiryMonth, expiryYear),\n month: expiryMonth,\n year: expiryYear,\n },\n cvc: {\n isValid: this.validateCVC(cvc, cardType),\n length: cvc.replace(/\\D/g, '').length,\n },\n };\n }\n}\n","export class InputSanitizer {\n static sanitizeCardNumber(input: string): string {\n return input.replace(/\\D/g, '');\n }\n\n static formatCardNumber(input: string): string {\n const cleaned = this.sanitizeCardNumber(input);\n return cleaned.replace(/(\\d{4})/g, '$1 ').trim();\n }\n\n static sanitizeCVC(input: string): string {\n return input.replace(/\\D/g, '').slice(0, 4);\n }\n\n static sanitizeExpiry(input: string): { month: number; year: number } | null {\n const cleaned = input.replace(/\\D/g, '');\n\n if (cleaned.length === 4) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 4), 10),\n };\n } else if (cleaned.length === 6) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 6), 10),\n };\n }\n\n return null;\n }\n}\n","export { VerapayClient } from './client/verapay-client';\nexport { VerapayService } from './services/verapay-service';\n\nexport type {\n InitialisePaymentRequest,\n InitialisePaymentResponse,\n ProcessPrePaymentRequest,\n} from './services/verapay-service';\n\nexport type {\n VerapayConfig,\n ElementsConfig,\n ProcessPaymentRequest,\n PaymentResult,\n CardValidation,\n ErrorDetails,\n ErrorCode,\n} from './types';\n\nexport {\n VerapayError,\n ValidationError,\n PaymentError,\n ErrorFormatter,\n} from './errors';\n\nexport { CardValidator, InputSanitizer } from './validation';\n\nexport type {\n PaymentExtension,\n DatabaseExtension,\n AnalyticsExtension,\n} from './extensions';\n\nexport const VERSION = '1.1.0';\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/errors/verapay-error.ts","../src/errors/validation-error.ts","../src/errors/payment-error.ts","../src/errors/error-formatter.ts","../src/client/stripe-adapter.ts","../src/client/elements-manager.ts","../src/client/payment-extensions-manager.ts","../src/services/payment-service.ts","../src/services/setup-service.ts","../src/services/verapay-service.ts","../src/utils/secret.util.ts","../src/client/verapay-client.ts","../src/validation/card-validator.ts","../src/validation/input-sanitizer.ts","../src/index.ts"],"names":["VerapayError","_VerapayError","message","code","details","ValidationError","field","metadata","PaymentError","_PaymentError","stripeCode","ErrorFormatter","error","StripeAdapter","stripe","paymentMethodId","clientSecret","result","elements","isUsingIndividualFormElements","address","DEFAULT_CARD_ELEMENT_CONFIG","FIELD_LABELS","ElementsManager","config","selector","elementsConfig","element","mode","fieldType","options","formFieldType","elementType","errors","state","handleElementChange","event","PaymentExtensionsManager","extension","request","modifiedRequest","ext","PaymentService","stripeAdapter","elementsManager","verapayService","context","validation","paymentIntent","status","SetupService","setupIntent","paymentMethod","savedPaymentMethodId","VerapayService","baseUrl","apiKey","response","merchantId","paymentData","errorData","data","record","candidates","candidate","unwrapClientSecret","wrappedSecret","_VerapayClient","backendUrl","paymentIntentId","stripePublishableKey","loadStripe","paymentResult","expected","method","amount","currency","platformFee","uppercaseCurrency","paymentAmount","platformFeeAmount","value","fieldName","Money","VerapayClient","CardValidator","cardNumber","cleaned","sum","isEven","i","digit","month","year","now","currentYear","currentMonth","fullYear","cvc","cardType","expiryMonth","expiryYear","InputSanitizer","input","VERSION"],"mappings":"uFAGaA,CAAAA,CAAN,MAAMC,UAAqB,KAAM,CAItC,YACEC,CAAAA,CACAC,CAAAA,CAAAA,gBAAAA,CACAC,EACA,CACA,KAAA,CAAMF,CAAO,CAAA,CACb,IAAA,CAAK,KAAO,cAAA,CACZ,IAAA,CAAK,KAAOC,CAAAA,CACZ,IAAA,CAAK,QAAU,CACb,IAAA,CAAAA,EACA,OAAA,CAAAD,CAAAA,CACA,iBAAkB,IAAA,CAAK,aAAA,CAAcA,EAASC,CAAI,CAAA,CAClD,GAAGC,CACL,CAAA,CAEI,KAAA,CAAM,iBAAA,EACR,KAAA,CAAM,iBAAA,CAAkB,KAAMH,CAAY,EAE9C,CAEQ,aAAA,CAAcC,CAAAA,CAAiBC,EAAyB,CAsB9D,OArB8C,CAC3C,gBAAA,CACC,sDAAA,CACD,eACC,wDAAA,CACD,qBAAA,CACC,mDACD,aAAA,CACC,4DAAA,CACD,aACC,gDAAA,CACD,mBAAA,CACC,8CAAA,CACD,aAAA,CACC,gEAAA,CACD,kBAAA,CACC,6DACD,YAAA,CACC,+DACJ,EAEkBA,CAAI,CAAA,EAAKD,CAC7B,CAEA,MAAA,EAAS,CACP,OAAO,CACL,KAAM,IAAA,CAAK,IAAA,CACX,KAAM,IAAA,CAAK,IAAA,CACX,QAAS,IAAA,CAAK,OAAA,CACd,OAAA,CAAS,IAAA,CAAK,OAChB,CACF,CACF,ECzDO,IAAMG,EAAN,cAA8BL,CAAa,CAChD,WAAA,CAAYE,CAAAA,CAAiBI,EAAgBC,CAAAA,CAAoC,CAE/E,MAAML,CAAAA,CAAAA,kBAAAA,CAAqC,CACzC,MAAAI,CAAAA,CACA,QAAA,CAAAC,CACF,CAAC,CAAA,CACD,IAAA,CAAK,IAAA,CAAO,kBACd,CACF,ECTO,IAAMC,CAAAA,CAAN,MAAMC,CAAAA,SAAqBT,CAAa,CAC7C,WAAA,CACEE,CAAAA,CACAQ,EACAH,CAAAA,CACA,CACA,IAAMJ,CAAAA,CAAOM,CAAAA,CAAa,cAAcC,CAAU,CAAA,CAClD,MAAMR,CAAAA,CAASC,CAAAA,CAAM,CACnB,UAAA,CAAAO,CAAAA,CACA,QAAA,CAAAH,CACF,CAAC,CAAA,CACD,KAAK,IAAA,CAAO,eACd,CAEA,OAAe,aAAA,CAAcG,EAAgC,CAC3D,OAAKA,EAEsC,CACzC,aAAA,CAAA,eAAA,CACA,wCACA,YAAA,CAAA,cAAA,CACA,aAAA,CAAA,kBAAA,CACA,kCACA,qBAAA,CAAA,uBACF,CAAA,CAEeA,CAAU,CAAA,EAAK,gBAAA,CAAA,gBAChC,CACF,EC7BO,IAAMC,CAAAA,CAAN,KAAqB,CAC1B,OAAO,cAAcC,CAAAA,CAAqC,CACxD,OAAI,kBAAA,GAAsBA,CAAAA,CACjBA,EAAM,gBAAA,CAGb,SAAA,GAAaA,GACbA,CAAAA,CAAM,OAAA,EACN,OAAOA,CAAAA,CAAM,OAAA,EAAY,QAAA,EACzB,kBAAA,GAAsBA,CAAAA,CAAM,OAAA,EAC5B,OAAOA,CAAAA,CAAM,OAAA,CAAQ,kBAAqB,QAAA,CAEnCA,CAAAA,CAAM,QAAQ,gBAAA,CAEhB,iDACT,CAEA,OAAO,kBAAA,CAAmBA,EAAqC,CAC7D,OAAI,SAAUA,CAAAA,EAAS,SAAA,GAAaA,EAC3B,CAAA,CAAA,EAAIA,CAAAA,CAAM,IAAI,CAAA,EAAA,EAAKA,CAAAA,CAAM,OAAO,GAElCA,CAAAA,CAAM,OAAA,EAAW,eAC1B,CAEA,OAAO,OAAOA,CAAAA,CAAsD,CAElE,OAAI,QAAA,GAAYA,CAAAA,EAAS,OAAOA,CAAAA,CAAM,MAAA,EAAW,WACxCA,CAAAA,CAAM,MAAA,GAGR,CACL,IAAA,CAAOA,CAAAA,CAAgB,IAAA,EAAQ,OAAA,CAC/B,OAAA,CAASA,EAAM,OAAA,CACf,GAAI,SAAUA,CAAAA,EAAS,CAAE,KAAMA,CAAAA,CAAM,IAAK,EAC1C,GAAI,SAAA,GAAaA,GAAS,CAAE,OAAA,CAASA,EAAM,OAAQ,CACrD,CACF,CACF,ECpCO,IAAMC,CAAAA,CAAN,KAAoB,CACzB,YAAoBC,CAAAA,CAAgB,CAAhB,YAAAA,EAAiB,CAErC,MAAM,cAAA,CACJC,CAAAA,CACAC,EAC2C,CAC3C,IAAMC,EAAS,MAAM,IAAA,CAAK,OAAO,cAAA,CAAe,CAC9C,aAAAD,CAAAA,CACA,aAAA,CAAe,CACb,cAAA,CAAgBD,CAAAA,CAChB,UAAA,CAAY,OAAO,QAAA,CAAS,IAC9B,EACA,QAAA,CAAU,aACZ,CAAC,CAAA,CAED,GAAIE,EAAO,KAAA,CACT,MAAM,IAAIT,CAAAA,CACRS,CAAAA,CAAO,MAAM,OAAA,EAAW,gBAAA,CACxBA,EAAO,KAAA,CAAM,IACf,CAAA,CAGF,OAAOA,CACT,CAEA,MAAM,kBAAA,CACJF,CAAAA,CACAC,EAC2C,CAC3C,IAAMC,EAAS,MAAM,IAAA,CAAK,OAAO,kBAAA,CAAmBD,CAAAA,CAAc,CAChE,cAAA,CAAgBD,CAClB,CAAC,CAAA,CAED,GAAIE,EAAO,KAAA,CACT,MAAM,IAAIT,CAAAA,CACRS,CAAAA,CAAO,KAAA,CAAM,SAAW,gBAAA,CACxBA,CAAAA,CAAO,MAAM,IACf,CAAA,CAGF,OAAOA,CACT,CAEA,MAAM,mBAAA,CACJC,CAAAA,CACAC,EAAyC,KAAA,CACxB,CACjB,IAAIF,CAAAA,CAEJ,GAAI,CAACE,CAAAA,CACHF,CAAAA,CAAS,MAAM,IAAA,CAAK,MAAA,CAAO,mBAAA,CAAoB,CAC7C,QAAA,CAAAC,CACF,CAAC,CAAA,CAAA,KACI,CAIL,IAAME,CAAAA,CAAAA,CAFiB,MAAMF,EAAS,UAAA,CAAW,SAAA,CAAW,CAAE,IAAA,CAAM,SAAU,CAAC,CAAA,CAAG,QAAA,IAElD,KAAA,CAEhCD,CAAAA,CAAS,MAAM,IAAA,CAAK,MAAA,CAAO,mBAAA,CAAoB,CAC7C,IAAA,CAAM,MAAA,CACN,KAAMC,CAAAA,CAAS,UAAA,CAAW,YAAY,CAAA,CACtC,eAAA,CAAiB,CACf,IAAA,CAAME,CAAAA,CAAQ,KACd,OAAA,CAAS,CACP,GAAGA,CAAAA,CAAQ,OAAA,CACX,MAAOA,CAAAA,CAAQ,OAAA,CAAQ,OAAS,MAClC,CACF,CACF,CAAC,EACH,CAEA,GAAIH,CAAAA,CAAO,OAAS,CAACA,CAAAA,CAAO,cAC1B,MAAM,IAAIT,EACRS,CAAAA,CAAO,KAAA,EAAO,SAAW,iCAAA,CACzBA,CAAAA,CAAO,OAAO,IAChB,CAAA,CAGF,OAAOA,CAAAA,CAAO,aAAA,CAAc,EAC9B,CAEA,MAAM,qBAAA,CACJD,EAC2C,CAC3C,IAAMC,EAAS,MAAM,IAAA,CAAK,OAAO,qBAAA,CAAsBD,CAAY,EAEnE,GAAIC,CAAAA,CAAO,MACT,MAAM,IAAIT,EACRS,CAAAA,CAAO,KAAA,CAAM,OAAA,EAAW,mCAAA,CACxBA,CAAAA,CAAO,KAAA,CAAM,IACf,CAAA,CAGF,OAAOA,CACT,CAEA,MAAM,iBACJF,CAAAA,CACAC,CAAAA,CACuC,CACvC,IAAMC,CAAAA,CAAS,MAAM,IAAA,CAAK,MAAA,CAAO,iBAAiBD,CAAAA,CAAc,CAC9D,eAAgBD,CAClB,CAAC,CAAA,CAED,GAAIE,CAAAA,CAAO,KAAA,CACT,MAAM,IAAIT,CAAAA,CAAaS,EAAO,KAAA,CAAM,OAAA,EAAW,oBAAqBA,CAAAA,CAAO,KAAA,CAAM,IAAI,CAAA,CAGvF,OAAOA,CACT,CAEA,MAAM,oBAAoBD,CAAAA,CAA6D,CACrF,IAAMC,CAAAA,CAAS,MAAM,IAAA,CAAK,MAAA,CAAO,mBAAA,CAAoBD,CAAY,EAEjE,GAAIC,CAAAA,CAAO,MACT,MAAM,IAAIT,EACRS,CAAAA,CAAO,KAAA,CAAM,SAAW,iCAAA,CACxBA,CAAAA,CAAO,MAAM,IACf,CAAA,CAGF,OAAOA,CACT,CACF,ECnHA,IAAMI,CAAAA,CAA8B,CAClC,QAAA,CAAU,IAAA,CACV,SAAA,CAAW,QACX,YAAA,CAAc,CACZ,WAAY,qBAAA,CACZ,UAAA,CAAY,oBACZ,OAAA,CAAS,KACX,EACA,KAAA,CAAO,CACL,KAAM,CACJ,KAAA,CAAO,UACP,UAAA,CAAY,sCAAA,CACZ,SAAU,MAAA,CACV,eAAA,CAAiB,CAAE,KAAA,CAAO,SAAU,CACtC,EACA,QAAA,CAAU,CACR,MAAO,SACT,CAAA,CACA,MAAO,EAAC,CACR,QAAS,CACP,KAAA,CAAO,SACT,CACF,CACF,EAEMC,CAAAA,CAAuC,CAC3C,WAAY,aAAA,CACZ,UAAA,CAAY,aAAA,CACZ,OAAA,CAAS,KAAA,CACT,OAAA,CAAS,SACX,CAAA,CAEaC,CAAAA,CAAN,KAAsB,CAK3B,WAAA,CACUT,EACAU,CAAAA,CACAR,CAAAA,CACR,CAHQ,IAAA,CAAA,MAAA,CAAAF,CAAAA,CACA,YAAAU,CAAAA,CACA,IAAA,CAAA,YAAA,CAAAR,EAPV,IAAA,CAAQ,QAAA,CAAkC,KAC1C,IAAA,CAAQ,eAAA,CAA8C,IAAI,GAAA,CAC1D,IAAA,CAAQ,aAAA,CAA2C,IAAI,GAAA,CAOrD,GAAI,CAACA,CAAAA,CACH,MAAM,IAAIhB,CAAAA,CACR,+BAAA,CAAA,qBAEF,CAEJ,CAGA,mBAAA,CAAoByB,EAAwB,CAC1C,GAAI,CAAC,IAAA,CAAK,QAAA,CAAU,CAClB,IAAMC,CAAAA,CAAiB,CACrB,YAAA,CAAc,IAAA,CAAK,YAAA,CACnB,WAAY,IAAA,CAAK,MAAA,CAAO,WACxB,MAAA,CAAQ,IAAA,CAAK,OAAO,MAAA,CACpB,KAAA,CAAO,KAAK,MAAA,CAAO,KAAA,CACnB,sBAAuB,QACzB,CAAA,CAEA,KAAK,QAAA,CAAW,IAAA,CAAK,OAAO,QAAA,CAASA,CAAc,EACrD,CAIA,GAAI,CAFc,SAAS,aAAA,CAAcD,CAAQ,EAG/C,MAAM,IAAIzB,EACR,CAAA,mBAAA,EAAsByB,CAAQ,wBAEhC,CAAA,CAGF,IAAME,EAAU,IAAA,CAAK,QAAA,CAAS,OAAO,SAAA,CAAW,CAC9C,OAAQ,MAAA,CACR,OAAA,CAAS,CAAE,IAAA,CAAM,OAAQ,CAC3B,CAAC,CAAA,CAEDA,CAAAA,CAAQ,MAAMF,CAAQ,CAAA,CACtB,KAAK,eAAA,CAAgB,GAAA,CAAI,UAAWE,CAAO,EAC7C,CAEA,sBAAA,CAAuBF,CAAAA,CAAwB,CAC7C,IAAA,CAAK,0BAAA,CAA2BA,EAAU,YAAA,CAAc,IAAA,CAAK,kBAAA,CAAmB,YAAY,CAAC,EAC/F,CAEA,sBAAA,CAAuBA,CAAAA,CAAwB,CAC7C,IAAA,CAAK,0BAAA,CAA2BA,EAAU,YAAA,CAAc,IAAA,CAAK,mBAAmB,YAAY,CAAC,EAC/F,CAEA,mBAAA,CAAoBA,EAAwB,CAC1C,IAAA,CAAK,2BAA2BA,CAAAA,CAAU,SAAA,CAAW,IAAA,CAAK,kBAAA,CAAmB,SAAS,CAAC,EACzF,CAEA,mBAAA,CAAoBA,EAAkBG,CAAAA,CAAoC,CACxE,KAAK,0BAAA,CAA2BH,CAAAA,CAAU,UAAW,CAAE,IAAA,CAAAG,CAAK,CAAC,EAC/D,CAEQ,kBAAA,CAAmBC,CAAAA,CAA6E,CACtG,GAAM,CAAE,cAAA,CAAAH,CAAe,CAAA,CAAI,IAAA,CAAK,OAC1BI,CAAAA,CAAmC,CACvC,YAAaJ,CAAAA,EAAgB,YAAA,GAAeG,CAAS,CAAA,EAAKR,CAAAA,CAA4B,aAAaQ,CAAS,CAAA,CAC5G,MAAO,CACL,IAAA,CAAM,CAAE,GAAGR,CAAAA,CAA4B,MAAM,IAAA,CAAM,GAAGK,CAAAA,EAAgB,KAAA,EAAO,IAAK,CAAA,CAClF,SAAU,CAAE,GAAGL,EAA4B,KAAA,CAAM,QAAA,CAAU,GAAGK,CAAAA,EAAgB,KAAA,EAAO,QAAS,CAAA,CAC9F,KAAA,CAAO,CAAE,GAAGL,CAAAA,CAA4B,MAAM,KAAA,CAAO,GAAGK,GAAgB,KAAA,EAAO,KAAM,EACrF,OAAA,CAAS,CAAE,GAAGL,CAAAA,CAA4B,KAAA,CAAM,QAAS,GAAGK,CAAAA,EAAgB,OAAO,OAAQ,CAC7F,CACF,CAAA,CAEA,OAAIG,IAAc,YAAA,GAChBC,CAAAA,CAAQ,SAAWJ,CAAAA,EAAgB,QAAA,EAAYL,EAA4B,QAAA,CAC3ES,CAAAA,CAAQ,SAAA,CAAYJ,CAAAA,EAAgB,SAAA,EAAaL,CAAAA,CAA4B,WAGxES,CACT,CAEQ,2BAA2BL,CAAAA,CAAkBM,CAAAA,CAAoED,EAAoC,CAG3J,GAAI,CAFc,QAAA,CAAS,aAAA,CAAcL,CAAQ,CAAA,CAG/C,MAAM,IAAIzB,CAAAA,CACR,CAAA,mBAAA,EAAsByB,CAAQ,CAAA,CAAA,CAAA,qBAEhC,CAAA,CAGF,IAAME,CAAAA,CAAU,IAAA,CAAK,2BAAA,CAA4BI,EAAeD,CAAO,CAAA,CACvEH,EAAQ,KAAA,CAAMF,CAAQ,EAEtB,IAAA,CAAK,eAAA,CAAgB,IAAIM,CAAAA,CAAeJ,CAAO,EAC/C,IAAA,CAAK,iBAAA,CAAkBI,EAAeJ,CAAO,EAC/C,CAEQ,2BAAA,CACNK,CAAAA,CACAF,CAAAA,CACe,CACf,OAAK,IAAA,CAAK,WACR,IAAA,CAAK,QAAA,CAAW,KAAK,MAAA,CAAO,QAAA,CAAS,CACnC,UAAA,CAAY,IAAA,CAAK,OAAO,UAAA,CACxB,MAAA,CAAQ,KAAK,MAAA,CAAO,MAAA,CACpB,MAAO,IAAA,CAAK,MAAA,CAAO,MACnB,qBAAA,CAAuB,QACzB,CAAC,CAAA,CAAA,CAGI,IAAA,CAAK,QAAA,CAAS,OAAOE,CAAAA,CAA6BF,CAAO,CAClE,CAIA,MAAM,UAAsC,CAC1C,IAAMG,EAA4B,EAAC,CAEnC,OAAW,CAAC3B,CAAAA,CAAO4B,CAAK,CAAA,GAAK,IAAA,CAAK,cAAc,OAAA,EAAQ,CACjDA,CAAAA,CAAM,QAAA,EACTD,CAAAA,CAAO,IAAA,CAAK,CACV,KAAA,CAAA3B,CAAAA,CACA,QAAS4B,CAAAA,CAAM,KAAA,EAAS,GAAGZ,CAAAA,CAAahB,CAAK,GAAKA,CAAK,CAAA,kBAAA,CACzD,CAAC,CAAA,CAIL,OAAO,CAAE,OAAA,CAAS2B,CAAAA,CAAO,SAAW,CAAA,CAAG,MAAA,CAAAA,CAAO,CAChD,CAEA,WAAA,EAAqC,CACnC,OAAO,IAAA,CAAK,QACd,CAEA,UAAA,EAAmB,CACjB,IAAA,IAAWN,CAAAA,IAAW,KAAK,eAAA,CAAgB,MAAA,GACzCA,CAAAA,CAAQ,OAAA,GAEV,IAAA,CAAK,eAAA,CAAgB,OAAM,CAC3B,IAAA,CAAK,aAAA,CAAc,KAAA,GACrB,CAEQ,kBAAkBrB,CAAAA,CAAeqB,CAAAA,CAA8B,CACrE,IAAA,CAAK,aAAA,CAAc,IAAIrB,CAAAA,CAAO,CAAE,SAAU,KAAM,CAAC,EAEjD,IAAM6B,CAAAA,CAAuBC,GAA8D,CACzF,IAAA,CAAK,cAAc,GAAA,CAAI9B,CAAAA,CAAO,CAAE,QAAA,CAAU8B,CAAAA,CAAM,QAAA,CAAU,MAAOA,CAAAA,CAAM,KAAA,EAAO,OAAQ,CAAC,EACzF,EAECT,CAAAA,CAAsF,EAAA,CACrF,SACAQ,CACF,EACF,CACF,CAAA,CC1MO,IAAME,EAAN,KAA+B,CAA/B,cACL,IAAA,CAAQ,UAAA,CAAiC,GAAC,CAE1C,GAAA,CAAIC,CAAAA,CAAmC,CACrC,IAAA,CAAK,UAAA,CAAW,KAAKA,CAAS,EAChC,CAEA,MAAM,gBAAA,CAAiBC,EAAgE,CACrF,IAAIC,EAAkBD,CAAAA,CACtB,IAAA,IAAWE,KAAO,IAAA,CAAK,UAAA,CACjBA,EAAI,aAAA,GACND,CAAAA,CAAkB,MAAMC,CAAAA,CAAI,aAAA,CAAcD,CAAe,GAG7D,OAAOA,CACT,CAEA,MAAM,eAAA,CAAgBvB,EAAsC,CAC1D,MAAM,QAAQ,GAAA,CACZ,IAAA,CAAK,WACF,MAAA,CAAQwB,CAAAA,EAAQA,EAAI,YAAY,CAAA,CAChC,IAAKA,CAAAA,EAAQA,CAAAA,CAAI,YAAA,CAAcxB,CAAM,CAAC,CAC3C,EACF,CAEA,MAAM,WAAWL,CAAAA,CAA6B,CAC5C,MAAM,OAAA,CAAQ,GAAA,CACZ,KAAK,UAAA,CACF,MAAA,CAAQ6B,GAAQA,CAAAA,CAAI,cAAc,EAClC,GAAA,CAAKA,CAAAA,EAAQA,EAAI,cAAA,CAAgB7B,CAAK,CAAC,CAC5C,EACF,CACF,EClBO,IAAM8B,CAAAA,CAAN,KAAqB,CAC1B,WAAA,CACUC,EACAC,CAAAA,CACAC,CAAAA,CACR,CAHQ,IAAA,CAAA,aAAA,CAAAF,CAAAA,CACA,qBAAAC,CAAAA,CACA,IAAA,CAAA,cAAA,CAAAC,EACP,CAEH,MAAM,QAAQN,CAAAA,CAAgCO,CAAAA,CAAwD,CACpG,IAAM5B,CAAAA,CAAW,IAAA,CAAK,gBAAgB,WAAA,EAAY,CAElD,MAAM,IAAA,CAAK,yBAAA,CAA0BA,EAAU4B,CAAO,CAAA,CAEtD,MAAM5B,CAAAA,CAAU,MAAA,GAEhB,IAAMH,CAAAA,CAAkB,MAAM,IAAA,CAAK,aAAA,CAAc,oBAC/CG,CAAAA,CACA4B,CAAAA,CAAQ,6BACV,CAAA,CAEA,OAAA,MAAM,IAAA,CAAK,eAAe,iBAAA,CAAkB,CAC1C,WAAYA,CAAAA,CAAQ,UAAA,CACpB,gBAAiBA,CAAAA,CAAQ,eAAA,CACzB,gBAAA/B,CAAAA,CACA,MAAA,CAAQ+B,EAAQ,MAAA,CAChB,QAAA,CAAUA,EAAQ,QAAA,CAClB,YAAA,CAAc,CACZ,KAAA,CAAOP,CAAAA,CAAQ,aAAA,CACf,SAAA,CAAWA,CAAAA,CAAQ,iBAAA,CACnB,SAAUA,CAAAA,CAAQ,gBACpB,EACA,WAAA,CAAaA,CAAAA,CAAQ,YACrB,QAAA,CAAUA,CAAAA,CAAQ,QACpB,CAAC,CAAA,CAEM,KAAK,OAAA,CAAQO,CAAAA,CAAQ,aAAc,CACxC,eAAA,CAAA/B,EACA,2BAAA,CAA6B+B,CAAAA,CAAQ,4BACrC,6BAAA,CAA+BA,CAAAA,CAAQ,6BACzC,CAAC,CACH,CAEA,MAAc,yBAAA,CACZ5B,EACA4B,CAAAA,CACA,CACA,GAAI,CAAC5B,CAAAA,CACH,MAAM,IAAIlB,CAAAA,CAAa,gDAAyD,CAAA,CAGlF,GAAI8C,EAAQ,2BAAA,EAA+BA,CAAAA,CAAQ,6BAAA,CACjD,MAAM,IAAI9C,CAAAA,CAAa,mCAAmC,CAAA,CAG5D,GAAI8C,EAAQ,6BAAA,CAA+B,CACzC,IAAMC,CAAAA,CAAa,MAAM,KAAK,eAAA,CAAgB,QAAA,GAC9C,GAAI,CAACA,EAAW,OAAA,CACd,MAAM,IAAI/C,CAAAA,CAAa+C,CAAAA,CAAW,MAAA,CAAO,CAAC,CAAA,CAAE,OAAA,CAAA,kBAAmC,CAEnF,CACF,CAEA,MAAM,OAAA,CACJ/B,CAAAA,CACAc,EAII,EAAC,CACmB,CACxB,IAAIb,CAAAA,CAEJ,OAAIa,CAAAA,CAAQ,2BAAA,CACVb,EAAS,MAAM,IAAA,CAAK,cAAc,cAAA,CAAea,CAAAA,CAAQ,eAAA,EAAmB,EAAA,CAAId,CAAY,CAAA,CACnFc,EAAQ,6BAAA,CACjBb,CAAAA,CAAS,MAAM,IAAA,CAAK,aAAA,CAAc,mBAChCa,CAAAA,CAAQ,eAAA,EAAmB,GAC3Bd,CACF,CAAA,CAEAC,EAAS,MAAM,IAAA,CAAK,cAAc,cAAA,CAAea,CAAAA,CAAQ,iBAAmB,EAAA,CAAId,CAAY,CAAA,CAGvF,IAAA,CAAK,mBAAA,CAAoBC,CAAM,CACxC,CAEA,MAAM,sBAAsBD,CAAAA,CAA8C,CACxE,IAAMC,CAAAA,CAAS,MAAM,KAAK,aAAA,CAAc,qBAAA,CAAsBD,CAAY,CAAA,CAC1E,OAAO,KAAK,mBAAA,CAAoBC,CAAM,CACxC,CAEQ,mBAAA,CAAoBA,CAAAA,CAAgC,CAC1D,IAAM+B,CAAAA,CAAiB/B,EACpB,aAAA,CAECgC,CAAAA,CAAgD,SACpD,OAAID,CAAAA,CAAc,SAAW,WAAA,CAC3BC,CAAAA,CAAS,YAET,CAAC,YAAA,CAAc,kBAAmB,uBAAuB,CAAA,CAAE,SACzDD,CAAAA,CAAc,MAChB,IAEAC,CAAAA,CAAS,YAAA,CAAA,CAGJ,CACL,OAAA,CAASD,CAAAA,CAAc,MAAA,GAAW,YAClC,eAAA,CAAiBA,CAAAA,CAAc,GAC/B,MAAA,CAAAC,CACF,CACF,CAEF,CAAA,CCtHO,IAAMC,CAAAA,CAAN,KAAmB,CACxB,WAAA,CACUP,CAAAA,CACAC,EACR,CAFQ,IAAA,CAAA,aAAA,CAAAD,EACA,IAAA,CAAA,eAAA,CAAAC,EACP,CAEH,MAAM,IAAA,CAAK5B,CAAAA,CAAsB8B,EAAgD,CAC/E,IAAM5B,EAAW,IAAA,CAAK,eAAA,CAAgB,aAAY,CAElD,MAAM,KAAK,uBAAA,CAAwBA,CAAAA,CAAU4B,CAAO,CAAA,CAEpD,MAAM5B,EAAU,MAAA,EAAO,CAEvB,IAAMH,CAAAA,CAAkB,MAAM,IAAA,CAAK,aAAA,CAAc,mBAAA,CAC/CG,CAAAA,CACA4B,EAAQ,6BACV,CAAA,CAEM7B,EAAS,MAAM,IAAA,CAAK,cAAc,gBAAA,CAAiBF,CAAAA,CAAiBC,CAAY,CAAA,CAEtF,OAAO,KAAK,iBAAA,CAAkBC,CAAM,CACtC,CAEA,MAAM,SAASD,CAAAA,CAA4C,CACzD,IAAMC,CAAAA,CAAS,MAAM,IAAA,CAAK,cAAc,mBAAA,CAAoBD,CAAY,EACxE,OAAO,IAAA,CAAK,kBAAkBC,CAAM,CACtC,CAEA,MAAc,uBAAA,CACZC,EACA4B,CAAAA,CACe,CACf,GAAI,CAAC5B,CAAAA,CACH,MAAM,IAAIlB,CAAAA,CAAa,uBAAA,CAAA,qBAAsD,CAAA,CAG/E,GAAI8C,CAAAA,CAAQ,6BAA+BA,CAAAA,CAAQ,6BAAA,CACjD,MAAM,IAAI9C,CAAAA,CAAa,sDAA+D,CAAA,CAGxF,GAAI8C,EAAQ,6BAAA,CAA+B,CACzC,IAAMC,CAAAA,CAAa,MAAM,KAAK,eAAA,CAAgB,QAAA,GAC9C,GAAI,CAACA,CAAAA,CAAW,OAAA,CACd,MAAM,IAAI/C,EAAa+C,CAAAA,CAAW,MAAA,CAAO,CAAC,CAAA,CAAE,OAAA,CAAA,kBAAmC,CAEnF,CACF,CAEQ,kBAAkB9B,CAAAA,CAA8B,CACtD,IAAMkC,CAAAA,CACJlC,CAAAA,CACA,YAEEgC,CAAAA,CAAgC,QAAA,CAChCE,EAAY,MAAA,GAAW,WAAA,CACzBF,CAAAA,CAAS,WAAA,CACAE,CAAAA,CAAY,MAAA,GAAW,aAChCF,CAAAA,CAAS,YAAA,CAAA,CAETE,EAAY,MAAA,GAAW,iBAAA,EACvBA,EAAY,MAAA,GAAW,uBAAA,IAEvBF,EAAS,iBAAA,CAAA,CAGX,IAAMG,EAAgBD,CAAAA,CAAY,cAAA,CAC5BE,EACJ,OAAOD,CAAAA,EAAkB,SACrBA,CAAAA,CACCA,CAAAA,EAA+C,EAAA,CAEtD,OAAO,CACL,OAAA,CAASD,EAAY,MAAA,GAAW,WAAA,CAChC,qBAAAE,CAAAA,CACA,aAAA,CAAeF,EAAY,EAAA,CAC3B,MAAA,CAAAF,CACF,CACF,CACF,EC9DO,IAAMK,CAAAA,CAAN,KAAqB,CAI1B,WAAA,CAAYC,EAAiBC,CAAAA,CAAiB,CAC5C,IAAA,CAAK,OAAA,CAAUD,CAAAA,CACf,IAAA,CAAK,OAASC,EAChB,CAEA,UAAUA,CAAAA,CAAsB,CAC9B,KAAK,MAAA,CAASA,EAChB,CAGA,MAAM,sBAAA,CAAuBxC,EAAwD,CAEnF,GAAI,CACF,IAAMyC,CAAAA,CAAW,MAAM,KAAA,CACrB,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,yCAAA,EAA4C,kBAAA,CACzDzC,CACF,CAAC,CAAA,CAAA,CACD,CACE,MAAA,CAAQ,KAAA,CACR,QAAS,CACP,cAAA,CAAgB,kBAClB,CACF,CACF,EAEA,GAAI,CAACyC,EAAS,EAAA,CACZ,MAAM,IAAIzD,CAAAA,CAAa,iCAAA,CAAA,qBAAgE,EAGzF,OAAOyD,CAAAA,CAAS,MAClB,CAAA,MAAS7C,EAAO,CACd,MAAIA,aAAiBZ,CAAAA,CAAoBY,CAAAA,CACnC,IAAIZ,CAAAA,CAAa,iCAAA,CAAA,eAA0D,CACnF,CACF,CAEA,MAAM,oBAAA,CAAqBgB,CAAAA,CAAwD,CACjF,GAAI,CACF,IAAMyC,CAAAA,CAAW,MAAM,KAAA,CACrB,GAAG,IAAA,CAAK,OAAO,0CAA0C,kBAAA,CACvDzC,CACF,CAAC,CAAA,CAAA,CACD,CACE,OAAQ,KAAA,CACR,OAAA,CAAS,CACP,cAAA,CAAgB,kBAClB,CACF,CACF,CAAA,CAEA,GAAI,CAACyC,CAAAA,CAAS,EAAA,CACZ,MAAM,IAAIzD,CAAAA,CAAa,oDAA6D,CAAA,CAGtF,OAAOyD,EAAS,IAAA,EAClB,OAAS7C,CAAAA,CAAO,CACd,MAAIA,CAAAA,YAAiBZ,CAAAA,CAAoBY,EACnC,IAAIZ,CAAAA,CAAa,iDAA0D,CACnF,CACF,CAGA,MAAM,iBAAA,CACJuC,CAAAA,CACoC,CACpC,GAAM,CAAE,WAAAmB,CAAAA,CAAY,WAAA,CAAAC,CAAY,CAAA,CAAIpB,CAAAA,CAEpC,GAAI,CACF,IAAMkB,EAAW,MAAM,KAAA,CAAM,GAAG,IAAA,CAAK,OAAO,0BAA2B,CACrE,MAAA,CAAQ,OACR,OAAA,CAAS,CACP,cAAA,CAAgB,kBAAA,CAChB,GAAI,IAAA,CAAK,OAAS,CAAE,WAAA,CAAa,KAAK,MAAO,CAAA,CAAI,EACnD,CAAA,CAEA,KAAM,IAAA,CAAK,SAAA,CAAU,CACnB,UAAA,CAAAC,CAAAA,CACA,YAAa,CAAE,GAAGC,EAAa,iBAAA,CAAmB,MAAO,CAC3D,CAAC,CACH,CAAC,EAED,GAAI,CAACF,EAAS,EAAA,CAAI,CAChB,IAAMG,CAAAA,CAAY,MAAMH,EAAS,IAAA,EAAK,CAAE,MAAM,KAAO,GAAG,CAAA,CACxD,MAAM,IAAIzD,CAAAA,CACR,IAAA,CAAK,mBAAA,CAAoB4D,CAAAA,CAAWH,CAAAA,CAAS,MAAM,uBAErD,CACF,CAEA,IAAMI,CAAAA,CAAO,MAAMJ,EAAS,IAAA,EAAK,CAEjC,GAAI,CAACI,CAAAA,CAAK,cAAgB,CAACA,CAAAA,CAAK,gBAC9B,MAAM,IAAI7D,EACR,4DAAA,CAAA,qBAEF,CAAA,CAGF,OAAO,CACL,eAAA,CAAiB6D,CAAAA,CAAK,gBACtB,YAAA,CAAcA,CAAAA,CAAK,aACnB,gBAAA,CAAkBA,CAAAA,CAAK,iBACvB,oBAAA,CAAsBA,CAAAA,CAAK,oBAC7B,CACF,CAAA,MAASjD,EAAO,CACd,MAAIA,aAAiBZ,CAAAA,CACbY,CAAAA,CAEF,IAAIZ,CAAAA,CACRY,CAAAA,YAAiB,KAAA,CAAQA,CAAAA,CAAM,OAAA,CAAU,wBAAA,CAAA,qBAE3C,CACF,CACF,CAEA,MAAM,iBAAA,CAAkB2B,CAAAA,CAAkD,CACxE,GAAI,CACF,IAAMkB,CAAAA,CAAW,MAAM,MAAM,CAAA,EAAG,IAAA,CAAK,OAAO,CAAA,uBAAA,CAAA,CAA2B,CACrE,OAAQ,MAAA,CACR,OAAA,CAAS,CACP,cAAA,CAAgB,kBAAA,CAChB,GAAI,KAAK,MAAA,CAAS,CAAE,YAAa,IAAA,CAAK,MAAO,EAAI,EACnD,EAEA,IAAA,CAAM,IAAA,CAAK,UAAU,CACnB,UAAA,CAAYlB,EAAQ,UAAA,CACpB,eAAA,CAAiBA,EAAQ,eAAA,CACzB,eAAA,CAAiBA,CAAAA,CAAQ,eAAA,CACzB,MAAA,CAAQA,CAAAA,CAAQ,OAChB,QAAA,CAAUA,CAAAA,CAAQ,SAClB,YAAA,CAAcA,CAAAA,CAAQ,aACtB,WAAA,CAAaA,CAAAA,CAAQ,YACrB,QAAA,CAAUA,CAAAA,CAAQ,QACpB,CAAC,CACH,CAAC,CAAA,CAED,GAAI,CAACkB,CAAAA,CAAS,EAAA,CAAI,CAChB,IAAMG,CAAAA,CAAY,MAAMH,EAAS,IAAA,EAAK,CAAE,MAAM,KAAO,GAAG,CAAA,CACxD,MAAM,IAAIzD,CAAAA,CACR,IAAA,CAAK,oBAAoB4D,CAAAA,CAAWH,CAAAA,CAAS,MAAM,CAAA,CAAA,qBAErD,CACF,CACF,CAAA,MAAS7C,CAAAA,CAAO,CACd,MAAIA,CAAAA,YAAiBZ,CAAAA,CACbY,EAEF,IAAIZ,CAAAA,CACRY,aAAiB,KAAA,CAAQA,CAAAA,CAAM,QAAU,wBAAA,CAAA,qBAE3C,CACF,CACF,CAEQ,mBAAA,CAAoBgD,EAAoBX,CAAAA,CAAwB,CACtE,GAAI,CAACW,CAAAA,EAAa,OAAOA,CAAAA,EAAc,QAAA,CACrC,OAAO,CAAA,oBAAA,EAAuBX,CAAM,CAAA,CAAA,CAGtC,IAAMa,CAAAA,CAASF,CAAAA,CACTG,EAAa,CAACD,CAAAA,CAAO,MAAOA,CAAAA,CAAO,OAAA,CAASA,EAAO,OAAO,CAAA,CAEhE,QAAWE,CAAAA,IAAaD,CAAAA,CAAY,CAClC,GAAI,OAAOC,GAAc,QAAA,EAAYA,CAAAA,CAAU,IAAA,EAAK,CAAE,MAAA,CAAS,CAAA,CAC7D,OAAOA,CAAAA,CAGT,GAAIA,GAAa,OAAOA,CAAAA,EAAc,SACpC,GAAI,CACF,OAAO,IAAA,CAAK,SAAA,CAAUA,CAAS,CACjC,CAAA,KAAQ,CAER,CAEJ,CAEA,OAAO,CAAA,oBAAA,EAAuBf,CAAM,CAAA,CACtC,CACF,ECjNO,SAASgB,EAAmBC,CAAAA,CAA+B,CAChE,OAAIA,CAAAA,CAAc,UAAA,CAAW,cAAc,CAAA,CAClCA,CAAAA,CAAc,QAAQ,cAAA,CAAgB,EAAE,EAE7CA,CAAAA,CAAc,UAAA,CAAW,cAAc,CAAA,CAClCA,CAAAA,CAAc,QAAQ,cAAA,CAAgB,EAAE,EAE1CA,CACT,CCiBO,IAAMC,CAAAA,CAAN,MAAMA,CAAc,CAuBzB,WAAA,CAAY3C,EAAuB,CAhBnC,IAAA,CAAQ,cAAsC,IAAA,CAC9C,IAAA,CAAQ,gBAA0C,IAAA,CAClD,IAAA,CAAQ,eAAwC,IAAA,CAChD,IAAA,CAAQ,aAAoC,IAAA,CAC5C,IAAA,CAAQ,qBAAA,CAA8C,IAAA,CAEtD,IAAA,CAAQ,2BAAA,CAAuC,MAC/C,IAAA,CAAQ,6BAAA,CAAyC,MAEjD,IAAA,CAAQ,UAAA,CAAyB,UACjC,IAAA,CAAQ,SAAA,CAA2B,KACnC,IAAA,CAAQ,eAAA,CAAiC,KACzC,IAAA,CAAQ,MAAA,CAAwB,KAChC,IAAA,CAAQ,QAAA,CAA0B,KAClC,IAAA,CAAQ,UAAA,CAA4B,IAAA,CAGlC,GAAI,CAACA,CAAAA,CAAO,QAAU,CAACA,CAAAA,CAAO,aAC5B,MAAM,IAAIxB,EACR,4CAAA,CAAA,qBAEF,CAAA,CAGF,GAAIwB,CAAAA,CAAO,MAAA,EAAUA,EAAO,YAAA,CAC1B,MAAM,IAAIxB,CAAAA,CACR,uIAAA,CAAA,qBAEF,EAGEwB,CAAAA,CAAO,MAAA,EAAU,CAACA,CAAAA,CAAO,MAAA,CAAO,QAAA,CAAS,MAAM,CAAA,EAAK,OAAO,OAAW,GAAA,EACxE,OAAA,CAAQ,KACN,oIACF,CAAA,CAGF,KAAK,MAAA,CAASA,CAAAA,CAEd,IAAM4C,CAAAA,CAAa,IAAA,CAAK,OAAO,cAAA,EAAkBD,CAAAA,CAAc,YAE/D,IAAA,CAAK,cAAA,CAAiB,IAAIb,CAAAA,CAAec,CAAAA,CAAY,IAAA,CAAK,OAAO,MAAA,EAAU,EAAE,EAC7E,IAAA,CAAK,iBAAA,CAAoB,IAAI/B,EAC/B,CAEA,MAAM,UAAA,EAA4B,CAChC,OAAI,IAAA,CAAK,qBAAA,CACA,KAAK,qBAAA,EAGd,IAAA,CAAK,uBAAyB,SAAY,CACxC,IAAIrB,CAAAA,CACAqD,CAAAA,CACAC,CAAAA,CAGN,GAAI,IAAA,CAAK,MAAA,CAAO,aAKd,GAJA,IAAA,CAAK,WAAaL,CAAAA,CAAmB,IAAA,CAAK,OAAO,YAAY,CAAA,CAAE,WAAW,OAAO,CAAA,CAC7E,QACA,SAAA,CAEA,IAAA,CAAK,aAAe,OAAA,CAAS,CAC/B,IAAMzC,CAAAA,CAAU,MAAM,IAAA,CAAK,eAAe,oBAAA,CACxC,IAAA,CAAK,OAAO,YACd,CAAA,CAEA,GAAIA,CAAAA,CAAO,MAAA,GAAW,sBACpB,MAAM,IAAIxB,EACR,oDAAA,CAAA,qBAEF,CAAA,CAGFgB,EAAe,IAAA,CAAK,MAAA,CAAO,aAC3BqD,CAAAA,CAAkB,EAAA,CAClBC,CAAAA,CAAuB9C,CAAAA,CAAO,cAAA,CAC9B,IAAA,CAAK,WAAaA,CAAAA,CAAO,UAAA,CAErBA,EAAO,qBAAA,EACT,IAAA,CAAK,eAAe,SAAA,CAAUA,CAAAA,CAAO,qBAAqB,EAE9D,CAAA,KAAO,CACL,IAAMA,CAAAA,CAAU,MAAM,IAAA,CAAK,cAAA,CAAe,uBACxC,IAAA,CAAK,MAAA,CAAO,YACd,CAAA,CACAR,CAAAA,CAAe,IAAA,CAAK,OAAO,YAAA,CAC3BqD,CAAAA,CAAkB7C,EAAO,eAAA,CACzB8C,CAAAA,CAAuB9C,EAAO,cAAA,CAC9B,IAAA,CAAK,OAASA,CAAAA,CAAO,MAAA,CACrB,KAAK,QAAA,CAAWA,CAAAA,CAAO,SACvB,IAAA,CAAK,UAAA,CAAaA,EAAO,UAAA,CAErBA,CAAAA,CAAO,qBAAA,EACT,IAAA,CAAK,cAAA,CAAe,SAAA,CAAUA,EAAO,qBAAqB,EAE9D,MACK,CACL,IAAA,CAAK,+BAA8B,CAEnC,IAAMiC,EAAW,MAAM,IAAA,CAAK,eAAe,iBAAA,CAAkB,CAC3D,WAAY,IAAA,CAAK,MAAA,CAAO,YAAc,EAAA,CACtC,WAAA,CAAa,IAAA,CAAK,MAAA,CAAO,WAC3B,CAAC,EACDzC,CAAAA,CAAeyC,CAAAA,CAAS,aACxBY,CAAAA,CAAkBZ,CAAAA,CAAS,gBAC3Ba,CAAAA,CAAuBb,CAAAA,CAAS,qBAChC,IAAA,CAAK,MAAA,CAAS,KAAK,MAAA,CAAO,WAAA,CAAa,OACvC,IAAA,CAAK,QAAA,CAAW,KAAK,MAAA,CAAO,WAAA,CAAa,QAAA,CACzC,IAAA,CAAK,UAAA,CAAa,IAAA,CAAK,OAAO,UAAA,EAAc,GAC9C,CAEA,IAAA,CAAK,SAAA,CAAYQ,EAAmBjD,CAAY,CAAA,CAChD,KAAK,eAAA,CAAkBqD,CAAAA,CAEvB,IAAMvD,CAAAA,CAAS,MAAMyD,oBAAWD,CAAoB,CAAA,CAEpD,GAAI,CAACxD,CAAAA,CACH,MAAM,IAAId,CAAAA,CACR,uBAAA,CAAA,qBAEF,EAGF,IAAA,CAAK,aAAA,CAAgB,IAAIa,CAAAA,CAAcC,CAAM,EAC7C,IAAA,CAAK,eAAA,CAAkB,IAAIS,CAAAA,CAAgBT,CAAAA,CAAQ,KAAK,MAAA,CAAQ,IAAA,CAAK,SAAU,CAAA,CAC/E,IAAA,CAAK,eAAiB,IAAI4B,CAAAA,CACxB,IAAA,CAAK,aAAA,CACL,IAAA,CAAK,eAAA,CACL,KAAK,cACP,CAAA,CACA,KAAK,YAAA,CAAe,IAAIQ,EAAa,IAAA,CAAK,aAAA,CAAe,KAAK,eAAe,EAC7E,IAAG,CAAE,KAAA,CAAOtC,GAAU,CACpB,MAAA,IAAA,CAAK,sBAAwB,IAAA,CACvBA,CACR,CAAC,CAAA,CAEM,IAAA,CAAK,qBAAA,CACd,CAEA,MAAM,cAAA,EAAyC,CAC7C,OAAA,MAAM,IAAA,CAAK,mBAAkB,CAC7B,IAAA,CAAK,iBAAiB,SAAA,CAAW,gBAAgB,EAC1C,IAAA,CAAK,cAAA,CAAgB,QAAQ,IAAA,CAAK,SAAA,CAAY,CACnD,2BAAA,CAA6B,IAAA,CAAK,2BAAA,CAClC,6BAAA,CAA+B,IAAA,CAAK,6BACtC,CAAC,CACH,CAEA,MAAM,QAAA,EAAiC,CACrC,MAAM,IAAA,CAAK,iBAAA,GACX,IAAA,CAAK,gBAAA,CAAiB,QAAS,UAAU,CAAA,CACzC,GAAI,CACF,OAAO,MAAM,IAAA,CAAK,YAAA,CAAc,KAAK,IAAA,CAAK,SAAA,CAAY,CACpD,2BAAA,CAA6B,IAAA,CAAK,4BAClC,6BAAA,CAA+B,IAAA,CAAK,6BACtC,CAAC,CACH,OAASA,CAAAA,CAAO,CACd,MAAM,IAAA,CAAK,kBAAA,CAAmBA,CAAK,CACrC,CACF,CAEA,MAAM,mBAAA,EAA4C,CAChD,OAAA,MAAM,IAAA,CAAK,iBAAA,GACX,IAAA,CAAK,gBAAA,CAAiB,QAAS,qBAAqB,CAAA,CAC7C,KAAK,YAAA,CAAc,QAAA,CAAS,KAAK,SAAU,CACpD,CAEA,QAAA,EAAiB,CACf,KAAK,eAAA,EAAiB,UAAA,GACtB,IAAA,CAAK,aAAA,CAAgB,IAAA,CACrB,IAAA,CAAK,eAAA,CAAkB,IAAA,CACvB,KAAK,cAAA,CAAiB,IAAA,CACtB,KAAK,YAAA,CAAe,IAAA,CACpB,KAAK,qBAAA,CAAwB,IAAA,CAC7B,KAAK,2BAAA,CAA8B,KAAA,CACnC,KAAK,6BAAA,CAAgC,KAAA,CACrC,KAAK,UAAA,CAAa,SAAA,CAClB,KAAK,SAAA,CAAY,IAAA,CACjB,IAAA,CAAK,eAAA,CAAkB,IAAA,CACvB,IAAA,CAAK,OAAS,IAAA,CACd,IAAA,CAAK,SAAW,IAAA,CAChB,IAAA,CAAK,WAAa,KACpB,CAEA,MAAM,qBAAA,EAAgD,CACpD,aAAM,IAAA,CAAK,iBAAA,GACJ,IAAA,CAAK,cAAA,CAAgB,sBAAsB,IAAA,CAAK,SAAU,CACnE,CAEA,MAAM,cAAA,CAAe2B,EAAwD,CAC3E,MAAM,KAAK,iBAAA,EAAkB,CAC7B,KAAK,gBAAA,CAAiB,SAAA,CAAW,gBAAgB,CAAA,CAEjD,IAAMC,EACJ,MAAM,IAAA,CAAK,kBAAkB,gBAAA,CAAiBD,CAAO,EAEvD,GAAI,CACF,IAAMiC,CAAAA,CAAgB,MAAM,IAAA,CAAK,eAAgB,OAAA,CAAQhC,CAAAA,CAAiB,CACxE,UAAA,CAAY,IAAA,CAAK,WACjB,eAAA,CAAiB,IAAA,CAAK,gBACtB,YAAA,CAAc,IAAA,CAAK,UACnB,MAAA,CAAQ,IAAA,CAAK,OACb,QAAA,CAAU,IAAA,CAAK,SACf,2BAAA,CAA6B,IAAA,CAAK,2BAAA,CAClC,6BAAA,CAA+B,IAAA,CAAK,6BACtC,CAAC,CAAA,CAGD,OAAA,MAAM,KAAK,iBAAA,CAAkB,eAAA,CAAgBgC,CAAa,CAAA,CAEnDA,CACT,OAAS5D,CAAAA,CAAO,CACd,YAAM,IAAA,CAAK,iBAAA,CAAkB,WAAWA,CAAc,CAAA,CAChD,KAAK,kBAAA,CAAmBA,CAAK,CACrC,CACF,CAEA,MAAM,iBAAiBa,CAAAA,CAAiC,CACtD,MAAM,IAAA,CAAK,iBAAA,GACX,IAAA,CAAK,eAAA,CAAiB,oBAAoBA,CAAQ,CAAA,CAClD,KAAK,2BAAA,CAA8B,KACrC,CAEA,MAAM,eAAA,CAAgBA,EAAiC,CACrD,MAAM,IAAA,CAAK,iBAAA,EAAkB,CAC7B,IAAA,CAAK,gBAAiB,sBAAA,CAAuBA,CAAQ,EACrD,IAAA,CAAK,6BAAA,CAAgC,KACvC,CAEA,MAAM,gBAAgBA,CAAAA,CAAiC,CACrD,MAAM,IAAA,CAAK,iBAAA,GACX,IAAA,CAAK,eAAA,CAAiB,uBAAuBA,CAAQ,CAAA,CACrD,IAAA,CAAK,6BAAA,CAAgC,KACvC,CAEA,MAAM,YAAA,CAAaA,CAAAA,CAAiC,CAClD,MAAM,IAAA,CAAK,mBAAkB,CAC7B,IAAA,CAAK,gBAAiB,mBAAA,CAAoBA,CAAQ,EAClD,IAAA,CAAK,6BAAA,CAAgC,KACvC,CAEA,MAAM,aACJA,CAAAA,CACAG,CAAAA,CACe,CACf,MAAM,IAAA,CAAK,iBAAA,GACX,IAAA,CAAK,eAAA,CAAiB,oBAAoBH,CAAAA,CAAUG,CAAI,EACxD,IAAA,CAAK,6BAAA,CAAgC,KACvC,CAEA,YAAA,CAAaU,EAAmC,CAC9C,IAAA,CAAK,kBAAkB,GAAA,CAAIA,CAAS,EACtC,CAEA,MAAc,iBAAA,EAAmC,CAC1C,IAAA,CAAK,aAAA,EACR,MAAM,IAAA,CAAK,UAAA,GAEf,CAEQ,gBAAA,CAAiBmC,EAAsBC,CAAAA,CAAsB,CACnE,GAAI,IAAA,CAAK,UAAA,GAAeD,EACtB,MAAM,IAAIzE,EACR,CAAA,EAAG0E,CAAM,eAAeD,CAAQ,CAAA,qBAAA,CAAA,CAAA,qBAElC,CAEJ,CAEQ,6BAAA,EAAsC,CAC5C,GAAI,CAAC,IAAA,CAAK,OAAO,WAAA,CACf,MAAM,IAAIzE,CAAAA,CACR,yDAAA,CAAA,qBAEF,EAGF,GAAM,CAAE,OAAA2E,CAAAA,CAAQ,QAAA,CAAAC,EAAU,WAAA,CAAAC,CAAY,EAAI,IAAA,CAAK,MAAA,CAAO,WAAA,CAGtD,GAAI,CAACD,CAAAA,CACH,MAAM,IAAIvE,CAAAA,CAAgB,uBAAwB,UAAU,CAAA,CAG9D,IAAMyE,CAAAA,CAAoBF,CAAAA,CAAS,aAAY,CAEzCG,CAAAA,CAAgB,KAAK,OAAA,CAAQJ,CAAAA,CAAQG,EAAmB,QAAQ,CAAA,CAEtE,GAAIC,CAAAA,CAAc,MAAA,EAAO,EAAKA,CAAAA,CAAc,UAAA,EAAW,CACrD,MAAM,IAAI1E,CAAAA,CAAgB,gCAAiC,QAAQ,CAAA,CAGrE,GAAIwE,CAAAA,GAAgB,MAAA,CAAW,CAC7B,IAAMG,CAAAA,CAAoB,KAAK,OAAA,CAAQH,CAAAA,CAAaC,EAAmB,aAAa,CAAA,CAEpF,GAAIE,CAAAA,CAAkB,UAAA,EAAW,CAC/B,MAAM,IAAI3E,CAAAA,CAAgB,iCAAkC,aAAa,CAAA,CAG3E,GAAI2E,CAAAA,CAAkB,WAAA,CAAYD,CAAa,CAAA,CAC7C,MAAM,IAAI1E,CAAAA,CAAgB,8CAAA,CAAgD,aAAa,CAE3F,CACF,CAEQ,OAAA,CAAQ4E,CAAAA,CAAeL,EAAkBM,CAAAA,CAA0B,CACzE,GAAI,CACF,OAAOC,aAAAA,CAAM,YAAYF,CAAAA,CAAOL,CAAQ,CAC1C,CAAA,KAAQ,CACN,MAAM,IAAIvE,CAAAA,CACR,GAAG6E,CAAS,CAAA,uEAAA,CAAA,CACZA,CACF,CACF,CACF,CAGQ,kBAAA,CAAmBtE,CAAAA,CAAuB,CAChD,GAAIA,CAAAA,YAAiBZ,CAAAA,CACnB,OAAOY,CAAAA,CAET,IAAMV,EAAUU,CAAAA,YAAiB,KAAA,CAAQA,EAAM,OAAA,CAAU,gBAAA,CACnDT,EAAQS,CAAAA,EAAmC,IAAA,CAEjD,OAAO,IAAIJ,CAAAA,CAAaN,EAASC,CAAI,CACvC,CACF,CAAA,CA7UagE,CAAAA,CACa,YAAc,yBAAA,CADjC,IAAMiB,CAAAA,CAANjB,ECvBA,IAAMkB,CAAAA,CAAN,KAAoB,CACzB,kBAAA,CAAmBC,EAA6B,CAC9C,IAAMC,EAAUD,CAAAA,CAAW,OAAA,CAAQ,MAAO,EAAE,CAAA,CAE5C,GAAIC,CAAAA,CAAQ,MAAA,CAAS,IAAMA,CAAAA,CAAQ,MAAA,CAAS,GAC1C,OAAO,MAAA,CAGT,IAAIC,CAAAA,CAAM,CAAA,CACNC,CAAAA,CAAS,MAEb,IAAA,IAASC,CAAAA,CAAIH,EAAQ,MAAA,CAAS,CAAA,CAAGG,GAAK,CAAA,CAAGA,CAAAA,EAAAA,CAAK,CAC5C,IAAIC,CAAAA,CAAQ,SAASJ,CAAAA,CAAQG,CAAC,EAAG,EAAE,CAAA,CAE/BD,IACFE,CAAAA,EAAS,CAAA,CACLA,CAAAA,CAAQ,CAAA,GACVA,CAAAA,EAAS,CAAA,CAAA,CAAA,CAIbH,GAAOG,CAAAA,CACPF,CAAAA,CAAS,CAACA,EACZ,CAEA,OAAOD,CAAAA,CAAM,EAAA,GAAO,CACtB,CAEA,cAAA,CAAeF,EAA4B,CACzC,IAAMC,EAAUD,CAAAA,CAAW,OAAA,CAAQ,MAAO,EAAE,CAAA,CAE5C,OAAI,IAAA,CAAK,IAAA,CAAKC,CAAO,EAAU,MAAA,CAC3B,SAAA,CAAU,KAAKA,CAAO,CAAA,CAAU,aAChC,QAAA,CAAS,IAAA,CAAKA,CAAO,CAAA,CAAU,MAAA,CAC/B,cAAc,IAAA,CAAKA,CAAO,EAAU,UAAA,CAEjC,SACT,CAEA,cAAA,CAAeK,CAAAA,CAAeC,CAAAA,CAAuB,CACnD,IAAMC,CAAAA,CAAM,IAAI,IAAA,CACVC,CAAAA,CAAcD,EAAI,WAAA,EAAY,CAC9BE,EAAeF,CAAAA,CAAI,QAAA,GAAa,CAAA,CAEtC,GAAIF,EAAQ,CAAA,EAAKA,CAAAA,CAAQ,GACvB,OAAO,MAAA,CAGT,IAAMK,CAAAA,CAAWJ,CAAAA,CAAO,GAAA,CAAM,GAAA,CAAOA,CAAAA,CAAOA,CAAAA,CAM5C,OAJI,EAAAI,CAAAA,CAAWF,GAIXE,CAAAA,GAAaF,CAAAA,EAAeH,EAAQI,CAAAA,CAK1C,CAEA,YAAYE,CAAAA,CAAaC,CAAAA,CAAmB,UAAoB,CAC9D,IAAMZ,EAAUW,CAAAA,CAAI,OAAA,CAAQ,MAAO,EAAE,CAAA,CAErC,OAAIC,CAAAA,GAAa,MAAA,CACRZ,CAAAA,CAAQ,SAAW,CAAA,CAGrBA,CAAAA,CAAQ,SAAW,CAAA,EAAKA,CAAAA,CAAQ,SAAW,CACpD,CAEA,YACED,CAAAA,CACAc,CAAAA,CACAC,EACAH,CAAAA,CACgB,CAChB,IAAMC,CAAAA,CAAW,IAAA,CAAK,eAAeb,CAAU,CAAA,CAE/C,OAAO,CACL,MAAA,CAAQ,CACN,QAAS,IAAA,CAAK,kBAAA,CAAmBA,CAAU,CAAA,CAC3C,QAAA,CAAUa,CAEZ,CAAA,CACA,MAAA,CAAQ,CACN,OAAA,CAAS,IAAA,CAAK,eAAeC,CAAAA,CAAaC,CAAU,EACpD,KAAA,CAAOD,CAAAA,CACP,KAAMC,CACR,CAAA,CACA,GAAA,CAAK,CACH,OAAA,CAAS,IAAA,CAAK,YAAYH,CAAAA,CAAKC,CAAQ,EACvC,MAAA,CAAQD,CAAAA,CAAI,QAAQ,KAAA,CAAO,EAAE,EAAE,MACjC,CACF,CACF,CACF,MClGaI,CAAAA,CAAN,KAAqB,CAC1B,OAAO,kBAAA,CAAmBC,CAAAA,CAAuB,CAC/C,OAAOA,CAAAA,CAAM,QAAQ,KAAA,CAAO,EAAE,CAChC,CAEA,OAAO,iBAAiBA,CAAAA,CAAuB,CAE7C,OADgB,IAAA,CAAK,kBAAA,CAAmBA,CAAK,CAAA,CAC9B,OAAA,CAAQ,WAAY,KAAK,CAAA,CAAE,MAC5C,CAEA,OAAO,WAAA,CAAYA,CAAAA,CAAuB,CACxC,OAAOA,CAAAA,CAAM,OAAA,CAAQ,MAAO,EAAE,CAAA,CAAE,MAAM,CAAA,CAAG,CAAC,CAC5C,CAEA,OAAO,eAAeA,CAAAA,CAAuD,CAC3E,IAAMhB,CAAAA,CAAUgB,CAAAA,CAAM,QAAQ,KAAA,CAAO,EAAE,CAAA,CAEvC,OAAIhB,CAAAA,CAAQ,MAAA,GAAW,EACd,CACL,KAAA,CAAO,SAASA,CAAAA,CAAQ,KAAA,CAAM,EAAG,CAAC,CAAA,CAAG,EAAE,CAAA,CACvC,IAAA,CAAM,SAASA,CAAAA,CAAQ,KAAA,CAAM,EAAG,CAAC,CAAA,CAAG,EAAE,CACxC,CAAA,CACSA,CAAAA,CAAQ,MAAA,GAAW,CAAA,CACrB,CACL,MAAO,QAAA,CAASA,CAAAA,CAAQ,MAAM,CAAA,CAAG,CAAC,EAAG,EAAE,CAAA,CACvC,KAAM,QAAA,CAASA,CAAAA,CAAQ,MAAM,CAAA,CAAG,CAAC,EAAG,EAAE,CACxC,EAGK,IACT,CACF,ECIO,IAAMiB,EAAAA,CAAU","file":"index.cjs","sourcesContent":["import type { ErrorDetails } from '../types';\nimport { ErrorCode } from '../types';\n\nexport class VerapayError extends Error {\n public readonly code: ErrorCode;\n public readonly details: ErrorDetails;\n\n constructor(\n message: string,\n code: ErrorCode = ErrorCode.PAYMENT_FAILED,\n details?: Partial<ErrorDetails>\n ) {\n super(message);\n this.name = 'VerapayError';\n this.code = code;\n this.details = {\n code,\n message,\n formattedMessage: this.formatMessage(message, code),\n ...details,\n };\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, VerapayError);\n }\n }\n\n private formatMessage(message: string, code: ErrorCode): string {\n const messageMap: Record<ErrorCode, string> = {\n [ErrorCode.VALIDATION_ERROR]:\n 'Please check your payment information and try again.',\n [ErrorCode.PAYMENT_FAILED]:\n 'Your payment could not be processed. Please try again.',\n [ErrorCode.AUTHENTICATION_FAILED]:\n 'Payment authentication failed. Please try again.',\n [ErrorCode.NETWORK_ERROR]:\n 'Network error. Please check your connection and try again.',\n [ErrorCode.STRIPE_ERROR]:\n 'Payment service error. Please try again later.',\n [ErrorCode.CONFIGURATION_ERROR]:\n 'Configuration error. Please contact support.',\n [ErrorCode.CARD_DECLINED]:\n 'Your card was declined. Please use a different payment method.',\n [ErrorCode.INSUFFICIENT_FUNDS]:\n 'Insufficient funds. Please use a different payment method.',\n [ErrorCode.EXPIRED_CARD]:\n 'Your card has expired. Please use a different payment method.',\n };\n\n return messageMap[code] || message;\n }\n\n toJSON() {\n return {\n name: this.name,\n code: this.code,\n message: this.message,\n details: this.details,\n };\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class ValidationError extends VerapayError {\n constructor(message: string, field?: string, metadata?: Record<string, unknown>) {\n\n super(message, ErrorCode.VALIDATION_ERROR, {\n field,\n metadata,\n });\n this.name = 'ValidationError';\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class PaymentError extends VerapayError {\n constructor(\n message: string,\n stripeCode?: string,\n metadata?: Record<string, unknown>\n ) {\n const code = PaymentError.mapStripeCode(stripeCode);\n super(message, code, {\n stripeCode,\n metadata,\n });\n this.name = 'PaymentError';\n }\n\n private static mapStripeCode(stripeCode?: string): ErrorCode {\n if (!stripeCode) return ErrorCode.PAYMENT_FAILED;\n\n const codeMap: Record<string, ErrorCode> = {\n card_declined: ErrorCode.CARD_DECLINED,\n insufficient_funds: ErrorCode.INSUFFICIENT_FUNDS,\n expired_card: ErrorCode.EXPIRED_CARD,\n incorrect_cvc: ErrorCode.VALIDATION_ERROR,\n processing_error: ErrorCode.PAYMENT_FAILED,\n authentication_failed: ErrorCode.AUTHENTICATION_FAILED,\n };\n\n return codeMap[stripeCode] || ErrorCode.PAYMENT_FAILED;\n }\n}\n","import type { ErrorDetails } from '../types';\n\nexport class ErrorFormatter {\n static formatForUser(error: Error | ErrorDetails): string {\n if ('formattedMessage' in error) {\n return error.formattedMessage;\n }\n if (\n 'details' in error &&\n error.details &&\n typeof error.details === 'object' &&\n 'formattedMessage' in error.details &&\n typeof error.details.formattedMessage === 'string'\n ) {\n return error.details.formattedMessage;\n }\n return 'An unexpected error occurred. Please try again.';\n }\n\n static formatForDeveloper(error: Error | ErrorDetails): string {\n if ('code' in error && 'message' in error) {\n return `[${error.code}] ${error.message}`;\n }\n return error.message || 'Unknown error';\n }\n\n static toJSON(error: Error | ErrorDetails): Record<string, unknown> {\n\n if ('toJSON' in error && typeof error.toJSON === 'function') {\n return error.toJSON();\n }\n\n return {\n name: (error as Error).name || 'Error',\n message: error.message,\n ...('code' in error && { code: error.code }),\n ...('details' in error && { details: error.details }),\n };\n }\n}\n","import type { PaymentIntent, SetupIntent, Stripe, StripeElements } from '@stripe/stripe-js';\nimport { PaymentError } from '../errors';\n\nexport class StripeAdapter {\n constructor(private stripe: Stripe) {}\n\n async confirmPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmPayment({\n clientSecret,\n confirmParams: {\n payment_method: paymentMethodId,\n return_url: window.location.href,\n },\n redirect: 'if_required',\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmCardPayment(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async createPaymentMethod(\n elements: StripeElements,\n isUsingIndividualFormElements: boolean = false\n ): Promise<string> {\n let result;\n\n if (!isUsingIndividualFormElements) {\n result = await this.stripe.createPaymentMethod({\n elements,\n });\n } else {\n // @ts-expect-error - Stripe types don't include mode parameter for getElement\n const addressElement = await elements.getElement('address', { mode: 'billing' })!.getValue();\n\n const address = addressElement!.value;\n\n result = await this.stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement('cardNumber')!,\n billing_details: {\n name: address.name,\n address: {\n ...address.address,\n line2: address.address.line2 ?? undefined,\n },\n },\n });\n }\n\n if (result.error || !result.paymentMethod) {\n throw new PaymentError(\n result.error?.message || 'Failed to create payment method',\n result.error?.code\n );\n }\n\n return result.paymentMethod.id;\n }\n\n async retrievePaymentIntent(\n clientSecret: string,\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.retrievePaymentIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve payment intent',\n result.error.code,\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardSetup(\n paymentMethodId: string,\n clientSecret: string,\n ): Promise<{ setupIntent: SetupIntent }> {\n const result = await this.stripe.confirmCardSetup(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(result.error.message || 'Card setup failed', result.error.code);\n }\n\n return result as { setupIntent: SetupIntent };\n }\n\n async retrieveSetupIntent(clientSecret: string): Promise<{ setupIntent: SetupIntent }> {\n const result = await this.stripe.retrieveSetupIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve setup intent',\n result.error.code,\n );\n }\n\n return result as { setupIntent: SetupIntent };\n }\n}\n\n","import type {\n Stripe,\n StripeElements,\n StripeElement,\n StripePaymentElement,\n StripeCardNumberElement,\n PaymentWalletsOption,\n} from '@stripe/stripe-js';\nimport type { VerapayConfig, ValidationError, ValidationResult } from '../types';\nimport { VerapayError, ErrorCode } from '../errors';\n\ntype ElementState = { complete: boolean; error?: string }\n\nconst DEFAULT_CARD_ELEMENT_CONFIG = {\n showIcon: true,\n iconStyle: 'solid' as const,\n placeholders: {\n cardNumber: '1234 1234 1234 1234',\n cardExpiry: 'MM / YY - TESTING',\n cardCvc: 'CVC',\n },\n style: {\n base: {\n color: '#333333',\n fontFamily: 'system-ui, -apple-system, sans-serif',\n fontSize: '16px',\n '::placeholder': { color: '#aab7c4' },\n },\n complete: {\n color: '#333333',\n },\n empty: {},\n invalid: {\n color: '#df1b41',\n },\n },\n}\n\nconst FIELD_LABELS: Record<string, string> = {\n cardNumber: 'Card number',\n cardExpiry: 'Expiry date',\n cardCvc: 'CVC',\n address: 'Address',\n}\n\nexport class ElementsManager {\n private elements: StripeElements | null = null;\n private mountedElements: Map<string, StripeElement> = new Map();\n private elementStates: Map<string, ElementState> = new Map();\n\n constructor(\n private stripe: Stripe,\n private config: VerapayConfig,\n private clientSecret: string,\n ) {\n if (!clientSecret) {\n throw new VerapayError(\n 'Client secret not initialized',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n\n mountPaymentElement(selector: string): void {\n if (!this.elements) {\n const elementsConfig = {\n clientSecret: this.clientSecret,\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n };\n\n this.elements = this.stripe.elements(elementsConfig);\n }\n\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.elements.create('payment', {\n layout: 'tabs',\n wallets: { link: 'never' } as unknown as PaymentWalletsOption,\n }) as StripePaymentElement;\n\n element.mount(selector);\n this.mountedElements.set('payment', element);\n }\n\n mountCardNumberElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardNumber', this.cardElementOptions('cardNumber'));\n }\n\n mountCardExpiryElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardExpiry', this.cardElementOptions('cardExpiry'));\n }\n\n mountCardCvcElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardCvc', this.cardElementOptions('cardCvc'));\n }\n\n mountAddressElement(selector: string, mode: 'billing' | 'shipping'): void {\n this.mountIndividualFormElement(selector, 'address', { mode });\n }\n\n private cardElementOptions(fieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc'): Record<string, unknown> {\n const { elementsConfig } = this.config;\n const options: Record<string, unknown> = {\n placeholder: elementsConfig?.placeholders?.[fieldType] ?? DEFAULT_CARD_ELEMENT_CONFIG.placeholders[fieldType],\n style: {\n base: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.base, ...elementsConfig?.style?.base },\n complete: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.complete, ...elementsConfig?.style?.complete },\n empty: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.empty, ...elementsConfig?.style?.empty },\n invalid: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.invalid, ...elementsConfig?.style?.invalid },\n },\n };\n\n if (fieldType === 'cardNumber') {\n options.showIcon = elementsConfig?.showIcon ?? DEFAULT_CARD_ELEMENT_CONFIG.showIcon;\n options.iconStyle = elementsConfig?.iconStyle ?? DEFAULT_CARD_ELEMENT_CONFIG.iconStyle;\n }\n\n return options;\n }\n\n private mountIndividualFormElement(selector: string, formFieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address', options?: Record<string, unknown>) {\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.createIndividualFormElement(formFieldType, options) as StripeCardNumberElement;\n element.mount(selector);\n\n this.mountedElements.set(formFieldType, element);\n this.trackElementState(formFieldType, element);\n }\n\n private createIndividualFormElement(\n elementType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address',\n options?: Record<string, unknown>,\n ): StripeElement {\n if (!this.elements) {\n this.elements = this.stripe.elements({\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n });\n }\n\n return this.elements.create(elementType as 'cardNumber', options);\n }\n\n\n\n async validate(): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n\n for (const [field, state] of this.elementStates.entries()) {\n if (!state.complete) {\n errors.push({\n field,\n message: state.error ?? `${FIELD_LABELS[field] ?? field} failed validation`,\n })\n }\n }\n\n return { isValid: errors.length === 0, errors }\n }\n\n getElements(): StripeElements | null {\n return this.elements;\n }\n\n unmountAll(): void {\n for (const element of this.mountedElements.values()) {\n element.unmount();\n }\n this.mountedElements.clear();\n this.elementStates.clear();\n }\n\n private trackElementState(field: string, element: StripeElement): void {\n this.elementStates.set(field, { complete: false })\n\n const handleElementChange = (event: { complete: boolean; error?: { message: string } }) => {\n this.elementStates.set(field, { complete: event.complete, error: event.error?.message })\n };\n\n (element as unknown as { on: (event: string, handler: (e: unknown) => void) => void }).on(\n 'change',\n handleElementChange as (e: unknown) => void,\n );\n }\n}\n\n\n","import type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport type { PaymentExtension } from '../extensions'\n\nexport class PaymentExtensionsManager {\n private extensions: PaymentExtension[] = []\n\n add(extension: PaymentExtension): void {\n this.extensions.push(extension)\n }\n\n async runBeforePayment(request: ProcessPaymentRequest): Promise<ProcessPaymentRequest> {\n let modifiedRequest = request\n for (const ext of this.extensions) {\n if (ext.beforePayment) {\n modifiedRequest = await ext.beforePayment(modifiedRequest)\n }\n }\n return modifiedRequest\n }\n\n async runAfterPayment(result: PaymentResult): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.afterPayment)\n .map((ext) => ext.afterPayment!(result)),\n )\n }\n\n async runOnError(error: Error): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.onPaymentError)\n .map((ext) => ext.onPaymentError!(error)),\n )\n }\n}\n","import { StripeAdapter } from '../client/stripe-adapter'\nimport { ElementsManager } from '../client/elements-manager'\nimport { ErrorCode, VerapayError } from '../errors'\nimport { VerapayService } from './verapay-service'\nimport type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface ProcessPaymentContext {\n merchantId: string\n paymentIntentId: string\n clientSecret: string\n amount: number\n currency: string\n isUsingStripePaymentElement: boolean\n isUsingIndividualFormElements: boolean\n}\n\nexport class PaymentService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n private verapayService: VerapayService,\n ) {}\n\n async process(request: ProcessPaymentRequest, context: ProcessPaymentContext): Promise<PaymentResult> {\n const elements = this.elementsManager.getElements()\n\n await this.validatePaymentCanProceed(elements, context);\n\n await elements!.submit()\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n )\n\n await this.verapayService.processPrePayment({\n merchantId: context.merchantId,\n paymentIntentId: context.paymentIntentId,\n paymentMethodId,\n amount: context.amount,\n currency: context.currency,\n customerData: {\n email: request.customerEmail,\n firstName: request.customerFirstName,\n lastName: request.customerLastName,\n },\n description: request.description,\n metadata: request.metadata,\n })\n\n return this.confirm(context.clientSecret, {\n paymentMethodId,\n isUsingStripePaymentElement: context.isUsingStripePaymentElement,\n isUsingIndividualFormElements: context.isUsingIndividualFormElements,\n });\n }\n\n private async validatePaymentCanProceed(\n elements: StripeElements | null,\n context: ProcessPaymentContext,\n ) {\n if (!elements) {\n throw new VerapayError('Payment form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of payment form in use');\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n async confirm(\n clientSecret: string,\n options: {\n isUsingStripePaymentElement?: boolean;\n isUsingIndividualFormElements?: boolean;\n paymentMethodId?: string;\n } = {},\n ): Promise<PaymentResult> {\n let result;\n\n if (options.isUsingStripePaymentElement) {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n } else if (options.isUsingIndividualFormElements) {\n result = await this.stripeAdapter.confirmCardPayment(\n options.paymentMethodId || '',\n clientSecret,\n );\n } else {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n }\n\n return this.formatPaymentResult(result);\n }\n\n async retrievePaymentIntent(clientSecret: string): Promise<PaymentResult> {\n const result = await this.stripeAdapter.retrievePaymentIntent(clientSecret);\n return this.formatPaymentResult(result);\n }\n\n private formatPaymentResult(result: unknown): PaymentResult {\n const paymentIntent = (result as { paymentIntent: { status: string; id: string } })\n .paymentIntent\n\n let status: 'succeeded' | 'processing' | 'failed' = 'failed'\n if (paymentIntent.status === 'succeeded') {\n status = 'succeeded'\n } else if (\n ['processing', 'requires_action', 'requires_confirmation'].includes(\n paymentIntent.status,\n )\n ) {\n status = 'processing'\n }\n\n return {\n success: paymentIntent.status === 'succeeded',\n paymentIntentId: paymentIntent.id,\n status,\n }\n }\n\n}\n\n\n","import { StripeAdapter } from '../client/stripe-adapter';\nimport { ElementsManager } from '../client/elements-manager';\nimport { ErrorCode, VerapayError } from '../errors';\nimport type { SetupResult } from '../types';\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface SaveCardContext {\n isUsingStripePaymentElement: boolean;\n isUsingIndividualFormElements: boolean;\n}\n\nexport class SetupService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n ) {}\n\n async save(clientSecret: string, context: SaveCardContext): Promise<SetupResult> {\n const elements = this.elementsManager.getElements();\n\n await this.validateSetupCanProceed(elements, context);\n\n await elements!.submit();\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n );\n\n const result = await this.stripeAdapter.confirmCardSetup(paymentMethodId, clientSecret);\n\n return this.formatSetupResult(result);\n }\n\n async retrieve(clientSecret: string): Promise<SetupResult> {\n const result = await this.stripeAdapter.retrieveSetupIntent(clientSecret);\n return this.formatSetupResult(result);\n }\n\n private async validateSetupCanProceed(\n elements: StripeElements | null,\n context: SaveCardContext,\n ): Promise<void> {\n if (!elements) {\n throw new VerapayError('Card form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of card form in use', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n private formatSetupResult(result: unknown): SetupResult {\n const setupIntent = (\n result as { setupIntent: { status: string; id: string; payment_method?: unknown } }\n ).setupIntent;\n\n let status: SetupResult['status'] = 'failed';\n if (setupIntent.status === 'succeeded') {\n status = 'succeeded';\n } else if (setupIntent.status === 'processing') {\n status = 'processing';\n } else if (\n setupIntent.status === 'requires_action' ||\n setupIntent.status === 'requires_confirmation'\n ) {\n status = 'requires_action';\n }\n\n const paymentMethod = setupIntent.payment_method;\n const savedPaymentMethodId =\n typeof paymentMethod === 'string'\n ? paymentMethod\n : (paymentMethod as { id?: string } | undefined)?.id;\n\n return {\n success: setupIntent.status === 'succeeded',\n savedPaymentMethodId,\n setupIntentId: setupIntent.id,\n status,\n };\n }\n}\n","import { ErrorCode, VerapayError } from '../errors';\nimport { PaymentData } from '../types';\n\nexport interface InitialisePaymentRequest {\n merchantId: string;\n paymentData: PaymentData;\n}\n\nexport interface InitialisePaymentResponse {\n paymentIntentId: string;\n clientSecret: string;\n connectAccountId: string;\n stripePublishableKey: string;\n}\n\nexport interface ProcessPrePaymentRequest {\n merchantId: string;\n paymentIntentId: string;\n paymentMethodId: string;\n amount: number;\n currency: string;\n customerData: Record<string, unknown>;\n\n description?: string;\n metadata?: Record<string, string>;\n}\n\nexport class VerapayService {\n private readonly baseUrl: string;\n private apiKey?: string;\n\n constructor(baseUrl: string, apiKey?: string) {\n this.baseUrl = baseUrl;\n this.apiKey = apiKey;\n }\n\n setApiKey(apiKey: string): void {\n this.apiKey = apiKey;\n }\n\n\n async getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch provider config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n async getSetupIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/setup_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch setup config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n\n async initialisePayment(\n request: InitialisePaymentRequest\n ): Promise<InitialisePaymentResponse> {\n const { merchantId, paymentData } = request;\n\n try {\n const response = await fetch(`${this.baseUrl}/api/initialise-payment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId,\n paymentData: { ...paymentData, paymentMethodType: 'card' },\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const data = await response.json();\n\n if (!data.clientSecret || !data.paymentIntentId) {\n throw new VerapayError(\n 'Missing clientSecret or paymentIntentId in server response',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n return {\n paymentIntentId: data.paymentIntentId,\n clientSecret: data.clientSecret,\n connectAccountId: data.connectAccountId,\n stripePublishableKey: data.stripePublishableKey,\n };\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n async processPrePayment(request: ProcessPrePaymentRequest): Promise<void> {\n try {\n const response = await fetch(`${this.baseUrl}/api/process-prepayment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId: request.merchantId,\n paymentIntentId: request.paymentIntentId,\n paymentMethodId: request.paymentMethodId,\n amount: request.amount,\n currency: request.currency,\n customerData: request.customerData,\n description: request.description,\n metadata: request.metadata,\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n private extractErrorMessage(errorData: unknown, status: number): string {\n if (!errorData || typeof errorData !== 'object') {\n return `HTTP error! status: ${status}`;\n }\n\n const record = errorData as Record<string, unknown>;\n const candidates = [record.error, record.message, record.details];\n\n for (const candidate of candidates) {\n if (typeof candidate === 'string' && candidate.trim().length > 0) {\n return candidate;\n }\n\n if (candidate && typeof candidate === 'object') {\n try {\n return JSON.stringify(candidate);\n } catch {\n // Ignore serialization issues and continue trying fallback messages.\n }\n }\n }\n\n return `HTTP error! status: ${status}`;\n }\n}\n","export function unwrapClientSecret(wrappedSecret: string): string {\n if (wrappedSecret.startsWith('vpy_cs_test_')) {\n return wrappedSecret.replace('vpy_cs_test_', '');\n }\n if (wrappedSecret.startsWith('vpy_cs_live_')) {\n return wrappedSecret.replace('vpy_cs_live_', '');\n }\n return wrappedSecret;\n}\n","import { loadStripe } from '@stripe/stripe-js';\nimport { Money } from 'ts-money';\nimport { StripeAdapter } from './stripe-adapter';\nimport { ElementsManager } from './elements-manager';\nimport type { PaymentExtension } from '../extensions';\nimport { PaymentExtensionsManager } from './payment-extensions-manager';\nimport { PaymentService } from '../services/payment-service';\nimport { SetupService } from '../services/setup-service';\nimport {\n ErrorCode,\n VerapayError,\n PaymentError,\n ValidationError,\n} from '../errors';\nimport { VerapayService } from '../services/verapay-service';\nimport { unwrapClientSecret } from '../utils/secret.util';\nimport type {\n VerapayConfig,\n ProcessPaymentRequest,\n PaymentResult,\n SetupResult,\n} from '../types';\n\ntype IntentKind = 'payment' | 'setup';\n\nexport class VerapayClient {\n private static readonly BACKEND_URL = 'https://api.verapay.app';\n\n private config: VerapayConfig;\n private verapayService: VerapayService;\n private extensionsManager: PaymentExtensionsManager;\n\n private stripeAdapter: StripeAdapter | null = null;\n private elementsManager: ElementsManager | null = null;\n private paymentService: PaymentService | null = null;\n private setupService: SetupService | null = null;\n private initializationPromise: Promise<void> | null = null;\n\n private isUsingStripePaymentElement: boolean = false;\n private isUsingIndividualFormElements: boolean = false;\n\n private intentKind: IntentKind = 'payment';\n private rawSecret: string | null = null;\n private paymentIntentId: string | null = null;\n private amount: number | null = null;\n private currency: string | null = null;\n private merchantId: string | null = null;\n\n constructor(config: VerapayConfig) {\n if (!config.apiKey && !config.clientSecret) {\n throw new VerapayError(\n 'Either apiKey or clientSecret is required.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && config.clientSecret) {\n throw new VerapayError(\n 'Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && !config.apiKey.includes(\"_pk_\") && typeof window !== \"undefined\") {\n console.warn(\n \"Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead.\"\n );\n }\n\n this.config = config;\n\n const backendUrl = this.config.apiUrlOverride || VerapayClient.BACKEND_URL;\n\n this.verapayService = new VerapayService(backendUrl, this.config.apiKey || '');\n this.extensionsManager = new PaymentExtensionsManager();\n }\n\n async initialize(): Promise<void> {\n if (this.initializationPromise) {\n return this.initializationPromise;\n }\n\n this.initializationPromise = (async () => {\n let clientSecret: string;\n let paymentIntentId: string;\n let stripePublishableKey: string;\n\n\n if (this.config.clientSecret) {\n this.intentKind = unwrapClientSecret(this.config.clientSecret).startsWith('seti_')\n ? 'setup'\n : 'payment';\n\n if (this.intentKind === 'setup') {\n const config = (await this.verapayService.getSetupIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n\n if (config.object !== 'setup_intent_config') {\n throw new VerapayError(\n 'Unexpected configuration returned for setup intent',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n clientSecret = this.config.clientSecret;\n paymentIntentId = '';\n stripePublishableKey = config.publishableKey;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n } else {\n const config = (await this.verapayService.getPaymentIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n clientSecret = this.config.clientSecret;\n paymentIntentId = config.paymentIntentId;\n stripePublishableKey = config.publishableKey;\n this.amount = config.amount;\n this.currency = config.currency;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n }\n } else {\n this.validatePaymentInitialisation();\n\n const response = await this.verapayService.initialisePayment({\n merchantId: this.config.merchantId ?? '',\n paymentData: this.config.paymentData!,\n });\n clientSecret = response.clientSecret;\n paymentIntentId = response.paymentIntentId;\n stripePublishableKey = response.stripePublishableKey;\n this.amount = this.config.paymentData!.amount;\n this.currency = this.config.paymentData!.currency;\n this.merchantId = this.config.merchantId ?? '';\n }\n\n this.rawSecret = unwrapClientSecret(clientSecret);\n this.paymentIntentId = paymentIntentId;\n\n const stripe = await loadStripe(stripePublishableKey);\n\n if (!stripe) {\n throw new VerapayError(\n 'Failed to load Stripe',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n this.stripeAdapter = new StripeAdapter(stripe);\n this.elementsManager = new ElementsManager(stripe, this.config, this.rawSecret!);\n this.paymentService = new PaymentService(\n this.stripeAdapter,\n this.elementsManager,\n this.verapayService,\n );\n this.setupService = new SetupService(this.stripeAdapter, this.elementsManager);\n })().catch((error) => {\n this.initializationPromise = null;\n throw error;\n });\n\n return this.initializationPromise;\n }\n\n async confirmPayment(): Promise<PaymentResult> {\n await this.ensureInitialized();\n this.assertIntentKind('payment', 'confirmPayment');\n return this.paymentService!.confirm(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n }\n\n async saveCard(): Promise<SetupResult> {\n await this.ensureInitialized();\n this.assertIntentKind('setup', 'saveCard');\n try {\n return await this.setupService!.save(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n } catch (error) {\n throw this.handlePaymentError(error);\n }\n }\n\n async retrieveSetupIntent(): Promise<SetupResult> {\n await this.ensureInitialized();\n this.assertIntentKind('setup', 'retrieveSetupIntent');\n return this.setupService!.retrieve(this.rawSecret!);\n }\n\n teardown(): void {\n this.elementsManager?.unmountAll();\n this.stripeAdapter = null;\n this.elementsManager = null;\n this.paymentService = null;\n this.setupService = null;\n this.initializationPromise = null;\n this.isUsingStripePaymentElement = false;\n this.isUsingIndividualFormElements = false;\n this.intentKind = 'payment';\n this.rawSecret = null;\n this.paymentIntentId = null;\n this.amount = null;\n this.currency = null;\n this.merchantId = null;\n }\n\n async retrievePaymentIntent(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.retrievePaymentIntent(this.rawSecret!);\n }\n\n async processPayment(request: ProcessPaymentRequest): Promise<PaymentResult> {\n await this.ensureInitialized();\n this.assertIntentKind('payment', 'processPayment');\n\n const modifiedRequest =\n await this.extensionsManager.runBeforePayment(request);\n\n try {\n const paymentResult = await this.paymentService!.process(modifiedRequest, {\n merchantId: this.merchantId!,\n paymentIntentId: this.paymentIntentId!,\n clientSecret: this.rawSecret!,\n amount: this.amount!,\n currency: this.currency!,\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n\n\n await this.extensionsManager.runAfterPayment(paymentResult);\n\n return paymentResult;\n } catch (error) {\n await this.extensionsManager.runOnError(error as Error);\n throw this.handlePaymentError(error);\n }\n }\n\n async mountPaymentForm(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountPaymentElement(selector);\n this.isUsingStripePaymentElement = true;\n }\n\n async mountCardNumber(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardNumberElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardExpiry(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardExpiryElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardCvc(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardCvcElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountAddress(\n selector: string,\n mode: 'billing' | 'shipping'\n ): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountAddressElement(selector, mode);\n this.isUsingIndividualFormElements = true;\n }\n\n addExtension(extension: PaymentExtension): void {\n this.extensionsManager.add(extension);\n }\n\n private async ensureInitialized(): Promise<void> {\n if (!this.stripeAdapter) {\n await this.initialize();\n }\n }\n\n private assertIntentKind(expected: IntentKind, method: string): void {\n if (this.intentKind !== expected) {\n throw new VerapayError(\n `${method} requires a ${expected} intent client secret`,\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n private validatePaymentInitialisation(): void {\n if (!this.config.paymentData) {\n throw new VerapayError(\n 'paymentData is required for frontend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n const { amount, currency, platformFee } = this.config.paymentData;\n\n\n if (!currency) {\n throw new ValidationError('Currency is required', 'currency');\n }\n\n const uppercaseCurrency = currency.toUpperCase();\n\n const paymentAmount = this.toMoney(amount, uppercaseCurrency, 'amount');\n\n if (paymentAmount.isZero() || paymentAmount.isNegative()) {\n throw new ValidationError('Amount must be greater than 0', 'amount');\n }\n\n if (platformFee !== undefined) {\n const platformFeeAmount = this.toMoney(platformFee, uppercaseCurrency, 'platformFee');\n\n if (platformFeeAmount.isNegative()) {\n throw new ValidationError('platformFee cannot be negative', 'platformFee');\n }\n\n if (platformFeeAmount.greaterThan(paymentAmount)) {\n throw new ValidationError('platformFee cannot exceed the payment amount', 'platformFee');\n }\n }\n }\n\n private toMoney(value: number, currency: string, fieldName: string): Money {\n try {\n return Money.fromInteger(value, currency);\n } catch {\n throw new ValidationError(\n `${fieldName} must be an integer in the smallest currency unit (e.g., cents for USD)`,\n fieldName\n );\n }\n }\n\n\n private handlePaymentError(error: unknown): Error {\n if (error instanceof VerapayError) {\n return error;\n }\n const message = error instanceof Error ? error.message : 'Payment failed';\n const code = (error as Record<string, unknown>)?.code as string | undefined;\n\n return new PaymentError(message, code);\n }\n}\n\n","import type { CardValidation } from '../types';\n\nexport class CardValidator {\n validateCardNumber(cardNumber: string): boolean {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (cleaned.length < 13 || cleaned.length > 19) {\n return false;\n }\n\n let sum = 0;\n let isEven = false;\n\n for (let i = cleaned.length - 1; i >= 0; i--) {\n let digit = parseInt(cleaned[i], 10);\n\n if (isEven) {\n digit *= 2;\n if (digit > 9) {\n digit -= 9;\n }\n }\n\n sum += digit;\n isEven = !isEven;\n }\n\n return sum % 10 === 0;\n }\n\n detectCardType(cardNumber: string): string {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (/^4/.test(cleaned)) return 'visa';\n if (/^5[1-5]/.test(cleaned)) return 'mastercard';\n if (/^3[47]/.test(cleaned)) return 'amex';\n if (/^6(?:011|5)/.test(cleaned)) return 'discover';\n\n return 'unknown';\n }\n\n validateExpiry(month: number, year: number): boolean {\n const now = new Date();\n const currentYear = now.getFullYear();\n const currentMonth = now.getMonth() + 1;\n\n if (month < 1 || month > 12) {\n return false;\n }\n\n const fullYear = year < 100 ? 2000 + year : year;\n\n if (fullYear < currentYear) {\n return false;\n }\n\n if (fullYear === currentYear && month < currentMonth) {\n return false;\n }\n\n return true;\n }\n\n validateCVC(cvc: string, cardType: string = 'unknown'): boolean {\n const cleaned = cvc.replace(/\\D/g, '');\n\n if (cardType === 'amex') {\n return cleaned.length === 4;\n }\n\n return cleaned.length === 3 || cleaned.length === 4;\n }\n\n validateAll(\n cardNumber: string,\n expiryMonth: number,\n expiryYear: number,\n cvc: string\n ): CardValidation {\n const cardType = this.detectCardType(cardNumber);\n\n return {\n number: {\n isValid: this.validateCardNumber(cardNumber),\n cardType: cardType as 'visa' | 'mastercard' | 'amex' | 'discover' | 'unknown',\n\n },\n expiry: {\n isValid: this.validateExpiry(expiryMonth, expiryYear),\n month: expiryMonth,\n year: expiryYear,\n },\n cvc: {\n isValid: this.validateCVC(cvc, cardType),\n length: cvc.replace(/\\D/g, '').length,\n },\n };\n }\n}\n","export class InputSanitizer {\n static sanitizeCardNumber(input: string): string {\n return input.replace(/\\D/g, '');\n }\n\n static formatCardNumber(input: string): string {\n const cleaned = this.sanitizeCardNumber(input);\n return cleaned.replace(/(\\d{4})/g, '$1 ').trim();\n }\n\n static sanitizeCVC(input: string): string {\n return input.replace(/\\D/g, '').slice(0, 4);\n }\n\n static sanitizeExpiry(input: string): { month: number; year: number } | null {\n const cleaned = input.replace(/\\D/g, '');\n\n if (cleaned.length === 4) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 4), 10),\n };\n } else if (cleaned.length === 6) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 6), 10),\n };\n }\n\n return null;\n }\n}\n","export { VerapayClient } from './client/verapay-client';\nexport { VerapayService } from './services/verapay-service';\n\nexport type {\n InitialisePaymentRequest,\n InitialisePaymentResponse,\n ProcessPrePaymentRequest,\n} from './services/verapay-service';\n\nexport type {\n VerapayConfig,\n ElementsConfig,\n ProcessPaymentRequest,\n PaymentResult,\n SetupResult,\n CardValidation,\n ErrorDetails,\n ErrorCode,\n} from './types';\n\nexport {\n VerapayError,\n ValidationError,\n PaymentError,\n ErrorFormatter,\n} from './errors';\n\nexport { CardValidator, InputSanitizer } from './validation';\n\nexport type {\n PaymentExtension,\n DatabaseExtension,\n AnalyticsExtension,\n} from './extensions';\n\nexport const VERSION = '1.4.0';\n"]}
|
package/dist/index.d.cts
CHANGED
|
@@ -22,7 +22,7 @@ interface BackendConfig extends BaseConfig {
|
|
|
22
22
|
interface PaymentData {
|
|
23
23
|
amount: number;
|
|
24
24
|
currency: string;
|
|
25
|
-
|
|
25
|
+
platformFee?: number;
|
|
26
26
|
}
|
|
27
27
|
interface ElementsConfig {
|
|
28
28
|
style?: {
|
|
@@ -53,6 +53,13 @@ interface PaymentResult {
|
|
|
53
53
|
status: 'succeeded' | 'processing' | 'failed';
|
|
54
54
|
error?: string;
|
|
55
55
|
}
|
|
56
|
+
interface SetupResult {
|
|
57
|
+
success: boolean;
|
|
58
|
+
savedPaymentMethodId?: string;
|
|
59
|
+
setupIntentId: string;
|
|
60
|
+
status: 'succeeded' | 'processing' | 'requires_action' | 'failed';
|
|
61
|
+
error?: string;
|
|
62
|
+
}
|
|
56
63
|
interface CardValidation {
|
|
57
64
|
number: {
|
|
58
65
|
isValid: boolean;
|
|
@@ -114,9 +121,11 @@ declare class VerapayClient {
|
|
|
114
121
|
private stripeAdapter;
|
|
115
122
|
private elementsManager;
|
|
116
123
|
private paymentService;
|
|
124
|
+
private setupService;
|
|
117
125
|
private initializationPromise;
|
|
118
126
|
private isUsingStripePaymentElement;
|
|
119
127
|
private isUsingIndividualFormElements;
|
|
128
|
+
private intentKind;
|
|
120
129
|
private rawSecret;
|
|
121
130
|
private paymentIntentId;
|
|
122
131
|
private amount;
|
|
@@ -125,6 +134,9 @@ declare class VerapayClient {
|
|
|
125
134
|
constructor(config: VerapayConfig);
|
|
126
135
|
initialize(): Promise<void>;
|
|
127
136
|
confirmPayment(): Promise<PaymentResult>;
|
|
137
|
+
saveCard(): Promise<SetupResult>;
|
|
138
|
+
retrieveSetupIntent(): Promise<SetupResult>;
|
|
139
|
+
teardown(): void;
|
|
128
140
|
retrievePaymentIntent(): Promise<PaymentResult>;
|
|
129
141
|
processPayment(request: ProcessPaymentRequest): Promise<PaymentResult>;
|
|
130
142
|
mountPaymentForm(selector: string): Promise<void>;
|
|
@@ -134,6 +146,7 @@ declare class VerapayClient {
|
|
|
134
146
|
mountAddress(selector: string, mode: 'billing' | 'shipping'): Promise<void>;
|
|
135
147
|
addExtension(extension: PaymentExtension): void;
|
|
136
148
|
private ensureInitialized;
|
|
149
|
+
private assertIntentKind;
|
|
137
150
|
private validatePaymentInitialisation;
|
|
138
151
|
private toMoney;
|
|
139
152
|
private handlePaymentError;
|
|
@@ -165,6 +178,7 @@ declare class VerapayService {
|
|
|
165
178
|
constructor(baseUrl: string, apiKey?: string);
|
|
166
179
|
setApiKey(apiKey: string): void;
|
|
167
180
|
getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>>;
|
|
181
|
+
getSetupIntentConfig(clientSecret: string): Promise<Record<string, unknown>>;
|
|
168
182
|
initialisePayment(request: InitialisePaymentRequest): Promise<InitialisePaymentResponse>;
|
|
169
183
|
processPrePayment(request: ProcessPrePaymentRequest): Promise<void>;
|
|
170
184
|
private extractErrorMessage;
|
|
@@ -216,6 +230,6 @@ declare class InputSanitizer {
|
|
|
216
230
|
} | null;
|
|
217
231
|
}
|
|
218
232
|
|
|
219
|
-
declare const VERSION = "1.
|
|
233
|
+
declare const VERSION = "1.4.0";
|
|
220
234
|
|
|
221
|
-
export { type AnalyticsExtension, type CardValidation, CardValidator, type DatabaseExtension, type ElementsConfig, ErrorCode, type ErrorDetails, ErrorFormatter, type InitialisePaymentRequest, type InitialisePaymentResponse, InputSanitizer, PaymentError, type PaymentExtension, type PaymentResult, type ProcessPaymentRequest, type ProcessPrePaymentRequest, VERSION, ValidationError, VerapayClient, type VerapayConfig, VerapayError, VerapayService };
|
|
235
|
+
export { type AnalyticsExtension, type CardValidation, CardValidator, type DatabaseExtension, type ElementsConfig, ErrorCode, type ErrorDetails, ErrorFormatter, type InitialisePaymentRequest, type InitialisePaymentResponse, InputSanitizer, PaymentError, type PaymentExtension, type PaymentResult, type ProcessPaymentRequest, type ProcessPrePaymentRequest, type SetupResult, VERSION, ValidationError, VerapayClient, type VerapayConfig, VerapayError, VerapayService };
|
package/dist/index.d.ts
CHANGED
|
@@ -22,7 +22,7 @@ interface BackendConfig extends BaseConfig {
|
|
|
22
22
|
interface PaymentData {
|
|
23
23
|
amount: number;
|
|
24
24
|
currency: string;
|
|
25
|
-
|
|
25
|
+
platformFee?: number;
|
|
26
26
|
}
|
|
27
27
|
interface ElementsConfig {
|
|
28
28
|
style?: {
|
|
@@ -53,6 +53,13 @@ interface PaymentResult {
|
|
|
53
53
|
status: 'succeeded' | 'processing' | 'failed';
|
|
54
54
|
error?: string;
|
|
55
55
|
}
|
|
56
|
+
interface SetupResult {
|
|
57
|
+
success: boolean;
|
|
58
|
+
savedPaymentMethodId?: string;
|
|
59
|
+
setupIntentId: string;
|
|
60
|
+
status: 'succeeded' | 'processing' | 'requires_action' | 'failed';
|
|
61
|
+
error?: string;
|
|
62
|
+
}
|
|
56
63
|
interface CardValidation {
|
|
57
64
|
number: {
|
|
58
65
|
isValid: boolean;
|
|
@@ -114,9 +121,11 @@ declare class VerapayClient {
|
|
|
114
121
|
private stripeAdapter;
|
|
115
122
|
private elementsManager;
|
|
116
123
|
private paymentService;
|
|
124
|
+
private setupService;
|
|
117
125
|
private initializationPromise;
|
|
118
126
|
private isUsingStripePaymentElement;
|
|
119
127
|
private isUsingIndividualFormElements;
|
|
128
|
+
private intentKind;
|
|
120
129
|
private rawSecret;
|
|
121
130
|
private paymentIntentId;
|
|
122
131
|
private amount;
|
|
@@ -125,6 +134,9 @@ declare class VerapayClient {
|
|
|
125
134
|
constructor(config: VerapayConfig);
|
|
126
135
|
initialize(): Promise<void>;
|
|
127
136
|
confirmPayment(): Promise<PaymentResult>;
|
|
137
|
+
saveCard(): Promise<SetupResult>;
|
|
138
|
+
retrieveSetupIntent(): Promise<SetupResult>;
|
|
139
|
+
teardown(): void;
|
|
128
140
|
retrievePaymentIntent(): Promise<PaymentResult>;
|
|
129
141
|
processPayment(request: ProcessPaymentRequest): Promise<PaymentResult>;
|
|
130
142
|
mountPaymentForm(selector: string): Promise<void>;
|
|
@@ -134,6 +146,7 @@ declare class VerapayClient {
|
|
|
134
146
|
mountAddress(selector: string, mode: 'billing' | 'shipping'): Promise<void>;
|
|
135
147
|
addExtension(extension: PaymentExtension): void;
|
|
136
148
|
private ensureInitialized;
|
|
149
|
+
private assertIntentKind;
|
|
137
150
|
private validatePaymentInitialisation;
|
|
138
151
|
private toMoney;
|
|
139
152
|
private handlePaymentError;
|
|
@@ -165,6 +178,7 @@ declare class VerapayService {
|
|
|
165
178
|
constructor(baseUrl: string, apiKey?: string);
|
|
166
179
|
setApiKey(apiKey: string): void;
|
|
167
180
|
getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>>;
|
|
181
|
+
getSetupIntentConfig(clientSecret: string): Promise<Record<string, unknown>>;
|
|
168
182
|
initialisePayment(request: InitialisePaymentRequest): Promise<InitialisePaymentResponse>;
|
|
169
183
|
processPrePayment(request: ProcessPrePaymentRequest): Promise<void>;
|
|
170
184
|
private extractErrorMessage;
|
|
@@ -216,6 +230,6 @@ declare class InputSanitizer {
|
|
|
216
230
|
} | null;
|
|
217
231
|
}
|
|
218
232
|
|
|
219
|
-
declare const VERSION = "1.
|
|
233
|
+
declare const VERSION = "1.4.0";
|
|
220
234
|
|
|
221
|
-
export { type AnalyticsExtension, type CardValidation, CardValidator, type DatabaseExtension, type ElementsConfig, ErrorCode, type ErrorDetails, ErrorFormatter, type InitialisePaymentRequest, type InitialisePaymentResponse, InputSanitizer, PaymentError, type PaymentExtension, type PaymentResult, type ProcessPaymentRequest, type ProcessPrePaymentRequest, VERSION, ValidationError, VerapayClient, type VerapayConfig, VerapayError, VerapayService };
|
|
235
|
+
export { type AnalyticsExtension, type CardValidation, CardValidator, type DatabaseExtension, type ElementsConfig, ErrorCode, type ErrorDetails, ErrorFormatter, type InitialisePaymentRequest, type InitialisePaymentResponse, InputSanitizer, PaymentError, type PaymentExtension, type PaymentResult, type ProcessPaymentRequest, type ProcessPrePaymentRequest, type SetupResult, VERSION, ValidationError, VerapayClient, type VerapayConfig, VerapayError, VerapayService };
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import {loadStripe}from'@stripe/stripe-js';import {Money}from'ts-money';var a=class s extends Error{constructor(e,t="PAYMENT_FAILED",n){super(e),this.name="VerapayError",this.code=t,this.details={code:t,message:e,formattedMessage:this.formatMessage(e,t),...n},Error.captureStackTrace&&Error.captureStackTrace(this,s);}formatMessage(e,t){return {VALIDATION_ERROR:"Please check your payment information and try again.",PAYMENT_FAILED:"Your payment could not be processed. Please try again.",AUTHENTICATION_FAILED:"Payment authentication failed. Please try again.",NETWORK_ERROR:"Network error. Please check your connection and try again.",STRIPE_ERROR:"Payment service error. Please try again later.",CONFIGURATION_ERROR:"Configuration error. Please contact support.",CARD_DECLINED:"Your card was declined. Please use a different payment method.",INSUFFICIENT_FUNDS:"Insufficient funds. Please use a different payment method.",EXPIRED_CARD:"Your card has expired. Please use a different payment method."}[t]||e}toJSON(){return {name:this.name,code:this.code,message:this.message,details:this.details}}};var c=class extends a{constructor(e,t,n){super(e,"VALIDATION_ERROR",{field:t,metadata:n}),this.name="ValidationError";}};var m=class s extends a{constructor(e,t,n){let i=s.mapStripeCode(t);super(e,i,{stripeCode:t,metadata:n}),this.name="PaymentError";}static mapStripeCode(e){return e?{card_declined:"CARD_DECLINED",insufficient_funds:"INSUFFICIENT_FUNDS",expired_card:"EXPIRED_CARD",incorrect_cvc:"VALIDATION_ERROR",processing_error:"PAYMENT_FAILED",authentication_failed:"AUTHENTICATION_FAILED"}[e]||"PAYMENT_FAILED":"PAYMENT_FAILED"}};var y=class{static formatForUser(e){return "formattedMessage"in e?e.formattedMessage:"details"in e&&e.details&&typeof e.details=="object"&&"formattedMessage"in e.details&&typeof e.details.formattedMessage=="string"?e.details.formattedMessage:"An unexpected error occurred. Please try again."}static formatForDeveloper(e){return "code"in e&&"message"in e?`[${e.code}] ${e.message}`:e.message||"Unknown error"}static toJSON(e){return "toJSON"in e&&typeof e.toJSON=="function"?e.toJSON():{name:e.name||"Error",message:e.message,..."code"in e&&{code:e.code},..."details"in e&&{details:e.details}}}};var u=class{constructor(e){this.stripe=e;}async confirmPayment(e,t){let n=await this.stripe.confirmPayment({clientSecret:t,confirmParams:{payment_method:e,return_url:window.location.href},redirect:"if_required"});if(n.error)throw new m(n.error.message||"Payment failed",n.error.code);return n}async confirmCardPayment(e,t){let n=await this.stripe.confirmCardPayment(t,{payment_method:e});if(n.error)throw new m(n.error.message||"Payment failed",n.error.code);return n}async createPaymentMethod(e,t=false){let n;if(!t)n=await this.stripe.createPaymentMethod({elements:e});else {let r=(await e.getElement("address",{mode:"billing"}).getValue()).value;n=await this.stripe.createPaymentMethod({type:"card",card:e.getElement("cardNumber"),billing_details:{name:r.name,address:{...r.address,line2:r.address.line2??void 0}}});}if(n.error||!n.paymentMethod)throw new m(n.error?.message||"Failed to create payment method",n.error?.code);return n.paymentMethod.id}async retrievePaymentIntent(e){let t=await this.stripe.retrievePaymentIntent(e);if(t.error)throw new m(t.error.message||"Failed to retrieve payment intent",t.error.code);return t}};var d={showIcon:true,iconStyle:"solid",placeholders:{cardNumber:"1234 1234 1234 1234",cardExpiry:"MM / YY - TESTING",cardCvc:"CVC"},style:{base:{color:"#333333",fontFamily:"system-ui, -apple-system, sans-serif",fontSize:"16px","::placeholder":{color:"#aab7c4"}},complete:{color:"#333333"},empty:{},invalid:{color:"#df1b41"}}},w={cardNumber:"Card number",cardExpiry:"Expiry date",cardCvc:"CVC",address:"Address"},h=class{constructor(e,t,n){this.stripe=e;this.config=t;this.clientSecret=n;this.elements=null;this.mountedElements=new Map;this.elementStates=new Map;if(!n)throw new a("Client secret not initialized","CONFIGURATION_ERROR")}mountPaymentElement(e){if(!this.elements){let i={clientSecret:this.clientSecret,appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"};this.elements=this.stripe.elements(i);}if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let n=this.elements.create("payment",{layout:"tabs",wallets:{link:"never"}});n.mount(e),this.mountedElements.set("payment",n);}mountCardNumberElement(e){this.mountIndividualFormElement(e,"cardNumber",this.cardElementOptions("cardNumber"));}mountCardExpiryElement(e){this.mountIndividualFormElement(e,"cardExpiry",this.cardElementOptions("cardExpiry"));}mountCardCvcElement(e){this.mountIndividualFormElement(e,"cardCvc",this.cardElementOptions("cardCvc"));}mountAddressElement(e,t){this.mountIndividualFormElement(e,"address",{mode:t});}cardElementOptions(e){let{elementsConfig:t}=this.config,n={placeholder:t?.placeholders?.[e]??d.placeholders[e],style:{base:{...d.style.base,...t?.style?.base},complete:{...d.style.complete,...t?.style?.complete},empty:{...d.style.empty,...t?.style?.empty},invalid:{...d.style.invalid,...t?.style?.invalid}}};return e==="cardNumber"&&(n.showIcon=t?.showIcon??d.showIcon,n.iconStyle=t?.iconStyle??d.iconStyle),n}mountIndividualFormElement(e,t,n){if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let r=this.createIndividualFormElement(t,n);r.mount(e),this.mountedElements.set(t,r),this.trackElementState(t,r);}createIndividualFormElement(e,t){return this.elements||(this.elements=this.stripe.elements({appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"})),this.elements.create(e,t)}async validate(){let e=[];for(let[t,n]of this.elementStates.entries())n.complete||e.push({field:t,message:n.error??`${w[t]??t} failed validation`});return {isValid:e.length===0,errors:e}}getElements(){return this.elements}unmountAll(){for(let e of this.mountedElements.values())e.unmount();this.mountedElements.clear(),this.elementStates.clear();}trackElementState(e,t){this.elementStates.set(e,{complete:false});let n=i=>{this.elementStates.set(e,{complete:i.complete,error:i.error?.message});};t.on("change",n);}};var g=class{constructor(){this.extensions=[];}add(e){this.extensions.push(e);}async runBeforePayment(e){let t=e;for(let n of this.extensions)n.beforePayment&&(t=await n.beforePayment(t));return t}async runAfterPayment(e){await Promise.all(this.extensions.filter(t=>t.afterPayment).map(t=>t.afterPayment(e)));}async runOnError(e){await Promise.all(this.extensions.filter(t=>t.onPaymentError).map(t=>t.onPaymentError(e)));}};var f=class{constructor(e,t,n){this.stripeAdapter=e;this.elementsManager=t;this.verapayService=n;}async process(e,t){let n=this.elementsManager.getElements();await this.validatePaymentCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements);return await this.verapayService.processPrePayment({merchantId:t.merchantId,paymentIntentId:t.paymentIntentId,paymentMethodId:i,amount:t.amount,currency:t.currency,customerData:{email:e.customerEmail,firstName:e.customerFirstName,lastName:e.customerLastName},description:e.description,metadata:e.metadata}),this.confirm(t.clientSecret,{paymentMethodId:i,isUsingStripePaymentElement:t.isUsingStripePaymentElement,isUsingIndividualFormElements:t.isUsingIndividualFormElements})}async validatePaymentCanProceed(e,t){if(!e)throw new a("Payment form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of payment form in use");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}async confirm(e,t={}){let n;return t.isUsingStripePaymentElement?n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e):t.isUsingIndividualFormElements?n=await this.stripeAdapter.confirmCardPayment(t.paymentMethodId||"",e):n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e),this.formatPaymentResult(n)}async retrievePaymentIntent(e){let t=await this.stripeAdapter.retrievePaymentIntent(e);return this.formatPaymentResult(t)}formatPaymentResult(e){let t=e.paymentIntent,n="failed";return t.status==="succeeded"?n="succeeded":["processing","requires_action","requires_confirmation"].includes(t.status)&&(n="processing"),{success:t.status==="succeeded",paymentIntentId:t.id,status:n}}};var p=class{constructor(e,t){this.baseUrl=e,this.apiKey=t;}setApiKey(e){this.apiKey=e;}async getPaymentIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch provider config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async initialisePayment(e){let{merchantId:t,paymentData:n}=e;try{let i=await fetch(`${this.baseUrl}/api/initialise-payment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:t,paymentData:{...n,paymentMethodType:"card"}})});if(!i.ok){let o=await i.json().catch(()=>({}));throw new a(this.extractErrorMessage(o,i.status),"CONFIGURATION_ERROR")}let r=await i.json();if(!r.clientSecret||!r.paymentIntentId)throw new a("Missing clientSecret or paymentIntentId in server response","CONFIGURATION_ERROR");return {paymentIntentId:r.paymentIntentId,clientSecret:r.clientSecret,connectAccountId:r.connectAccountId,stripePublishableKey:r.stripePublishableKey}}catch(i){throw i instanceof a?i:new a(i instanceof Error?i.message:"Unknown error occurred","CONFIGURATION_ERROR")}}async processPrePayment(e){try{let t=await fetch(`${this.baseUrl}/api/process-prepayment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:e.merchantId,paymentIntentId:e.paymentIntentId,paymentMethodId:e.paymentMethodId,amount:e.amount,currency:e.currency,customerData:e.customerData,description:e.description,metadata:e.metadata})});if(!t.ok){let n=await t.json().catch(()=>({}));throw new a(this.extractErrorMessage(n,t.status),"CONFIGURATION_ERROR")}}catch(t){throw t instanceof a?t:new a(t instanceof Error?t.message:"Unknown error occurred","CONFIGURATION_ERROR")}}extractErrorMessage(e,t){if(!e||typeof e!="object")return `HTTP error! status: ${t}`;let n=e,i=[n.error,n.message,n.details];for(let r of i){if(typeof r=="string"&&r.trim().length>0)return r;if(r&&typeof r=="object")try{return JSON.stringify(r)}catch{}}return `HTTP error! status: ${t}`}};function R(s){return s.startsWith("vpy_cs_test_")?s.replace("vpy_cs_test_",""):s.startsWith("vpy_cs_live_")?s.replace("vpy_cs_live_",""):s}var E=class E{constructor(e){this.stripeAdapter=null;this.elementsManager=null;this.paymentService=null;this.initializationPromise=null;this.isUsingStripePaymentElement=false;this.isUsingIndividualFormElements=false;this.rawSecret=null;this.paymentIntentId=null;this.amount=null;this.currency=null;this.merchantId=null;if(!e.apiKey&&!e.clientSecret)throw new a("Either apiKey or clientSecret is required.","CONFIGURATION_ERROR");if(e.apiKey&&e.clientSecret)throw new a("Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.","CONFIGURATION_ERROR");e.apiKey&&!e.apiKey.includes("_pk_")&&typeof window<"u"&&console.warn("Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead."),this.config=e;let t=this.config.apiUrlOverride||E.BACKEND_URL;this.verapayService=new p(t,this.config.apiKey||""),this.extensionsManager=new g;}async initialize(){return this.initializationPromise?this.initializationPromise:(this.initializationPromise=(async()=>{let e,t,n;if(this.config.clientSecret){let r=await this.verapayService.getPaymentIntentConfig(this.config.clientSecret);e=this.config.clientSecret,t=r.paymentIntentId,n=r.publishableKey,this.amount=r.amount,this.currency=r.currency,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {this.validatePaymentInitialisation();let r=await this.verapayService.initialisePayment({merchantId:this.config.merchantId??"",paymentData:this.config.paymentData});e=r.clientSecret,t=r.paymentIntentId,n=r.stripePublishableKey,this.amount=this.config.paymentData.amount,this.currency=this.config.paymentData.currency,this.merchantId=this.config.merchantId??"";}this.rawSecret=R(e),this.paymentIntentId=t;let i=await loadStripe(n);if(!i)throw new a("Failed to load Stripe","CONFIGURATION_ERROR");this.stripeAdapter=new u(i),this.elementsManager=new h(i,this.config,this.rawSecret),this.paymentService=new f(this.stripeAdapter,this.elementsManager,this.verapayService);})().catch(e=>{throw this.initializationPromise=null,e}),this.initializationPromise)}async confirmPayment(){return await this.ensureInitialized(),this.paymentService.confirm(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}async retrievePaymentIntent(){return await this.ensureInitialized(),this.paymentService.retrievePaymentIntent(this.rawSecret)}async processPayment(e){await this.ensureInitialized();let t=await this.extensionsManager.runBeforePayment(e);try{let n=await this.paymentService.process(t,{merchantId:this.merchantId,paymentIntentId:this.paymentIntentId,clientSecret:this.rawSecret,amount:this.amount,currency:this.currency,isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements});return await this.extensionsManager.runAfterPayment(n),n}catch(n){throw await this.extensionsManager.runOnError(n),this.handlePaymentError(n)}}async mountPaymentForm(e){await this.ensureInitialized(),this.elementsManager.mountPaymentElement(e),this.isUsingStripePaymentElement=true;}async mountCardNumber(e){await this.ensureInitialized(),this.elementsManager.mountCardNumberElement(e),this.isUsingIndividualFormElements=true;}async mountCardExpiry(e){await this.ensureInitialized(),this.elementsManager.mountCardExpiryElement(e),this.isUsingIndividualFormElements=true;}async mountCardCvc(e){await this.ensureInitialized(),this.elementsManager.mountCardCvcElement(e),this.isUsingIndividualFormElements=true;}async mountAddress(e,t){await this.ensureInitialized(),this.elementsManager.mountAddressElement(e,t),this.isUsingIndividualFormElements=true;}addExtension(e){this.extensionsManager.add(e);}async ensureInitialized(){this.stripeAdapter||await this.initialize();}validatePaymentInitialisation(){if(!this.config.paymentData)throw new a("paymentData is required for frontend-initialized flows.","CONFIGURATION_ERROR");let{amount:e,currency:t,partnerFee:n}=this.config.paymentData;if(!t)throw new c("Currency is required","currency");let i=t.toUpperCase(),r=this.toMoney(e,i,"amount");if(r.isZero()||r.isNegative())throw new c("Amount must be greater than 0","amount");if(n!==void 0){let o=this.toMoney(n,i,"partnerFee");if(o.isNegative())throw new c("partnerFee cannot be negative","partnerFee");if(o.greaterThan(r))throw new c("partnerFee cannot exceed the payment amount","partnerFee")}}toMoney(e,t,n){try{return Money.fromInteger(e,t)}catch{throw new c(`${n} must be an integer in the smallest currency unit (e.g., cents for USD)`,n)}}handlePaymentError(e){if(e instanceof a)return e;let t=e instanceof Error?e.message:"Payment failed",n=e?.code;return new m(t,n)}};E.BACKEND_URL="https://api.verapay.app";var v=E;var I=class{validateCardNumber(e){let t=e.replace(/\D/g,"");if(t.length<13||t.length>19)return false;let n=0,i=false;for(let r=t.length-1;r>=0;r--){let o=parseInt(t[r],10);i&&(o*=2,o>9&&(o-=9)),n+=o,i=!i;}return n%10===0}detectCardType(e){let t=e.replace(/\D/g,"");return /^4/.test(t)?"visa":/^5[1-5]/.test(t)?"mastercard":/^3[47]/.test(t)?"amex":/^6(?:011|5)/.test(t)?"discover":"unknown"}validateExpiry(e,t){let n=new Date,i=n.getFullYear(),r=n.getMonth()+1;if(e<1||e>12)return false;let o=t<100?2e3+t:t;return !(o<i||o===i&&e<r)}validateCVC(e,t="unknown"){let n=e.replace(/\D/g,"");return t==="amex"?n.length===4:n.length===3||n.length===4}validateAll(e,t,n,i){let r=this.detectCardType(e);return {number:{isValid:this.validateCardNumber(e),cardType:r},expiry:{isValid:this.validateExpiry(t,n),month:t,year:n},cvc:{isValid:this.validateCVC(i,r),length:i.replace(/\D/g,"").length}}}};var P=class{static sanitizeCardNumber(e){return e.replace(/\D/g,"")}static formatCardNumber(e){return this.sanitizeCardNumber(e).replace(/(\d{4})/g,"$1 ").trim()}static sanitizeCVC(e){return e.replace(/\D/g,"").slice(0,4)}static sanitizeExpiry(e){let t=e.replace(/\D/g,"");return t.length===4?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,4),10)}:t.length===6?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,6),10)}:null}};var fe="1.1.0";
|
|
2
|
-
export{
|
|
1
|
+
import {loadStripe}from'@stripe/stripe-js';import {Money}from'ts-money';var a=class s extends Error{constructor(e,t="PAYMENT_FAILED",n){super(e),this.name="VerapayError",this.code=t,this.details={code:t,message:e,formattedMessage:this.formatMessage(e,t),...n},Error.captureStackTrace&&Error.captureStackTrace(this,s);}formatMessage(e,t){return {VALIDATION_ERROR:"Please check your payment information and try again.",PAYMENT_FAILED:"Your payment could not be processed. Please try again.",AUTHENTICATION_FAILED:"Payment authentication failed. Please try again.",NETWORK_ERROR:"Network error. Please check your connection and try again.",STRIPE_ERROR:"Payment service error. Please try again later.",CONFIGURATION_ERROR:"Configuration error. Please contact support.",CARD_DECLINED:"Your card was declined. Please use a different payment method.",INSUFFICIENT_FUNDS:"Insufficient funds. Please use a different payment method.",EXPIRED_CARD:"Your card has expired. Please use a different payment method."}[t]||e}toJSON(){return {name:this.name,code:this.code,message:this.message,details:this.details}}};var l=class extends a{constructor(e,t,n){super(e,"VALIDATION_ERROR",{field:t,metadata:n}),this.name="ValidationError";}};var o=class s extends a{constructor(e,t,n){let i=s.mapStripeCode(t);super(e,i,{stripeCode:t,metadata:n}),this.name="PaymentError";}static mapStripeCode(e){return e?{card_declined:"CARD_DECLINED",insufficient_funds:"INSUFFICIENT_FUNDS",expired_card:"EXPIRED_CARD",incorrect_cvc:"VALIDATION_ERROR",processing_error:"PAYMENT_FAILED",authentication_failed:"AUTHENTICATION_FAILED"}[e]||"PAYMENT_FAILED":"PAYMENT_FAILED"}};var u=class{static formatForUser(e){return "formattedMessage"in e?e.formattedMessage:"details"in e&&e.details&&typeof e.details=="object"&&"formattedMessage"in e.details&&typeof e.details.formattedMessage=="string"?e.details.formattedMessage:"An unexpected error occurred. Please try again."}static formatForDeveloper(e){return "code"in e&&"message"in e?`[${e.code}] ${e.message}`:e.message||"Unknown error"}static toJSON(e){return "toJSON"in e&&typeof e.toJSON=="function"?e.toJSON():{name:e.name||"Error",message:e.message,..."code"in e&&{code:e.code},..."details"in e&&{details:e.details}}}};var y=class{constructor(e){this.stripe=e;}async confirmPayment(e,t){let n=await this.stripe.confirmPayment({clientSecret:t,confirmParams:{payment_method:e,return_url:window.location.href},redirect:"if_required"});if(n.error)throw new o(n.error.message||"Payment failed",n.error.code);return n}async confirmCardPayment(e,t){let n=await this.stripe.confirmCardPayment(t,{payment_method:e});if(n.error)throw new o(n.error.message||"Payment failed",n.error.code);return n}async createPaymentMethod(e,t=false){let n;if(!t)n=await this.stripe.createPaymentMethod({elements:e});else {let r=(await e.getElement("address",{mode:"billing"}).getValue()).value;n=await this.stripe.createPaymentMethod({type:"card",card:e.getElement("cardNumber"),billing_details:{name:r.name,address:{...r.address,line2:r.address.line2??void 0}}});}if(n.error||!n.paymentMethod)throw new o(n.error?.message||"Failed to create payment method",n.error?.code);return n.paymentMethod.id}async retrievePaymentIntent(e){let t=await this.stripe.retrievePaymentIntent(e);if(t.error)throw new o(t.error.message||"Failed to retrieve payment intent",t.error.code);return t}async confirmCardSetup(e,t){let n=await this.stripe.confirmCardSetup(t,{payment_method:e});if(n.error)throw new o(n.error.message||"Card setup failed",n.error.code);return n}async retrieveSetupIntent(e){let t=await this.stripe.retrieveSetupIntent(e);if(t.error)throw new o(t.error.message||"Failed to retrieve setup intent",t.error.code);return t}};var p={showIcon:true,iconStyle:"solid",placeholders:{cardNumber:"1234 1234 1234 1234",cardExpiry:"MM / YY - TESTING",cardCvc:"CVC"},style:{base:{color:"#333333",fontFamily:"system-ui, -apple-system, sans-serif",fontSize:"16px","::placeholder":{color:"#aab7c4"}},complete:{color:"#333333"},empty:{},invalid:{color:"#df1b41"}}},S={cardNumber:"Card number",cardExpiry:"Expiry date",cardCvc:"CVC",address:"Address"},h=class{constructor(e,t,n){this.stripe=e;this.config=t;this.clientSecret=n;this.elements=null;this.mountedElements=new Map;this.elementStates=new Map;if(!n)throw new a("Client secret not initialized","CONFIGURATION_ERROR")}mountPaymentElement(e){if(!this.elements){let i={clientSecret:this.clientSecret,appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"};this.elements=this.stripe.elements(i);}if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let n=this.elements.create("payment",{layout:"tabs",wallets:{link:"never"}});n.mount(e),this.mountedElements.set("payment",n);}mountCardNumberElement(e){this.mountIndividualFormElement(e,"cardNumber",this.cardElementOptions("cardNumber"));}mountCardExpiryElement(e){this.mountIndividualFormElement(e,"cardExpiry",this.cardElementOptions("cardExpiry"));}mountCardCvcElement(e){this.mountIndividualFormElement(e,"cardCvc",this.cardElementOptions("cardCvc"));}mountAddressElement(e,t){this.mountIndividualFormElement(e,"address",{mode:t});}cardElementOptions(e){let{elementsConfig:t}=this.config,n={placeholder:t?.placeholders?.[e]??p.placeholders[e],style:{base:{...p.style.base,...t?.style?.base},complete:{...p.style.complete,...t?.style?.complete},empty:{...p.style.empty,...t?.style?.empty},invalid:{...p.style.invalid,...t?.style?.invalid}}};return e==="cardNumber"&&(n.showIcon=t?.showIcon??p.showIcon,n.iconStyle=t?.iconStyle??p.iconStyle),n}mountIndividualFormElement(e,t,n){if(!document.querySelector(e))throw new a(`Element not found: ${e}`,"CONFIGURATION_ERROR");let r=this.createIndividualFormElement(t,n);r.mount(e),this.mountedElements.set(t,r),this.trackElementState(t,r);}createIndividualFormElement(e,t){return this.elements||(this.elements=this.stripe.elements({appearance:this.config.appearance,locale:this.config.locale,fonts:this.config.fonts,paymentMethodCreation:"manual"})),this.elements.create(e,t)}async validate(){let e=[];for(let[t,n]of this.elementStates.entries())n.complete||e.push({field:t,message:n.error??`${S[t]??t} failed validation`});return {isValid:e.length===0,errors:e}}getElements(){return this.elements}unmountAll(){for(let e of this.mountedElements.values())e.unmount();this.mountedElements.clear(),this.elementStates.clear();}trackElementState(e,t){this.elementStates.set(e,{complete:false});let n=i=>{this.elementStates.set(e,{complete:i.complete,error:i.error?.message});};t.on("change",n);}};var f=class{constructor(){this.extensions=[];}add(e){this.extensions.push(e);}async runBeforePayment(e){let t=e;for(let n of this.extensions)n.beforePayment&&(t=await n.beforePayment(t));return t}async runAfterPayment(e){await Promise.all(this.extensions.filter(t=>t.afterPayment).map(t=>t.afterPayment(e)));}async runOnError(e){await Promise.all(this.extensions.filter(t=>t.onPaymentError).map(t=>t.onPaymentError(e)));}};var g=class{constructor(e,t,n){this.stripeAdapter=e;this.elementsManager=t;this.verapayService=n;}async process(e,t){let n=this.elementsManager.getElements();await this.validatePaymentCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements);return await this.verapayService.processPrePayment({merchantId:t.merchantId,paymentIntentId:t.paymentIntentId,paymentMethodId:i,amount:t.amount,currency:t.currency,customerData:{email:e.customerEmail,firstName:e.customerFirstName,lastName:e.customerLastName},description:e.description,metadata:e.metadata}),this.confirm(t.clientSecret,{paymentMethodId:i,isUsingStripePaymentElement:t.isUsingStripePaymentElement,isUsingIndividualFormElements:t.isUsingIndividualFormElements})}async validatePaymentCanProceed(e,t){if(!e)throw new a("Payment form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of payment form in use");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}async confirm(e,t={}){let n;return t.isUsingStripePaymentElement?n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e):t.isUsingIndividualFormElements?n=await this.stripeAdapter.confirmCardPayment(t.paymentMethodId||"",e):n=await this.stripeAdapter.confirmPayment(t.paymentMethodId||"",e),this.formatPaymentResult(n)}async retrievePaymentIntent(e){let t=await this.stripeAdapter.retrievePaymentIntent(e);return this.formatPaymentResult(t)}formatPaymentResult(e){let t=e.paymentIntent,n="failed";return t.status==="succeeded"?n="succeeded":["processing","requires_action","requires_confirmation"].includes(t.status)&&(n="processing"),{success:t.status==="succeeded",paymentIntentId:t.id,status:n}}};var I=class{constructor(e,t){this.stripeAdapter=e;this.elementsManager=t;}async save(e,t){let n=this.elementsManager.getElements();await this.validateSetupCanProceed(n,t),await n.submit();let i=await this.stripeAdapter.createPaymentMethod(n,t.isUsingIndividualFormElements),r=await this.stripeAdapter.confirmCardSetup(i,e);return this.formatSetupResult(r)}async retrieve(e){let t=await this.stripeAdapter.retrieveSetupIntent(e);return this.formatSetupResult(t)}async validateSetupCanProceed(e,t){if(!e)throw new a("Card form not mounted","CONFIGURATION_ERROR");if(t.isUsingStripePaymentElement&&t.isUsingIndividualFormElements)throw new a("Both forms of card form in use","CONFIGURATION_ERROR");if(t.isUsingIndividualFormElements){let n=await this.elementsManager.validate();if(!n.isValid)throw new a(n.errors[0].message,"VALIDATION_ERROR")}}formatSetupResult(e){let t=e.setupIntent,n="failed";t.status==="succeeded"?n="succeeded":t.status==="processing"?n="processing":(t.status==="requires_action"||t.status==="requires_confirmation")&&(n="requires_action");let i=t.payment_method,r=typeof i=="string"?i:i?.id;return {success:t.status==="succeeded",savedPaymentMethodId:r,setupIntentId:t.id,status:n}}};var d=class{constructor(e,t){this.baseUrl=e,this.apiKey=t;}setApiKey(e){this.apiKey=e;}async getPaymentIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch provider config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async getSetupIntentConfig(e){try{let t=await fetch(`${this.baseUrl}/v1/setup_intents/config?client_secret=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});if(!t.ok)throw new a("Failed to fetch setup config","CONFIGURATION_ERROR");return t.json()}catch(t){throw t instanceof a?t:new a("Error connecting to Verapay API","NETWORK_ERROR")}}async initialisePayment(e){let{merchantId:t,paymentData:n}=e;try{let i=await fetch(`${this.baseUrl}/api/initialise-payment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:t,paymentData:{...n,paymentMethodType:"card"}})});if(!i.ok){let m=await i.json().catch(()=>({}));throw new a(this.extractErrorMessage(m,i.status),"CONFIGURATION_ERROR")}let r=await i.json();if(!r.clientSecret||!r.paymentIntentId)throw new a("Missing clientSecret or paymentIntentId in server response","CONFIGURATION_ERROR");return {paymentIntentId:r.paymentIntentId,clientSecret:r.clientSecret,connectAccountId:r.connectAccountId,stripePublishableKey:r.stripePublishableKey}}catch(i){throw i instanceof a?i:new a(i instanceof Error?i.message:"Unknown error occurred","CONFIGURATION_ERROR")}}async processPrePayment(e){try{let t=await fetch(`${this.baseUrl}/api/process-prepayment`,{method:"POST",headers:{"Content-Type":"application/json",...this.apiKey?{"x-api-key":this.apiKey}:{}},body:JSON.stringify({merchantId:e.merchantId,paymentIntentId:e.paymentIntentId,paymentMethodId:e.paymentMethodId,amount:e.amount,currency:e.currency,customerData:e.customerData,description:e.description,metadata:e.metadata})});if(!t.ok){let n=await t.json().catch(()=>({}));throw new a(this.extractErrorMessage(n,t.status),"CONFIGURATION_ERROR")}}catch(t){throw t instanceof a?t:new a(t instanceof Error?t.message:"Unknown error occurred","CONFIGURATION_ERROR")}}extractErrorMessage(e,t){if(!e||typeof e!="object")return `HTTP error! status: ${t}`;let n=e,i=[n.error,n.message,n.details];for(let r of i){if(typeof r=="string"&&r.trim().length>0)return r;if(r&&typeof r=="object")try{return JSON.stringify(r)}catch{}}return `HTTP error! status: ${t}`}};function R(s){return s.startsWith("vpy_cs_test_")?s.replace("vpy_cs_test_",""):s.startsWith("vpy_cs_live_")?s.replace("vpy_cs_live_",""):s}var E=class E{constructor(e){this.stripeAdapter=null;this.elementsManager=null;this.paymentService=null;this.setupService=null;this.initializationPromise=null;this.isUsingStripePaymentElement=false;this.isUsingIndividualFormElements=false;this.intentKind="payment";this.rawSecret=null;this.paymentIntentId=null;this.amount=null;this.currency=null;this.merchantId=null;if(!e.apiKey&&!e.clientSecret)throw new a("Either apiKey or clientSecret is required.","CONFIGURATION_ERROR");if(e.apiKey&&e.clientSecret)throw new a("Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.","CONFIGURATION_ERROR");e.apiKey&&!e.apiKey.includes("_pk_")&&typeof window<"u"&&console.warn("Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead."),this.config=e;let t=this.config.apiUrlOverride||E.BACKEND_URL;this.verapayService=new d(t,this.config.apiKey||""),this.extensionsManager=new f;}async initialize(){return this.initializationPromise?this.initializationPromise:(this.initializationPromise=(async()=>{let e,t,n;if(this.config.clientSecret)if(this.intentKind=R(this.config.clientSecret).startsWith("seti_")?"setup":"payment",this.intentKind==="setup"){let r=await this.verapayService.getSetupIntentConfig(this.config.clientSecret);if(r.object!=="setup_intent_config")throw new a("Unexpected configuration returned for setup intent","CONFIGURATION_ERROR");e=this.config.clientSecret,t="",n=r.publishableKey,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {let r=await this.verapayService.getPaymentIntentConfig(this.config.clientSecret);e=this.config.clientSecret,t=r.paymentIntentId,n=r.publishableKey,this.amount=r.amount,this.currency=r.currency,this.merchantId=r.merchantId,r.verapayPublishableKey&&this.verapayService.setApiKey(r.verapayPublishableKey);}else {this.validatePaymentInitialisation();let r=await this.verapayService.initialisePayment({merchantId:this.config.merchantId??"",paymentData:this.config.paymentData});e=r.clientSecret,t=r.paymentIntentId,n=r.stripePublishableKey,this.amount=this.config.paymentData.amount,this.currency=this.config.paymentData.currency,this.merchantId=this.config.merchantId??"";}this.rawSecret=R(e),this.paymentIntentId=t;let i=await loadStripe(n);if(!i)throw new a("Failed to load Stripe","CONFIGURATION_ERROR");this.stripeAdapter=new y(i),this.elementsManager=new h(i,this.config,this.rawSecret),this.paymentService=new g(this.stripeAdapter,this.elementsManager,this.verapayService),this.setupService=new I(this.stripeAdapter,this.elementsManager);})().catch(e=>{throw this.initializationPromise=null,e}),this.initializationPromise)}async confirmPayment(){return await this.ensureInitialized(),this.assertIntentKind("payment","confirmPayment"),this.paymentService.confirm(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}async saveCard(){await this.ensureInitialized(),this.assertIntentKind("setup","saveCard");try{return await this.setupService.save(this.rawSecret,{isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements})}catch(e){throw this.handlePaymentError(e)}}async retrieveSetupIntent(){return await this.ensureInitialized(),this.assertIntentKind("setup","retrieveSetupIntent"),this.setupService.retrieve(this.rawSecret)}teardown(){this.elementsManager?.unmountAll(),this.stripeAdapter=null,this.elementsManager=null,this.paymentService=null,this.setupService=null,this.initializationPromise=null,this.isUsingStripePaymentElement=false,this.isUsingIndividualFormElements=false,this.intentKind="payment",this.rawSecret=null,this.paymentIntentId=null,this.amount=null,this.currency=null,this.merchantId=null;}async retrievePaymentIntent(){return await this.ensureInitialized(),this.paymentService.retrievePaymentIntent(this.rawSecret)}async processPayment(e){await this.ensureInitialized(),this.assertIntentKind("payment","processPayment");let t=await this.extensionsManager.runBeforePayment(e);try{let n=await this.paymentService.process(t,{merchantId:this.merchantId,paymentIntentId:this.paymentIntentId,clientSecret:this.rawSecret,amount:this.amount,currency:this.currency,isUsingStripePaymentElement:this.isUsingStripePaymentElement,isUsingIndividualFormElements:this.isUsingIndividualFormElements});return await this.extensionsManager.runAfterPayment(n),n}catch(n){throw await this.extensionsManager.runOnError(n),this.handlePaymentError(n)}}async mountPaymentForm(e){await this.ensureInitialized(),this.elementsManager.mountPaymentElement(e),this.isUsingStripePaymentElement=true;}async mountCardNumber(e){await this.ensureInitialized(),this.elementsManager.mountCardNumberElement(e),this.isUsingIndividualFormElements=true;}async mountCardExpiry(e){await this.ensureInitialized(),this.elementsManager.mountCardExpiryElement(e),this.isUsingIndividualFormElements=true;}async mountCardCvc(e){await this.ensureInitialized(),this.elementsManager.mountCardCvcElement(e),this.isUsingIndividualFormElements=true;}async mountAddress(e,t){await this.ensureInitialized(),this.elementsManager.mountAddressElement(e,t),this.isUsingIndividualFormElements=true;}addExtension(e){this.extensionsManager.add(e);}async ensureInitialized(){this.stripeAdapter||await this.initialize();}assertIntentKind(e,t){if(this.intentKind!==e)throw new a(`${t} requires a ${e} intent client secret`,"CONFIGURATION_ERROR")}validatePaymentInitialisation(){if(!this.config.paymentData)throw new a("paymentData is required for frontend-initialized flows.","CONFIGURATION_ERROR");let{amount:e,currency:t,platformFee:n}=this.config.paymentData;if(!t)throw new l("Currency is required","currency");let i=t.toUpperCase(),r=this.toMoney(e,i,"amount");if(r.isZero()||r.isNegative())throw new l("Amount must be greater than 0","amount");if(n!==void 0){let m=this.toMoney(n,i,"platformFee");if(m.isNegative())throw new l("platformFee cannot be negative","platformFee");if(m.greaterThan(r))throw new l("platformFee cannot exceed the payment amount","platformFee")}}toMoney(e,t,n){try{return Money.fromInteger(e,t)}catch{throw new l(`${n} must be an integer in the smallest currency unit (e.g., cents for USD)`,n)}}handlePaymentError(e){if(e instanceof a)return e;let t=e instanceof Error?e.message:"Payment failed",n=e?.code;return new o(t,n)}};E.BACKEND_URL="https://api.verapay.app";var w=E;var P=class{validateCardNumber(e){let t=e.replace(/\D/g,"");if(t.length<13||t.length>19)return false;let n=0,i=false;for(let r=t.length-1;r>=0;r--){let m=parseInt(t[r],10);i&&(m*=2,m>9&&(m-=9)),n+=m,i=!i;}return n%10===0}detectCardType(e){let t=e.replace(/\D/g,"");return /^4/.test(t)?"visa":/^5[1-5]/.test(t)?"mastercard":/^3[47]/.test(t)?"amex":/^6(?:011|5)/.test(t)?"discover":"unknown"}validateExpiry(e,t){let n=new Date,i=n.getFullYear(),r=n.getMonth()+1;if(e<1||e>12)return false;let m=t<100?2e3+t:t;return !(m<i||m===i&&e<r)}validateCVC(e,t="unknown"){let n=e.replace(/\D/g,"");return t==="amex"?n.length===4:n.length===3||n.length===4}validateAll(e,t,n,i){let r=this.detectCardType(e);return {number:{isValid:this.validateCardNumber(e),cardType:r},expiry:{isValid:this.validateExpiry(t,n),month:t,year:n},cvc:{isValid:this.validateCVC(i,r),length:i.replace(/\D/g,"").length}}}};var v=class{static sanitizeCardNumber(e){return e.replace(/\D/g,"")}static formatCardNumber(e){return this.sanitizeCardNumber(e).replace(/(\d{4})/g,"$1 ").trim()}static sanitizeCVC(e){return e.replace(/\D/g,"").slice(0,4)}static sanitizeExpiry(e){let t=e.replace(/\D/g,"");return t.length===4?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,4),10)}:t.length===6?{month:parseInt(t.slice(0,2),10),year:parseInt(t.slice(2,6),10)}:null}};var ve="1.4.0";
|
|
2
|
+
export{P as CardValidator,u as ErrorFormatter,v as InputSanitizer,o as PaymentError,ve as VERSION,l as ValidationError,w as VerapayClient,a as VerapayError,d as VerapayService};//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/errors/verapay-error.ts","../src/errors/validation-error.ts","../src/errors/payment-error.ts","../src/errors/error-formatter.ts","../src/client/stripe-adapter.ts","../src/client/elements-manager.ts","../src/client/payment-extensions-manager.ts","../src/services/payment-service.ts","../src/services/verapay-service.ts","../src/utils/secret.util.ts","../src/client/verapay-client.ts","../src/validation/card-validator.ts","../src/validation/input-sanitizer.ts","../src/index.ts"],"names":["VerapayError","_VerapayError","message","code","details","ValidationError","field","metadata","PaymentError","_PaymentError","stripeCode","ErrorFormatter","error","StripeAdapter","stripe","paymentMethodId","clientSecret","result","elements","isUsingIndividualFormElements","address","DEFAULT_CARD_ELEMENT_CONFIG","FIELD_LABELS","ElementsManager","config","selector","elementsConfig","element","mode","fieldType","options","formFieldType","elementType","errors","state","handleElementChange","event","PaymentExtensionsManager","extension","request","modifiedRequest","ext","PaymentService","stripeAdapter","elementsManager","verapayService","context","validation","paymentIntent","status","VerapayService","baseUrl","apiKey","response","merchantId","paymentData","errorData","data","record","candidates","candidate","unwrapClientSecret","wrappedSecret","_VerapayClient","backendUrl","paymentIntentId","stripePublishableKey","loadStripe","paymentResult","amount","currency","partnerFee","uppercaseCurrency","paymentAmount","partnerFeeAmount","value","fieldName","Money","VerapayClient","CardValidator","cardNumber","cleaned","sum","isEven","i","digit","month","year","now","currentYear","currentMonth","fullYear","cvc","cardType","expiryMonth","expiryYear","InputSanitizer","input","VERSION"],"mappings":"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","file":"index.js","sourcesContent":["import type { ErrorDetails } from '../types';\nimport { ErrorCode } from '../types';\n\nexport class VerapayError extends Error {\n public readonly code: ErrorCode;\n public readonly details: ErrorDetails;\n\n constructor(\n message: string,\n code: ErrorCode = ErrorCode.PAYMENT_FAILED,\n details?: Partial<ErrorDetails>\n ) {\n super(message);\n this.name = 'VerapayError';\n this.code = code;\n this.details = {\n code,\n message,\n formattedMessage: this.formatMessage(message, code),\n ...details,\n };\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, VerapayError);\n }\n }\n\n private formatMessage(message: string, code: ErrorCode): string {\n const messageMap: Record<ErrorCode, string> = {\n [ErrorCode.VALIDATION_ERROR]:\n 'Please check your payment information and try again.',\n [ErrorCode.PAYMENT_FAILED]:\n 'Your payment could not be processed. Please try again.',\n [ErrorCode.AUTHENTICATION_FAILED]:\n 'Payment authentication failed. Please try again.',\n [ErrorCode.NETWORK_ERROR]:\n 'Network error. Please check your connection and try again.',\n [ErrorCode.STRIPE_ERROR]:\n 'Payment service error. Please try again later.',\n [ErrorCode.CONFIGURATION_ERROR]:\n 'Configuration error. Please contact support.',\n [ErrorCode.CARD_DECLINED]:\n 'Your card was declined. Please use a different payment method.',\n [ErrorCode.INSUFFICIENT_FUNDS]:\n 'Insufficient funds. Please use a different payment method.',\n [ErrorCode.EXPIRED_CARD]:\n 'Your card has expired. Please use a different payment method.',\n };\n\n return messageMap[code] || message;\n }\n\n toJSON() {\n return {\n name: this.name,\n code: this.code,\n message: this.message,\n details: this.details,\n };\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class ValidationError extends VerapayError {\n constructor(message: string, field?: string, metadata?: Record<string, unknown>) {\n\n super(message, ErrorCode.VALIDATION_ERROR, {\n field,\n metadata,\n });\n this.name = 'ValidationError';\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class PaymentError extends VerapayError {\n constructor(\n message: string,\n stripeCode?: string,\n metadata?: Record<string, unknown>\n ) {\n const code = PaymentError.mapStripeCode(stripeCode);\n super(message, code, {\n stripeCode,\n metadata,\n });\n this.name = 'PaymentError';\n }\n\n private static mapStripeCode(stripeCode?: string): ErrorCode {\n if (!stripeCode) return ErrorCode.PAYMENT_FAILED;\n\n const codeMap: Record<string, ErrorCode> = {\n card_declined: ErrorCode.CARD_DECLINED,\n insufficient_funds: ErrorCode.INSUFFICIENT_FUNDS,\n expired_card: ErrorCode.EXPIRED_CARD,\n incorrect_cvc: ErrorCode.VALIDATION_ERROR,\n processing_error: ErrorCode.PAYMENT_FAILED,\n authentication_failed: ErrorCode.AUTHENTICATION_FAILED,\n };\n\n return codeMap[stripeCode] || ErrorCode.PAYMENT_FAILED;\n }\n}\n","import type { ErrorDetails } from '../types';\n\nexport class ErrorFormatter {\n static formatForUser(error: Error | ErrorDetails): string {\n if ('formattedMessage' in error) {\n return error.formattedMessage;\n }\n if (\n 'details' in error &&\n error.details &&\n typeof error.details === 'object' &&\n 'formattedMessage' in error.details &&\n typeof error.details.formattedMessage === 'string'\n ) {\n return error.details.formattedMessage;\n }\n return 'An unexpected error occurred. Please try again.';\n }\n\n static formatForDeveloper(error: Error | ErrorDetails): string {\n if ('code' in error && 'message' in error) {\n return `[${error.code}] ${error.message}`;\n }\n return error.message || 'Unknown error';\n }\n\n static toJSON(error: Error | ErrorDetails): Record<string, unknown> {\n\n if ('toJSON' in error && typeof error.toJSON === 'function') {\n return error.toJSON();\n }\n\n return {\n name: (error as Error).name || 'Error',\n message: error.message,\n ...('code' in error && { code: error.code }),\n ...('details' in error && { details: error.details }),\n };\n }\n}\n","import type { PaymentIntent, Stripe, StripeElements } from '@stripe/stripe-js';\nimport { PaymentError } from '../errors';\n\nexport class StripeAdapter {\n constructor(private stripe: Stripe) {}\n\n async confirmPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmPayment({\n clientSecret,\n confirmParams: {\n payment_method: paymentMethodId,\n return_url: window.location.href,\n },\n redirect: 'if_required',\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmCardPayment(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async createPaymentMethod(\n elements: StripeElements,\n isUsingIndividualFormElements: boolean = false\n ): Promise<string> {\n let result;\n\n if (!isUsingIndividualFormElements) {\n result = await this.stripe.createPaymentMethod({\n elements,\n });\n } else {\n // @ts-expect-error - Stripe types don't include mode parameter for getElement\n const addressElement = await elements.getElement('address', { mode: 'billing' })!.getValue();\n\n const address = addressElement!.value;\n\n result = await this.stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement('cardNumber')!,\n billing_details: {\n name: address.name,\n address: {\n ...address.address,\n line2: address.address.line2 ?? undefined,\n },\n },\n });\n }\n\n if (result.error || !result.paymentMethod) {\n throw new PaymentError(\n result.error?.message || 'Failed to create payment method',\n result.error?.code\n );\n }\n\n return result.paymentMethod.id;\n }\n\n async retrievePaymentIntent(\n clientSecret: string,\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.retrievePaymentIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve payment intent',\n result.error.code,\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n}\n\n","import type {\n Stripe,\n StripeElements,\n StripeElement,\n StripePaymentElement,\n StripeCardNumberElement,\n PaymentWalletsOption,\n} from '@stripe/stripe-js';\nimport type { VerapayConfig, ValidationError, ValidationResult } from '../types';\nimport { VerapayError, ErrorCode } from '../errors';\n\ntype ElementState = { complete: boolean; error?: string }\n\nconst DEFAULT_CARD_ELEMENT_CONFIG = {\n showIcon: true,\n iconStyle: 'solid' as const,\n placeholders: {\n cardNumber: '1234 1234 1234 1234',\n cardExpiry: 'MM / YY - TESTING',\n cardCvc: 'CVC',\n },\n style: {\n base: {\n color: '#333333',\n fontFamily: 'system-ui, -apple-system, sans-serif',\n fontSize: '16px',\n '::placeholder': { color: '#aab7c4' },\n },\n complete: {\n color: '#333333',\n },\n empty: {},\n invalid: {\n color: '#df1b41',\n },\n },\n}\n\nconst FIELD_LABELS: Record<string, string> = {\n cardNumber: 'Card number',\n cardExpiry: 'Expiry date',\n cardCvc: 'CVC',\n address: 'Address',\n}\n\nexport class ElementsManager {\n private elements: StripeElements | null = null;\n private mountedElements: Map<string, StripeElement> = new Map();\n private elementStates: Map<string, ElementState> = new Map();\n\n constructor(\n private stripe: Stripe,\n private config: VerapayConfig,\n private clientSecret: string,\n ) {\n if (!clientSecret) {\n throw new VerapayError(\n 'Client secret not initialized',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n\n mountPaymentElement(selector: string): void {\n if (!this.elements) {\n const elementsConfig = {\n clientSecret: this.clientSecret,\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n };\n\n this.elements = this.stripe.elements(elementsConfig);\n }\n\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.elements.create('payment', {\n layout: 'tabs',\n wallets: { link: 'never' } as unknown as PaymentWalletsOption,\n }) as StripePaymentElement;\n\n element.mount(selector);\n this.mountedElements.set('payment', element);\n }\n\n mountCardNumberElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardNumber', this.cardElementOptions('cardNumber'));\n }\n\n mountCardExpiryElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardExpiry', this.cardElementOptions('cardExpiry'));\n }\n\n mountCardCvcElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardCvc', this.cardElementOptions('cardCvc'));\n }\n\n mountAddressElement(selector: string, mode: 'billing' | 'shipping'): void {\n this.mountIndividualFormElement(selector, 'address', { mode });\n }\n\n private cardElementOptions(fieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc'): Record<string, unknown> {\n const { elementsConfig } = this.config;\n const options: Record<string, unknown> = {\n placeholder: elementsConfig?.placeholders?.[fieldType] ?? DEFAULT_CARD_ELEMENT_CONFIG.placeholders[fieldType],\n style: {\n base: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.base, ...elementsConfig?.style?.base },\n complete: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.complete, ...elementsConfig?.style?.complete },\n empty: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.empty, ...elementsConfig?.style?.empty },\n invalid: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.invalid, ...elementsConfig?.style?.invalid },\n },\n };\n\n if (fieldType === 'cardNumber') {\n options.showIcon = elementsConfig?.showIcon ?? DEFAULT_CARD_ELEMENT_CONFIG.showIcon;\n options.iconStyle = elementsConfig?.iconStyle ?? DEFAULT_CARD_ELEMENT_CONFIG.iconStyle;\n }\n\n return options;\n }\n\n private mountIndividualFormElement(selector: string, formFieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address', options?: Record<string, unknown>) {\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.createIndividualFormElement(formFieldType, options) as StripeCardNumberElement;\n element.mount(selector);\n\n this.mountedElements.set(formFieldType, element);\n this.trackElementState(formFieldType, element);\n }\n\n private createIndividualFormElement(\n elementType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address',\n options?: Record<string, unknown>,\n ): StripeElement {\n if (!this.elements) {\n this.elements = this.stripe.elements({\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n });\n }\n\n return this.elements.create(elementType as 'cardNumber', options);\n }\n\n\n\n async validate(): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n\n for (const [field, state] of this.elementStates.entries()) {\n if (!state.complete) {\n errors.push({\n field,\n message: state.error ?? `${FIELD_LABELS[field] ?? field} failed validation`,\n })\n }\n }\n\n return { isValid: errors.length === 0, errors }\n }\n\n getElements(): StripeElements | null {\n return this.elements;\n }\n\n unmountAll(): void {\n for (const element of this.mountedElements.values()) {\n element.unmount();\n }\n this.mountedElements.clear();\n this.elementStates.clear();\n }\n\n private trackElementState(field: string, element: StripeElement): void {\n this.elementStates.set(field, { complete: false })\n\n const handleElementChange = (event: { complete: boolean; error?: { message: string } }) => {\n this.elementStates.set(field, { complete: event.complete, error: event.error?.message })\n };\n\n (element as unknown as { on: (event: string, handler: (e: unknown) => void) => void }).on(\n 'change',\n handleElementChange as (e: unknown) => void,\n );\n }\n}\n\n\n","import type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport type { PaymentExtension } from '../extensions'\n\nexport class PaymentExtensionsManager {\n private extensions: PaymentExtension[] = []\n\n add(extension: PaymentExtension): void {\n this.extensions.push(extension)\n }\n\n async runBeforePayment(request: ProcessPaymentRequest): Promise<ProcessPaymentRequest> {\n let modifiedRequest = request\n for (const ext of this.extensions) {\n if (ext.beforePayment) {\n modifiedRequest = await ext.beforePayment(modifiedRequest)\n }\n }\n return modifiedRequest\n }\n\n async runAfterPayment(result: PaymentResult): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.afterPayment)\n .map((ext) => ext.afterPayment!(result)),\n )\n }\n\n async runOnError(error: Error): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.onPaymentError)\n .map((ext) => ext.onPaymentError!(error)),\n )\n }\n}\n","import { StripeAdapter } from '../client/stripe-adapter'\nimport { ElementsManager } from '../client/elements-manager'\nimport { ErrorCode, VerapayError } from '../errors'\nimport { VerapayService } from './verapay-service'\nimport type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface ProcessPaymentContext {\n merchantId: string\n paymentIntentId: string\n clientSecret: string\n amount: number\n currency: string\n isUsingStripePaymentElement: boolean\n isUsingIndividualFormElements: boolean\n}\n\nexport class PaymentService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n private verapayService: VerapayService,\n ) {}\n\n async process(request: ProcessPaymentRequest, context: ProcessPaymentContext): Promise<PaymentResult> {\n const elements = this.elementsManager.getElements()\n\n await this.validatePaymentCanProceed(elements, context);\n\n await elements!.submit()\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n )\n\n await this.verapayService.processPrePayment({\n merchantId: context.merchantId,\n paymentIntentId: context.paymentIntentId,\n paymentMethodId,\n amount: context.amount,\n currency: context.currency,\n customerData: {\n email: request.customerEmail,\n firstName: request.customerFirstName,\n lastName: request.customerLastName,\n },\n description: request.description,\n metadata: request.metadata,\n })\n\n return this.confirm(context.clientSecret, {\n paymentMethodId,\n isUsingStripePaymentElement: context.isUsingStripePaymentElement,\n isUsingIndividualFormElements: context.isUsingIndividualFormElements,\n });\n }\n\n private async validatePaymentCanProceed(\n elements: StripeElements | null,\n context: ProcessPaymentContext,\n ) {\n if (!elements) {\n throw new VerapayError('Payment form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of payment form in use');\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n async confirm(\n clientSecret: string,\n options: {\n isUsingStripePaymentElement?: boolean;\n isUsingIndividualFormElements?: boolean;\n paymentMethodId?: string;\n } = {},\n ): Promise<PaymentResult> {\n let result;\n\n if (options.isUsingStripePaymentElement) {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n } else if (options.isUsingIndividualFormElements) {\n result = await this.stripeAdapter.confirmCardPayment(\n options.paymentMethodId || '',\n clientSecret,\n );\n } else {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n }\n\n return this.formatPaymentResult(result);\n }\n\n async retrievePaymentIntent(clientSecret: string): Promise<PaymentResult> {\n const result = await this.stripeAdapter.retrievePaymentIntent(clientSecret);\n return this.formatPaymentResult(result);\n }\n\n private formatPaymentResult(result: unknown): PaymentResult {\n const paymentIntent = (result as { paymentIntent: { status: string; id: string } })\n .paymentIntent\n\n let status: 'succeeded' | 'processing' | 'failed' = 'failed'\n if (paymentIntent.status === 'succeeded') {\n status = 'succeeded'\n } else if (\n ['processing', 'requires_action', 'requires_confirmation'].includes(\n paymentIntent.status,\n )\n ) {\n status = 'processing'\n }\n\n return {\n success: paymentIntent.status === 'succeeded',\n paymentIntentId: paymentIntent.id,\n status,\n }\n }\n\n}\n\n\n","import { ErrorCode, VerapayError } from '../errors';\nimport { PaymentData } from '../types';\n\nexport interface InitialisePaymentRequest {\n merchantId: string;\n paymentData: PaymentData;\n}\n\nexport interface InitialisePaymentResponse {\n paymentIntentId: string;\n clientSecret: string;\n connectAccountId: string;\n stripePublishableKey: string;\n}\n\nexport interface ProcessPrePaymentRequest {\n merchantId: string;\n paymentIntentId: string;\n paymentMethodId: string;\n amount: number;\n currency: string;\n customerData: Record<string, unknown>;\n\n description?: string;\n metadata?: Record<string, string>;\n}\n\nexport class VerapayService {\n private readonly baseUrl: string;\n private apiKey?: string;\n\n constructor(baseUrl: string, apiKey?: string) {\n this.baseUrl = baseUrl;\n this.apiKey = apiKey;\n }\n\n setApiKey(apiKey: string): void {\n this.apiKey = apiKey;\n }\n\n\n async getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch provider config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n\n async initialisePayment(\n request: InitialisePaymentRequest\n ): Promise<InitialisePaymentResponse> {\n const { merchantId, paymentData } = request;\n\n try {\n const response = await fetch(`${this.baseUrl}/api/initialise-payment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId,\n paymentData: { ...paymentData, paymentMethodType: 'card' },\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const data = await response.json();\n\n if (!data.clientSecret || !data.paymentIntentId) {\n throw new VerapayError(\n 'Missing clientSecret or paymentIntentId in server response',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n return {\n paymentIntentId: data.paymentIntentId,\n clientSecret: data.clientSecret,\n connectAccountId: data.connectAccountId,\n stripePublishableKey: data.stripePublishableKey,\n };\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n async processPrePayment(request: ProcessPrePaymentRequest): Promise<void> {\n try {\n const response = await fetch(`${this.baseUrl}/api/process-prepayment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId: request.merchantId,\n paymentIntentId: request.paymentIntentId,\n paymentMethodId: request.paymentMethodId,\n amount: request.amount,\n currency: request.currency,\n customerData: request.customerData,\n description: request.description,\n metadata: request.metadata,\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n private extractErrorMessage(errorData: unknown, status: number): string {\n if (!errorData || typeof errorData !== 'object') {\n return `HTTP error! status: ${status}`;\n }\n\n const record = errorData as Record<string, unknown>;\n const candidates = [record.error, record.message, record.details];\n\n for (const candidate of candidates) {\n if (typeof candidate === 'string' && candidate.trim().length > 0) {\n return candidate;\n }\n\n if (candidate && typeof candidate === 'object') {\n try {\n return JSON.stringify(candidate);\n } catch {\n // Ignore serialization issues and continue trying fallback messages.\n }\n }\n }\n\n return `HTTP error! status: ${status}`;\n }\n}\n","export function unwrapClientSecret(wrappedSecret: string): string {\n if (wrappedSecret.startsWith('vpy_cs_test_')) {\n return wrappedSecret.replace('vpy_cs_test_', '');\n }\n if (wrappedSecret.startsWith('vpy_cs_live_')) {\n return wrappedSecret.replace('vpy_cs_live_', '');\n }\n return wrappedSecret;\n}\n","import { loadStripe } from '@stripe/stripe-js';\nimport { Money } from 'ts-money';\nimport { StripeAdapter } from './stripe-adapter';\nimport { ElementsManager } from './elements-manager';\nimport type { PaymentExtension } from '../extensions';\nimport { PaymentExtensionsManager } from './payment-extensions-manager';\nimport { PaymentService } from '../services/payment-service';\nimport {\n ErrorCode,\n VerapayError,\n PaymentError,\n ValidationError,\n} from '../errors';\nimport { VerapayService } from '../services/verapay-service';\nimport { unwrapClientSecret } from '../utils/secret.util';\nimport type {\n VerapayConfig,\n ProcessPaymentRequest,\n PaymentResult,\n} from '../types';\n\nexport class VerapayClient {\n private static readonly BACKEND_URL = 'https://api.verapay.app';\n\n private config: VerapayConfig;\n private verapayService: VerapayService;\n private extensionsManager: PaymentExtensionsManager;\n\n private stripeAdapter: StripeAdapter | null = null;\n private elementsManager: ElementsManager | null = null;\n private paymentService: PaymentService | null = null;\n private initializationPromise: Promise<void> | null = null;\n\n private isUsingStripePaymentElement: boolean = false;\n private isUsingIndividualFormElements: boolean = false;\n\n private rawSecret: string | null = null;\n private paymentIntentId: string | null = null;\n private amount: number | null = null;\n private currency: string | null = null;\n private merchantId: string | null = null;\n\n constructor(config: VerapayConfig) {\n if (!config.apiKey && !config.clientSecret) {\n throw new VerapayError(\n 'Either apiKey or clientSecret is required.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && config.clientSecret) {\n throw new VerapayError(\n 'Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && !config.apiKey.includes(\"_pk_\") && typeof window !== \"undefined\") {\n console.warn(\n \"Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead.\"\n );\n }\n\n this.config = config;\n\n const backendUrl = this.config.apiUrlOverride || VerapayClient.BACKEND_URL;\n\n this.verapayService = new VerapayService(backendUrl, this.config.apiKey || '');\n this.extensionsManager = new PaymentExtensionsManager();\n }\n\n async initialize(): Promise<void> {\n if (this.initializationPromise) {\n return this.initializationPromise;\n }\n\n this.initializationPromise = (async () => {\n let clientSecret: string;\n let paymentIntentId: string;\n let stripePublishableKey: string;\n\n\n if (this.config.clientSecret) {\n const config = (await this.verapayService.getPaymentIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n clientSecret = this.config.clientSecret;\n paymentIntentId = config.paymentIntentId;\n stripePublishableKey = config.publishableKey;\n this.amount = config.amount;\n this.currency = config.currency;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n\n } else {\n this.validatePaymentInitialisation();\n\n const response = await this.verapayService.initialisePayment({\n merchantId: this.config.merchantId ?? '',\n paymentData: this.config.paymentData!,\n });\n clientSecret = response.clientSecret;\n paymentIntentId = response.paymentIntentId;\n stripePublishableKey = response.stripePublishableKey;\n this.amount = this.config.paymentData!.amount;\n this.currency = this.config.paymentData!.currency;\n this.merchantId = this.config.merchantId ?? '';\n }\n\n this.rawSecret = unwrapClientSecret(clientSecret);\n this.paymentIntentId = paymentIntentId;\n\n const stripe = await loadStripe(stripePublishableKey);\n\n if (!stripe) {\n throw new VerapayError(\n 'Failed to load Stripe',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n this.stripeAdapter = new StripeAdapter(stripe);\n this.elementsManager = new ElementsManager(stripe, this.config, this.rawSecret!);\n this.paymentService = new PaymentService(\n this.stripeAdapter,\n this.elementsManager,\n this.verapayService,\n );\n })().catch((error) => {\n this.initializationPromise = null;\n throw error;\n });\n\n return this.initializationPromise;\n }\n\n async confirmPayment(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.confirm(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n }\n\n async retrievePaymentIntent(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.retrievePaymentIntent(this.rawSecret!);\n }\n\n async processPayment(request: ProcessPaymentRequest): Promise<PaymentResult> {\n await this.ensureInitialized();\n\n const modifiedRequest =\n await this.extensionsManager.runBeforePayment(request);\n\n try {\n const paymentResult = await this.paymentService!.process(modifiedRequest, {\n merchantId: this.merchantId!,\n paymentIntentId: this.paymentIntentId!,\n clientSecret: this.rawSecret!,\n amount: this.amount!,\n currency: this.currency!,\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n\n\n await this.extensionsManager.runAfterPayment(paymentResult);\n\n return paymentResult;\n } catch (error) {\n await this.extensionsManager.runOnError(error as Error);\n throw this.handlePaymentError(error);\n }\n }\n\n async mountPaymentForm(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountPaymentElement(selector);\n this.isUsingStripePaymentElement = true;\n }\n\n async mountCardNumber(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardNumberElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardExpiry(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardExpiryElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardCvc(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardCvcElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountAddress(\n selector: string,\n mode: 'billing' | 'shipping'\n ): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountAddressElement(selector, mode);\n this.isUsingIndividualFormElements = true;\n }\n\n addExtension(extension: PaymentExtension): void {\n this.extensionsManager.add(extension);\n }\n\n private async ensureInitialized(): Promise<void> {\n if (!this.stripeAdapter) {\n await this.initialize();\n }\n }\n\n private validatePaymentInitialisation(): void {\n if (!this.config.paymentData) {\n throw new VerapayError(\n 'paymentData is required for frontend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n const { amount, currency, partnerFee } = this.config.paymentData;\n\n\n if (!currency) {\n throw new ValidationError('Currency is required', 'currency');\n }\n\n const uppercaseCurrency = currency.toUpperCase();\n\n const paymentAmount = this.toMoney(amount, uppercaseCurrency, 'amount');\n\n if (paymentAmount.isZero() || paymentAmount.isNegative()) {\n throw new ValidationError('Amount must be greater than 0', 'amount');\n }\n\n if (partnerFee !== undefined) {\n const partnerFeeAmount = this.toMoney(partnerFee, uppercaseCurrency, 'partnerFee');\n\n if (partnerFeeAmount.isNegative()) {\n throw new ValidationError('partnerFee cannot be negative', 'partnerFee');\n }\n\n if (partnerFeeAmount.greaterThan(paymentAmount)) {\n throw new ValidationError('partnerFee cannot exceed the payment amount', 'partnerFee');\n }\n }\n }\n\n private toMoney(value: number, currency: string, fieldName: string): Money {\n try {\n return Money.fromInteger(value, currency);\n } catch {\n throw new ValidationError(\n `${fieldName} must be an integer in the smallest currency unit (e.g., cents for USD)`,\n fieldName\n );\n }\n }\n\n\n private handlePaymentError(error: unknown): Error {\n if (error instanceof VerapayError) {\n return error;\n }\n const message = error instanceof Error ? error.message : 'Payment failed';\n const code = (error as Record<string, unknown>)?.code as string | undefined;\n\n return new PaymentError(message, code);\n }\n}\n\n","import type { CardValidation } from '../types';\n\nexport class CardValidator {\n validateCardNumber(cardNumber: string): boolean {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (cleaned.length < 13 || cleaned.length > 19) {\n return false;\n }\n\n let sum = 0;\n let isEven = false;\n\n for (let i = cleaned.length - 1; i >= 0; i--) {\n let digit = parseInt(cleaned[i], 10);\n\n if (isEven) {\n digit *= 2;\n if (digit > 9) {\n digit -= 9;\n }\n }\n\n sum += digit;\n isEven = !isEven;\n }\n\n return sum % 10 === 0;\n }\n\n detectCardType(cardNumber: string): string {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (/^4/.test(cleaned)) return 'visa';\n if (/^5[1-5]/.test(cleaned)) return 'mastercard';\n if (/^3[47]/.test(cleaned)) return 'amex';\n if (/^6(?:011|5)/.test(cleaned)) return 'discover';\n\n return 'unknown';\n }\n\n validateExpiry(month: number, year: number): boolean {\n const now = new Date();\n const currentYear = now.getFullYear();\n const currentMonth = now.getMonth() + 1;\n\n if (month < 1 || month > 12) {\n return false;\n }\n\n const fullYear = year < 100 ? 2000 + year : year;\n\n if (fullYear < currentYear) {\n return false;\n }\n\n if (fullYear === currentYear && month < currentMonth) {\n return false;\n }\n\n return true;\n }\n\n validateCVC(cvc: string, cardType: string = 'unknown'): boolean {\n const cleaned = cvc.replace(/\\D/g, '');\n\n if (cardType === 'amex') {\n return cleaned.length === 4;\n }\n\n return cleaned.length === 3 || cleaned.length === 4;\n }\n\n validateAll(\n cardNumber: string,\n expiryMonth: number,\n expiryYear: number,\n cvc: string\n ): CardValidation {\n const cardType = this.detectCardType(cardNumber);\n\n return {\n number: {\n isValid: this.validateCardNumber(cardNumber),\n cardType: cardType as 'visa' | 'mastercard' | 'amex' | 'discover' | 'unknown',\n\n },\n expiry: {\n isValid: this.validateExpiry(expiryMonth, expiryYear),\n month: expiryMonth,\n year: expiryYear,\n },\n cvc: {\n isValid: this.validateCVC(cvc, cardType),\n length: cvc.replace(/\\D/g, '').length,\n },\n };\n }\n}\n","export class InputSanitizer {\n static sanitizeCardNumber(input: string): string {\n return input.replace(/\\D/g, '');\n }\n\n static formatCardNumber(input: string): string {\n const cleaned = this.sanitizeCardNumber(input);\n return cleaned.replace(/(\\d{4})/g, '$1 ').trim();\n }\n\n static sanitizeCVC(input: string): string {\n return input.replace(/\\D/g, '').slice(0, 4);\n }\n\n static sanitizeExpiry(input: string): { month: number; year: number } | null {\n const cleaned = input.replace(/\\D/g, '');\n\n if (cleaned.length === 4) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 4), 10),\n };\n } else if (cleaned.length === 6) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 6), 10),\n };\n }\n\n return null;\n }\n}\n","export { VerapayClient } from './client/verapay-client';\nexport { VerapayService } from './services/verapay-service';\n\nexport type {\n InitialisePaymentRequest,\n InitialisePaymentResponse,\n ProcessPrePaymentRequest,\n} from './services/verapay-service';\n\nexport type {\n VerapayConfig,\n ElementsConfig,\n ProcessPaymentRequest,\n PaymentResult,\n CardValidation,\n ErrorDetails,\n ErrorCode,\n} from './types';\n\nexport {\n VerapayError,\n ValidationError,\n PaymentError,\n ErrorFormatter,\n} from './errors';\n\nexport { CardValidator, InputSanitizer } from './validation';\n\nexport type {\n PaymentExtension,\n DatabaseExtension,\n AnalyticsExtension,\n} from './extensions';\n\nexport const VERSION = '1.1.0';\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/errors/verapay-error.ts","../src/errors/validation-error.ts","../src/errors/payment-error.ts","../src/errors/error-formatter.ts","../src/client/stripe-adapter.ts","../src/client/elements-manager.ts","../src/client/payment-extensions-manager.ts","../src/services/payment-service.ts","../src/services/setup-service.ts","../src/services/verapay-service.ts","../src/utils/secret.util.ts","../src/client/verapay-client.ts","../src/validation/card-validator.ts","../src/validation/input-sanitizer.ts","../src/index.ts"],"names":["VerapayError","_VerapayError","message","code","details","ValidationError","field","metadata","PaymentError","_PaymentError","stripeCode","ErrorFormatter","error","StripeAdapter","stripe","paymentMethodId","clientSecret","result","elements","isUsingIndividualFormElements","address","DEFAULT_CARD_ELEMENT_CONFIG","FIELD_LABELS","ElementsManager","config","selector","elementsConfig","element","mode","fieldType","options","formFieldType","elementType","errors","state","handleElementChange","event","PaymentExtensionsManager","extension","request","modifiedRequest","ext","PaymentService","stripeAdapter","elementsManager","verapayService","context","validation","paymentIntent","status","SetupService","setupIntent","paymentMethod","savedPaymentMethodId","VerapayService","baseUrl","apiKey","response","merchantId","paymentData","errorData","data","record","candidates","candidate","unwrapClientSecret","wrappedSecret","_VerapayClient","backendUrl","paymentIntentId","stripePublishableKey","loadStripe","paymentResult","expected","method","amount","currency","platformFee","uppercaseCurrency","paymentAmount","platformFeeAmount","value","fieldName","Money","VerapayClient","CardValidator","cardNumber","cleaned","sum","isEven","i","digit","month","year","now","currentYear","currentMonth","fullYear","cvc","cardType","expiryMonth","expiryYear","InputSanitizer","input","VERSION"],"mappings":"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","file":"index.js","sourcesContent":["import type { ErrorDetails } from '../types';\nimport { ErrorCode } from '../types';\n\nexport class VerapayError extends Error {\n public readonly code: ErrorCode;\n public readonly details: ErrorDetails;\n\n constructor(\n message: string,\n code: ErrorCode = ErrorCode.PAYMENT_FAILED,\n details?: Partial<ErrorDetails>\n ) {\n super(message);\n this.name = 'VerapayError';\n this.code = code;\n this.details = {\n code,\n message,\n formattedMessage: this.formatMessage(message, code),\n ...details,\n };\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, VerapayError);\n }\n }\n\n private formatMessage(message: string, code: ErrorCode): string {\n const messageMap: Record<ErrorCode, string> = {\n [ErrorCode.VALIDATION_ERROR]:\n 'Please check your payment information and try again.',\n [ErrorCode.PAYMENT_FAILED]:\n 'Your payment could not be processed. Please try again.',\n [ErrorCode.AUTHENTICATION_FAILED]:\n 'Payment authentication failed. Please try again.',\n [ErrorCode.NETWORK_ERROR]:\n 'Network error. Please check your connection and try again.',\n [ErrorCode.STRIPE_ERROR]:\n 'Payment service error. Please try again later.',\n [ErrorCode.CONFIGURATION_ERROR]:\n 'Configuration error. Please contact support.',\n [ErrorCode.CARD_DECLINED]:\n 'Your card was declined. Please use a different payment method.',\n [ErrorCode.INSUFFICIENT_FUNDS]:\n 'Insufficient funds. Please use a different payment method.',\n [ErrorCode.EXPIRED_CARD]:\n 'Your card has expired. Please use a different payment method.',\n };\n\n return messageMap[code] || message;\n }\n\n toJSON() {\n return {\n name: this.name,\n code: this.code,\n message: this.message,\n details: this.details,\n };\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class ValidationError extends VerapayError {\n constructor(message: string, field?: string, metadata?: Record<string, unknown>) {\n\n super(message, ErrorCode.VALIDATION_ERROR, {\n field,\n metadata,\n });\n this.name = 'ValidationError';\n }\n}\n","import { VerapayError } from './verapay-error';\nimport { ErrorCode } from '../types';\n\nexport class PaymentError extends VerapayError {\n constructor(\n message: string,\n stripeCode?: string,\n metadata?: Record<string, unknown>\n ) {\n const code = PaymentError.mapStripeCode(stripeCode);\n super(message, code, {\n stripeCode,\n metadata,\n });\n this.name = 'PaymentError';\n }\n\n private static mapStripeCode(stripeCode?: string): ErrorCode {\n if (!stripeCode) return ErrorCode.PAYMENT_FAILED;\n\n const codeMap: Record<string, ErrorCode> = {\n card_declined: ErrorCode.CARD_DECLINED,\n insufficient_funds: ErrorCode.INSUFFICIENT_FUNDS,\n expired_card: ErrorCode.EXPIRED_CARD,\n incorrect_cvc: ErrorCode.VALIDATION_ERROR,\n processing_error: ErrorCode.PAYMENT_FAILED,\n authentication_failed: ErrorCode.AUTHENTICATION_FAILED,\n };\n\n return codeMap[stripeCode] || ErrorCode.PAYMENT_FAILED;\n }\n}\n","import type { ErrorDetails } from '../types';\n\nexport class ErrorFormatter {\n static formatForUser(error: Error | ErrorDetails): string {\n if ('formattedMessage' in error) {\n return error.formattedMessage;\n }\n if (\n 'details' in error &&\n error.details &&\n typeof error.details === 'object' &&\n 'formattedMessage' in error.details &&\n typeof error.details.formattedMessage === 'string'\n ) {\n return error.details.formattedMessage;\n }\n return 'An unexpected error occurred. Please try again.';\n }\n\n static formatForDeveloper(error: Error | ErrorDetails): string {\n if ('code' in error && 'message' in error) {\n return `[${error.code}] ${error.message}`;\n }\n return error.message || 'Unknown error';\n }\n\n static toJSON(error: Error | ErrorDetails): Record<string, unknown> {\n\n if ('toJSON' in error && typeof error.toJSON === 'function') {\n return error.toJSON();\n }\n\n return {\n name: (error as Error).name || 'Error',\n message: error.message,\n ...('code' in error && { code: error.code }),\n ...('details' in error && { details: error.details }),\n };\n }\n}\n","import type { PaymentIntent, SetupIntent, Stripe, StripeElements } from '@stripe/stripe-js';\nimport { PaymentError } from '../errors';\n\nexport class StripeAdapter {\n constructor(private stripe: Stripe) {}\n\n async confirmPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmPayment({\n clientSecret,\n confirmParams: {\n payment_method: paymentMethodId,\n return_url: window.location.href,\n },\n redirect: 'if_required',\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardPayment(\n paymentMethodId: string,\n clientSecret: string\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.confirmCardPayment(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Payment failed',\n result.error.code\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async createPaymentMethod(\n elements: StripeElements,\n isUsingIndividualFormElements: boolean = false\n ): Promise<string> {\n let result;\n\n if (!isUsingIndividualFormElements) {\n result = await this.stripe.createPaymentMethod({\n elements,\n });\n } else {\n // @ts-expect-error - Stripe types don't include mode parameter for getElement\n const addressElement = await elements.getElement('address', { mode: 'billing' })!.getValue();\n\n const address = addressElement!.value;\n\n result = await this.stripe.createPaymentMethod({\n type: 'card',\n card: elements.getElement('cardNumber')!,\n billing_details: {\n name: address.name,\n address: {\n ...address.address,\n line2: address.address.line2 ?? undefined,\n },\n },\n });\n }\n\n if (result.error || !result.paymentMethod) {\n throw new PaymentError(\n result.error?.message || 'Failed to create payment method',\n result.error?.code\n );\n }\n\n return result.paymentMethod.id;\n }\n\n async retrievePaymentIntent(\n clientSecret: string,\n ): Promise<{ paymentIntent: PaymentIntent }> {\n const result = await this.stripe.retrievePaymentIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve payment intent',\n result.error.code,\n );\n }\n\n return result as { paymentIntent: PaymentIntent };\n }\n\n async confirmCardSetup(\n paymentMethodId: string,\n clientSecret: string,\n ): Promise<{ setupIntent: SetupIntent }> {\n const result = await this.stripe.confirmCardSetup(clientSecret, {\n payment_method: paymentMethodId,\n });\n\n if (result.error) {\n throw new PaymentError(result.error.message || 'Card setup failed', result.error.code);\n }\n\n return result as { setupIntent: SetupIntent };\n }\n\n async retrieveSetupIntent(clientSecret: string): Promise<{ setupIntent: SetupIntent }> {\n const result = await this.stripe.retrieveSetupIntent(clientSecret);\n\n if (result.error) {\n throw new PaymentError(\n result.error.message || 'Failed to retrieve setup intent',\n result.error.code,\n );\n }\n\n return result as { setupIntent: SetupIntent };\n }\n}\n\n","import type {\n Stripe,\n StripeElements,\n StripeElement,\n StripePaymentElement,\n StripeCardNumberElement,\n PaymentWalletsOption,\n} from '@stripe/stripe-js';\nimport type { VerapayConfig, ValidationError, ValidationResult } from '../types';\nimport { VerapayError, ErrorCode } from '../errors';\n\ntype ElementState = { complete: boolean; error?: string }\n\nconst DEFAULT_CARD_ELEMENT_CONFIG = {\n showIcon: true,\n iconStyle: 'solid' as const,\n placeholders: {\n cardNumber: '1234 1234 1234 1234',\n cardExpiry: 'MM / YY - TESTING',\n cardCvc: 'CVC',\n },\n style: {\n base: {\n color: '#333333',\n fontFamily: 'system-ui, -apple-system, sans-serif',\n fontSize: '16px',\n '::placeholder': { color: '#aab7c4' },\n },\n complete: {\n color: '#333333',\n },\n empty: {},\n invalid: {\n color: '#df1b41',\n },\n },\n}\n\nconst FIELD_LABELS: Record<string, string> = {\n cardNumber: 'Card number',\n cardExpiry: 'Expiry date',\n cardCvc: 'CVC',\n address: 'Address',\n}\n\nexport class ElementsManager {\n private elements: StripeElements | null = null;\n private mountedElements: Map<string, StripeElement> = new Map();\n private elementStates: Map<string, ElementState> = new Map();\n\n constructor(\n private stripe: Stripe,\n private config: VerapayConfig,\n private clientSecret: string,\n ) {\n if (!clientSecret) {\n throw new VerapayError(\n 'Client secret not initialized',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n\n mountPaymentElement(selector: string): void {\n if (!this.elements) {\n const elementsConfig = {\n clientSecret: this.clientSecret,\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n };\n\n this.elements = this.stripe.elements(elementsConfig);\n }\n\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.elements.create('payment', {\n layout: 'tabs',\n wallets: { link: 'never' } as unknown as PaymentWalletsOption,\n }) as StripePaymentElement;\n\n element.mount(selector);\n this.mountedElements.set('payment', element);\n }\n\n mountCardNumberElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardNumber', this.cardElementOptions('cardNumber'));\n }\n\n mountCardExpiryElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardExpiry', this.cardElementOptions('cardExpiry'));\n }\n\n mountCardCvcElement(selector: string): void {\n this.mountIndividualFormElement(selector, 'cardCvc', this.cardElementOptions('cardCvc'));\n }\n\n mountAddressElement(selector: string, mode: 'billing' | 'shipping'): void {\n this.mountIndividualFormElement(selector, 'address', { mode });\n }\n\n private cardElementOptions(fieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc'): Record<string, unknown> {\n const { elementsConfig } = this.config;\n const options: Record<string, unknown> = {\n placeholder: elementsConfig?.placeholders?.[fieldType] ?? DEFAULT_CARD_ELEMENT_CONFIG.placeholders[fieldType],\n style: {\n base: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.base, ...elementsConfig?.style?.base },\n complete: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.complete, ...elementsConfig?.style?.complete },\n empty: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.empty, ...elementsConfig?.style?.empty },\n invalid: { ...DEFAULT_CARD_ELEMENT_CONFIG.style.invalid, ...elementsConfig?.style?.invalid },\n },\n };\n\n if (fieldType === 'cardNumber') {\n options.showIcon = elementsConfig?.showIcon ?? DEFAULT_CARD_ELEMENT_CONFIG.showIcon;\n options.iconStyle = elementsConfig?.iconStyle ?? DEFAULT_CARD_ELEMENT_CONFIG.iconStyle;\n }\n\n return options;\n }\n\n private mountIndividualFormElement(selector: string, formFieldType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address', options?: Record<string, unknown>) {\n const container = document.querySelector(selector);\n\n if (!container) {\n throw new VerapayError(\n `Element not found: ${selector}`,\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const element = this.createIndividualFormElement(formFieldType, options) as StripeCardNumberElement;\n element.mount(selector);\n\n this.mountedElements.set(formFieldType, element);\n this.trackElementState(formFieldType, element);\n }\n\n private createIndividualFormElement(\n elementType: 'cardNumber' | 'cardExpiry' | 'cardCvc' | 'address',\n options?: Record<string, unknown>,\n ): StripeElement {\n if (!this.elements) {\n this.elements = this.stripe.elements({\n appearance: this.config.appearance,\n locale: this.config.locale,\n fonts: this.config.fonts,\n paymentMethodCreation: 'manual',\n });\n }\n\n return this.elements.create(elementType as 'cardNumber', options);\n }\n\n\n\n async validate(): Promise<ValidationResult> {\n const errors: ValidationError[] = []\n\n for (const [field, state] of this.elementStates.entries()) {\n if (!state.complete) {\n errors.push({\n field,\n message: state.error ?? `${FIELD_LABELS[field] ?? field} failed validation`,\n })\n }\n }\n\n return { isValid: errors.length === 0, errors }\n }\n\n getElements(): StripeElements | null {\n return this.elements;\n }\n\n unmountAll(): void {\n for (const element of this.mountedElements.values()) {\n element.unmount();\n }\n this.mountedElements.clear();\n this.elementStates.clear();\n }\n\n private trackElementState(field: string, element: StripeElement): void {\n this.elementStates.set(field, { complete: false })\n\n const handleElementChange = (event: { complete: boolean; error?: { message: string } }) => {\n this.elementStates.set(field, { complete: event.complete, error: event.error?.message })\n };\n\n (element as unknown as { on: (event: string, handler: (e: unknown) => void) => void }).on(\n 'change',\n handleElementChange as (e: unknown) => void,\n );\n }\n}\n\n\n","import type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport type { PaymentExtension } from '../extensions'\n\nexport class PaymentExtensionsManager {\n private extensions: PaymentExtension[] = []\n\n add(extension: PaymentExtension): void {\n this.extensions.push(extension)\n }\n\n async runBeforePayment(request: ProcessPaymentRequest): Promise<ProcessPaymentRequest> {\n let modifiedRequest = request\n for (const ext of this.extensions) {\n if (ext.beforePayment) {\n modifiedRequest = await ext.beforePayment(modifiedRequest)\n }\n }\n return modifiedRequest\n }\n\n async runAfterPayment(result: PaymentResult): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.afterPayment)\n .map((ext) => ext.afterPayment!(result)),\n )\n }\n\n async runOnError(error: Error): Promise<void> {\n await Promise.all(\n this.extensions\n .filter((ext) => ext.onPaymentError)\n .map((ext) => ext.onPaymentError!(error)),\n )\n }\n}\n","import { StripeAdapter } from '../client/stripe-adapter'\nimport { ElementsManager } from '../client/elements-manager'\nimport { ErrorCode, VerapayError } from '../errors'\nimport { VerapayService } from './verapay-service'\nimport type { ProcessPaymentRequest, PaymentResult } from '../types'\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface ProcessPaymentContext {\n merchantId: string\n paymentIntentId: string\n clientSecret: string\n amount: number\n currency: string\n isUsingStripePaymentElement: boolean\n isUsingIndividualFormElements: boolean\n}\n\nexport class PaymentService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n private verapayService: VerapayService,\n ) {}\n\n async process(request: ProcessPaymentRequest, context: ProcessPaymentContext): Promise<PaymentResult> {\n const elements = this.elementsManager.getElements()\n\n await this.validatePaymentCanProceed(elements, context);\n\n await elements!.submit()\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n )\n\n await this.verapayService.processPrePayment({\n merchantId: context.merchantId,\n paymentIntentId: context.paymentIntentId,\n paymentMethodId,\n amount: context.amount,\n currency: context.currency,\n customerData: {\n email: request.customerEmail,\n firstName: request.customerFirstName,\n lastName: request.customerLastName,\n },\n description: request.description,\n metadata: request.metadata,\n })\n\n return this.confirm(context.clientSecret, {\n paymentMethodId,\n isUsingStripePaymentElement: context.isUsingStripePaymentElement,\n isUsingIndividualFormElements: context.isUsingIndividualFormElements,\n });\n }\n\n private async validatePaymentCanProceed(\n elements: StripeElements | null,\n context: ProcessPaymentContext,\n ) {\n if (!elements) {\n throw new VerapayError('Payment form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of payment form in use');\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n async confirm(\n clientSecret: string,\n options: {\n isUsingStripePaymentElement?: boolean;\n isUsingIndividualFormElements?: boolean;\n paymentMethodId?: string;\n } = {},\n ): Promise<PaymentResult> {\n let result;\n\n if (options.isUsingStripePaymentElement) {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n } else if (options.isUsingIndividualFormElements) {\n result = await this.stripeAdapter.confirmCardPayment(\n options.paymentMethodId || '',\n clientSecret,\n );\n } else {\n result = await this.stripeAdapter.confirmPayment(options.paymentMethodId || '', clientSecret);\n }\n\n return this.formatPaymentResult(result);\n }\n\n async retrievePaymentIntent(clientSecret: string): Promise<PaymentResult> {\n const result = await this.stripeAdapter.retrievePaymentIntent(clientSecret);\n return this.formatPaymentResult(result);\n }\n\n private formatPaymentResult(result: unknown): PaymentResult {\n const paymentIntent = (result as { paymentIntent: { status: string; id: string } })\n .paymentIntent\n\n let status: 'succeeded' | 'processing' | 'failed' = 'failed'\n if (paymentIntent.status === 'succeeded') {\n status = 'succeeded'\n } else if (\n ['processing', 'requires_action', 'requires_confirmation'].includes(\n paymentIntent.status,\n )\n ) {\n status = 'processing'\n }\n\n return {\n success: paymentIntent.status === 'succeeded',\n paymentIntentId: paymentIntent.id,\n status,\n }\n }\n\n}\n\n\n","import { StripeAdapter } from '../client/stripe-adapter';\nimport { ElementsManager } from '../client/elements-manager';\nimport { ErrorCode, VerapayError } from '../errors';\nimport type { SetupResult } from '../types';\nimport { StripeElements } from '@stripe/stripe-js';\n\nexport interface SaveCardContext {\n isUsingStripePaymentElement: boolean;\n isUsingIndividualFormElements: boolean;\n}\n\nexport class SetupService {\n constructor(\n private stripeAdapter: StripeAdapter,\n private elementsManager: ElementsManager,\n ) {}\n\n async save(clientSecret: string, context: SaveCardContext): Promise<SetupResult> {\n const elements = this.elementsManager.getElements();\n\n await this.validateSetupCanProceed(elements, context);\n\n await elements!.submit();\n\n const paymentMethodId = await this.stripeAdapter.createPaymentMethod(\n elements!,\n context.isUsingIndividualFormElements,\n );\n\n const result = await this.stripeAdapter.confirmCardSetup(paymentMethodId, clientSecret);\n\n return this.formatSetupResult(result);\n }\n\n async retrieve(clientSecret: string): Promise<SetupResult> {\n const result = await this.stripeAdapter.retrieveSetupIntent(clientSecret);\n return this.formatSetupResult(result);\n }\n\n private async validateSetupCanProceed(\n elements: StripeElements | null,\n context: SaveCardContext,\n ): Promise<void> {\n if (!elements) {\n throw new VerapayError('Card form not mounted', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingStripePaymentElement && context.isUsingIndividualFormElements) {\n throw new VerapayError('Both forms of card form in use', ErrorCode.CONFIGURATION_ERROR);\n }\n\n if (context.isUsingIndividualFormElements) {\n const validation = await this.elementsManager.validate();\n if (!validation.isValid) {\n throw new VerapayError(validation.errors[0].message, ErrorCode.VALIDATION_ERROR);\n }\n }\n }\n\n private formatSetupResult(result: unknown): SetupResult {\n const setupIntent = (\n result as { setupIntent: { status: string; id: string; payment_method?: unknown } }\n ).setupIntent;\n\n let status: SetupResult['status'] = 'failed';\n if (setupIntent.status === 'succeeded') {\n status = 'succeeded';\n } else if (setupIntent.status === 'processing') {\n status = 'processing';\n } else if (\n setupIntent.status === 'requires_action' ||\n setupIntent.status === 'requires_confirmation'\n ) {\n status = 'requires_action';\n }\n\n const paymentMethod = setupIntent.payment_method;\n const savedPaymentMethodId =\n typeof paymentMethod === 'string'\n ? paymentMethod\n : (paymentMethod as { id?: string } | undefined)?.id;\n\n return {\n success: setupIntent.status === 'succeeded',\n savedPaymentMethodId,\n setupIntentId: setupIntent.id,\n status,\n };\n }\n}\n","import { ErrorCode, VerapayError } from '../errors';\nimport { PaymentData } from '../types';\n\nexport interface InitialisePaymentRequest {\n merchantId: string;\n paymentData: PaymentData;\n}\n\nexport interface InitialisePaymentResponse {\n paymentIntentId: string;\n clientSecret: string;\n connectAccountId: string;\n stripePublishableKey: string;\n}\n\nexport interface ProcessPrePaymentRequest {\n merchantId: string;\n paymentIntentId: string;\n paymentMethodId: string;\n amount: number;\n currency: string;\n customerData: Record<string, unknown>;\n\n description?: string;\n metadata?: Record<string, string>;\n}\n\nexport class VerapayService {\n private readonly baseUrl: string;\n private apiKey?: string;\n\n constructor(baseUrl: string, apiKey?: string) {\n this.baseUrl = baseUrl;\n this.apiKey = apiKey;\n }\n\n setApiKey(apiKey: string): void {\n this.apiKey = apiKey;\n }\n\n\n async getPaymentIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/payment_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch provider config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n async getSetupIntentConfig(clientSecret: string): Promise<Record<string, unknown>> {\n try {\n const response = await fetch(\n `${this.baseUrl}/v1/setup_intents/config?client_secret=${encodeURIComponent(\n clientSecret,\n )}`,\n {\n method: 'GET',\n headers: {\n 'Content-Type': 'application/json',\n },\n },\n );\n\n if (!response.ok) {\n throw new VerapayError('Failed to fetch setup config', ErrorCode.CONFIGURATION_ERROR);\n }\n\n return response.json();\n } catch (error) {\n if (error instanceof VerapayError) throw error;\n throw new VerapayError('Error connecting to Verapay API', ErrorCode.NETWORK_ERROR);\n }\n }\n\n\n async initialisePayment(\n request: InitialisePaymentRequest\n ): Promise<InitialisePaymentResponse> {\n const { merchantId, paymentData } = request;\n\n try {\n const response = await fetch(`${this.baseUrl}/api/initialise-payment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId,\n paymentData: { ...paymentData, paymentMethodType: 'card' },\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n const data = await response.json();\n\n if (!data.clientSecret || !data.paymentIntentId) {\n throw new VerapayError(\n 'Missing clientSecret or paymentIntentId in server response',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n return {\n paymentIntentId: data.paymentIntentId,\n clientSecret: data.clientSecret,\n connectAccountId: data.connectAccountId,\n stripePublishableKey: data.stripePublishableKey,\n };\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n async processPrePayment(request: ProcessPrePaymentRequest): Promise<void> {\n try {\n const response = await fetch(`${this.baseUrl}/api/process-prepayment`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(this.apiKey ? { 'x-api-key': this.apiKey } : {}),\n },\n\n body: JSON.stringify({\n merchantId: request.merchantId,\n paymentIntentId: request.paymentIntentId,\n paymentMethodId: request.paymentMethodId,\n amount: request.amount,\n currency: request.currency,\n customerData: request.customerData,\n description: request.description,\n metadata: request.metadata,\n }),\n });\n\n if (!response.ok) {\n const errorData = await response.json().catch(() => ({}));\n throw new VerapayError(\n this.extractErrorMessage(errorData, response.status),\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n } catch (error) {\n if (error instanceof VerapayError) {\n throw error;\n }\n throw new VerapayError(\n error instanceof Error ? error.message : 'Unknown error occurred',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n }\n\n private extractErrorMessage(errorData: unknown, status: number): string {\n if (!errorData || typeof errorData !== 'object') {\n return `HTTP error! status: ${status}`;\n }\n\n const record = errorData as Record<string, unknown>;\n const candidates = [record.error, record.message, record.details];\n\n for (const candidate of candidates) {\n if (typeof candidate === 'string' && candidate.trim().length > 0) {\n return candidate;\n }\n\n if (candidate && typeof candidate === 'object') {\n try {\n return JSON.stringify(candidate);\n } catch {\n // Ignore serialization issues and continue trying fallback messages.\n }\n }\n }\n\n return `HTTP error! status: ${status}`;\n }\n}\n","export function unwrapClientSecret(wrappedSecret: string): string {\n if (wrappedSecret.startsWith('vpy_cs_test_')) {\n return wrappedSecret.replace('vpy_cs_test_', '');\n }\n if (wrappedSecret.startsWith('vpy_cs_live_')) {\n return wrappedSecret.replace('vpy_cs_live_', '');\n }\n return wrappedSecret;\n}\n","import { loadStripe } from '@stripe/stripe-js';\nimport { Money } from 'ts-money';\nimport { StripeAdapter } from './stripe-adapter';\nimport { ElementsManager } from './elements-manager';\nimport type { PaymentExtension } from '../extensions';\nimport { PaymentExtensionsManager } from './payment-extensions-manager';\nimport { PaymentService } from '../services/payment-service';\nimport { SetupService } from '../services/setup-service';\nimport {\n ErrorCode,\n VerapayError,\n PaymentError,\n ValidationError,\n} from '../errors';\nimport { VerapayService } from '../services/verapay-service';\nimport { unwrapClientSecret } from '../utils/secret.util';\nimport type {\n VerapayConfig,\n ProcessPaymentRequest,\n PaymentResult,\n SetupResult,\n} from '../types';\n\ntype IntentKind = 'payment' | 'setup';\n\nexport class VerapayClient {\n private static readonly BACKEND_URL = 'https://api.verapay.app';\n\n private config: VerapayConfig;\n private verapayService: VerapayService;\n private extensionsManager: PaymentExtensionsManager;\n\n private stripeAdapter: StripeAdapter | null = null;\n private elementsManager: ElementsManager | null = null;\n private paymentService: PaymentService | null = null;\n private setupService: SetupService | null = null;\n private initializationPromise: Promise<void> | null = null;\n\n private isUsingStripePaymentElement: boolean = false;\n private isUsingIndividualFormElements: boolean = false;\n\n private intentKind: IntentKind = 'payment';\n private rawSecret: string | null = null;\n private paymentIntentId: string | null = null;\n private amount: number | null = null;\n private currency: string | null = null;\n private merchantId: string | null = null;\n\n constructor(config: VerapayConfig) {\n if (!config.apiKey && !config.clientSecret) {\n throw new VerapayError(\n 'Either apiKey or clientSecret is required.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && config.clientSecret) {\n throw new VerapayError(\n 'Cannot provide both apiKey and clientSecret. Use apiKey for frontend-initialized flows or clientSecret for backend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n if (config.apiKey && !config.apiKey.includes(\"_pk_\") && typeof window !== \"undefined\") {\n console.warn(\n \"Verapay Security Warning: You are using a Secret Key in a frontend environment. Please use a Publishable Key (vpy_pk_...) instead.\"\n );\n }\n\n this.config = config;\n\n const backendUrl = this.config.apiUrlOverride || VerapayClient.BACKEND_URL;\n\n this.verapayService = new VerapayService(backendUrl, this.config.apiKey || '');\n this.extensionsManager = new PaymentExtensionsManager();\n }\n\n async initialize(): Promise<void> {\n if (this.initializationPromise) {\n return this.initializationPromise;\n }\n\n this.initializationPromise = (async () => {\n let clientSecret: string;\n let paymentIntentId: string;\n let stripePublishableKey: string;\n\n\n if (this.config.clientSecret) {\n this.intentKind = unwrapClientSecret(this.config.clientSecret).startsWith('seti_')\n ? 'setup'\n : 'payment';\n\n if (this.intentKind === 'setup') {\n const config = (await this.verapayService.getSetupIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n\n if (config.object !== 'setup_intent_config') {\n throw new VerapayError(\n 'Unexpected configuration returned for setup intent',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n clientSecret = this.config.clientSecret;\n paymentIntentId = '';\n stripePublishableKey = config.publishableKey;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n } else {\n const config = (await this.verapayService.getPaymentIntentConfig(\n this.config.clientSecret,\n )) as Record<string, any>;\n clientSecret = this.config.clientSecret;\n paymentIntentId = config.paymentIntentId;\n stripePublishableKey = config.publishableKey;\n this.amount = config.amount;\n this.currency = config.currency;\n this.merchantId = config.merchantId;\n\n if (config.verapayPublishableKey) {\n this.verapayService.setApiKey(config.verapayPublishableKey);\n }\n }\n } else {\n this.validatePaymentInitialisation();\n\n const response = await this.verapayService.initialisePayment({\n merchantId: this.config.merchantId ?? '',\n paymentData: this.config.paymentData!,\n });\n clientSecret = response.clientSecret;\n paymentIntentId = response.paymentIntentId;\n stripePublishableKey = response.stripePublishableKey;\n this.amount = this.config.paymentData!.amount;\n this.currency = this.config.paymentData!.currency;\n this.merchantId = this.config.merchantId ?? '';\n }\n\n this.rawSecret = unwrapClientSecret(clientSecret);\n this.paymentIntentId = paymentIntentId;\n\n const stripe = await loadStripe(stripePublishableKey);\n\n if (!stripe) {\n throw new VerapayError(\n 'Failed to load Stripe',\n ErrorCode.CONFIGURATION_ERROR\n );\n }\n\n this.stripeAdapter = new StripeAdapter(stripe);\n this.elementsManager = new ElementsManager(stripe, this.config, this.rawSecret!);\n this.paymentService = new PaymentService(\n this.stripeAdapter,\n this.elementsManager,\n this.verapayService,\n );\n this.setupService = new SetupService(this.stripeAdapter, this.elementsManager);\n })().catch((error) => {\n this.initializationPromise = null;\n throw error;\n });\n\n return this.initializationPromise;\n }\n\n async confirmPayment(): Promise<PaymentResult> {\n await this.ensureInitialized();\n this.assertIntentKind('payment', 'confirmPayment');\n return this.paymentService!.confirm(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n }\n\n async saveCard(): Promise<SetupResult> {\n await this.ensureInitialized();\n this.assertIntentKind('setup', 'saveCard');\n try {\n return await this.setupService!.save(this.rawSecret!, {\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n } catch (error) {\n throw this.handlePaymentError(error);\n }\n }\n\n async retrieveSetupIntent(): Promise<SetupResult> {\n await this.ensureInitialized();\n this.assertIntentKind('setup', 'retrieveSetupIntent');\n return this.setupService!.retrieve(this.rawSecret!);\n }\n\n teardown(): void {\n this.elementsManager?.unmountAll();\n this.stripeAdapter = null;\n this.elementsManager = null;\n this.paymentService = null;\n this.setupService = null;\n this.initializationPromise = null;\n this.isUsingStripePaymentElement = false;\n this.isUsingIndividualFormElements = false;\n this.intentKind = 'payment';\n this.rawSecret = null;\n this.paymentIntentId = null;\n this.amount = null;\n this.currency = null;\n this.merchantId = null;\n }\n\n async retrievePaymentIntent(): Promise<PaymentResult> {\n await this.ensureInitialized();\n return this.paymentService!.retrievePaymentIntent(this.rawSecret!);\n }\n\n async processPayment(request: ProcessPaymentRequest): Promise<PaymentResult> {\n await this.ensureInitialized();\n this.assertIntentKind('payment', 'processPayment');\n\n const modifiedRequest =\n await this.extensionsManager.runBeforePayment(request);\n\n try {\n const paymentResult = await this.paymentService!.process(modifiedRequest, {\n merchantId: this.merchantId!,\n paymentIntentId: this.paymentIntentId!,\n clientSecret: this.rawSecret!,\n amount: this.amount!,\n currency: this.currency!,\n isUsingStripePaymentElement: this.isUsingStripePaymentElement,\n isUsingIndividualFormElements: this.isUsingIndividualFormElements,\n });\n\n\n await this.extensionsManager.runAfterPayment(paymentResult);\n\n return paymentResult;\n } catch (error) {\n await this.extensionsManager.runOnError(error as Error);\n throw this.handlePaymentError(error);\n }\n }\n\n async mountPaymentForm(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountPaymentElement(selector);\n this.isUsingStripePaymentElement = true;\n }\n\n async mountCardNumber(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardNumberElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardExpiry(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardExpiryElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountCardCvc(selector: string): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountCardCvcElement(selector);\n this.isUsingIndividualFormElements = true;\n }\n\n async mountAddress(\n selector: string,\n mode: 'billing' | 'shipping'\n ): Promise<void> {\n await this.ensureInitialized();\n this.elementsManager!.mountAddressElement(selector, mode);\n this.isUsingIndividualFormElements = true;\n }\n\n addExtension(extension: PaymentExtension): void {\n this.extensionsManager.add(extension);\n }\n\n private async ensureInitialized(): Promise<void> {\n if (!this.stripeAdapter) {\n await this.initialize();\n }\n }\n\n private assertIntentKind(expected: IntentKind, method: string): void {\n if (this.intentKind !== expected) {\n throw new VerapayError(\n `${method} requires a ${expected} intent client secret`,\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n }\n\n private validatePaymentInitialisation(): void {\n if (!this.config.paymentData) {\n throw new VerapayError(\n 'paymentData is required for frontend-initialized flows.',\n ErrorCode.CONFIGURATION_ERROR,\n );\n }\n\n const { amount, currency, platformFee } = this.config.paymentData;\n\n\n if (!currency) {\n throw new ValidationError('Currency is required', 'currency');\n }\n\n const uppercaseCurrency = currency.toUpperCase();\n\n const paymentAmount = this.toMoney(amount, uppercaseCurrency, 'amount');\n\n if (paymentAmount.isZero() || paymentAmount.isNegative()) {\n throw new ValidationError('Amount must be greater than 0', 'amount');\n }\n\n if (platformFee !== undefined) {\n const platformFeeAmount = this.toMoney(platformFee, uppercaseCurrency, 'platformFee');\n\n if (platformFeeAmount.isNegative()) {\n throw new ValidationError('platformFee cannot be negative', 'platformFee');\n }\n\n if (platformFeeAmount.greaterThan(paymentAmount)) {\n throw new ValidationError('platformFee cannot exceed the payment amount', 'platformFee');\n }\n }\n }\n\n private toMoney(value: number, currency: string, fieldName: string): Money {\n try {\n return Money.fromInteger(value, currency);\n } catch {\n throw new ValidationError(\n `${fieldName} must be an integer in the smallest currency unit (e.g., cents for USD)`,\n fieldName\n );\n }\n }\n\n\n private handlePaymentError(error: unknown): Error {\n if (error instanceof VerapayError) {\n return error;\n }\n const message = error instanceof Error ? error.message : 'Payment failed';\n const code = (error as Record<string, unknown>)?.code as string | undefined;\n\n return new PaymentError(message, code);\n }\n}\n\n","import type { CardValidation } from '../types';\n\nexport class CardValidator {\n validateCardNumber(cardNumber: string): boolean {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (cleaned.length < 13 || cleaned.length > 19) {\n return false;\n }\n\n let sum = 0;\n let isEven = false;\n\n for (let i = cleaned.length - 1; i >= 0; i--) {\n let digit = parseInt(cleaned[i], 10);\n\n if (isEven) {\n digit *= 2;\n if (digit > 9) {\n digit -= 9;\n }\n }\n\n sum += digit;\n isEven = !isEven;\n }\n\n return sum % 10 === 0;\n }\n\n detectCardType(cardNumber: string): string {\n const cleaned = cardNumber.replace(/\\D/g, '');\n\n if (/^4/.test(cleaned)) return 'visa';\n if (/^5[1-5]/.test(cleaned)) return 'mastercard';\n if (/^3[47]/.test(cleaned)) return 'amex';\n if (/^6(?:011|5)/.test(cleaned)) return 'discover';\n\n return 'unknown';\n }\n\n validateExpiry(month: number, year: number): boolean {\n const now = new Date();\n const currentYear = now.getFullYear();\n const currentMonth = now.getMonth() + 1;\n\n if (month < 1 || month > 12) {\n return false;\n }\n\n const fullYear = year < 100 ? 2000 + year : year;\n\n if (fullYear < currentYear) {\n return false;\n }\n\n if (fullYear === currentYear && month < currentMonth) {\n return false;\n }\n\n return true;\n }\n\n validateCVC(cvc: string, cardType: string = 'unknown'): boolean {\n const cleaned = cvc.replace(/\\D/g, '');\n\n if (cardType === 'amex') {\n return cleaned.length === 4;\n }\n\n return cleaned.length === 3 || cleaned.length === 4;\n }\n\n validateAll(\n cardNumber: string,\n expiryMonth: number,\n expiryYear: number,\n cvc: string\n ): CardValidation {\n const cardType = this.detectCardType(cardNumber);\n\n return {\n number: {\n isValid: this.validateCardNumber(cardNumber),\n cardType: cardType as 'visa' | 'mastercard' | 'amex' | 'discover' | 'unknown',\n\n },\n expiry: {\n isValid: this.validateExpiry(expiryMonth, expiryYear),\n month: expiryMonth,\n year: expiryYear,\n },\n cvc: {\n isValid: this.validateCVC(cvc, cardType),\n length: cvc.replace(/\\D/g, '').length,\n },\n };\n }\n}\n","export class InputSanitizer {\n static sanitizeCardNumber(input: string): string {\n return input.replace(/\\D/g, '');\n }\n\n static formatCardNumber(input: string): string {\n const cleaned = this.sanitizeCardNumber(input);\n return cleaned.replace(/(\\d{4})/g, '$1 ').trim();\n }\n\n static sanitizeCVC(input: string): string {\n return input.replace(/\\D/g, '').slice(0, 4);\n }\n\n static sanitizeExpiry(input: string): { month: number; year: number } | null {\n const cleaned = input.replace(/\\D/g, '');\n\n if (cleaned.length === 4) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 4), 10),\n };\n } else if (cleaned.length === 6) {\n return {\n month: parseInt(cleaned.slice(0, 2), 10),\n year: parseInt(cleaned.slice(2, 6), 10),\n };\n }\n\n return null;\n }\n}\n","export { VerapayClient } from './client/verapay-client';\nexport { VerapayService } from './services/verapay-service';\n\nexport type {\n InitialisePaymentRequest,\n InitialisePaymentResponse,\n ProcessPrePaymentRequest,\n} from './services/verapay-service';\n\nexport type {\n VerapayConfig,\n ElementsConfig,\n ProcessPaymentRequest,\n PaymentResult,\n SetupResult,\n CardValidation,\n ErrorDetails,\n ErrorCode,\n} from './types';\n\nexport {\n VerapayError,\n ValidationError,\n PaymentError,\n ErrorFormatter,\n} from './errors';\n\nexport { CardValidator, InputSanitizer } from './validation';\n\nexport type {\n PaymentExtension,\n DatabaseExtension,\n AnalyticsExtension,\n} from './extensions';\n\nexport const VERSION = '1.4.0';\n"]}
|