@cedros/pay-react 1.0.4 → 1.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/README.md +109 -3
  2. package/dist/CedrosContext-CFEXGwQg.mjs +2163 -0
  3. package/dist/CedrosContext-DbndTsTA.js +11 -0
  4. package/dist/components/CryptoSubscribeButton.d.ts +50 -0
  5. package/dist/components/CryptoSubscribeButton.d.ts.map +1 -0
  6. package/dist/components/SubscribeButton.d.ts +55 -0
  7. package/dist/components/SubscribeButton.d.ts.map +1 -0
  8. package/dist/components/SubscriptionManagementPanel.d.ts +67 -0
  9. package/dist/components/SubscriptionManagementPanel.d.ts.map +1 -0
  10. package/dist/components/subscriptionPanelStyles.d.ts +13 -0
  11. package/dist/components/subscriptionPanelStyles.d.ts.map +1 -0
  12. package/dist/context/CedrosContext.d.ts +4 -0
  13. package/dist/context/CedrosContext.d.ts.map +1 -1
  14. package/dist/crypto-only.js +1 -1
  15. package/dist/crypto-only.mjs +2 -2
  16. package/dist/en-C739WV_-.mjs +19 -0
  17. package/dist/en-Cz4OpvN-.js +1 -0
  18. package/dist/hooks/useCryptoSubscription.d.ts +42 -0
  19. package/dist/hooks/useCryptoSubscription.d.ts.map +1 -0
  20. package/dist/hooks/useSubscription.d.ts +42 -0
  21. package/dist/hooks/useSubscription.d.ts.map +1 -0
  22. package/dist/hooks/useSubscriptionManagement.d.ts +88 -0
  23. package/dist/hooks/useSubscriptionManagement.d.ts.map +1 -0
  24. package/dist/i18n/index.d.ts +7 -0
  25. package/dist/i18n/index.d.ts.map +1 -1
  26. package/dist/index.d.ts +11 -1
  27. package/dist/index.d.ts.map +1 -1
  28. package/dist/index.js +1 -1
  29. package/dist/index.mjs +1658 -361
  30. package/dist/managers/ManagerCache.d.ts +4 -0
  31. package/dist/managers/ManagerCache.d.ts.map +1 -1
  32. package/dist/managers/SubscriptionChangeManager.d.ts +42 -0
  33. package/dist/managers/SubscriptionChangeManager.d.ts.map +1 -0
  34. package/dist/managers/SubscriptionManager.d.ts +113 -0
  35. package/dist/managers/SubscriptionManager.d.ts.map +1 -0
  36. package/dist/pay-react.css +1 -1
  37. package/dist/stripe-only.js +1 -1
  38. package/dist/stripe-only.mjs +2 -2
  39. package/dist/{styles-DI2LPVdQ.mjs → styles-DFcRS8Uu.mjs} +13 -12
  40. package/dist/{styles-61pRysGe.js → styles-Dup9uK6S.js} +1 -1
  41. package/dist/testing/index.js +1 -1
  42. package/dist/testing/index.mjs +1 -1
  43. package/dist/types/index.d.ts +1 -0
  44. package/dist/types/index.d.ts.map +1 -1
  45. package/dist/types/subscription.d.ts +300 -0
  46. package/dist/types/subscription.d.ts.map +1 -0
  47. package/package.json +1 -1
  48. package/dist/CedrosContext-B3iCqN6e.js +0 -11
  49. package/dist/CedrosContext-vX9uqZKp.mjs +0 -1796
  50. package/dist/en-CSsJl3nf.mjs +0 -19
  51. package/dist/en-D-uY3ltT.js +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,300 @@
1
+ import { X402Requirement, PaymentResult } from './index';
2
+ /**
3
+ * Subscription billing interval
4
+ */
5
+ export type BillingInterval = 'weekly' | 'monthly' | 'yearly' | 'custom';
6
+ /**
7
+ * Subscription status
8
+ */
9
+ export type SubscriptionStatus = 'active' | 'trialing' | 'past_due' | 'canceled' | 'unpaid' | 'expired';
10
+ /**
11
+ * Request to create a Stripe subscription session
12
+ */
13
+ export interface SubscriptionSessionRequest {
14
+ /** Resource/plan ID for the subscription */
15
+ resource: string;
16
+ /** Billing interval */
17
+ interval: BillingInterval;
18
+ /** Custom interval in days (only used when interval is 'custom') */
19
+ intervalDays?: number;
20
+ /** Number of trial days (0 for no trial) */
21
+ trialDays?: number;
22
+ /** Customer email (pre-fills Stripe checkout) */
23
+ customerEmail?: string;
24
+ /** Metadata for tracking */
25
+ metadata?: Record<string, string>;
26
+ /** Coupon code for discount */
27
+ couponCode?: string;
28
+ /** URL to redirect on success */
29
+ successUrl?: string;
30
+ /** URL to redirect on cancel */
31
+ cancelUrl?: string;
32
+ }
33
+ /**
34
+ * Response from subscription session creation
35
+ */
36
+ export interface SubscriptionSessionResponse {
37
+ /** Stripe checkout session ID */
38
+ sessionId: string;
39
+ /** Stripe checkout URL */
40
+ url: string;
41
+ }
42
+ /**
43
+ * Request to check subscription status
44
+ */
45
+ export interface SubscriptionStatusRequest {
46
+ /** Resource/plan ID */
47
+ resource: string;
48
+ /** User identifier (wallet address for crypto, email/customer ID for Stripe) */
49
+ userId: string;
50
+ }
51
+ /**
52
+ * Response from subscription status check
53
+ */
54
+ export interface SubscriptionStatusResponse {
55
+ /** Whether subscription is currently active */
56
+ active: boolean;
57
+ /** Current subscription status */
58
+ status: SubscriptionStatus;
59
+ /** Subscription expiry timestamp (ISO 8601) */
60
+ expiresAt?: string;
61
+ /** Current billing period end timestamp (ISO 8601) */
62
+ currentPeriodEnd?: string;
63
+ /** Billing interval */
64
+ interval?: BillingInterval;
65
+ /** Whether subscription will cancel at period end */
66
+ cancelAtPeriodEnd?: boolean;
67
+ }
68
+ /**
69
+ * x402 subscription quote
70
+ * Extends standard X402Requirement with subscription-specific details
71
+ */
72
+ export interface SubscriptionQuote {
73
+ /** Standard x402 payment requirement */
74
+ requirement: X402Requirement;
75
+ /** Subscription-specific details */
76
+ subscription: {
77
+ /** Billing interval */
78
+ interval: BillingInterval;
79
+ /** Custom interval in days (for 'custom' interval) */
80
+ intervalDays?: number;
81
+ /** Duration in seconds this payment covers */
82
+ durationSeconds: number;
83
+ /** When the subscription period starts (ISO 8601) */
84
+ periodStart: string;
85
+ /** When the subscription period ends (ISO 8601) */
86
+ periodEnd: string;
87
+ };
88
+ }
89
+ /**
90
+ * Subscription payment state
91
+ */
92
+ export interface SubscriptionState {
93
+ /** Current state of the subscription flow */
94
+ status: 'idle' | 'loading' | 'checking' | 'success' | 'error';
95
+ /** Error message if status is 'error' */
96
+ error: string | null;
97
+ /** Stripe checkout session ID (for redirect flow) */
98
+ sessionId: string | null;
99
+ /** Subscription status after verification */
100
+ subscriptionStatus: SubscriptionStatus | null;
101
+ /** When subscription expires (ISO 8601) */
102
+ expiresAt: string | null;
103
+ }
104
+ /**
105
+ * Subscription payment result
106
+ * Extends PaymentResult with subscription-specific fields
107
+ */
108
+ export interface SubscriptionPaymentResult extends PaymentResult {
109
+ /** Subscription status after payment */
110
+ subscriptionStatus?: SubscriptionStatus;
111
+ /** New expiry date after payment (ISO 8601) */
112
+ expiresAt?: string;
113
+ /** Current billing period end (ISO 8601) */
114
+ currentPeriodEnd?: string;
115
+ }
116
+ /**
117
+ * Request to cancel a subscription
118
+ */
119
+ export interface CancelSubscriptionRequest {
120
+ /** Resource/plan ID */
121
+ resource: string;
122
+ /** User identifier (wallet address for crypto, email/customer ID for Stripe) */
123
+ userId: string;
124
+ /** Whether to cancel immediately or at period end (default: at period end) */
125
+ immediate?: boolean;
126
+ }
127
+ /**
128
+ * Response from subscription cancellation
129
+ */
130
+ export interface CancelSubscriptionResponse {
131
+ /** Whether cancellation was successful */
132
+ success: boolean;
133
+ /** Updated subscription status */
134
+ status: SubscriptionStatus;
135
+ /** When the subscription will end (ISO 8601) */
136
+ endsAt?: string;
137
+ /** Error message if cancellation failed */
138
+ error?: string;
139
+ }
140
+ /**
141
+ * Request for Stripe billing portal
142
+ */
143
+ export interface BillingPortalRequest {
144
+ /** User identifier (email or Stripe customer ID) */
145
+ userId: string;
146
+ /** URL to return to after portal session */
147
+ returnUrl?: string;
148
+ }
149
+ /**
150
+ * Response from billing portal request
151
+ */
152
+ export interface BillingPortalResponse {
153
+ /** Stripe billing portal URL */
154
+ url: string;
155
+ }
156
+ /**
157
+ * Request to activate x402 subscription after payment verification
158
+ */
159
+ export interface ActivateX402SubscriptionRequest {
160
+ /** Resource/plan ID */
161
+ resource: string;
162
+ /** User wallet address (base58) */
163
+ walletAddress: string;
164
+ /** Transaction signature from x402 payment */
165
+ transactionSignature: string;
166
+ /** Billing interval */
167
+ interval: BillingInterval;
168
+ /** Custom interval in days (for 'custom' interval) */
169
+ intervalDays?: number;
170
+ }
171
+ /**
172
+ * Response from x402 subscription activation
173
+ */
174
+ export interface ActivateX402SubscriptionResponse {
175
+ /** Whether activation was successful */
176
+ success: boolean;
177
+ /** Subscription status after activation */
178
+ status: SubscriptionStatus;
179
+ /** When subscription period starts (ISO 8601) */
180
+ periodStart: string;
181
+ /** When subscription period ends (ISO 8601) */
182
+ periodEnd: string;
183
+ /** Error message if activation failed */
184
+ error?: string;
185
+ }
186
+ /**
187
+ * Proration behavior when changing subscriptions
188
+ */
189
+ export type ProrationBehavior = 'create_prorations' | 'none' | 'always_invoice';
190
+ /**
191
+ * Request to change subscription plan (upgrade/downgrade)
192
+ */
193
+ export interface ChangeSubscriptionRequest {
194
+ /** Current resource/plan ID */
195
+ currentResource: string;
196
+ /** New resource/plan ID to change to */
197
+ newResource: string;
198
+ /** User identifier (wallet address for crypto, email/customer ID for Stripe) */
199
+ userId: string;
200
+ /** New billing interval (if changing interval) */
201
+ newInterval?: BillingInterval;
202
+ /** How to handle proration (Stripe only) */
203
+ prorationBehavior?: ProrationBehavior;
204
+ /** Whether to apply change immediately or at period end */
205
+ immediate?: boolean;
206
+ }
207
+ /**
208
+ * Response from subscription change
209
+ */
210
+ export interface ChangeSubscriptionResponse {
211
+ /** Whether change was successful */
212
+ success: boolean;
213
+ /** Updated subscription status */
214
+ status: SubscriptionStatus;
215
+ /** New resource/plan ID */
216
+ newResource: string;
217
+ /** New billing interval */
218
+ newInterval: BillingInterval;
219
+ /** Amount credited/debited for proration (in cents) */
220
+ prorationAmount?: number;
221
+ /** Next billing date (ISO 8601) */
222
+ nextBillingDate?: string;
223
+ /** When the new plan becomes effective (ISO 8601) */
224
+ effectiveDate: string;
225
+ /** Error message if change failed */
226
+ error?: string;
227
+ }
228
+ /**
229
+ * Request for subscription change preview (proration calculation)
230
+ */
231
+ export interface ChangePreviewRequest {
232
+ /** Current resource/plan ID */
233
+ currentResource: string;
234
+ /** New resource/plan ID to preview */
235
+ newResource: string;
236
+ /** User identifier */
237
+ userId: string;
238
+ /** New billing interval (if changing interval) */
239
+ newInterval?: BillingInterval;
240
+ }
241
+ /**
242
+ * Response from subscription change preview
243
+ */
244
+ export interface ChangePreviewResponse {
245
+ /** Whether preview was successful */
246
+ success: boolean;
247
+ /** Amount to be charged immediately (positive) or credited (negative) in cents */
248
+ immediateAmount: number;
249
+ /** Currency for the amounts */
250
+ currency: string;
251
+ /** Current plan price per period (in cents) */
252
+ currentPlanPrice: number;
253
+ /** New plan price per period (in cents) */
254
+ newPlanPrice: number;
255
+ /** Days remaining in current period */
256
+ daysRemaining: number;
257
+ /** When the new plan would become effective (ISO 8601) */
258
+ effectiveDate: string;
259
+ /** Breakdown of proration calculation */
260
+ prorationDetails?: {
261
+ /** Credit for unused time on current plan (in cents) */
262
+ unusedCredit: number;
263
+ /** Cost for remaining time on new plan (in cents) */
264
+ newPlanCost: number;
265
+ };
266
+ /** Error message if preview failed */
267
+ error?: string;
268
+ }
269
+ /**
270
+ * Full subscription details (for management UI)
271
+ */
272
+ export interface SubscriptionDetails {
273
+ /** Unique subscription ID */
274
+ id: string;
275
+ /** Resource/plan ID */
276
+ resource: string;
277
+ /** Current status */
278
+ status: SubscriptionStatus;
279
+ /** Billing interval */
280
+ interval: BillingInterval;
281
+ /** Custom interval in days (for 'custom' interval) */
282
+ intervalDays?: number;
283
+ /** Price per period (in cents for fiat, atomic units for crypto) */
284
+ pricePerPeriod: number;
285
+ /** Currency (e.g., "USD", "USDC") */
286
+ currency: string;
287
+ /** Whether subscription will cancel at period end */
288
+ cancelAtPeriodEnd: boolean;
289
+ /** Current period start (ISO 8601) */
290
+ currentPeriodStart: string;
291
+ /** Current period end (ISO 8601) */
292
+ currentPeriodEnd: string;
293
+ /** When subscription was created (ISO 8601) */
294
+ createdAt: string;
295
+ /** Payment method type */
296
+ paymentMethod: 'stripe' | 'x402';
297
+ /** Trial end date if in trial (ISO 8601) */
298
+ trialEnd?: string;
299
+ }
300
+ //# sourceMappingURL=subscription.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"subscription.d.ts","sourceRoot":"","sources":["../../src/types/subscription.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAE9D;;GAEG;AACH,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,SAAS,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAEzE;;GAEG;AACH,MAAM,MAAM,kBAAkB,GAC1B,QAAQ,GACR,UAAU,GACV,UAAU,GACV,UAAU,GACV,QAAQ,GACR,SAAS,CAAC;AAEd;;GAEG;AACH,MAAM,WAAW,0BAA0B;IACzC,4CAA4C;IAC5C,QAAQ,EAAE,MAAM,CAAC;IACjB,uBAAuB;IACvB,QAAQ,EAAE,eAAe,CAAC;IAC1B,oEAAoE;IACpE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,4CAA4C;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,iDAAiD;IACjD,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,4BAA4B;IAC5B,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAClC,+BAA+B;IAC/B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,iCAAiC;IACjC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,2BAA2B;IAC1C,iCAAiC;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,0BAA0B;IAC1B,GAAG,EAAE,MAAM,CAAC;CACb;AAED;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,uBAAuB;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,gFAAgF;IAChF,MAAM,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,0BAA0B;IACzC,+CAA+C;IAC/C,MAAM,EAAE,OAAO,CAAC;IAChB,kCAAkC;IAClC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,+CAA+C;IAC/C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,sDAAsD;IACtD,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,uBAAuB;IACvB,QAAQ,CAAC,EAAE,eAAe,CAAC;IAC3B,qDAAqD;IACrD,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B;AAED;;;GAGG;AACH,MAAM,WAAW,iBAAiB;IAChC,wCAAwC;IACxC,WAAW,EAAE,eAAe,CAAC;IAC7B,oCAAoC;IACpC,YAAY,EAAE;QACZ,uBAAuB;QACvB,QAAQ,EAAE,eAAe,CAAC;QAC1B,sDAAsD;QACtD,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,8CAA8C;QAC9C,eAAe,EAAE,MAAM,CAAC;QACxB,qDAAqD;QACrD,WAAW,EAAE,MAAM,CAAC;QACpB,mDAAmD;QACnD,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC;CACH;AAED;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,6CAA6C;IAC7C,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,UAAU,GAAG,SAAS,GAAG,OAAO,CAAC;IAC9D,yCAAyC;IACzC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,qDAAqD;IACrD,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,6CAA6C;IAC7C,kBAAkB,EAAE,kBAAkB,GAAG,IAAI,CAAC;IAC9C,2CAA2C;IAC3C,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;CAC1B;AAED;;;GAGG;AACH,MAAM,WAAW,yBAA0B,SAAQ,aAAa;IAC9D,wCAAwC;IACxC,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IACxC,+CAA+C;IAC/C,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4CAA4C;IAC5C,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,uBAAuB;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,gFAAgF;IAChF,MAAM,EAAE,MAAM,CAAC;IACf,8EAA8E;IAC9E,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,0BAA0B;IACzC,0CAA0C;IAC1C,OAAO,EAAE,OAAO,CAAC;IACjB,kCAAkC;IAClC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,gDAAgD;IAChD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,2CAA2C;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,oDAAoD;IACpD,MAAM,EAAE,MAAM,CAAC;IACf,4CAA4C;IAC5C,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,gCAAgC;IAChC,GAAG,EAAE,MAAM,CAAC;CACb;AAED;;GAEG;AACH,MAAM,WAAW,+BAA+B;IAC9C,uBAAuB;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,mCAAmC;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,8CAA8C;IAC9C,oBAAoB,EAAE,MAAM,CAAC;IAC7B,uBAAuB;IACvB,QAAQ,EAAE,eAAe,CAAC;IAC1B,sDAAsD;IACtD,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,gCAAgC;IAC/C,wCAAwC;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,2CAA2C;IAC3C,MAAM,EAAE,kBAAkB,CAAC;IAC3B,iDAAiD;IACjD,WAAW,EAAE,MAAM,CAAC;IACpB,+CAA+C;IAC/C,SAAS,EAAE,MAAM,CAAC;IAClB,yCAAyC;IACzC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,MAAM,iBAAiB,GACzB,mBAAmB,GACnB,MAAM,GACN,gBAAgB,CAAC;AAErB;;GAEG;AACH,MAAM,WAAW,yBAAyB;IACxC,+BAA+B;IAC/B,eAAe,EAAE,MAAM,CAAC;IACxB,wCAAwC;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,gFAAgF;IAChF,MAAM,EAAE,MAAM,CAAC;IACf,kDAAkD;IAClD,WAAW,CAAC,EAAE,eAAe,CAAC;IAC9B,4CAA4C;IAC5C,iBAAiB,CAAC,EAAE,iBAAiB,CAAC;IACtC,2DAA2D;IAC3D,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,0BAA0B;IACzC,oCAAoC;IACpC,OAAO,EAAE,OAAO,CAAC;IACjB,kCAAkC;IAClC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,2BAA2B;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,2BAA2B;IAC3B,WAAW,EAAE,eAAe,CAAC;IAC7B,uDAAuD;IACvD,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,mCAAmC;IACnC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,qDAAqD;IACrD,aAAa,EAAE,MAAM,CAAC;IACtB,qCAAqC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,+BAA+B;IAC/B,eAAe,EAAE,MAAM,CAAC;IACxB,sCAAsC;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,sBAAsB;IACtB,MAAM,EAAE,MAAM,CAAC;IACf,kDAAkD;IAClD,WAAW,CAAC,EAAE,eAAe,CAAC;CAC/B;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,qCAAqC;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,kFAAkF;IAClF,eAAe,EAAE,MAAM,CAAC;IACxB,+BAA+B;IAC/B,QAAQ,EAAE,MAAM,CAAC;IACjB,+CAA+C;IAC/C,gBAAgB,EAAE,MAAM,CAAC;IACzB,2CAA2C;IAC3C,YAAY,EAAE,MAAM,CAAC;IACrB,uCAAuC;IACvC,aAAa,EAAE,MAAM,CAAC;IACtB,0DAA0D;IAC1D,aAAa,EAAE,MAAM,CAAC;IACtB,yCAAyC;IACzC,gBAAgB,CAAC,EAAE;QACjB,wDAAwD;QACxD,YAAY,EAAE,MAAM,CAAC;QACrB,qDAAqD;QACrD,WAAW,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,sCAAsC;IACtC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,mBAAmB;IAClC,6BAA6B;IAC7B,EAAE,EAAE,MAAM,CAAC;IACX,uBAAuB;IACvB,QAAQ,EAAE,MAAM,CAAC;IACjB,qBAAqB;IACrB,MAAM,EAAE,kBAAkB,CAAC;IAC3B,uBAAuB;IACvB,QAAQ,EAAE,eAAe,CAAC;IAC1B,sDAAsD;IACtD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,oEAAoE;IACpE,cAAc,EAAE,MAAM,CAAC;IACvB,qCAAqC;IACrC,QAAQ,EAAE,MAAM,CAAC;IACjB,qDAAqD;IACrD,iBAAiB,EAAE,OAAO,CAAC;IAC3B,sCAAsC;IACtC,kBAAkB,EAAE,MAAM,CAAC;IAC3B,oCAAoC;IACpC,gBAAgB,EAAE,MAAM,CAAC;IACzB,+CAA+C;IAC/C,SAAS,EAAE,MAAM,CAAC;IAClB,0BAA0B;IAC1B,aAAa,EAAE,QAAQ,GAAG,MAAM,CAAC;IACjC,4CAA4C;IAC5C,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cedros/pay-react",
3
- "version": "1.0.4",
3
+ "version": "1.0.5",
4
4
  "description": "React frontend library for Cedros Pay - unified Stripe and Solana x402 payments",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.mjs",
@@ -1,11 +0,0 @@
1
- "use strict";var qe=Object.create;var ae=Object.defineProperty;var We=Object.getOwnPropertyDescriptor;var Ke=Object.getOwnPropertyNames;var ze=Object.getPrototypeOf,Ve=Object.prototype.hasOwnProperty;var Ge=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of Ke(e))!Ve.call(t,a)&&a!==r&&ae(t,a,{get:()=>e[a],enumerable:!(n=We(e,a))||n.enumerable});return t};var oe=(t,e,r)=>(r=t!=null?qe(ze(t)):{},Ge(e||!t||!t.__esModule?ae(r,"default",{value:t,enumerable:!0}):r,t));const Q=require("react/jsx-runtime"),b=require("react"),I=require("./uuid-C0iMjdcc.js"),T=require("@solana/web3.js"),ie=require("@solana/spl-token"),se=require("@solana/wallet-adapter-wallets");var ge="https://js.stripe.com/v3",He=/^https:\/\/js\.stripe\.com\/v3\/?(\?.*)?$/;var Xe=function(){for(var e=document.querySelectorAll('script[src^="'.concat(ge,'"]')),r=0;r<e.length;r++){var n=e[r];if(He.test(n.src))return n}return null},ce=function(e){var r="",n=document.createElement("script");n.src="".concat(ge).concat(r);var a=document.head||document.body;if(!a)throw new Error("Expected document.body not to be null. Stripe.js requires a <body> element.");return a.appendChild(n),n},Ye=function(e,r){!e||!e._registerWrapper||e._registerWrapper({name:"stripe-js",version:"4.6.0",startTime:r})},O=null,$=null,j=null,Qe=function(e){return function(){e(new Error("Failed to load Stripe.js"))}},Je=function(e,r){return function(){window.Stripe?e(window.Stripe):r(new Error("Stripe.js not available"))}},Ze=function(e){return O!==null?O:(O=new Promise(function(r,n){if(typeof window>"u"||typeof document>"u"){r(null);return}if(window.Stripe){r(window.Stripe);return}try{var a=Xe();if(!(a&&e)){if(!a)a=ce(e);else if(a&&j!==null&&$!==null){var o;a.removeEventListener("load",j),a.removeEventListener("error",$),(o=a.parentNode)===null||o===void 0||o.removeChild(a),a=ce(e)}}j=Je(r,n),$=Qe(n),a.addEventListener("load",j),a.addEventListener("error",$)}catch(i){n(i);return}}),O.catch(function(r){return O=null,Promise.reject(r)}))},et=function(e,r,n){if(e===null)return null;var a=e.apply(void 0,r);return Ye(a,n),a},B,we=!1,be=function(){return B||(B=Ze(null).catch(function(e){return B=null,Promise.reject(e)}),B)};Promise.resolve().then(function(){return be()}).catch(function(t){we||console.warn(t)});var tt=function(){for(var e=arguments.length,r=new Array(e),n=0;n<e;n++)r[n]=arguments[n];we=!0;var a=Date.now();return be().then(function(o){return et(o,r,a)})},Ee=(t=>(t[t.DEBUG=0]="DEBUG",t[t.INFO=1]="INFO",t[t.WARN=2]="WARN",t[t.ERROR=3]="ERROR",t[t.SILENT=4]="SILENT",t))(Ee||{});class ee{config;constructor(e){this.config=e}setLevel(e){this.config.level=e}getLevel(){return this.config.level}debug(...e){this.config.level<=0&&this.log("DEBUG",console.log,e)}info(...e){this.config.level<=1&&this.log("INFO",console.info,e)}warn(...e){this.config.level<=2&&this.log("WARN",console.warn,e)}error(...e){this.config.level<=3&&this.log("ERROR",console.error,e)}log(e,r,n){const a=this.config.prefix?`${this.config.prefix} `:"",o=new Date().toISOString();r(`[${o}] ${a}[${e}]`,...n)}}const rt=()=>typeof process<"u"&&process.env.NODE_ENV==="development"?0:2;let W=null;function d(){return W||(W=new ee({level:rt(),prefix:"[CedrosPay]"})),W}function nt(t){W=t}function ve(t){return new ee(t)}function U(t,e){return t instanceof Error?t.message:typeof t=="string"?t:e}const at={service_unavailable:"Service temporarily unavailable. Please try again later or contact support.",server_insufficient_funds:"Service temporarily unavailable. Please try again later or contact support.",insufficient_funds_token:"Insufficient token balance in your wallet. Please add more tokens and try again.",insufficient_funds_sol:"Insufficient SOL for transaction fees. Please add some SOL to your wallet and try again.",insufficient_amount:"Payment amount is insufficient. Please check the required amount.",invalid_signature:"Transaction signature is invalid. Please try again.",send_failed:"Failed to send transaction. Please try again or contact support.",timeout:"Transaction timed out. Please check the blockchain explorer or try again."};async function k(t,e,r=!1){try{const n=await t.json();if(r&&n.verificationError){d().debug(`Payment verification failed: ${n.verificationError.code}`);const a=n.verificationError.code;return at[a]||n.verificationError.message||e}return typeof n.error=="string"?n.error:n.error&&typeof n.error=="object"&&"message"in n.error?n.error.message:e}catch{return await t.text()||e}}const ot=3e4;async function R(t,e={},r=ot){const n=new AbortController,a=e.signal;if(a?.aborted)throw n.abort(),new DOMException("The operation was aborted","AbortError");const o=setTimeout(()=>n.abort(),r);let i=null;a&&(i=()=>n.abort(),a.addEventListener("abort",i));try{return await fetch(t,{...e,signal:n.signal})}catch(s){throw s instanceof Error&&s.name==="AbortError"?a?.aborted?s:new Error(`Request timeout after ${r}ms`):s}finally{clearTimeout(o),a&&i&&a.removeEventListener("abort",i)}}function _(t){const{maxRequests:e,windowMs:r}=t;let n=e,a=Date.now();const o=e/r;function i(){const f=Date.now(),h=f-a;if(h>0){const y=h*o;n=Math.min(e,n+y),a=f}}function s(){return i(),n>=1?(n-=1,!0):!1}function l(){return i(),Math.floor(n)}function c(){if(i(),n>=1)return 0;const h=(1-n)/o;return Math.ceil(h)}function u(){n=e,a=Date.now()}return{tryConsume:s,getAvailableTokens:l,getTimeUntilRefill:c,reset:u}}const z={PAYMENT:{maxRequests:10,windowMs:6e4},QUOTE:{maxRequests:30,windowMs:6e4},STRICT:{maxRequests:5,windowMs:6e4},PERMISSIVE:{maxRequests:100,windowMs:6e4}};var Ce=(t=>(t.CLOSED="CLOSED",t.OPEN="OPEN",t.HALF_OPEN="HALF_OPEN",t))(Ce||{});class C extends Error{constructor(e){super(e),this.name="CircuitBreakerOpenError"}}function H(t){const{failureThreshold:e,timeout:r,name:n="circuit-breaker"}=t;let a="CLOSED",o=0,i=0,s=0,l=null,c=null,u=null;function f(){a==="OPEN"&&u!==null&&Date.now()>=u&&(d().debug(`[CircuitBreaker:${n}] Transitioning OPEN → HALF_OPEN (timeout expired)`),a="HALF_OPEN",u=null)}function h(){c=Date.now(),i++,a==="HALF_OPEN"?(d().debug(`[CircuitBreaker:${n}] Success in HALF_OPEN → CLOSED`),a="CLOSED",o=0):a==="CLOSED"&&(o=0)}function y(E){l=Date.now(),o++,d().warn(`[CircuitBreaker:${n}] Failure recorded (${o}/${e}):`,E.message),a==="HALF_OPEN"?(d().warn(`[CircuitBreaker:${n}] Failed in HALF_OPEN → OPEN`),a="OPEN",u=Date.now()+r):a==="CLOSED"&&o>=e&&(d().error(`[CircuitBreaker:${n}] Failure threshold reached (${o}) → OPEN`),a="OPEN",u=Date.now()+r)}async function m(E){if(f(),a==="OPEN"){s++;const g=u?Math.ceil((u-Date.now())/1e3):0;throw new C(`Circuit breaker is OPEN. Service is unavailable. Retry in ${g}s.`)}try{const g=await E();return h(),g}catch(g){throw y(g instanceof Error?g:new Error(String(g))),g}}function p(){return f(),a}function v(){return f(),{state:a,failures:o,successes:i,rejections:s,lastFailureTime:l,lastSuccessTime:c}}function A(){d().debug(`[CircuitBreaker:${n}] Manual reset → CLOSED`),a="CLOSED",o=0,i=0,s=0,l=null,c=null,u=null}function S(){d().warn(`[CircuitBreaker:${n}] Manual trip → OPEN`),a="OPEN",u=Date.now()+r}return{execute:m,getState:p,getStats:v,reset:A,trip:S}}const it={STRICT:{failureThreshold:3,timeout:6e4},STANDARD:{failureThreshold:5,timeout:3e4},LENIENT:{failureThreshold:10,timeout:15e3}};function st(t,e){if(e>=3)return!1;const r=t.message.toLowerCase();return r.includes("network")||r.includes("timeout")||r.includes("fetch failed")||r.includes("econnrefused")||r.includes("503")||r.includes("502")||r.includes("500")||r.includes("429")?!0:(r.includes("400")||r.includes("401")||r.includes("403")||r.includes("404"),!1)}function ct(t,e,r,n,a){const o=e*Math.pow(r,t),i=Math.min(o,n);if(a){const s=Math.random()*i;return Math.floor(s)}return Math.floor(i)}function lt(t){return new Promise(e=>setTimeout(e,t))}async function x(t,e={}){const{maxRetries:r=3,initialDelayMs:n=1e3,backoffFactor:a=2,maxDelayMs:o=3e4,jitter:i=!0,shouldRetry:s=st,name:l="retry"}=e;let c=null,u=0;for(let f=0;f<=r;f++)try{const h=await t();return f>0&&d().debug(`[Retry:${l}] Succeeded on attempt ${f+1}/${r+1} after ${u}ms`),h}catch(h){c=h instanceof Error?h:new Error(String(h));const y=f===r,m=s(c,f);if(y||!m)throw d().warn(`[Retry:${l}] Failed on attempt ${f+1}/${r+1}. ${y?"No more retries.":"Error not retryable."}`),c;const p=ct(f,n,a,o,i);u+=p,d().warn(`[Retry:${l}] Attempt ${f+1}/${r+1} failed: ${c.message}. Retrying in ${p}ms...`),await lt(p)}throw c||new Error("Retry failed with no error")}const P={QUICK:{maxRetries:3,initialDelayMs:1e3,backoffFactor:2,maxDelayMs:1e4},STANDARD:{maxRetries:3,initialDelayMs:2e3,backoffFactor:2,maxDelayMs:3e4},AGGRESSIVE:{maxRetries:5,initialDelayMs:500,backoffFactor:1.5,maxDelayMs:15e3},PATIENT:{maxRetries:5,initialDelayMs:5e3,backoffFactor:2,maxDelayMs:6e4}};class ut{stripe=null;publicKey;routeDiscovery;rateLimiter=_(z.PAYMENT);circuitBreaker=H({failureThreshold:5,timeout:1e4,name:"stripe-manager"});constructor(e,r){this.publicKey=e,this.routeDiscovery=r}async initialize(){if(!this.stripe&&(this.stripe=await tt(this.publicKey),!this.stripe))throw new Error("Failed to initialize Stripe")}async createSession(e){if(!this.rateLimiter.tryConsume())throw new Error("Rate limit exceeded for Stripe session creation. Please try again later.");try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const r=await this.routeDiscovery.buildUrl("/paywall/v1/stripe-session");d().debug("[StripeManager] Creating session with request:",e),e.couponCode?d().debug("[StripeManager] Coupon code included:",e.couponCode):d().debug("[StripeManager] No coupon code in request");const n=await R(r,{method:"POST",headers:{"Content-Type":"application/json","Idempotency-Key":I.generateUUID()},body:JSON.stringify(e)});if(!n.ok){const a=await k(n,"Failed to create Stripe session");throw new Error(a)}return n.json()},{...P.STANDARD,name:"stripe-create-session"}))}catch(r){throw r instanceof C?(d().error("[StripeManager] Circuit breaker is OPEN - Stripe service unavailable"),new Error("Stripe payment service is temporarily unavailable. Please try again in a few moments.")):r}}async redirectToCheckout(e){if(this.stripe||await this.initialize(),!this.stripe)return{success:!1,error:"Stripe not initialized"};const r=await this.stripe.redirectToCheckout({sessionId:e});return r.error?{success:!1,error:r.error.message}:{success:!0}}async processPayment(e){try{const r=await this.createSession(e);return await this.redirectToCheckout(r.sessionId)}catch(r){return{success:!1,error:U(r,"Unknown error")}}}async processCartCheckout(e){const{items:r,successUrl:n,cancelUrl:a,metadata:o,customerEmail:i,couponCode:s}=e;if(!this.rateLimiter.tryConsume())return{success:!1,error:"Rate limit exceeded for cart checkout. Please try again later."};try{const l=await this.circuitBreaker.execute(async()=>await x(async()=>{const c=await this.routeDiscovery.buildUrl("/paywall/v1/cart/checkout"),u={items:r,successUrl:n,cancelUrl:a,metadata:o,customerEmail:i,couponCode:s},f=await R(c,{method:"POST",headers:{"Content-Type":"application/json","Idempotency-Key":I.generateUUID()},body:JSON.stringify(u)});if(!f.ok){const h=await k(f,"Failed to create cart checkout session");throw new Error(h)}return await f.json()},{...P.STANDARD,name:"stripe-cart-checkout"}));return await this.redirectToCheckout(l.sessionId)}catch(l){return l instanceof C?{success:!1,error:"Stripe payment service is temporarily unavailable. Please try again in a few moments."}:{success:!1,error:U(l,"Cart checkout failed")}}}}const xe="3.7.8",dt=xe,D=typeof Buffer=="function",le=typeof TextDecoder=="function"?new TextDecoder:void 0,ue=typeof TextEncoder=="function"?new TextEncoder:void 0,ft="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",N=Array.prototype.slice.call(ft),q=(t=>{let e={};return t.forEach((r,n)=>e[r]=n),e})(N),ht=/^(?:[A-Za-z\d+\/]{4})*?(?:[A-Za-z\d+\/]{2}(?:==)?|[A-Za-z\d+\/]{3}=?)?$/,w=String.fromCharCode.bind(String),de=typeof Uint8Array.from=="function"?Uint8Array.from.bind(Uint8Array):t=>new Uint8Array(Array.prototype.slice.call(t,0)),Pe=t=>t.replace(/=/g,"").replace(/[+\/]/g,e=>e=="+"?"-":"_"),Se=t=>t.replace(/[^A-Za-z0-9\+\/]/g,""),Te=t=>{let e,r,n,a,o="";const i=t.length%3;for(let s=0;s<t.length;){if((r=t.charCodeAt(s++))>255||(n=t.charCodeAt(s++))>255||(a=t.charCodeAt(s++))>255)throw new TypeError("invalid character found");e=r<<16|n<<8|a,o+=N[e>>18&63]+N[e>>12&63]+N[e>>6&63]+N[e&63]}return i?o.slice(0,i-3)+"===".substring(i):o},te=typeof btoa=="function"?t=>btoa(t):D?t=>Buffer.from(t,"binary").toString("base64"):Te,J=D?t=>Buffer.from(t).toString("base64"):t=>{let r=[];for(let n=0,a=t.length;n<a;n+=4096)r.push(w.apply(null,t.subarray(n,n+4096)));return te(r.join(""))},K=(t,e=!1)=>e?Pe(J(t)):J(t),mt=t=>{if(t.length<2){var e=t.charCodeAt(0);return e<128?t:e<2048?w(192|e>>>6)+w(128|e&63):w(224|e>>>12&15)+w(128|e>>>6&63)+w(128|e&63)}else{var e=65536+(t.charCodeAt(0)-55296)*1024+(t.charCodeAt(1)-56320);return w(240|e>>>18&7)+w(128|e>>>12&63)+w(128|e>>>6&63)+w(128|e&63)}},yt=/[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g,Re=t=>t.replace(yt,mt),fe=D?t=>Buffer.from(t,"utf8").toString("base64"):ue?t=>J(ue.encode(t)):t=>te(Re(t)),M=(t,e=!1)=>e?Pe(fe(t)):fe(t),he=t=>M(t,!0),pt=/[\xC0-\xDF][\x80-\xBF]|[\xE0-\xEF][\x80-\xBF]{2}|[\xF0-\xF7][\x80-\xBF]{3}/g,gt=t=>{switch(t.length){case 4:var e=(7&t.charCodeAt(0))<<18|(63&t.charCodeAt(1))<<12|(63&t.charCodeAt(2))<<6|63&t.charCodeAt(3),r=e-65536;return w((r>>>10)+55296)+w((r&1023)+56320);case 3:return w((15&t.charCodeAt(0))<<12|(63&t.charCodeAt(1))<<6|63&t.charCodeAt(2));default:return w((31&t.charCodeAt(0))<<6|63&t.charCodeAt(1))}},Ae=t=>t.replace(pt,gt),ke=t=>{if(t=t.replace(/\s+/g,""),!ht.test(t))throw new TypeError("malformed base64.");t+="==".slice(2-(t.length&3));let e,r,n,a=[];for(let o=0;o<t.length;)e=q[t.charAt(o++)]<<18|q[t.charAt(o++)]<<12|(r=q[t.charAt(o++)])<<6|(n=q[t.charAt(o++)]),r===64?a.push(w(e>>16&255)):n===64?a.push(w(e>>16&255,e>>8&255)):a.push(w(e>>16&255,e>>8&255,e&255));return a.join("")},re=typeof atob=="function"?t=>atob(Se(t)):D?t=>Buffer.from(t,"base64").toString("binary"):ke,Me=D?t=>de(Buffer.from(t,"base64")):t=>de(re(t).split("").map(e=>e.charCodeAt(0))),Ue=t=>Me(De(t)),wt=D?t=>Buffer.from(t,"base64").toString("utf8"):le?t=>le.decode(Me(t)):t=>Ae(re(t)),De=t=>Se(t.replace(/[-_]/g,e=>e=="-"?"+":"/")),Z=t=>wt(De(t)),bt=t=>{if(typeof t!="string")return!1;const e=t.replace(/\s+/g,"").replace(/={0,2}$/,"");return!/[^\s0-9a-zA-Z\+/]/.test(e)||!/[^\s0-9a-zA-Z\-_]/.test(e)},Oe=t=>({value:t,enumerable:!1,writable:!0,configurable:!0}),Be=function(){const t=(e,r)=>Object.defineProperty(String.prototype,e,Oe(r));t("fromBase64",function(){return Z(this)}),t("toBase64",function(e){return M(this,e)}),t("toBase64URI",function(){return M(this,!0)}),t("toBase64URL",function(){return M(this,!0)}),t("toUint8Array",function(){return Ue(this)})},Ne=function(){const t=(e,r)=>Object.defineProperty(Uint8Array.prototype,e,Oe(r));t("toBase64",function(e){return K(this,e)}),t("toBase64URI",function(){return K(this,!0)}),t("toBase64URL",function(){return K(this,!0)})},Et=()=>{Be(),Ne()},L={version:xe,VERSION:dt,atob:re,atobPolyfill:ke,btoa:te,btoaPolyfill:Te,fromBase64:Z,toBase64:M,encode:M,encodeURI:he,encodeURL:he,utob:Re,btou:Ae,decode:Z,isValid:bt,fromUint8Array:K,toUint8Array:Ue,extendString:Be,extendUint8Array:Ne,extendBuiltins:Et};class vt{routeDiscovery;quoteRateLimiter=_(z.QUOTE);verifyRateLimiter=_(z.PAYMENT);circuitBreaker=H({failureThreshold:5,timeout:1e4,name:"x402-manager"});constructor(e){this.routeDiscovery=e}async requestQuote(e){const{resource:r,couponCode:n}=e;if(!this.quoteRateLimiter.tryConsume())throw new Error("Rate limit exceeded for quote requests. Please try again later.");try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const a="/paywall/v1/quote";d().debug("[X402Manager] Requesting quote",n?"with coupon":"without coupon");const o=await this.routeDiscovery.buildUrl(a),i=await R(o,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({resource:r,couponCode:n||null})});if(i.status!==402)throw new Error(`Expected 402 status, got ${i.status}`);const s=await i.json();if(!s.accepts||s.accepts.length===0)throw new Error("Invalid x402 response: missing accepts array");return s.accepts[0]},{...P.QUICK,name:"x402-quote"}))}catch(a){throw a instanceof C?(d().error("[X402Manager] Circuit breaker is OPEN - x402 service unavailable"),new Error("Payment service is temporarily unavailable. Please try again in a few moments.")):a}}async requestCartQuote(e){const{items:r,metadata:n,couponCode:a}=e;if(!this.quoteRateLimiter.tryConsume())throw new Error("Rate limit exceeded for cart quote requests. Please try again later.");try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const o=await this.routeDiscovery.buildUrl("/paywall/v1/cart/quote"),i={items:r,metadata:n,couponCode:a},s=await R(o,{method:"POST",headers:{"Content-Type":"application/json","Idempotency-Key":I.generateUUID()},body:JSON.stringify(i)});if(s.status!==402&&!s.ok){const l=await k(s,"Failed to get cart quote");throw new Error(l)}return s.json()},{...P.QUICK,name:"x402-cart-quote"}))}catch(o){throw o instanceof C?(d().error("[X402Manager] Circuit breaker is OPEN - cart quote service unavailable"),new Error("Payment service is temporarily unavailable. Please try again in a few moments.")):o}}buildPaymentHeader(e){const r=JSON.stringify(e);return L.encode(r)}parseSettlementResponse(e){const r=e.headers.get("X-PAYMENT-RESPONSE");if(!r)return null;try{const n=L.decode(r),a=JSON.parse(n);return typeof a.success!="boolean"?(d().error("Invalid settlement response: missing success field"),null):a}catch(n){return d().error("Failed to parse settlement response:",n),null}}async submitPayment(e){const{resource:r,payload:n,couponCode:a,metadata:o,resourceType:i="regular"}=e;if(!this.verifyRateLimiter.tryConsume())return{success:!1,error:"Rate limit exceeded for payment verification. Please try again later."};try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const l={...n,payload:{...n.payload,resource:r,resourceType:i,metadata:{...n.payload.metadata||{},...o||{},...a?{couponCode:a}:{}}}},c=this.buildPaymentHeader(l),u="/paywall/v1/verify";d().debug("[X402Manager] Submitting payment",{resourceType:i,hasCoupon:!!a,hasMetadata:!!o});const f=await this.routeDiscovery.buildUrl(u),h=await R(f,{method:"POST",headers:{"Content-Type":"application/json","X-PAYMENT":c,"Idempotency-Key":I.generateUUID()}});if(h.ok){const{settlement:m,transactionId:p}=await this.handlePaymentVerification(h,n.payload.signature);return{success:!0,transactionId:p,settlement:m||void 0}}return{success:!1,error:await k(h,"Payment verification failed",!0)}},{...P.STANDARD,name:"x402-verify"}))}catch(s){return s instanceof C?{success:!1,error:"Payment verification service is temporarily unavailable. Please try again in a few moments."}:{success:!1,error:U(s,"Unknown error")}}}async buildGaslessTransaction(e){const{resourceId:r,userWallet:n,feePayer:a,couponCode:o}=e;if(!this.quoteRateLimiter.tryConsume())throw new Error("Rate limit exceeded for gasless transaction requests. Please try again later.");try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const i=await this.routeDiscovery.buildUrl("/paywall/v1/gasless-transaction"),s=await R(i,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({resourceId:r,userWallet:n,feePayer:a,couponCode:o})});if(!s.ok){const l=await k(s,"Failed to build gasless transaction");throw new Error(l)}return s.json()},{...P.QUICK,name:"x402-gasless-build"}))}catch(i){throw i instanceof C?(d().error("[X402Manager] Circuit breaker is OPEN - gasless transaction service unavailable"),new Error("Gasless transaction service is temporarily unavailable. Please try again in a few moments.")):i}}async submitGaslessTransaction(e){const{resource:r,partialTx:n,couponCode:a,metadata:o,resourceType:i="regular",requirement:s}=e;if(!this.verifyRateLimiter.tryConsume())return{success:!1,error:"Rate limit exceeded for gasless transaction verification. Please try again later."};try{return await this.circuitBreaker.execute(async()=>await x(async()=>{const c={x402Version:0,scheme:s?.scheme||"solana-spl-transfer",network:s?.network||"mainnet-beta",payload:{signature:"",transaction:n,feePayer:s?.extra?.feePayer||"",resource:r,resourceType:i,metadata:{...o||{},...a?{couponCode:a}:{}}}},u=this.buildPaymentHeader(c),h=await this.routeDiscovery.buildUrl("/paywall/v1/verify"),y=await R(h,{method:"POST",headers:{"Content-Type":"application/json","X-PAYMENT":u,"Idempotency-Key":I.generateUUID()}});if(y.ok){const{settlement:p,transactionId:v}=await this.handlePaymentVerification(y,"gasless-tx");return{success:!0,transactionId:v,settlement:p||void 0}}return{success:!1,error:await k(y,"Gasless transaction failed",!0)}},{...P.STANDARD,name:"x402-gasless-verify"}))}catch(l){return l instanceof C?{success:!1,error:"Gasless transaction verification service is temporarily unavailable. Please try again in a few moments."}:{success:!1,error:U(l,"Unknown error")}}}async handlePaymentVerification(e,r){const n=this.parseSettlementResponse(e),a=e.headers.get("Content-Type")||"";let o=r;if(a.includes("application/json"))try{o=(await e.json()).signature||r}catch(i){d().warn("Failed to parse JSON response body:",i)}return{settlement:n,transactionId:o}}validateRequirement(e){return!!(e.scheme&&e.network&&e.maxAmountRequired&&e.resource&&e.payTo&&e.asset&&e.maxTimeoutSeconds>0)}}function Ct(t){if(t.length>=255)throw new TypeError("Alphabet too long");const e=new Uint8Array(256);for(let c=0;c<e.length;c++)e[c]=255;for(let c=0;c<t.length;c++){const u=t.charAt(c),f=u.charCodeAt(0);if(e[f]!==255)throw new TypeError(u+" is ambiguous");e[f]=c}const r=t.length,n=t.charAt(0),a=Math.log(r)/Math.log(256),o=Math.log(256)/Math.log(r);function i(c){if(c instanceof Uint8Array||(ArrayBuffer.isView(c)?c=new Uint8Array(c.buffer,c.byteOffset,c.byteLength):Array.isArray(c)&&(c=Uint8Array.from(c))),!(c instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(c.length===0)return"";let u=0,f=0,h=0;const y=c.length;for(;h!==y&&c[h]===0;)h++,u++;const m=(y-h)*o+1>>>0,p=new Uint8Array(m);for(;h!==y;){let S=c[h],E=0;for(let g=m-1;(S!==0||E<f)&&g!==-1;g--,E++)S+=256*p[g]>>>0,p[g]=S%r>>>0,S=S/r>>>0;if(S!==0)throw new Error("Non-zero carry");f=E,h++}let v=m-f;for(;v!==m&&p[v]===0;)v++;let A=n.repeat(u);for(;v<m;++v)A+=t.charAt(p[v]);return A}function s(c){if(typeof c!="string")throw new TypeError("Expected String");if(c.length===0)return new Uint8Array;let u=0,f=0,h=0;for(;c[u]===n;)f++,u++;const y=(c.length-u)*a+1>>>0,m=new Uint8Array(y);for(;u<c.length;){const S=c.charCodeAt(u);if(S>255)return;let E=e[S];if(E===255)return;let g=0;for(let F=y-1;(E!==0||g<h)&&F!==-1;F--,g++)E+=r*m[F]>>>0,m[F]=E%256>>>0,E=E/256>>>0;if(E!==0)throw new Error("Non-zero carry");h=g,u++}let p=y-h;for(;p!==y&&m[p]===0;)p++;const v=new Uint8Array(f+(y-p));let A=f;for(;p!==y;)v[A++]=m[p++];return v}function l(c){const u=s(c);if(u)return u;throw new Error("Non-base"+r+" character")}return{encode:i,decodeUnsafe:s,decode:l}}var xt="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";const me=Ct(xt),V={CASHx9KJUStyftLFWGvEVf59SGeG9sh5FfcnZMVPCASH:"CASH",EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v:"USDC",Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB:"USDT","2b1kV6DkPAnxd5ixfnxCpjxmKwqjjaYmCZfHsFu24GXo":"PYUSD"};function Pt(t){return t in V}function ne(t,e="token mint",r=!1){if(!t||t.trim().length===0)return{isValid:!0,isKnownStablecoin:!1};const n=t.trim();if(Pt(n))return{isValid:!0,isKnownStablecoin:!0,symbol:V[n]};const a=Object.entries(V).map(([o,i])=>` ${i}: ${o}`).join(`
2
- `);return r?{isValid:!0,isKnownStablecoin:!1,warning:[`Warning: Unrecognized token mint address in ${e}`,` Provided: ${n}`,"","This token mint does not match any known stablecoin addresses.","You have set dangerouslyAllowUnknownMint=true, so this will proceed.","If this is a typo, payments will be sent to the wrong token and funds will be PERMANENTLY LOST.","","Known stablecoin mints (mainnet-beta):",a,"","Double-check your token mint address before deploying to production."].join(`
3
- `)}:{isValid:!1,isKnownStablecoin:!1,error:[`SAFETY ERROR: Unrecognized token mint address in ${e}`,` Provided: ${n}`,"","This token mint does not match any known stablecoin addresses.","Using an unknown token mint can result in PERMANENT LOSS OF FUNDS if it's a typo.","","Known stablecoin mints (mainnet-beta):",a,"","If you are CERTAIN this is the correct mint address (custom token, testnet, or new stablecoin),","set dangerouslyAllowUnknownMint={true} in your CedrosProvider config:",""," <CedrosProvider"," config={{"," ...",' tokenMint: "'+n+'",'," dangerouslyAllowUnknownMint: true, // ⚠️ I have verified this mint address"," }}"," />","","⚠️ WARNING: Only enable dangerouslyAllowUnknownMint if you have TRIPLE-CHECKED the mint address."].join(`
4
- `)}}function St(t,e="unknown",r=!1){return ne(t,`X402Requirement (resource: ${e})`,r)}class Tt{connection;cluster;endpoint;allowUnknownMint;rpcRateLimiter=_({maxRequests:50,windowMs:6e4});rpcCircuitBreaker=H({failureThreshold:5,timeout:1e4,name:"solana-rpc"});constructor(e="mainnet-beta",r,n=!1){this.cluster=e,this.endpoint=r,this.allowUnknownMint=n,this.connection=this.createConnection()}createConnection(){const e=this.endpoint??T.clusterApiUrl(this.cluster);return new T.Connection(e,"confirmed")}transformRpcError(e){const r=e instanceof Error?e.message:typeof e=="string"?e:String(e);return r.includes("403")||r.includes("Access forbidden")?new Error("Public Solana RPC access denied. Please configure a custom RPC endpoint (e.g., from Helius, QuickNode, or Alchemy) in your CedrosProvider config using the solanaEndpoint option."):r.includes("429")||r.includes("Too Many Requests")?new Error("Solana RPC rate limit exceeded. Please configure a custom RPC endpoint with higher limits in your CedrosProvider config using the solanaEndpoint option."):e instanceof Error?e:new Error(r)}async buildTransaction(e){const{requirement:r,payerPublicKey:n,blockhash:a}=e;if(!r||!r.payTo)throw new Error("Invalid requirement: missing payTo");console.log("🔨 [WalletManager] Building NEW transaction for resource:",r.resource);const o=new T.Transaction,i=this.resolveAmountInMinorUnits(r),s=r.asset;if(!s)throw new Error("asset is required in x402 requirement");const l=St(s,r.resource,this.allowUnknownMint);if(!l.isValid&&l.error)throw new Error(l.error);l.warning&&d().warn(l.warning);const c=new T.PublicKey(s),u=await ie.getAssociatedTokenAddress(c,n);if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");let f;try{f=await this.rpcCircuitBreaker.execute(async()=>await x(async()=>await this.connection.getAccountInfo(u),{...P.QUICK,name:"rpc-get-account-info"}))}catch(m){throw m instanceof C?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(m)}if(!f)throw new Error("Payer is missing an associated token account for this mint");let h;try{h=r.extra?.recipientTokenAccount?new T.PublicKey(r.extra.recipientTokenAccount):new T.PublicKey(r.payTo)}catch{throw new Error("We are currently unable to process payment, please try again later")}if(o.add(ie.createTransferInstruction(u,h,n,i)),r.extra?.memo){const{TransactionInstruction:m}=await import("@solana/web3.js"),p=new m({keys:[],programId:new T.PublicKey("MemoSq4gqABAXKb96qnH8TysNcWxMyWCqXgDLGmfcHr"),data:Buffer.from(r.extra.memo,"utf8")});o.add(p)}let y;if(a)y=a;else{if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{y=(await this.rpcCircuitBreaker.execute(async()=>await x(async()=>await this.connection.getLatestBlockhash(),{...P.QUICK,name:"rpc-get-blockhash"}))).blockhash}catch(m){throw m instanceof C?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(m)}}return o.recentBlockhash=y,r.extra?.feePayer?o.feePayer=new T.PublicKey(r.extra.feePayer):o.feePayer=n,o}resolveAmountInMinorUnits(e){const r=parseInt(e.maxAmountRequired,10);if(Number.isNaN(r)||r<=0)throw new Error("Invalid maxAmountRequired in requirement");return r}buildPaymentPayload(e){const{requirement:r,signedTx:n,payerPublicKey:a}=e;return{x402Version:0,scheme:r.scheme,network:r.network,payload:{signature:n.signature,transaction:n.serialized,payer:a.toString(),memo:r.extra?.memo,recipientTokenAccount:r.extra?.recipientTokenAccount}}}async signTransaction(e){const{transaction:r,signTransaction:n}=e;console.log("✍️ [WalletManager] Requesting wallet to sign transaction");const a=await n(r),o=a.serialize(),i=a.signatures[0]?.signature;if(!i)throw new Error("Signed transaction missing signature");const s=me.encode(i);return console.log("✅ [WalletManager] Transaction signed with signature:",s.substring(0,20)+"..."),{serialized:L.fromUint8Array(o),signature:s}}deserializeTransaction(e){try{const r=L.toUint8Array(e);return T.Transaction.from(r)}catch(r){throw new Error(`Failed to deserialize transaction: ${U(r,"Unknown error")}`)}}async partiallySignTransaction(e){const{transaction:r,signTransaction:n,blockhash:a}=e;a&&r.recentBlockhash!==a&&(r.recentBlockhash=a);const o=await n(r),i=o.signatures[0]?.signature;if(i){const l=me.encode(i);console.log("✅ [WalletManager] Partially signed with signature:",l.substring(0,20)+"...")}const s=o.serialize({requireAllSignatures:!1,verifySignatures:!1});return L.fromUint8Array(s)}async getBalance(e){if(!this.rpcRateLimiter.tryConsume())throw new Error("RPC rate limit exceeded. Please try again in a moment.");try{return await this.rpcCircuitBreaker.execute(async()=>await x(async()=>await this.connection.getBalance(e),{...P.QUICK,name:"rpc-get-balance"}))/T.LAMPORTS_PER_SOL}catch(r){throw r instanceof C?new Error("Solana RPC service is temporarily unavailable. Please try again in a few moments."):this.transformRpcError(r)}}async verifyTransaction(e){if(!this.rpcRateLimiter.tryConsume())return d().warn("[WalletManager] RPC rate limit exceeded for transaction verification"),!1;try{return!!(await this.rpcCircuitBreaker.execute(async()=>await x(async()=>await this.connection.getSignatureStatus(e),{...P.QUICK,name:"rpc-verify-tx"}))).value?.confirmationStatus}catch(r){return r instanceof C&&d().warn("[WalletManager] Circuit breaker OPEN - cannot verify transaction"),!1}}}class Rt{serverUrl;routePrefix=null;discoveryPromise=null;maxRetries=3;baseDelayMs=1e3;constructor(e){this.serverUrl=e}async discoverPrefix(){if(this.routePrefix!==null)return this.routePrefix;if(this.discoveryPromise)return this.discoveryPromise;const e=(async()=>{let r=0;for(;r<this.maxRetries;)try{const n=await R(`${this.serverUrl}/cedros-health`);if(!n.ok){if(n.status>=400&&n.status<500)return d().warn(`Route discovery received ${n.status} - not retrying client error`),this.routePrefix="","";throw new Error(`Health check returned ${n.status}`)}const o=(await n.json()).routePrefix||"";return this.routePrefix=o,d().debug("Route discovery successful, prefix:",o||"(empty)"),o}catch(n){if(r++,r>=this.maxRetries)return d().warn(`Route discovery failed after ${r} attempts, using empty prefix for this request:`,n),"";const a=this.baseDelayMs*Math.pow(2,r-1);d().warn(`Route discovery failed (attempt ${r}/${this.maxRetries}), retrying in ${a}ms:`,n),await new Promise(o=>setTimeout(o,a))}return""})();this.discoveryPromise=e;try{return await this.discoveryPromise}finally{this.discoveryPromise=null}}async buildUrl(e){const r=await this.discoverPrefix(),n=e.startsWith("/")?e:`/${e}`;return`${this.serverUrl}${r}${n}`}reset(){this.routePrefix=null,this.discoveryPromise=null}}const G=new Map;function Ie(t,e,r,n,a){return JSON.stringify({stripePublicKey:t,serverUrl:e,solanaCluster:r,solanaEndpoint:n||"",dangerouslyAllowUnknownMint:a||!1})}function At(t,e,r,n,a){const o=Ie(t,e,r,n,a);let i=G.get(o);if(i)return i.refCount++,d().debug(`[ManagerCache] Reusing cached managers (refCount: ${i.refCount}):`,{stripePublicKey:t.slice(0,10)+"...",serverUrl:e}),i;d().debug("[ManagerCache] Creating new manager instances:",{stripePublicKey:t.slice(0,10)+"...",serverUrl:e});const s=new Rt(e),l=new ut(t,s),c=new vt(s),u=new Tt(r,n,a??!1);return i={stripeManager:l,x402Manager:c,walletManager:u,routeDiscovery:s,refCount:1},G.set(o,i),i}function kt(t,e,r,n,a){const o=Ie(t,e,r,n,a),i=G.get(o);if(!i){d().warn("[ManagerCache] Attempted to release non-existent managers:",{cacheKey:o});return}i.refCount--,d().debug(`[ManagerCache] Released manager reference (refCount: ${i.refCount}):`,{stripePublicKey:t.slice(0,10)+"...",serverUrl:e}),i.refCount<=0&&(G.delete(o),d().debug("[ManagerCache] Removed managers from cache (refCount reached 0)"))}const Mt=["stripePublicKey"],ye=new Set(["mainnet-beta","devnet","testnet"]);function Ut(){if(typeof window<"u"&&window.location)return window.location.origin;throw new Error("serverUrl is required in SSR/Node environments. In browser environments, it defaults to window.location.origin")}function Le(t){const e=[];Mt.forEach(n=>{const a=t[n];(typeof a!="string"||a.trim().length===0)&&e.push({field:n,message:"must be a non-empty string"})});let r;if(t.serverUrl!==void 0)typeof t.serverUrl!="string"||t.serverUrl.trim().length===0?(e.push({field:"serverUrl",message:"must be a non-empty string when provided"}),r=""):r=t.serverUrl;else try{r=Ut()}catch(n){e.push({field:"serverUrl",message:n instanceof Error?n.message:"failed to determine default"}),r=""}if(ye.has(t.solanaCluster)||e.push({field:"solanaCluster",message:`must be one of ${Array.from(ye).join(", ")}`}),t.solanaEndpoint!==void 0&&(typeof t.solanaEndpoint!="string"?e.push({field:"solanaEndpoint",message:"must be a string when provided"}):t.solanaEndpoint.trim().length===0?e.push({field:"solanaEndpoint",message:'must be a non-empty string when provided (e.g., "https://api.mainnet-beta.solana.com")'}):!t.solanaEndpoint.startsWith("http://")&&!t.solanaEndpoint.startsWith("https://")&&e.push({field:"solanaEndpoint",message:'must start with "http://" or "https://" (e.g., "https://api.mainnet-beta.solana.com")'})),t.tokenMint&&typeof t.tokenMint!="string"&&e.push({field:"tokenMint",message:"must be a string when provided"}),e.length>0){const n=e.map(a=>`- ${a.field} ${a.message}`).join(`
5
- `);throw new Error(`Invalid Cedros configuration:
6
- ${n}`)}if(t.tokenMint){const n=t.dangerouslyAllowUnknownMint===!0,a=ne(t.tokenMint,"CedrosConfig.tokenMint",n);if(!a.isValid&&a.error)throw new Error(a.error);a.warning&&d().warn(a.warning)}return{...t,serverUrl:r}}class _e{adapters=null;poolId;isCleanedUp=!1;constructor(e){this.poolId=e??`pool_${Date.now()}_${Math.random().toString(36).slice(2,11)}`,d().debug(`[WalletPool] Created pool: ${this.poolId}`)}getAdapters(){return typeof window>"u"?[]:this.isCleanedUp?(d().warn(`[WalletPool] Attempted to use pool after cleanup: ${this.poolId}`),[]):this.adapters!==null?this.adapters:(d().debug(`[WalletPool] Initializing adapters for pool: ${this.poolId}`),this.adapters=[new se.PhantomWalletAdapter,new se.SolflareWalletAdapter],this.adapters)}async cleanup(){if(this.isCleanedUp){d().debug(`[WalletPool] Pool already cleaned up: ${this.poolId}`);return}if(d().debug(`[WalletPool] Cleaning up pool: ${this.poolId}`),this.isCleanedUp=!0,this.adapters===null)return;const e=this.adapters.map(async r=>{try{r.connected&&(d().debug(`[WalletPool] Disconnecting wallet: ${r.name}`),await r.disconnect())}catch(n){d().warn(`[WalletPool] Failed to disconnect wallet ${r.name}:`,n)}});await Promise.allSettled(e),this.adapters=null,d().debug(`[WalletPool] Pool cleanup complete: ${this.poolId}`)}isInitialized(){return this.adapters!==null}getId(){return this.poolId}}function Fe(t){return new _e(t)}const Dt=Object.freeze({surfaceBackground:"rgba(255, 255, 255, 0)",surfaceText:"#111827",surfaceBorder:"rgba(15, 23, 42, 0.08)",stripeBackground:"linear-gradient(135deg, #635bff 0%, #4f46e5 100%)",stripeText:"#ffffff",stripeShadow:"rgba(79, 70, 229, 0.25)",cryptoBackground:"linear-gradient(135deg, #14f195 0%, #9945ff 100%)",cryptoText:"#ffffff",cryptoShadow:"rgba(99, 102, 241, 0.25)",errorBackground:"#fee2e2",errorBorder:"#fca5a5",errorText:"#b91c1c",successBackground:"#dcfce7",successBorder:"#86efac",successText:"#166534",modalOverlay:"rgba(0, 0, 0, 0.5)",modalBackground:"#ffffff",modalBorder:"rgba(15, 23, 42, 0.08)",buttonBorderRadius:"8px",buttonPadding:"0.75rem 1.5rem",buttonFontSize:"1rem",buttonFontWeight:"600"}),Ot=Object.freeze({surfaceBackground:"rgba(17, 24, 39, 0.6)",surfaceText:"#f9fafb",surfaceBorder:"rgba(148, 163, 184, 0.25)",stripeBackground:"linear-gradient(135deg, #4f46e5 0%, #3730a3 100%)",stripeText:"#f5f3ff",stripeShadow:"rgba(99, 102, 241, 0.35)",cryptoBackground:"linear-gradient(135deg, #1dd4a6 0%, #6d28d9 100%)",cryptoText:"#ecfeff",cryptoShadow:"rgba(75, 85, 99, 0.35)",errorBackground:"#7f1d1d",errorBorder:"#fca5a5",errorText:"#fecaca",successBackground:"#14532d",successBorder:"#4ade80",successText:"#bbf7d0",modalOverlay:"rgba(0, 0, 0, 0.75)",modalBackground:"#1f2937",modalBorder:"rgba(148, 163, 184, 0.25)",buttonBorderRadius:"8px",buttonPadding:"0.75rem 1.5rem",buttonFontSize:"1rem",buttonFontWeight:"600"}),Bt={surfaceBackground:"--cedros-surface-bg",surfaceText:"--cedros-surface-text",surfaceBorder:"--cedros-surface-border",stripeBackground:"--cedros-stripe-bg",stripeText:"--cedros-stripe-text",stripeShadow:"--cedros-stripe-shadow",cryptoBackground:"--cedros-crypto-bg",cryptoText:"--cedros-crypto-text",cryptoShadow:"--cedros-crypto-shadow",errorBackground:"--cedros-error-bg",errorBorder:"--cedros-error-border",errorText:"--cedros-error-text",successBackground:"--cedros-success-bg",successBorder:"--cedros-success-border",successText:"--cedros-success-text",modalOverlay:"--cedros-modal-overlay",modalBackground:"--cedros-modal-bg",modalBorder:"--cedros-modal-border",buttonBorderRadius:"--cedros-button-radius",buttonPadding:"--cedros-button-padding",buttonFontSize:"--cedros-button-font-size",buttonFontWeight:"--cedros-button-font-weight"},$e=b.createContext(null);function Nt(t,e){return{...t==="dark"?Ot:Dt,...e}}function It(t){const e=Object.entries(t).map(([r,n])=>[Bt[r],n]);return Object.fromEntries(e)}function Lt({initialMode:t="light",overrides:e,unstyled:r=!1,children:n}){const[a,o]=b.useState(t),[i,s]=b.useState(e),l=b.useRef(e);b.useEffect(()=>{if(e===l.current)return;(!e||!l.current?e!==l.current:Object.keys({...e,...l.current}).some(f=>e[f]!==l.current?.[f]))&&(l.current=e,s(e))},[e]);const c=b.useMemo(()=>{const u=Nt(a,i),f=r?{}:It(u),h=r?"":`cedros-theme-root cedros-theme cedros-theme--${a}`;return{mode:a,setMode:o,tokens:u,className:h,style:f,unstyled:r}},[a,i,r]);return Q.jsx($e.Provider,{value:c,children:n})}function _t(){const t=b.useContext($e);if(!t)throw new Error("useCedrosTheme must be used within CedrosProvider");return t}let X=!1,Y=!1;async function Ft(){if(X)return Y?{available:!0}:{available:!1,error:pe()};try{return await import("@solana/web3.js"),X=!0,Y=!0,{available:!0}}catch{return X=!0,Y=!1,{available:!1,error:pe()}}}function pe(){return`Solana dependencies not installed. To use crypto payments, install them with:
7
-
8
- npm install @solana/web3.js @solana/spl-token @solana/wallet-adapter-react @solana/wallet-adapter-react-ui @solana/wallet-adapter-wallets @solana/wallet-adapter-base
9
-
10
- Or if you only need Stripe payments, hide the crypto button with:
11
- <CedrosPay showCrypto={false} />`}function $t(){return typeof process<"u"&&process.env.NODE_ENV==="development"?0:2}const je=b.createContext(null);function jt({config:t,children:e}){const r=b.useMemo(()=>Le(t),[t]),n=b.useRef(null);n.current===null&&(n.current=Fe());const[a,o]=b.useState(null);b.useEffect(()=>{let s=!1;return Ft().then(l=>{s||(l.available?o(void 0):o(l.error||"Solana dependencies not available"))}),()=>{s=!0}},[]),b.useEffect(()=>{const s=r.logLevel??$t(),l=ve({level:s,prefix:"[CedrosPay]"});nt(l)},[r.logLevel]),b.useEffect(()=>{const s=n.current;return()=>{s&&s.cleanup().catch(l=>{d().warn("[CedrosProvider] Wallet pool cleanup failed:",l)})}},[]),b.useEffect(()=>{const s=r.stripePublicKey,l=r.serverUrl??"",c=r.solanaCluster,u=r.solanaEndpoint,f=r.dangerouslyAllowUnknownMint;return()=>{kt(s,l,c,u,f)}},[r.stripePublicKey,r.serverUrl,r.solanaCluster,r.solanaEndpoint,r.dangerouslyAllowUnknownMint]);const i=b.useMemo(()=>{const{stripeManager:s,x402Manager:l,walletManager:c}=At(r.stripePublicKey,r.serverUrl??"",r.solanaCluster,r.solanaEndpoint,r.dangerouslyAllowUnknownMint);return{config:r,stripeManager:s,x402Manager:l,walletManager:c,walletPool:n.current,solanaError:a}},[r,a]);return Q.jsx(je.Provider,{value:i,children:Q.jsx(Lt,{initialMode:r.theme??"light",overrides:r.themeOverrides,unstyled:r.unstyled??!1,children:e})})}function qt(){const t=b.useContext(je);if(!t)throw new Error("useCedrosContext must be used within CedrosProvider");return t}exports.CIRCUIT_BREAKER_PRESETS=it;exports.CedrosProvider=jt;exports.CircuitBreakerOpenError=C;exports.CircuitState=Ce;exports.KNOWN_STABLECOINS=V;exports.LogLevel=Ee;exports.Logger=ee;exports.RATE_LIMITER_PRESETS=z;exports.RETRY_PRESETS=P;exports.WalletPool=_e;exports.createCircuitBreaker=H;exports.createLogger=ve;exports.createRateLimiter=_;exports.createWalletPool=Fe;exports.formatError=U;exports.getLogger=d;exports.retryWithBackoff=x;exports.useCedrosContext=qt;exports.useCedrosTheme=_t;exports.validateConfig=Le;exports.validateTokenMint=ne;