@usdctofiat/offramp 0.1.4 → 0.2.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 +27 -6
- package/dist/{chunk-BJNSLI3D.js → chunk-E4AJU3FA.js} +98 -40
- package/dist/chunk-E4AJU3FA.js.map +1 -0
- package/dist/{types-DjkNvO-k.d.cts → errors-DQqv1xfX.d.cts} +18 -1
- package/dist/{types-DjkNvO-k.d.ts → errors-DQqv1xfX.d.ts} +18 -1
- package/dist/index.cjs +125 -69
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +40 -22
- package/dist/index.d.ts +40 -22
- package/dist/index.js +1 -1
- package/dist/react.cjs +120 -70
- package/dist/react.cjs.map +1 -1
- package/dist/react.d.cts +9 -2
- package/dist/react.d.ts +9 -2
- package/dist/react.js +12 -17
- package/dist/react.js.map +1 -1
- package/package.json +1 -1
- package/dist/chunk-BJNSLI3D.js.map +0 -1
package/dist/index.cjs
CHANGED
|
@@ -32,37 +32,6 @@ module.exports = __toCommonJS(index_exports);
|
|
|
32
32
|
var import_viem2 = require("viem");
|
|
33
33
|
var import_sdk4 = require("@zkp2p/sdk");
|
|
34
34
|
|
|
35
|
-
// src/deposit.ts
|
|
36
|
-
var import_viem = require("viem");
|
|
37
|
-
var import_chains = require("viem/chains");
|
|
38
|
-
var import_sdk3 = require("@zkp2p/sdk");
|
|
39
|
-
|
|
40
|
-
// src/config.ts
|
|
41
|
-
var import_sdk = require("@zkp2p/sdk");
|
|
42
|
-
var BASE_CHAIN_ID = 8453;
|
|
43
|
-
var RUNTIME_ENV = "production";
|
|
44
|
-
var API_BASE_URL = "https://api.zkp2p.xyz";
|
|
45
|
-
var BASE_RPC_URL = "https://mainnet.base.org";
|
|
46
|
-
var contracts = (0, import_sdk.getContracts)(BASE_CHAIN_ID, RUNTIME_ENV);
|
|
47
|
-
var addresses = contracts.addresses;
|
|
48
|
-
var addrs = addresses;
|
|
49
|
-
var USDC_ADDRESS = addrs.token || "0x833589fcd6edb6e08f4c7c32d4f71b54bda02913";
|
|
50
|
-
var ESCROW_ADDRESS = addrs.escrowV2 || addrs.escrow || "";
|
|
51
|
-
var GATING_SERVICE_ADDRESS = (0, import_sdk.getGatingServiceAddress)(BASE_CHAIN_ID, RUNTIME_ENV);
|
|
52
|
-
var DELEGATE_RATE_MANAGER_ID = "0x8666d6fb0f6797c56e95339fd7ca82fdd348b9db200e10a4c4aa0a0b879fc41c";
|
|
53
|
-
var RATE_MANAGER_REGISTRY_ADDRESS = "0xeed7db23e724ac4590d6db6f78fda6db203535f3";
|
|
54
|
-
var REFERRER = "galleonlabs";
|
|
55
|
-
var MIN_DEPOSIT_USDC = 1;
|
|
56
|
-
var MIN_ORDER_USDC = 1;
|
|
57
|
-
var INDEXER_MAX_ATTEMPTS = 12;
|
|
58
|
-
var INDEXER_INITIAL_DELAY_MS = 1e3;
|
|
59
|
-
var INDEXER_MAX_DELAY_MS = 1e4;
|
|
60
|
-
var PAYEE_REGISTRATION_TIMEOUT_MS = 8e3;
|
|
61
|
-
|
|
62
|
-
// src/platforms.ts
|
|
63
|
-
var import_sdk2 = require("@zkp2p/sdk");
|
|
64
|
-
var import_zod = require("zod");
|
|
65
|
-
|
|
66
35
|
// src/types.ts
|
|
67
36
|
var PLATFORMS = [
|
|
68
37
|
"venmo",
|
|
@@ -171,7 +140,36 @@ var CURRENCIES = {
|
|
|
171
140
|
ZAR: "ZAR"
|
|
172
141
|
};
|
|
173
142
|
|
|
143
|
+
// src/deposit.ts
|
|
144
|
+
var import_viem = require("viem");
|
|
145
|
+
var import_chains = require("viem/chains");
|
|
146
|
+
var import_sdk3 = require("@zkp2p/sdk");
|
|
147
|
+
|
|
148
|
+
// src/config.ts
|
|
149
|
+
var import_sdk = require("@zkp2p/sdk");
|
|
150
|
+
var BASE_CHAIN_ID = 8453;
|
|
151
|
+
var RUNTIME_ENV = "production";
|
|
152
|
+
var API_BASE_URL = "https://api.zkp2p.xyz";
|
|
153
|
+
var BASE_RPC_URL = "https://mainnet.base.org";
|
|
154
|
+
var contracts = (0, import_sdk.getContracts)(BASE_CHAIN_ID, RUNTIME_ENV);
|
|
155
|
+
var addresses = contracts.addresses;
|
|
156
|
+
var addrs = addresses;
|
|
157
|
+
var USDC_ADDRESS = addrs.token || "0x833589fcd6edb6e08f4c7c32d4f71b54bda02913";
|
|
158
|
+
var ESCROW_ADDRESS = addrs.escrowV2 || addrs.escrow || "";
|
|
159
|
+
var GATING_SERVICE_ADDRESS = (0, import_sdk.getGatingServiceAddress)(BASE_CHAIN_ID, RUNTIME_ENV);
|
|
160
|
+
var DELEGATE_RATE_MANAGER_ID = "0x8666d6fb0f6797c56e95339fd7ca82fdd348b9db200e10a4c4aa0a0b879fc41c";
|
|
161
|
+
var RATE_MANAGER_REGISTRY_ADDRESS = "0xeed7db23e724ac4590d6db6f78fda6db203535f3";
|
|
162
|
+
var REFERRER = "galleonlabs";
|
|
163
|
+
var MIN_DEPOSIT_USDC = 1;
|
|
164
|
+
var MIN_ORDER_USDC = 1;
|
|
165
|
+
var INDEXER_MAX_ATTEMPTS = 12;
|
|
166
|
+
var INDEXER_INITIAL_DELAY_MS = 1e3;
|
|
167
|
+
var INDEXER_MAX_DELAY_MS = 1e4;
|
|
168
|
+
var PAYEE_REGISTRATION_TIMEOUT_MS = 8e3;
|
|
169
|
+
|
|
174
170
|
// src/platforms.ts
|
|
171
|
+
var import_sdk2 = require("@zkp2p/sdk");
|
|
172
|
+
var import_zod = require("zod");
|
|
175
173
|
var ZELLE_HASH_LOOKUP_NAMES = ["zelle", "zelle-bofa", "zelle-chase", "zelle-citi"];
|
|
176
174
|
var PAYMENT_CATALOG = (0, import_sdk2.getPaymentMethodsCatalog)(BASE_CHAIN_ID, RUNTIME_ENV);
|
|
177
175
|
var FALLBACK_CURRENCIES = {
|
|
@@ -685,6 +683,14 @@ async function createOfframpDeposit(walletClient, params, onProgress) {
|
|
|
685
683
|
}
|
|
686
684
|
|
|
687
685
|
// src/client.ts
|
|
686
|
+
var indexerClient = null;
|
|
687
|
+
function getIndexerService() {
|
|
688
|
+
if (!indexerClient) {
|
|
689
|
+
const client = new import_sdk4.IndexerClient(`${API_BASE_URL.replace(/\/+$/, "")}`);
|
|
690
|
+
indexerClient = new import_sdk4.IndexerDepositService(client);
|
|
691
|
+
}
|
|
692
|
+
return indexerClient;
|
|
693
|
+
}
|
|
688
694
|
function toBigInt(value) {
|
|
689
695
|
try {
|
|
690
696
|
return BigInt(value || "0");
|
|
@@ -704,7 +710,7 @@ function resolveMethodNames(hashes) {
|
|
|
704
710
|
const names = /* @__PURE__ */ new Set();
|
|
705
711
|
for (const { paymentMethodHash } of hashes) {
|
|
706
712
|
const normalized = paymentMethodHash.toLowerCase();
|
|
707
|
-
for (const platform of
|
|
713
|
+
for (const platform of PLATFORMS) {
|
|
708
714
|
const platformHashes = getPaymentMethodHashes(platform);
|
|
709
715
|
if (platformHashes.some((h) => h.toLowerCase() === normalized)) {
|
|
710
716
|
names.add(getPlatformConfig(platform).name);
|
|
@@ -714,60 +720,104 @@ function resolveMethodNames(hashes) {
|
|
|
714
720
|
}
|
|
715
721
|
return Array.from(names);
|
|
716
722
|
}
|
|
723
|
+
function mapDeposit(d) {
|
|
724
|
+
const delegationState = (0, import_sdk4.classifyDelegationState)(
|
|
725
|
+
d.rateManagerId ?? void 0,
|
|
726
|
+
d.rateManagerAddress ?? void 0,
|
|
727
|
+
DELEGATE_RATE_MANAGER_ID,
|
|
728
|
+
RATE_MANAGER_REGISTRY_ADDRESS
|
|
729
|
+
);
|
|
730
|
+
return {
|
|
731
|
+
depositId: d.depositId,
|
|
732
|
+
compositeId: d.id,
|
|
733
|
+
txHash: d.txHash,
|
|
734
|
+
status: resolveStatus(d),
|
|
735
|
+
remainingUsdc: toUsdc(d.remainingDeposits),
|
|
736
|
+
outstandingUsdc: toUsdc(d.outstandingIntentAmount),
|
|
737
|
+
totalTakenUsdc: toUsdc(d.totalAmountTaken),
|
|
738
|
+
fulfilledIntents: d.fulfilledIntents ?? 0,
|
|
739
|
+
paymentMethods: resolveMethodNames(d.paymentMethods),
|
|
740
|
+
currencies: d.currencies.map((c) => {
|
|
741
|
+
const info = (0, import_sdk4.getCurrencyInfoFromHash)(c.currencyCode);
|
|
742
|
+
return info?.currencyCode ?? c.currencyCode;
|
|
743
|
+
}),
|
|
744
|
+
rateSource: d.currencies[0]?.rateSource || "unknown",
|
|
745
|
+
delegated: delegationState === "delegated_here",
|
|
746
|
+
escrowAddress: d.escrowAddress
|
|
747
|
+
};
|
|
748
|
+
}
|
|
749
|
+
function extractTxHash(result) {
|
|
750
|
+
if (typeof result === "string") return result;
|
|
751
|
+
if (result && typeof result === "object" && "hash" in result) return result.hash;
|
|
752
|
+
if (result && typeof result === "object" && "transactionHash" in result) return result.transactionHash;
|
|
753
|
+
throw new Error("Unexpected transaction result format");
|
|
754
|
+
}
|
|
717
755
|
var Offramp = class {
|
|
718
756
|
/**
|
|
719
757
|
* Create an offramp deposit: approve USDC, register payee, create deposit,
|
|
720
758
|
* confirm on-chain, and delegate to the vault. All in one call.
|
|
759
|
+
*
|
|
760
|
+
* @param walletClient - viem WalletClient with an account
|
|
761
|
+
* @param params - Deposit parameters (amount, platform, currency, identifier)
|
|
762
|
+
* @param onProgress - Optional callback for step-by-step progress updates
|
|
721
763
|
*/
|
|
722
764
|
async createDeposit(walletClient, params, onProgress) {
|
|
723
765
|
return createOfframpDeposit(walletClient, params, onProgress);
|
|
724
766
|
}
|
|
725
767
|
/**
|
|
726
|
-
* Fetch deposits for a wallet address.
|
|
727
|
-
* sorted by status
|
|
768
|
+
* Fetch all deposits for a wallet address. Read-only, no wallet needed.
|
|
769
|
+
* Returns active, empty, and closed deposits sorted by status then recency.
|
|
728
770
|
*/
|
|
729
771
|
async getDeposits(walletAddress) {
|
|
730
|
-
const
|
|
731
|
-
|
|
732
|
-
{ account: void 0, chain: void 0, transport: void 0 }
|
|
733
|
-
);
|
|
734
|
-
const raw = await client.indexer.getDepositsWithRelations(
|
|
772
|
+
const service = getIndexerService();
|
|
773
|
+
const raw = await service.fetchDepositsWithRelations(
|
|
735
774
|
{ depositor: walletAddress },
|
|
736
775
|
{ limit: 100 }
|
|
737
776
|
);
|
|
738
777
|
const statusOrder = { active: 0, empty: 1, closed: 2 };
|
|
739
|
-
return (raw || []).map((
|
|
740
|
-
const delegationState = (0, import_sdk4.classifyDelegationState)(
|
|
741
|
-
d.rateManagerId ?? void 0,
|
|
742
|
-
d.rateManagerAddress ?? void 0,
|
|
743
|
-
DELEGATE_RATE_MANAGER_ID,
|
|
744
|
-
RATE_MANAGER_REGISTRY_ADDRESS
|
|
745
|
-
);
|
|
746
|
-
return {
|
|
747
|
-
depositId: d.depositId,
|
|
748
|
-
compositeId: d.id,
|
|
749
|
-
status: resolveStatus(d),
|
|
750
|
-
remainingUsdc: toUsdc(d.remainingDeposits),
|
|
751
|
-
outstandingUsdc: toUsdc(d.outstandingIntentAmount),
|
|
752
|
-
totalTakenUsdc: toUsdc(d.totalAmountTaken),
|
|
753
|
-
fulfilledIntents: d.fulfilledIntents ?? 0,
|
|
754
|
-
paymentMethods: resolveMethodNames(d.paymentMethods),
|
|
755
|
-
currencies: d.currencies.map((c) => {
|
|
756
|
-
const info = (0, import_sdk4.getCurrencyInfoFromHash)(c.currencyCode);
|
|
757
|
-
return info?.currencyCode ?? c.currencyCode;
|
|
758
|
-
}),
|
|
759
|
-
rateSource: d.currencies[0]?.rateSource || "unknown",
|
|
760
|
-
delegated: delegationState === "delegated_here",
|
|
761
|
-
escrowAddress: d.escrowAddress
|
|
762
|
-
};
|
|
763
|
-
}).sort((a, b) => {
|
|
778
|
+
return (raw || []).map(mapDeposit).sort((a, b) => {
|
|
764
779
|
const diff = statusOrder[a.status] - statusOrder[b.status];
|
|
765
780
|
if (diff !== 0) return diff;
|
|
766
781
|
return Number(BigInt(b.depositId) - BigInt(a.depositId));
|
|
767
782
|
});
|
|
768
783
|
}
|
|
769
784
|
/**
|
|
770
|
-
*
|
|
785
|
+
* Find a deposit by its transaction hash. Useful for recovering from
|
|
786
|
+
* CONFIRMATION_FAILED errors where you have a txHash but no depositId.
|
|
787
|
+
*
|
|
788
|
+
* @param walletAddress - The depositor's wallet address
|
|
789
|
+
* @param txHash - The transaction hash from createDeposit
|
|
790
|
+
*/
|
|
791
|
+
async getDepositByTxHash(walletAddress, txHash) {
|
|
792
|
+
const deposits = await this.getDeposits(walletAddress);
|
|
793
|
+
const normalized = txHash.toLowerCase();
|
|
794
|
+
return deposits.find((d) => d.txHash?.toLowerCase() === normalized) ?? null;
|
|
795
|
+
}
|
|
796
|
+
/**
|
|
797
|
+
* Delegate an existing deposit to the Delegate vault. Use this to:
|
|
798
|
+
* - Retry after a DELEGATION_FAILED error
|
|
799
|
+
* - Delegate a deposit created outside the SDK
|
|
800
|
+
* - Delegate a deposit created via usdctofiat.xyz
|
|
801
|
+
*
|
|
802
|
+
* @param walletClient - viem WalletClient with the deposit owner's account
|
|
803
|
+
* @param depositId - The numeric deposit ID (not the composite escrow_id format)
|
|
804
|
+
*/
|
|
805
|
+
async delegateDeposit(walletClient, depositId, escrowAddress) {
|
|
806
|
+
const client = createSdkClient(walletClient);
|
|
807
|
+
const result = await client.setRateManager({
|
|
808
|
+
depositId: BigInt(depositId),
|
|
809
|
+
rateManagerAddress: RATE_MANAGER_REGISTRY_ADDRESS,
|
|
810
|
+
rateManagerId: DELEGATE_RATE_MANAGER_ID,
|
|
811
|
+
escrowAddress: escrowAddress || ESCROW_ADDRESS,
|
|
812
|
+
txOverrides: { referrer: [REFERRER] }
|
|
813
|
+
});
|
|
814
|
+
return extractTxHash(result);
|
|
815
|
+
}
|
|
816
|
+
/**
|
|
817
|
+
* Withdraw remaining USDC and close a deposit.
|
|
818
|
+
*
|
|
819
|
+
* @param walletClient - viem WalletClient with the deposit owner's account
|
|
820
|
+
* @param depositId - The numeric deposit ID (not the composite escrow_id format)
|
|
771
821
|
*/
|
|
772
822
|
async withdrawDeposit(walletClient, depositId, escrowAddress) {
|
|
773
823
|
const client = createSdkClient(walletClient);
|
|
@@ -776,9 +826,9 @@ var Offramp = class {
|
|
|
776
826
|
escrowAddress: escrowAddress || ESCROW_ADDRESS,
|
|
777
827
|
txOverrides: { referrer: [REFERRER] }
|
|
778
828
|
});
|
|
779
|
-
return
|
|
829
|
+
return extractTxHash(result);
|
|
780
830
|
}
|
|
781
|
-
/** List available payment platforms and
|
|
831
|
+
/** List available payment platforms with currencies, labels, and format requirements. */
|
|
782
832
|
getPlatforms() {
|
|
783
833
|
return getPlatforms();
|
|
784
834
|
}
|
|
@@ -786,7 +836,10 @@ var Offramp = class {
|
|
|
786
836
|
getCurrencies(platform) {
|
|
787
837
|
return getCurrencies(platform);
|
|
788
838
|
}
|
|
789
|
-
/**
|
|
839
|
+
/**
|
|
840
|
+
* Get currency metadata for UI rendering.
|
|
841
|
+
* @returns Symbol (€), full name (Euro), and country code (eu), or null if unsupported.
|
|
842
|
+
*/
|
|
790
843
|
getCurrencyInfo(code) {
|
|
791
844
|
const info = import_sdk4.currencyInfo[code];
|
|
792
845
|
if (!info) return null;
|
|
@@ -803,7 +856,10 @@ var Offramp = class {
|
|
|
803
856
|
return this.getCurrencyInfo(code);
|
|
804
857
|
}).filter(Boolean);
|
|
805
858
|
}
|
|
806
|
-
/**
|
|
859
|
+
/**
|
|
860
|
+
* Validate and normalize a payment identifier for a platform.
|
|
861
|
+
* Strips leading @/$ characters, validates format (email, IBAN, etc).
|
|
862
|
+
*/
|
|
807
863
|
validateIdentifier(platform, identifier) {
|
|
808
864
|
return validateIdentifier(platform, identifier);
|
|
809
865
|
}
|
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/client.ts","../src/deposit.ts","../src/config.ts","../src/platforms.ts","../src/types.ts","../src/errors.ts"],"sourcesContent":["export { Offramp } from \"./client\";\nexport { OfframpError } from \"./errors\";\nexport type { OfframpErrorCode } from \"./errors\";\nexport {\n PAYMENT_PLATFORMS,\n CURRENCIES,\n SUPPORTED_CURRENCIES,\n} from \"./types\";\nexport type {\n OfframpParams,\n OfframpResult,\n OfframpStep,\n OfframpProgress,\n OnProgress,\n Platform,\n Currency,\n CurrencyInfo,\n PlatformInfo,\n DepositInfo,\n DepositStatus,\n} from \"./types\";\n","import type { WalletClient } from \"viem\";\nimport { formatUnits } from \"viem\";\nimport { classifyDelegationState, currencyInfo, getCurrencyInfoFromHash } from \"@zkp2p/sdk\";\n\nimport type {\n OfframpParams,\n OfframpResult,\n OnProgress,\n PlatformInfo,\n Platform,\n CurrencyInfo,\n DepositInfo,\n DepositStatus,\n} from \"./types\";\nimport { createOfframpDeposit, createSdkClient } from \"./deposit\";\nimport {\n getPlatforms as getPlatformList,\n getCurrencies as getCurrencyList,\n validateIdentifier as validateId,\n getPaymentMethodHashes as getPaymentMethodHashesForPlatform,\n getPlatformConfig,\n} from \"./platforms\";\nimport {\n DELEGATE_RATE_MANAGER_ID,\n ESCROW_ADDRESS,\n RATE_MANAGER_REGISTRY_ADDRESS,\n REFERRER,\n} from \"./config\";\n\ntype IndexerDeposit = {\n id: string;\n depositId: string;\n status: string;\n remainingDeposits: string | null;\n outstandingIntentAmount: string | null;\n totalAmountTaken: string | null;\n fulfilledIntents: number | null;\n escrowAddress: string;\n rateManagerId?: string | null;\n rateManagerAddress?: string | null;\n paymentMethods: Array<{ paymentMethodHash: string }>;\n currencies: Array<{ currencyCode: string; rateSource?: string | null }>;\n};\n\nfunction toBigInt(value: string | null | undefined): bigint {\n try { return BigInt(value || \"0\"); } catch { return 0n; }\n}\n\nfunction toUsdc(value: string | null | undefined): number {\n return Number(formatUnits(toBigInt(value), 6));\n}\n\nfunction resolveStatus(deposit: IndexerDeposit): DepositStatus {\n if (deposit.status === \"CLOSED\") return \"closed\";\n if (toBigInt(deposit.remainingDeposits) === 0n) return \"empty\";\n return \"active\";\n}\n\nfunction resolveMethodNames(\n hashes: Array<{ paymentMethodHash: string }>,\n): string[] {\n const names = new Set<string>();\n for (const { paymentMethodHash } of hashes) {\n const normalized = paymentMethodHash.toLowerCase();\n for (const platform of [\"venmo\", \"cashapp\", \"chime\", \"revolut\", \"wise\", \"mercadopago\", \"zelle\", \"paypal\", \"monzo\", \"n26\"] as Platform[]) {\n const platformHashes = getPaymentMethodHashesForPlatform(platform);\n if (platformHashes.some((h) => h.toLowerCase() === normalized)) {\n names.add(getPlatformConfig(platform).name);\n break;\n }\n }\n }\n return Array.from(names);\n}\n\nexport class Offramp {\n /**\n * Create an offramp deposit: approve USDC, register payee, create deposit,\n * confirm on-chain, and delegate to the vault. All in one call.\n */\n async createDeposit(\n walletClient: WalletClient,\n params: OfframpParams,\n onProgress?: OnProgress,\n ): Promise<OfframpResult> {\n return createOfframpDeposit(walletClient, params, onProgress);\n }\n\n /**\n * Fetch deposits for a wallet address. Returns active, empty, and closed deposits\n * sorted by status (active first) then recency.\n */\n async getDeposits(walletAddress: string): Promise<DepositInfo[]> {\n const client = createSdkClient(\n // Read-only client -- no wallet needed for indexer queries\n { account: undefined, chain: undefined, transport: undefined } as unknown as WalletClient,\n );\n\n const raw = await client.indexer.getDepositsWithRelations(\n { depositor: walletAddress as `0x${string}` },\n { limit: 100 },\n ) as IndexerDeposit[];\n\n const statusOrder: Record<DepositStatus, number> = { active: 0, empty: 1, closed: 2 };\n\n return (raw || [])\n .map((d): DepositInfo => {\n const delegationState = classifyDelegationState(\n d.rateManagerId ?? undefined,\n d.rateManagerAddress ?? undefined,\n DELEGATE_RATE_MANAGER_ID,\n RATE_MANAGER_REGISTRY_ADDRESS,\n );\n return {\n depositId: d.depositId,\n compositeId: d.id,\n status: resolveStatus(d),\n remainingUsdc: toUsdc(d.remainingDeposits),\n outstandingUsdc: toUsdc(d.outstandingIntentAmount),\n totalTakenUsdc: toUsdc(d.totalAmountTaken),\n fulfilledIntents: d.fulfilledIntents ?? 0,\n paymentMethods: resolveMethodNames(d.paymentMethods),\n currencies: d.currencies.map((c) => {\n const info = getCurrencyInfoFromHash(c.currencyCode);\n return info?.currencyCode ?? c.currencyCode;\n }),\n rateSource: d.currencies[0]?.rateSource || \"unknown\",\n delegated: delegationState === \"delegated_here\",\n escrowAddress: d.escrowAddress,\n };\n })\n .sort((a, b) => {\n const diff = statusOrder[a.status] - statusOrder[b.status];\n if (diff !== 0) return diff;\n return Number(BigInt(b.depositId) - BigInt(a.depositId));\n });\n }\n\n /**\n * Withdraw and close a deposit, returning remaining USDC to the wallet.\n */\n async withdrawDeposit(\n walletClient: WalletClient,\n depositId: string,\n escrowAddress?: string,\n ): Promise<string> {\n const client = createSdkClient(walletClient);\n const result = await client.withdrawDeposit({\n depositId: BigInt(depositId),\n escrowAddress: (escrowAddress || ESCROW_ADDRESS) as `0x${string}`,\n txOverrides: { referrer: [REFERRER] },\n });\n return typeof result === \"string\" ? result : (result as { hash: string }).hash;\n }\n\n /** List available payment platforms and their supported currencies. */\n getPlatforms(): PlatformInfo[] {\n return getPlatformList();\n }\n\n /** Get supported currencies for a specific platform. */\n getCurrencies(platform: Platform): string[] {\n return getCurrencyList(platform);\n }\n\n /** Get currency metadata (symbol, name, country code) for a currency code. */\n getCurrencyInfo(code: string): CurrencyInfo | null {\n const info = (currencyInfo as Record<string, { currencyCode?: string; currencyName?: string; currencySymbol?: string; countryCode?: string }>)[code];\n if (!info) return null;\n return {\n code: info.currencyCode ?? code,\n name: info.currencyName ?? code,\n symbol: info.currencySymbol ?? code,\n countryCode: info.countryCode ?? \"\",\n };\n }\n\n /** Get all supported currencies with metadata. */\n getAllCurrencies(): CurrencyInfo[] {\n return Object.keys(currencyInfo as Record<string, unknown>).map((code) => {\n return this.getCurrencyInfo(code)!;\n }).filter(Boolean);\n }\n\n /** Validate a payment identifier for a platform without creating a deposit. */\n validateIdentifier(platform: Platform, identifier: string): {\n valid: boolean;\n normalized: string;\n error?: string;\n } {\n return validateId(platform, identifier);\n }\n}\n","import type { WalletClient } from \"viem\";\nimport { createPublicClient, decodeEventLog, formatUnits, http, parseUnits, type Hex } from \"viem\";\nimport { base } from \"viem/chains\";\nimport {\n OfframpClient,\n getSpreadOracleConfig,\n mapConversionRatesToOnchainMinRate,\n type CurrencyType,\n} from \"@zkp2p/sdk\";\n\nimport {\n API_BASE_URL,\n BASE_CHAIN_ID,\n BASE_RPC_URL,\n DELEGATE_RATE_MANAGER_ID,\n ESCROW_ADDRESS,\n GATING_SERVICE_ADDRESS,\n INDEXER_INITIAL_DELAY_MS,\n INDEXER_MAX_ATTEMPTS,\n INDEXER_MAX_DELAY_MS,\n MIN_DEPOSIT_USDC,\n MIN_ORDER_USDC,\n PAYEE_REGISTRATION_TIMEOUT_MS,\n RATE_MANAGER_REGISTRY_ADDRESS,\n REFERRER,\n RUNTIME_ENV,\n USDC_ADDRESS,\n} from \"./config\";\nimport {\n buildDepositData,\n getPaymentMethodHash,\n isSupportedCurrency,\n validateIdentifier,\n} from \"./platforms\";\nimport { OfframpError, isUserCancellation } from \"./errors\";\nimport type { OfframpParams, OfframpResult, OnProgress } from \"./types\";\n\n/* ── Helpers ──────────────────────────────────────────────────────── */\n\nfunction usdcToUnits(amount: string): bigint {\n return parseUnits(amount, 6);\n}\n\nconst DEPOSIT_RECEIVED_ABI = [\n {\n type: \"event\" as const,\n name: \"DepositReceived\" as const,\n inputs: [\n { indexed: true, name: \"depositId\", type: \"uint256\" },\n { indexed: true, name: \"depositor\", type: \"address\" },\n { indexed: true, name: \"token\", type: \"address\" },\n { indexed: false, name: \"amount\", type: \"uint256\" },\n { indexed: false, name: \"intentAmountRange\", type: \"tuple\", components: [\n { name: \"min\", type: \"uint256\" }, { name: \"max\", type: \"uint256\" },\n ] },\n { indexed: false, name: \"delegate\", type: \"address\" },\n { indexed: false, name: \"intentGuardian\", type: \"address\" },\n ],\n },\n] as const;\n\nfunction extractDepositIdFromLogs(logs: Array<{ topics?: Hex[]; data?: Hex }>): string | null {\n for (const log of logs) {\n if (!log?.topics?.length || !log.data) continue;\n try {\n const decoded = decodeEventLog({\n abi: DEPOSIT_RECEIVED_ABI,\n data: log.data,\n topics: log.topics as [Hex, ...Hex[]],\n });\n if (decoded.eventName !== \"DepositReceived\") continue;\n const args = decoded.args as { depositId?: bigint };\n if (typeof args.depositId === \"bigint\") return args.depositId.toString();\n } catch { continue; }\n }\n return null;\n}\n\nasync function registerPayeeDetails(\n processorName: string,\n depositData: Record<string, string>,\n): Promise<string> {\n const controller = new AbortController();\n const timeout = setTimeout(() => controller.abort(), PAYEE_REGISTRATION_TIMEOUT_MS);\n try {\n const res = await fetch(`${API_BASE_URL}/v1/makers/create`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ processorName, depositData }),\n signal: controller.signal,\n });\n if (!res.ok) {\n const txt = await res.text().catch(() => \"\");\n throw new Error(`makers/create failed (${res.status}): ${txt || res.statusText}`);\n }\n const json = await res.json() as { success: boolean; message: string; responseObject?: { hashedOnchainId: string } };\n if (!json.success || !json.responseObject?.hashedOnchainId) {\n throw new Error(json.message || \"makers/create returned no hashedOnchainId\");\n }\n return json.responseObject.hashedOnchainId;\n } finally {\n clearTimeout(timeout);\n }\n}\n\ntype OnchainCurrencyEntry = {\n code: `0x${string}`;\n minConversionRate: bigint;\n oracleRateConfig?: {\n adapter: `0x${string}`;\n adapterConfig: `0x${string}`;\n spreadBps: number;\n maxStaleness: number;\n };\n};\n\nfunction attachOracleConfig(\n entries: Array<Array<{ code: `0x${string}`; minConversionRate: bigint }>>,\n conversionRates: Array<Array<{ currency: CurrencyType; conversionRate: string }>>,\n): OnchainCurrencyEntry[][] {\n return entries.map((group, gi) =>\n group.map((entry, ci) => {\n const currency = conversionRates[gi]?.[ci]?.currency;\n if (!currency) return entry;\n const oracleConfig = getSpreadOracleConfig(currency);\n if (!oracleConfig) return entry;\n return {\n ...entry,\n oracleRateConfig: {\n adapter: oracleConfig.adapter,\n adapterConfig: oracleConfig.adapterConfig,\n spreadBps: 0,\n maxStaleness: oracleConfig.maxStaleness,\n },\n };\n }),\n );\n}\n\n/* ── SDK client factory ───────────────────────────────────────────── */\n\nexport function createSdkClient(walletClient: WalletClient): OfframpClient {\n return new OfframpClient({\n walletClient,\n chainId: BASE_CHAIN_ID,\n runtimeEnv: RUNTIME_ENV,\n rpcUrl: BASE_RPC_URL,\n baseApiUrl: API_BASE_URL,\n });\n}\n\n/* ── Main deposit flow ────────────────────────────────────────────── */\n\nexport async function createOfframpDeposit(\n walletClient: WalletClient,\n params: OfframpParams,\n onProgress?: OnProgress,\n): Promise<OfframpResult> {\n const { amount, platform, currency, identifier } = params;\n\n // 1. Validate\n const amt = parseFloat(amount);\n if (!Number.isFinite(amt) || amt < MIN_DEPOSIT_USDC) {\n throw new OfframpError(`Minimum deposit is ${MIN_DEPOSIT_USDC} USDC`, \"VALIDATION\");\n }\n\n if (!isSupportedCurrency(platform, currency)) {\n throw new OfframpError(`${currency} is not supported on ${platform}`, \"UNSUPPORTED\");\n }\n\n const validation = validateIdentifier(platform, identifier);\n if (!validation.valid) {\n throw new OfframpError(validation.error || \"Invalid identifier\", \"VALIDATION\");\n }\n const normalizedIdentifier = validation.normalized;\n\n const methodHash = getPaymentMethodHash(platform);\n if (!methodHash) {\n throw new OfframpError(`${platform} is not currently supported`, \"UNSUPPORTED\");\n }\n\n if (!walletClient.account?.address) {\n throw new OfframpError(\"Wallet client has no account. Connect a wallet first.\", \"VALIDATION\");\n }\n const walletAddress = walletClient.account.address;\n\n // Truncate to 6 decimals (USDC precision)\n const truncatedAmount = amt.toFixed(6).replace(/\\.?0+$/, \"\");\n const amountUnits = usdcToUnits(truncatedAmount);\n const minUnits = usdcToUnits(String(MIN_ORDER_USDC));\n const maxUnits = usdcToUnits(String(Math.min(amt, 2500)));\n\n // Pre-flight: check USDC balance\n try {\n const publicClient = createPublicClient({ chain: base, transport: http(BASE_RPC_URL) });\n const balance = await publicClient.readContract({\n address: USDC_ADDRESS,\n abi: [{ name: \"balanceOf\", type: \"function\", stateMutability: \"view\", inputs: [{ name: \"account\", type: \"address\" }], outputs: [{ name: \"\", type: \"uint256\" }] }] as const,\n functionName: \"balanceOf\",\n args: [walletAddress],\n });\n if (balance < amountUnits) {\n const available = Number(formatUnits(balance, 6));\n throw new OfframpError(\n `Insufficient USDC balance. Have ${available.toFixed(2)}, need ${truncatedAmount}.`,\n \"VALIDATION\",\n );\n }\n } catch (err) {\n if (err instanceof OfframpError) throw err;\n // If balance check fails (RPC issue), proceed anyway -- the tx will revert if insufficient\n }\n\n const client = createSdkClient(walletClient);\n const txOverrides = { referrer: [REFERRER] };\n\n // 2. Approve\n onProgress?.({ step: \"approving\" });\n try {\n await client.ensureAllowance({\n token: USDC_ADDRESS,\n amount: amountUnits,\n escrowAddress: ESCROW_ADDRESS,\n maxApprove: false,\n txOverrides,\n });\n } catch (err) {\n if (isUserCancellation(err)) throw new OfframpError(\"User cancelled\", \"USER_CANCELLED\", \"approving\", err);\n const detail = err instanceof Error ? err.message : String(err);\n throw new OfframpError(`USDC approval failed: ${detail}`, \"APPROVAL_FAILED\", \"approving\", err);\n }\n\n // 3. Register payee\n onProgress?.({ step: \"registering\" });\n let hashedOnchainId: string;\n try {\n const canonicalName = platform.startsWith(\"zelle\") ? \"zelle\" : platform;\n const depositData = buildDepositData(platform, normalizedIdentifier);\n hashedOnchainId = await registerPayeeDetails(canonicalName, depositData);\n } catch (err) {\n throw new OfframpError(\"Payee registration failed\", \"REGISTRATION_FAILED\", \"registering\", err);\n }\n\n // 4. Create deposit\n onProgress?.({ step: \"depositing\" });\n\n // 1 wei floor -- vault manages actual rates via oracle\n const conversionRates: Array<Array<{ currency: CurrencyType; conversionRate: string }>> = [\n [{ currency: currency as CurrencyType, conversionRate: \"1\" }],\n ];\n\n const baseCurrenciesOverride = mapConversionRatesToOnchainMinRate(conversionRates, 1);\n const currenciesOverride = attachOracleConfig(baseCurrenciesOverride, conversionRates);\n\n let hash: `0x${string}`;\n try {\n const result = await client.createDeposit({\n token: USDC_ADDRESS,\n amount: amountUnits,\n retainOnEmpty: false,\n intentAmountRange: { min: minUnits, max: maxUnits },\n processorNames: [platform],\n depositData: [buildDepositData(platform, normalizedIdentifier)],\n conversionRates,\n paymentMethodsOverride: [methodHash],\n paymentMethodDataOverride: [{\n intentGatingService: GATING_SERVICE_ADDRESS,\n payeeDetails: hashedOnchainId as `0x${string}`,\n data: \"0x\" as `0x${string}`,\n }],\n currenciesOverride,\n escrowAddress: ESCROW_ADDRESS,\n txOverrides,\n });\n if (!result?.hash) throw new Error(\"No transaction hash returned\");\n hash = result.hash;\n } catch (err) {\n if (isUserCancellation(err)) throw new OfframpError(\"User cancelled\", \"USER_CANCELLED\", \"depositing\", err);\n const detail = err instanceof Error ? err.message : String(err);\n throw new OfframpError(`Deposit transaction failed: ${detail}`, \"DEPOSIT_FAILED\", \"depositing\", err);\n }\n\n // 5. Confirm\n onProgress?.({ step: \"confirming\", txHash: hash });\n let depositId = \"\";\n\n const receiptClient = client as { waitForTransactionReceipt?: (p: { hash: `0x${string}`; confirmations?: number }) => Promise<{ logs: Array<{ topics?: Hex[]; data?: Hex }> }> };\n if (typeof receiptClient.waitForTransactionReceipt === \"function\") {\n try {\n const receipt = await receiptClient.waitForTransactionReceipt({ hash, confirmations: 1 });\n depositId = extractDepositIdFromLogs(receipt.logs) || \"\";\n } catch { /* fall through to indexer */ }\n }\n\n if (!depositId) {\n {\n let delay = INDEXER_INITIAL_DELAY_MS;\n for (let attempt = 0; attempt < INDEXER_MAX_ATTEMPTS && !depositId; attempt++) {\n try {\n const deposits = await client.indexer.getDepositsWithRelations(\n { depositor: walletAddress },\n { limit: 25 },\n ) as Array<{ txHash?: string; depositId: string }>;\n const hit = deposits.find((d) => (d?.txHash || \"\").toLowerCase() === hash.toLowerCase());\n if (hit) {\n depositId = String(hit.depositId);\n break;\n }\n } catch { /* continue */ }\n await new Promise((r) => setTimeout(r, delay));\n delay = Math.min(INDEXER_MAX_DELAY_MS, Math.floor(delay * 1.7));\n }\n }\n }\n\n if (!depositId) {\n throw new OfframpError(\n \"Deposit created on-chain but could not confirm deposit ID. Your funds are safe. Use the transaction hash to locate your deposit.\",\n \"CONFIRMATION_FAILED\",\n \"confirming\",\n undefined,\n { txHash: hash },\n );\n }\n\n // 6. Delegate\n onProgress?.({ step: \"delegating\", txHash: hash, depositId });\n try {\n await client.setRateManager({\n depositId: BigInt(depositId),\n rateManagerAddress: RATE_MANAGER_REGISTRY_ADDRESS,\n rateManagerId: DELEGATE_RATE_MANAGER_ID,\n escrowAddress: ESCROW_ADDRESS,\n txOverrides,\n });\n } catch (delegationError) {\n if (isUserCancellation(delegationError)) {\n throw new OfframpError(\"User cancelled delegation\", \"USER_CANCELLED\", \"delegating\", delegationError, { txHash: hash, depositId });\n }\n throw new OfframpError(\n \"Deposit created but delegation failed. Visit usdctofiat.xyz to manage your deposit manually.\",\n \"DELEGATION_FAILED\",\n \"delegating\",\n delegationError,\n { txHash: hash, depositId },\n );\n }\n\n onProgress?.({ step: \"done\", txHash: hash, depositId });\n return { depositId, txHash: hash };\n}\n","import { getContracts, getGatingServiceAddress } from \"@zkp2p/sdk\";\n\nexport const BASE_CHAIN_ID = 8453;\nexport const RUNTIME_ENV = \"production\" as const;\nexport const API_BASE_URL = \"https://api.zkp2p.xyz\";\nexport const BASE_RPC_URL = \"https://mainnet.base.org\";\n\nconst contracts = getContracts(BASE_CHAIN_ID, RUNTIME_ENV);\nconst addresses = contracts.addresses;\n\nconst addrs = addresses as unknown as Record<string, string>;\nexport const USDC_ADDRESS = (addrs.token || \"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913\") as `0x${string}`;\nexport const ESCROW_ADDRESS = (addrs.escrowV2 || addrs.escrow || \"\") as `0x${string}`;\nexport const GATING_SERVICE_ADDRESS = getGatingServiceAddress(BASE_CHAIN_ID, RUNTIME_ENV) as `0x${string}`;\n\nexport const DELEGATE_RATE_MANAGER_ID =\n \"0x8666d6fb0f6797c56e95339fd7ca82fdd348b9db200e10a4c4aa0a0b879fc41c\" as `0x${string}`;\nexport const RATE_MANAGER_REGISTRY_ADDRESS =\n \"0xeed7db23e724ac4590d6db6f78fda6db203535f3\" as `0x${string}`;\n\nexport const REFERRER = \"galleonlabs\";\n\nexport const MIN_DEPOSIT_USDC = 1;\nexport const MIN_ORDER_USDC = 1;\nexport const MAX_ORDER_USDC = 2500;\n\nexport const INDEXER_MAX_ATTEMPTS = 12;\nexport const INDEXER_INITIAL_DELAY_MS = 1000;\nexport const INDEXER_MAX_DELAY_MS = 10_000;\n\nexport const PAYEE_REGISTRATION_TIMEOUT_MS = 8000;\n","import {\n currencyInfo,\n getCurrencyInfoFromHash,\n getPaymentMethodsCatalog,\n resolvePaymentMethodHash,\n} from \"@zkp2p/sdk\";\nimport { z } from \"zod\";\nimport { BASE_CHAIN_ID, RUNTIME_ENV } from \"./config\";\nimport type { Currency, Platform, PlatformInfo } from \"./types\";\nimport { PLATFORMS } from \"./types\";\n\ntype CurrencyCode = keyof typeof currencyInfo;\n\nconst ZELLE_HASH_LOOKUP_NAMES = [\"zelle\", \"zelle-bofa\", \"zelle-chase\", \"zelle-citi\"] as const;\ntype PaymentMethodLookupName = Platform | (typeof ZELLE_HASH_LOOKUP_NAMES)[number];\n\ninterface PlatformConfig {\n id: Platform;\n name: string;\n identifierLabel: string;\n placeholder: string;\n helperText: string;\n currencies: string[];\n validation: z.ZodType<string>;\n transform?: (value: string) => string;\n}\n\ntype CatalogEntry = { currencies?: string[]; paymentMethodHash?: `0x${string}` };\nconst PAYMENT_CATALOG = getPaymentMethodsCatalog(BASE_CHAIN_ID, RUNTIME_ENV) as Record<string, CatalogEntry>;\n\nconst FALLBACK_CURRENCIES: Record<Platform, string[]> = {\n venmo: [\"USD\"],\n cashapp: [\"USD\"],\n chime: [\"USD\"],\n revolut: [\"USD\", \"EUR\", \"GBP\", \"SGD\", \"NZD\", \"AUD\", \"CAD\", \"HKD\", \"MXN\", \"SAR\", \"AED\", \"THB\", \"TRY\", \"PLN\", \"CHF\", \"ZAR\", \"CZK\", \"CNY\", \"DKK\", \"HUF\", \"NOK\", \"RON\", \"SEK\"],\n wise: [\"USD\", \"CNY\", \"EUR\", \"GBP\", \"AUD\", \"NZD\", \"CAD\", \"AED\", \"CHF\", \"ZAR\", \"SGD\", \"ILS\", \"HKD\", \"JPY\", \"PLN\", \"TRY\", \"IDR\", \"KES\", \"MYR\", \"MXN\", \"THB\", \"VND\", \"UGX\", \"CZK\", \"DKK\", \"HUF\", \"INR\", \"NOK\", \"PHP\", \"RON\", \"SEK\"],\n mercadopago: [\"ARS\"],\n zelle: [\"USD\"],\n paypal: [\"USD\", \"EUR\", \"GBP\", \"SGD\", \"NZD\", \"AUD\", \"CAD\"],\n monzo: [\"GBP\"],\n n26: [\"EUR\"],\n};\n\nfunction gatherCatalogHashes(platform: Platform): string[] {\n if (platform === \"zelle\") {\n return Object.entries(PAYMENT_CATALOG)\n .filter(([key]) => key.startsWith(\"zelle\"))\n .flatMap(([, entry]) => entry.currencies ?? []);\n }\n return PAYMENT_CATALOG[platform]?.currencies ?? [];\n}\n\nfunction resolveSupportedCurrencies(platform: Platform): string[] {\n const codes = new Set<string>();\n for (const hash of gatherCatalogHashes(platform)) {\n const info = getCurrencyInfoFromHash(hash);\n if (info?.currencyCode && currencyInfo[info.currencyCode as CurrencyCode]) {\n codes.add(info.currencyCode);\n }\n }\n if (!codes.size) {\n for (const code of FALLBACK_CURRENCIES[platform] ?? []) codes.add(code);\n }\n return Array.from(codes).sort();\n}\n\nconst BLUEPRINT: Record<Platform, Omit<PlatformConfig, \"currencies\">> = {\n venmo: {\n id: \"venmo\", name: \"Venmo\", identifierLabel: \"Username\", placeholder: \"venmo username (no @)\",\n helperText: \"Username without @ (publicly discoverable)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n transform: (v) => v.replace(/^@+/, \"\"),\n },\n cashapp: {\n id: \"cashapp\", name: \"Cash App\", identifierLabel: \"Cashtag\", placeholder: \"cashtag (no $)\",\n helperText: \"Cashtag without $ (publicly discoverable)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9]+$/),\n transform: (v) => v.replace(/^\\$+/, \"\"),\n },\n chime: {\n id: \"chime\", name: \"Chime\", identifierLabel: \"ChimeSign\", placeholder: \"$chimesign\",\n helperText: \"ChimeSign with $ (must be discoverable)\",\n validation: z.string().min(2).regex(/^\\$[a-zA-Z0-9]+$/),\n transform: (v) => {\n const t = v.trim().toLowerCase();\n return t.startsWith(\"$\") ? t : `$${t}`;\n },\n },\n revolut: {\n id: \"revolut\", name: \"Revolut\", identifierLabel: \"Revtag\", placeholder: \"revtag (no @)\",\n helperText: \"Revtag without @ (must be public)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9]+$/),\n transform: (v) => v.replace(/^@+/, \"\").trim(),\n },\n wise: {\n id: \"wise\", name: \"Wise\", identifierLabel: \"Wisetag\", placeholder: \"wisetag (no @)\",\n helperText: \"Your Wise @wisetag (no @)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n transform: (v) => v.replace(/^@+/, \"\").trim(),\n },\n mercadopago: {\n id: \"mercadopago\", name: \"Mercado Pago\", identifierLabel: \"CVU\", placeholder: \"22-digit CVU\",\n helperText: \"CVU must be exactly 22 digits\",\n validation: z.string().length(22).regex(/^\\d{22}$/),\n },\n zelle: {\n id: \"zelle\", name: \"Zelle\", identifierLabel: \"Email\", placeholder: \"email\",\n helperText: \"Registered Zelle email\",\n validation: z.string().email(),\n },\n paypal: {\n id: \"paypal\", name: \"PayPal\", identifierLabel: \"Email\", placeholder: \"email\",\n helperText: \"Email linked to PayPal account\",\n validation: z.string().email(),\n },\n monzo: {\n id: \"monzo\", name: \"Monzo\", identifierLabel: \"Username\", placeholder: \"monzo.me username\",\n helperText: \"Your Monzo.me username\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n },\n n26: {\n id: \"n26\", name: \"N26\", identifierLabel: \"IBAN\", placeholder: \"IBAN (e.g. DE89...)\",\n helperText: \"Your IBAN (spaces will be removed)\",\n validation: z.string().min(15).max(34).regex(/^[A-Z]{2}[0-9]{2}[A-Z0-9]+$/i),\n transform: (v) => v.replace(/\\s/g, \"\").toUpperCase(),\n },\n};\n\nconst CONFIGS: Record<Platform, PlatformConfig> = Object.fromEntries(\n Object.entries(BLUEPRINT).map(([p, bp]) => {\n const key = p as Platform;\n return [key, { ...bp, currencies: resolveSupportedCurrencies(key) }];\n }),\n) as Record<Platform, PlatformConfig>;\n\nexport function getPlatformConfig(platform: Platform): PlatformConfig {\n return CONFIGS[platform];\n}\n\nexport function getPlatforms(): PlatformInfo[] {\n return PLATFORMS.map((id) => {\n const cfg = CONFIGS[id];\n return {\n id,\n name: cfg.name,\n currencies: cfg.currencies as Currency[],\n identifierLabel: cfg.identifierLabel,\n identifierPlaceholder: cfg.placeholder,\n helperText: cfg.helperText,\n };\n });\n}\n\nexport function getCurrencies(platform: Platform): string[] {\n return CONFIGS[platform]?.currencies ?? [];\n}\n\nexport function validateIdentifier(\n platform: Platform,\n value: string,\n): { valid: boolean; normalized: string; error?: string } {\n const cfg = CONFIGS[platform];\n if (!cfg) return { valid: false, normalized: value, error: \"Unsupported platform\" };\n const transformed = cfg.transform ? cfg.transform(value) : value;\n const result = cfg.validation.safeParse(transformed);\n if (!result.success) {\n return { valid: false, normalized: transformed, error: result.error.issues[0]?.message || \"Invalid input\" };\n }\n return { valid: true, normalized: transformed };\n}\n\nexport function isSupportedCurrency(platform: Platform, currency: string): boolean {\n return CONFIGS[platform]?.currencies.includes(currency) ?? false;\n}\n\nfunction normalizePaymentMethodLookupName(platform: string): PaymentMethodLookupName | null {\n const normalized = platform.trim().toLowerCase();\n if (!normalized) return null;\n if (ZELLE_HASH_LOOKUP_NAMES.includes(normalized as (typeof ZELLE_HASH_LOOKUP_NAMES)[number])) {\n return normalized as PaymentMethodLookupName;\n }\n return PLATFORMS.includes(normalized as Platform) ? (normalized as Platform) : null;\n}\n\nfunction resolveCanonicalZelleHash(): `0x${string}` | null {\n const direct = PAYMENT_CATALOG.zelle?.paymentMethodHash;\n if (direct) return direct;\n const variant = Object.entries(PAYMENT_CATALOG).find(\n ([name, entry]) => name.startsWith(\"zelle\") && Boolean(entry.paymentMethodHash),\n );\n return variant?.[1]?.paymentMethodHash ?? null;\n}\n\nexport function getPaymentMethodHash(platform: Platform): `0x${string}` | null {\n const name = normalizePaymentMethodLookupName(platform);\n if (!name) return null;\n const catalogEntry = PAYMENT_CATALOG[name];\n if (catalogEntry?.paymentMethodHash) return catalogEntry.paymentMethodHash;\n if (name === \"zelle\" || name.startsWith(\"zelle-\")) return resolveCanonicalZelleHash();\n const sdkHash = resolvePaymentMethodHash(name);\n return sdkHash ? (sdkHash as `0x${string}`) : null;\n}\n\nexport function getPaymentMethodHashes(platform: Platform): `0x${string}`[] {\n if (platform !== \"zelle\") {\n const hash = getPaymentMethodHash(platform);\n return hash ? [hash] : [];\n }\n const hashes = new Set<`0x${string}`>();\n const generic = resolvePaymentMethodHash(\"zelle\") as `0x${string}` | undefined;\n if (generic) hashes.add(generic);\n const canonical = resolveCanonicalZelleHash();\n if (canonical) hashes.add(canonical);\n for (const [name, entry] of Object.entries(PAYMENT_CATALOG)) {\n if (name.startsWith(\"zelle\") && entry.paymentMethodHash) {\n hashes.add(entry.paymentMethodHash);\n }\n }\n return Array.from(hashes);\n}\n\nexport function buildDepositData(\n platform: Platform,\n identifier: string,\n): Record<string, string> {\n switch (platform) {\n case \"venmo\": return { venmoUsername: identifier, telegramUsername: \"\" };\n case \"cashapp\": return { cashtag: identifier, telegramUsername: \"\" };\n case \"chime\": return { chimesign: identifier.toLowerCase(), telegramUsername: \"\" };\n case \"revolut\": return { revolutUsername: identifier, telegramUsername: \"\" };\n case \"wise\": return { wisetag: identifier, telegramUsername: \"\" };\n case \"mercadopago\": return { cvu: identifier, telegramUsername: \"\" };\n case \"zelle\": return { zelleEmail: identifier, telegramUsername: \"\" };\n case \"paypal\": return { paypalEmail: identifier, telegramUsername: \"\" };\n case \"monzo\": return { monzoMeUsername: identifier, telegramUsername: \"\" };\n case \"n26\": return { iban: identifier, telegramUsername: \"\" };\n default: return { identifier, telegramUsername: \"\" };\n }\n}\n","export const PLATFORMS = [\n \"venmo\", \"cashapp\", \"chime\", \"revolut\", \"wise\",\n \"mercadopago\", \"zelle\", \"paypal\", \"monzo\", \"n26\",\n] as const;\n\nexport type Platform = (typeof PLATFORMS)[number];\n\n/** Constant map for platform autocomplete: `PAYMENT_PLATFORMS.REVOLUT` */\nexport const PAYMENT_PLATFORMS = {\n VENMO: \"venmo\",\n CASHAPP: \"cashapp\",\n CHIME: \"chime\",\n REVOLUT: \"revolut\",\n WISE: \"wise\",\n MERCADO_PAGO: \"mercadopago\",\n ZELLE: \"zelle\",\n PAYPAL: \"paypal\",\n MONZO: \"monzo\",\n N26: \"n26\",\n} as const satisfies Record<string, Platform>;\n\nexport const SUPPORTED_CURRENCIES = [\n \"AED\", \"ARS\", \"AUD\", \"BRL\", \"CAD\", \"CHF\", \"CLP\", \"CNY\", \"COP\",\n \"CZK\", \"DKK\", \"EUR\", \"GBP\", \"HKD\", \"HUF\", \"IDR\", \"ILS\", \"INR\",\n \"JPY\", \"KES\", \"KRW\", \"MXN\", \"MYR\", \"NOK\", \"NZD\", \"PEN\", \"PHP\",\n \"PLN\", \"RON\", \"SAR\", \"SEK\", \"SGD\", \"THB\", \"TRY\", \"TWD\", \"UGX\",\n \"USD\", \"VND\", \"ZAR\",\n] as const;\n\nexport type Currency = (typeof SUPPORTED_CURRENCIES)[number];\n\n/** Constant map for currency autocomplete: `CURRENCIES.EUR` */\nexport const CURRENCIES = {\n AED: \"AED\", ARS: \"ARS\", AUD: \"AUD\", BRL: \"BRL\", CAD: \"CAD\",\n CHF: \"CHF\", CLP: \"CLP\", CNY: \"CNY\", COP: \"COP\", CZK: \"CZK\",\n DKK: \"DKK\", EUR: \"EUR\", GBP: \"GBP\", HKD: \"HKD\", HUF: \"HUF\",\n IDR: \"IDR\", ILS: \"ILS\", INR: \"INR\", JPY: \"JPY\", KES: \"KES\",\n KRW: \"KRW\", MXN: \"MXN\", MYR: \"MYR\", NOK: \"NOK\", NZD: \"NZD\",\n PEN: \"PEN\", PHP: \"PHP\", PLN: \"PLN\", RON: \"RON\", SAR: \"SAR\",\n SEK: \"SEK\", SGD: \"SGD\", THB: \"THB\", TRY: \"TRY\", TWD: \"TWD\",\n UGX: \"UGX\", USD: \"USD\", VND: \"VND\", ZAR: \"ZAR\",\n} as const satisfies Record<string, Currency>;\n\nexport interface OfframpParams {\n amount: string;\n platform: Platform;\n currency: Currency;\n identifier: string;\n}\n\nexport interface OfframpResult {\n depositId: string;\n txHash: string;\n}\n\nexport type OfframpStep =\n | \"approving\"\n | \"registering\"\n | \"depositing\"\n | \"confirming\"\n | \"delegating\"\n | \"done\";\n\nexport interface OfframpProgress {\n step: OfframpStep;\n txHash?: string;\n depositId?: string;\n}\n\nexport type OnProgress = (progress: OfframpProgress) => void;\n\nexport interface PlatformInfo {\n id: Platform;\n name: string;\n currencies: Currency[];\n identifierLabel: string;\n identifierPlaceholder: string;\n helperText: string;\n}\n\nexport interface CurrencyInfo {\n code: string;\n name: string;\n symbol: string;\n countryCode: string;\n}\n\nexport type DepositStatus = \"active\" | \"empty\" | \"closed\";\n\nexport interface DepositInfo {\n depositId: string;\n compositeId: string;\n status: DepositStatus;\n remainingUsdc: number;\n outstandingUsdc: number;\n totalTakenUsdc: number;\n fulfilledIntents: number;\n paymentMethods: string[];\n currencies: string[];\n rateSource: string;\n delegated: boolean;\n escrowAddress: string;\n}\n","import type { OfframpStep } from \"./types\";\n\nexport type OfframpErrorCode =\n | \"VALIDATION\"\n | \"APPROVAL_FAILED\"\n | \"REGISTRATION_FAILED\"\n | \"DEPOSIT_FAILED\"\n | \"CONFIRMATION_FAILED\"\n | \"DELEGATION_FAILED\"\n | \"USER_CANCELLED\"\n | \"UNSUPPORTED\";\n\nexport class OfframpError extends Error {\n readonly code: OfframpErrorCode;\n readonly step?: OfframpStep;\n override readonly cause?: unknown;\n readonly txHash?: string;\n readonly depositId?: string;\n\n constructor(\n message: string,\n code: OfframpErrorCode,\n step?: OfframpStep,\n cause?: unknown,\n details?: { txHash?: string; depositId?: string },\n ) {\n super(message);\n this.name = \"OfframpError\";\n this.code = code;\n this.step = step;\n this.cause = cause;\n this.txHash = details?.txHash;\n this.depositId = details?.depositId;\n }\n}\n\nexport function isUserCancellation(error: unknown): boolean {\n if (!(error instanceof Error)) return false;\n const msg = error.message.toLowerCase();\n return (\n msg.includes(\"user rejected\") ||\n msg.includes(\"user denied\") ||\n msg.includes(\"user cancelled\") ||\n msg.includes(\"rejected the request\") ||\n msg.includes(\"action_rejected\")\n );\n}\n"],"mappings":"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","names":["import_viem","import_sdk","import_sdk","import_sdk"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/client.ts","../src/types.ts","../src/deposit.ts","../src/config.ts","../src/platforms.ts","../src/errors.ts"],"sourcesContent":["export { Offramp } from \"./client\";\nexport { OfframpError } from \"./errors\";\nexport type { OfframpErrorCode } from \"./errors\";\nexport {\n PAYMENT_PLATFORMS,\n CURRENCIES,\n SUPPORTED_CURRENCIES,\n} from \"./types\";\nexport type {\n OfframpParams,\n OfframpResult,\n OfframpStep,\n OfframpProgress,\n OnProgress,\n Platform,\n Currency,\n CurrencyInfo,\n PlatformInfo,\n DepositInfo,\n DepositStatus,\n} from \"./types\";\n","import type { WalletClient } from \"viem\";\nimport { formatUnits } from \"viem\";\nimport { classifyDelegationState, currencyInfo, getCurrencyInfoFromHash, IndexerClient, IndexerDepositService } from \"@zkp2p/sdk\";\n\nimport { PLATFORMS } from \"./types\";\nimport type {\n OfframpParams,\n OfframpResult,\n OnProgress,\n PlatformInfo,\n Platform,\n CurrencyInfo,\n DepositInfo,\n DepositStatus,\n} from \"./types\";\nimport { createOfframpDeposit, createSdkClient } from \"./deposit\";\nimport {\n getPlatforms as getPlatformList,\n getCurrencies as getCurrencyList,\n validateIdentifier as validateId,\n getPaymentMethodHashes as getPaymentMethodHashesForPlatform,\n getPlatformConfig,\n} from \"./platforms\";\nimport {\n API_BASE_URL,\n DELEGATE_RATE_MANAGER_ID,\n ESCROW_ADDRESS,\n RATE_MANAGER_REGISTRY_ADDRESS,\n REFERRER,\n} from \"./config\";\n\n/* ── Indexer client (read-only, no wallet needed) ─────────────────── */\n\nlet indexerClient: IndexerDepositService | null = null;\n\nfunction getIndexerService(): IndexerDepositService {\n if (!indexerClient) {\n const client = new IndexerClient(`${API_BASE_URL.replace(/\\/+$/, \"\")}`);\n indexerClient = new IndexerDepositService(client);\n }\n return indexerClient;\n}\n\n/* ── Helpers ──────────────────────────────────────────────────────── */\n\ntype IndexerDeposit = {\n id: string;\n depositId: string;\n txHash?: string;\n status: string;\n remainingDeposits: string | null;\n outstandingIntentAmount: string | null;\n totalAmountTaken: string | null;\n fulfilledIntents: number | null;\n escrowAddress: string;\n rateManagerId?: string | null;\n rateManagerAddress?: string | null;\n paymentMethods: Array<{ paymentMethodHash: string }>;\n currencies: Array<{ currencyCode: string; rateSource?: string | null }>;\n};\n\nfunction toBigInt(value: string | null | undefined): bigint {\n try { return BigInt(value || \"0\"); } catch { return 0n; }\n}\n\nfunction toUsdc(value: string | null | undefined): number {\n return Number(formatUnits(toBigInt(value), 6));\n}\n\nfunction resolveStatus(deposit: IndexerDeposit): DepositStatus {\n if (deposit.status === \"CLOSED\") return \"closed\";\n if (toBigInt(deposit.remainingDeposits) === 0n) return \"empty\";\n return \"active\";\n}\n\nfunction resolveMethodNames(\n hashes: Array<{ paymentMethodHash: string }>,\n): string[] {\n const names = new Set<string>();\n for (const { paymentMethodHash } of hashes) {\n const normalized = paymentMethodHash.toLowerCase();\n for (const platform of PLATFORMS) {\n const platformHashes = getPaymentMethodHashesForPlatform(platform);\n if (platformHashes.some((h) => h.toLowerCase() === normalized)) {\n names.add(getPlatformConfig(platform).name);\n break;\n }\n }\n }\n return Array.from(names);\n}\n\nfunction mapDeposit(d: IndexerDeposit): DepositInfo {\n const delegationState = classifyDelegationState(\n d.rateManagerId ?? undefined,\n d.rateManagerAddress ?? undefined,\n DELEGATE_RATE_MANAGER_ID,\n RATE_MANAGER_REGISTRY_ADDRESS,\n );\n return {\n depositId: d.depositId,\n compositeId: d.id,\n txHash: d.txHash,\n status: resolveStatus(d),\n remainingUsdc: toUsdc(d.remainingDeposits),\n outstandingUsdc: toUsdc(d.outstandingIntentAmount),\n totalTakenUsdc: toUsdc(d.totalAmountTaken),\n fulfilledIntents: d.fulfilledIntents ?? 0,\n paymentMethods: resolveMethodNames(d.paymentMethods),\n currencies: d.currencies.map((c) => {\n const info = getCurrencyInfoFromHash(c.currencyCode);\n return info?.currencyCode ?? c.currencyCode;\n }),\n rateSource: d.currencies[0]?.rateSource || \"unknown\",\n delegated: delegationState === \"delegated_here\",\n escrowAddress: d.escrowAddress,\n };\n}\n\nfunction extractTxHash(result: unknown): string {\n if (typeof result === \"string\") return result;\n if (result && typeof result === \"object\" && \"hash\" in result) return (result as { hash: string }).hash;\n if (result && typeof result === \"object\" && \"transactionHash\" in result) return (result as { transactionHash: string }).transactionHash;\n throw new Error(\"Unexpected transaction result format\");\n}\n\n/* ── Offramp class ────────────────────────────────────────────────── */\n\nexport class Offramp {\n /**\n * Create an offramp deposit: approve USDC, register payee, create deposit,\n * confirm on-chain, and delegate to the vault. All in one call.\n *\n * @param walletClient - viem WalletClient with an account\n * @param params - Deposit parameters (amount, platform, currency, identifier)\n * @param onProgress - Optional callback for step-by-step progress updates\n */\n async createDeposit(\n walletClient: WalletClient,\n params: OfframpParams,\n onProgress?: OnProgress,\n ): Promise<OfframpResult> {\n return createOfframpDeposit(walletClient, params, onProgress);\n }\n\n /**\n * Fetch all deposits for a wallet address. Read-only, no wallet needed.\n * Returns active, empty, and closed deposits sorted by status then recency.\n */\n async getDeposits(walletAddress: string): Promise<DepositInfo[]> {\n const service = getIndexerService();\n const raw = await service.fetchDepositsWithRelations(\n { depositor: walletAddress as `0x${string}` },\n { limit: 100 },\n ) as IndexerDeposit[];\n\n const statusOrder: Record<DepositStatus, number> = { active: 0, empty: 1, closed: 2 };\n\n return (raw || [])\n .map(mapDeposit)\n .sort((a, b) => {\n const diff = statusOrder[a.status] - statusOrder[b.status];\n if (diff !== 0) return diff;\n return Number(BigInt(b.depositId) - BigInt(a.depositId));\n });\n }\n\n /**\n * Find a deposit by its transaction hash. Useful for recovering from\n * CONFIRMATION_FAILED errors where you have a txHash but no depositId.\n *\n * @param walletAddress - The depositor's wallet address\n * @param txHash - The transaction hash from createDeposit\n */\n async getDepositByTxHash(walletAddress: string, txHash: string): Promise<DepositInfo | null> {\n const deposits = await this.getDeposits(walletAddress);\n const normalized = txHash.toLowerCase();\n return deposits.find((d) => d.txHash?.toLowerCase() === normalized) ?? null;\n }\n\n /**\n * Delegate an existing deposit to the Delegate vault. Use this to:\n * - Retry after a DELEGATION_FAILED error\n * - Delegate a deposit created outside the SDK\n * - Delegate a deposit created via usdctofiat.xyz\n *\n * @param walletClient - viem WalletClient with the deposit owner's account\n * @param depositId - The numeric deposit ID (not the composite escrow_id format)\n */\n async delegateDeposit(\n walletClient: WalletClient,\n depositId: string,\n escrowAddress?: string,\n ): Promise<string> {\n const client = createSdkClient(walletClient);\n const result = await client.setRateManager({\n depositId: BigInt(depositId),\n rateManagerAddress: RATE_MANAGER_REGISTRY_ADDRESS,\n rateManagerId: DELEGATE_RATE_MANAGER_ID,\n escrowAddress: (escrowAddress || ESCROW_ADDRESS) as `0x${string}`,\n txOverrides: { referrer: [REFERRER] },\n });\n return extractTxHash(result);\n }\n\n /**\n * Withdraw remaining USDC and close a deposit.\n *\n * @param walletClient - viem WalletClient with the deposit owner's account\n * @param depositId - The numeric deposit ID (not the composite escrow_id format)\n */\n async withdrawDeposit(\n walletClient: WalletClient,\n depositId: string,\n escrowAddress?: string,\n ): Promise<string> {\n const client = createSdkClient(walletClient);\n const result = await client.withdrawDeposit({\n depositId: BigInt(depositId),\n escrowAddress: (escrowAddress || ESCROW_ADDRESS) as `0x${string}`,\n txOverrides: { referrer: [REFERRER] },\n });\n return extractTxHash(result);\n }\n\n /** List available payment platforms with currencies, labels, and format requirements. */\n getPlatforms(): PlatformInfo[] {\n return getPlatformList();\n }\n\n /** Get supported currencies for a specific platform. */\n getCurrencies(platform: Platform): string[] {\n return getCurrencyList(platform);\n }\n\n /**\n * Get currency metadata for UI rendering.\n * @returns Symbol (€), full name (Euro), and country code (eu), or null if unsupported.\n */\n getCurrencyInfo(code: string): CurrencyInfo | null {\n const info = (currencyInfo as Record<string, { currencyCode?: string; currencyName?: string; currencySymbol?: string; countryCode?: string }>)[code];\n if (!info) return null;\n return {\n code: info.currencyCode ?? code,\n name: info.currencyName ?? code,\n symbol: info.currencySymbol ?? code,\n countryCode: info.countryCode ?? \"\",\n };\n }\n\n /** Get all supported currencies with metadata. */\n getAllCurrencies(): CurrencyInfo[] {\n return Object.keys(currencyInfo as Record<string, unknown>).map((code) => {\n return this.getCurrencyInfo(code)!;\n }).filter(Boolean);\n }\n\n /**\n * Validate and normalize a payment identifier for a platform.\n * Strips leading @/$ characters, validates format (email, IBAN, etc).\n */\n validateIdentifier(platform: Platform, identifier: string): {\n valid: boolean;\n normalized: string;\n error?: string;\n } {\n return validateId(platform, identifier);\n }\n}\n","export const PLATFORMS = [\n \"venmo\", \"cashapp\", \"chime\", \"revolut\", \"wise\",\n \"mercadopago\", \"zelle\", \"paypal\", \"monzo\", \"n26\",\n] as const;\n\nexport type Platform = (typeof PLATFORMS)[number];\n\n/** Constant map for platform autocomplete: `PAYMENT_PLATFORMS.REVOLUT` */\nexport const PAYMENT_PLATFORMS = {\n VENMO: \"venmo\",\n CASHAPP: \"cashapp\",\n CHIME: \"chime\",\n REVOLUT: \"revolut\",\n WISE: \"wise\",\n MERCADO_PAGO: \"mercadopago\",\n ZELLE: \"zelle\",\n PAYPAL: \"paypal\",\n MONZO: \"monzo\",\n N26: \"n26\",\n} as const satisfies Record<string, Platform>;\n\nexport const SUPPORTED_CURRENCIES = [\n \"AED\", \"ARS\", \"AUD\", \"BRL\", \"CAD\", \"CHF\", \"CLP\", \"CNY\", \"COP\",\n \"CZK\", \"DKK\", \"EUR\", \"GBP\", \"HKD\", \"HUF\", \"IDR\", \"ILS\", \"INR\",\n \"JPY\", \"KES\", \"KRW\", \"MXN\", \"MYR\", \"NOK\", \"NZD\", \"PEN\", \"PHP\",\n \"PLN\", \"RON\", \"SAR\", \"SEK\", \"SGD\", \"THB\", \"TRY\", \"TWD\", \"UGX\",\n \"USD\", \"VND\", \"ZAR\",\n] as const;\n\nexport type Currency = (typeof SUPPORTED_CURRENCIES)[number];\n\n/** Constant map for currency autocomplete: `CURRENCIES.EUR` */\nexport const CURRENCIES = {\n AED: \"AED\", ARS: \"ARS\", AUD: \"AUD\", BRL: \"BRL\", CAD: \"CAD\",\n CHF: \"CHF\", CLP: \"CLP\", CNY: \"CNY\", COP: \"COP\", CZK: \"CZK\",\n DKK: \"DKK\", EUR: \"EUR\", GBP: \"GBP\", HKD: \"HKD\", HUF: \"HUF\",\n IDR: \"IDR\", ILS: \"ILS\", INR: \"INR\", JPY: \"JPY\", KES: \"KES\",\n KRW: \"KRW\", MXN: \"MXN\", MYR: \"MYR\", NOK: \"NOK\", NZD: \"NZD\",\n PEN: \"PEN\", PHP: \"PHP\", PLN: \"PLN\", RON: \"RON\", SAR: \"SAR\",\n SEK: \"SEK\", SGD: \"SGD\", THB: \"THB\", TRY: \"TRY\", TWD: \"TWD\",\n UGX: \"UGX\", USD: \"USD\", VND: \"VND\", ZAR: \"ZAR\",\n} as const satisfies Record<string, Currency>;\n\nexport interface OfframpParams {\n amount: string;\n platform: Platform;\n currency: Currency;\n identifier: string;\n}\n\nexport interface OfframpResult {\n depositId: string;\n txHash: string;\n}\n\nexport type OfframpStep =\n | \"approving\"\n | \"registering\"\n | \"depositing\"\n | \"confirming\"\n | \"delegating\"\n | \"done\";\n\nexport interface OfframpProgress {\n step: OfframpStep;\n txHash?: string;\n depositId?: string;\n}\n\nexport type OnProgress = (progress: OfframpProgress) => void;\n\nexport interface PlatformInfo {\n id: Platform;\n name: string;\n currencies: Currency[];\n identifierLabel: string;\n identifierPlaceholder: string;\n helperText: string;\n}\n\nexport interface CurrencyInfo {\n code: string;\n name: string;\n symbol: string;\n countryCode: string;\n}\n\nexport type DepositStatus = \"active\" | \"empty\" | \"closed\";\n\nexport interface DepositInfo {\n /** Numeric deposit ID. Pass this to delegateDeposit/withdrawDeposit. */\n depositId: string;\n /** Composite ID (escrowAddress_depositId). For indexer queries. */\n compositeId: string;\n /** Transaction hash of the deposit creation. */\n txHash?: string;\n status: DepositStatus;\n remainingUsdc: number;\n outstandingUsdc: number;\n totalTakenUsdc: number;\n fulfilledIntents: number;\n paymentMethods: string[];\n currencies: string[];\n rateSource: string;\n delegated: boolean;\n escrowAddress: string;\n}\n","import type { WalletClient } from \"viem\";\nimport { createPublicClient, decodeEventLog, formatUnits, http, parseUnits, type Hex } from \"viem\";\nimport { base } from \"viem/chains\";\nimport {\n OfframpClient,\n getSpreadOracleConfig,\n mapConversionRatesToOnchainMinRate,\n type CurrencyType,\n} from \"@zkp2p/sdk\";\n\nimport {\n API_BASE_URL,\n BASE_CHAIN_ID,\n BASE_RPC_URL,\n DELEGATE_RATE_MANAGER_ID,\n ESCROW_ADDRESS,\n GATING_SERVICE_ADDRESS,\n INDEXER_INITIAL_DELAY_MS,\n INDEXER_MAX_ATTEMPTS,\n INDEXER_MAX_DELAY_MS,\n MIN_DEPOSIT_USDC,\n MIN_ORDER_USDC,\n PAYEE_REGISTRATION_TIMEOUT_MS,\n RATE_MANAGER_REGISTRY_ADDRESS,\n REFERRER,\n RUNTIME_ENV,\n USDC_ADDRESS,\n} from \"./config\";\nimport {\n buildDepositData,\n getPaymentMethodHash,\n isSupportedCurrency,\n validateIdentifier,\n} from \"./platforms\";\nimport { OfframpError, isUserCancellation } from \"./errors\";\nimport type { OfframpParams, OfframpResult, OnProgress } from \"./types\";\n\n/* ── Helpers ──────────────────────────────────────────────────────── */\n\nfunction usdcToUnits(amount: string): bigint {\n return parseUnits(amount, 6);\n}\n\nconst DEPOSIT_RECEIVED_ABI = [\n {\n type: \"event\" as const,\n name: \"DepositReceived\" as const,\n inputs: [\n { indexed: true, name: \"depositId\", type: \"uint256\" },\n { indexed: true, name: \"depositor\", type: \"address\" },\n { indexed: true, name: \"token\", type: \"address\" },\n { indexed: false, name: \"amount\", type: \"uint256\" },\n { indexed: false, name: \"intentAmountRange\", type: \"tuple\", components: [\n { name: \"min\", type: \"uint256\" }, { name: \"max\", type: \"uint256\" },\n ] },\n { indexed: false, name: \"delegate\", type: \"address\" },\n { indexed: false, name: \"intentGuardian\", type: \"address\" },\n ],\n },\n] as const;\n\nfunction extractDepositIdFromLogs(logs: Array<{ topics?: Hex[]; data?: Hex }>): string | null {\n for (const log of logs) {\n if (!log?.topics?.length || !log.data) continue;\n try {\n const decoded = decodeEventLog({\n abi: DEPOSIT_RECEIVED_ABI,\n data: log.data,\n topics: log.topics as [Hex, ...Hex[]],\n });\n if (decoded.eventName !== \"DepositReceived\") continue;\n const args = decoded.args as { depositId?: bigint };\n if (typeof args.depositId === \"bigint\") return args.depositId.toString();\n } catch { continue; }\n }\n return null;\n}\n\nasync function registerPayeeDetails(\n processorName: string,\n depositData: Record<string, string>,\n): Promise<string> {\n const controller = new AbortController();\n const timeout = setTimeout(() => controller.abort(), PAYEE_REGISTRATION_TIMEOUT_MS);\n try {\n const res = await fetch(`${API_BASE_URL}/v1/makers/create`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ processorName, depositData }),\n signal: controller.signal,\n });\n if (!res.ok) {\n const txt = await res.text().catch(() => \"\");\n throw new Error(`makers/create failed (${res.status}): ${txt || res.statusText}`);\n }\n const json = await res.json() as { success: boolean; message: string; responseObject?: { hashedOnchainId: string } };\n if (!json.success || !json.responseObject?.hashedOnchainId) {\n throw new Error(json.message || \"makers/create returned no hashedOnchainId\");\n }\n return json.responseObject.hashedOnchainId;\n } finally {\n clearTimeout(timeout);\n }\n}\n\ntype OnchainCurrencyEntry = {\n code: `0x${string}`;\n minConversionRate: bigint;\n oracleRateConfig?: {\n adapter: `0x${string}`;\n adapterConfig: `0x${string}`;\n spreadBps: number;\n maxStaleness: number;\n };\n};\n\nfunction attachOracleConfig(\n entries: Array<Array<{ code: `0x${string}`; minConversionRate: bigint }>>,\n conversionRates: Array<Array<{ currency: CurrencyType; conversionRate: string }>>,\n): OnchainCurrencyEntry[][] {\n return entries.map((group, gi) =>\n group.map((entry, ci) => {\n const currency = conversionRates[gi]?.[ci]?.currency;\n if (!currency) return entry;\n const oracleConfig = getSpreadOracleConfig(currency);\n if (!oracleConfig) return entry;\n return {\n ...entry,\n oracleRateConfig: {\n adapter: oracleConfig.adapter,\n adapterConfig: oracleConfig.adapterConfig,\n spreadBps: 0,\n maxStaleness: oracleConfig.maxStaleness,\n },\n };\n }),\n );\n}\n\n/* ── SDK client factory ───────────────────────────────────────────── */\n\nexport function createSdkClient(walletClient: WalletClient): OfframpClient {\n return new OfframpClient({\n walletClient,\n chainId: BASE_CHAIN_ID,\n runtimeEnv: RUNTIME_ENV,\n rpcUrl: BASE_RPC_URL,\n baseApiUrl: API_BASE_URL,\n });\n}\n\n/* ── Main deposit flow ────────────────────────────────────────────── */\n\nexport async function createOfframpDeposit(\n walletClient: WalletClient,\n params: OfframpParams,\n onProgress?: OnProgress,\n): Promise<OfframpResult> {\n const { amount, platform, currency, identifier } = params;\n\n // 1. Validate\n const amt = parseFloat(amount);\n if (!Number.isFinite(amt) || amt < MIN_DEPOSIT_USDC) {\n throw new OfframpError(`Minimum deposit is ${MIN_DEPOSIT_USDC} USDC`, \"VALIDATION\");\n }\n\n if (!isSupportedCurrency(platform, currency)) {\n throw new OfframpError(`${currency} is not supported on ${platform}`, \"UNSUPPORTED\");\n }\n\n const validation = validateIdentifier(platform, identifier);\n if (!validation.valid) {\n throw new OfframpError(validation.error || \"Invalid identifier\", \"VALIDATION\");\n }\n const normalizedIdentifier = validation.normalized;\n\n const methodHash = getPaymentMethodHash(platform);\n if (!methodHash) {\n throw new OfframpError(`${platform} is not currently supported`, \"UNSUPPORTED\");\n }\n\n if (!walletClient.account?.address) {\n throw new OfframpError(\"Wallet client has no account. Connect a wallet first.\", \"VALIDATION\");\n }\n const walletAddress = walletClient.account.address;\n\n // Truncate to 6 decimals (USDC precision)\n const truncatedAmount = amt.toFixed(6).replace(/\\.?0+$/, \"\");\n const amountUnits = usdcToUnits(truncatedAmount);\n const minUnits = usdcToUnits(String(MIN_ORDER_USDC));\n const maxUnits = usdcToUnits(String(Math.min(amt, 2500)));\n\n // Pre-flight: check USDC balance\n try {\n const publicClient = createPublicClient({ chain: base, transport: http(BASE_RPC_URL) });\n const balance = await publicClient.readContract({\n address: USDC_ADDRESS,\n abi: [{ name: \"balanceOf\", type: \"function\", stateMutability: \"view\", inputs: [{ name: \"account\", type: \"address\" }], outputs: [{ name: \"\", type: \"uint256\" }] }] as const,\n functionName: \"balanceOf\",\n args: [walletAddress],\n });\n if (balance < amountUnits) {\n const available = Number(formatUnits(balance, 6));\n throw new OfframpError(\n `Insufficient USDC balance. Have ${available.toFixed(2)}, need ${truncatedAmount}.`,\n \"VALIDATION\",\n );\n }\n } catch (err) {\n if (err instanceof OfframpError) throw err;\n // If balance check fails (RPC issue), proceed anyway -- the tx will revert if insufficient\n }\n\n const client = createSdkClient(walletClient);\n const txOverrides = { referrer: [REFERRER] };\n\n // 2. Approve\n onProgress?.({ step: \"approving\" });\n try {\n await client.ensureAllowance({\n token: USDC_ADDRESS,\n amount: amountUnits,\n escrowAddress: ESCROW_ADDRESS,\n maxApprove: false,\n txOverrides,\n });\n } catch (err) {\n if (isUserCancellation(err)) throw new OfframpError(\"User cancelled\", \"USER_CANCELLED\", \"approving\", err);\n const detail = err instanceof Error ? err.message : String(err);\n throw new OfframpError(`USDC approval failed: ${detail}`, \"APPROVAL_FAILED\", \"approving\", err);\n }\n\n // 3. Register payee\n onProgress?.({ step: \"registering\" });\n let hashedOnchainId: string;\n try {\n const canonicalName = platform.startsWith(\"zelle\") ? \"zelle\" : platform;\n const depositData = buildDepositData(platform, normalizedIdentifier);\n hashedOnchainId = await registerPayeeDetails(canonicalName, depositData);\n } catch (err) {\n throw new OfframpError(\"Payee registration failed\", \"REGISTRATION_FAILED\", \"registering\", err);\n }\n\n // 4. Create deposit\n onProgress?.({ step: \"depositing\" });\n\n // 1 wei floor -- vault manages actual rates via oracle\n const conversionRates: Array<Array<{ currency: CurrencyType; conversionRate: string }>> = [\n [{ currency: currency as CurrencyType, conversionRate: \"1\" }],\n ];\n\n const baseCurrenciesOverride = mapConversionRatesToOnchainMinRate(conversionRates, 1);\n const currenciesOverride = attachOracleConfig(baseCurrenciesOverride, conversionRates);\n\n let hash: `0x${string}`;\n try {\n const result = await client.createDeposit({\n token: USDC_ADDRESS,\n amount: amountUnits,\n retainOnEmpty: false,\n intentAmountRange: { min: minUnits, max: maxUnits },\n processorNames: [platform],\n depositData: [buildDepositData(platform, normalizedIdentifier)],\n conversionRates,\n paymentMethodsOverride: [methodHash],\n paymentMethodDataOverride: [{\n intentGatingService: GATING_SERVICE_ADDRESS,\n payeeDetails: hashedOnchainId as `0x${string}`,\n data: \"0x\" as `0x${string}`,\n }],\n currenciesOverride,\n escrowAddress: ESCROW_ADDRESS,\n txOverrides,\n });\n if (!result?.hash) throw new Error(\"No transaction hash returned\");\n hash = result.hash;\n } catch (err) {\n if (isUserCancellation(err)) throw new OfframpError(\"User cancelled\", \"USER_CANCELLED\", \"depositing\", err);\n const detail = err instanceof Error ? err.message : String(err);\n throw new OfframpError(`Deposit transaction failed: ${detail}`, \"DEPOSIT_FAILED\", \"depositing\", err);\n }\n\n // 5. Confirm\n onProgress?.({ step: \"confirming\", txHash: hash });\n let depositId = \"\";\n\n const receiptClient = client as { waitForTransactionReceipt?: (p: { hash: `0x${string}`; confirmations?: number }) => Promise<{ logs: Array<{ topics?: Hex[]; data?: Hex }> }> };\n if (typeof receiptClient.waitForTransactionReceipt === \"function\") {\n try {\n const receipt = await receiptClient.waitForTransactionReceipt({ hash, confirmations: 1 });\n depositId = extractDepositIdFromLogs(receipt.logs) || \"\";\n } catch { /* fall through to indexer */ }\n }\n\n if (!depositId) {\n {\n let delay = INDEXER_INITIAL_DELAY_MS;\n for (let attempt = 0; attempt < INDEXER_MAX_ATTEMPTS && !depositId; attempt++) {\n try {\n const deposits = await client.indexer.getDepositsWithRelations(\n { depositor: walletAddress },\n { limit: 25 },\n ) as Array<{ txHash?: string; depositId: string }>;\n const hit = deposits.find((d) => (d?.txHash || \"\").toLowerCase() === hash.toLowerCase());\n if (hit) {\n depositId = String(hit.depositId);\n break;\n }\n } catch { /* continue */ }\n await new Promise((r) => setTimeout(r, delay));\n delay = Math.min(INDEXER_MAX_DELAY_MS, Math.floor(delay * 1.7));\n }\n }\n }\n\n if (!depositId) {\n throw new OfframpError(\n \"Deposit created on-chain but could not confirm deposit ID. Your funds are safe. Use the transaction hash to locate your deposit.\",\n \"CONFIRMATION_FAILED\",\n \"confirming\",\n undefined,\n { txHash: hash },\n );\n }\n\n // 6. Delegate\n onProgress?.({ step: \"delegating\", txHash: hash, depositId });\n try {\n await client.setRateManager({\n depositId: BigInt(depositId),\n rateManagerAddress: RATE_MANAGER_REGISTRY_ADDRESS,\n rateManagerId: DELEGATE_RATE_MANAGER_ID,\n escrowAddress: ESCROW_ADDRESS,\n txOverrides,\n });\n } catch (delegationError) {\n if (isUserCancellation(delegationError)) {\n throw new OfframpError(\"User cancelled delegation\", \"USER_CANCELLED\", \"delegating\", delegationError, { txHash: hash, depositId });\n }\n throw new OfframpError(\n \"Deposit created but delegation failed. Visit usdctofiat.xyz to manage your deposit manually.\",\n \"DELEGATION_FAILED\",\n \"delegating\",\n delegationError,\n { txHash: hash, depositId },\n );\n }\n\n onProgress?.({ step: \"done\", txHash: hash, depositId });\n return { depositId, txHash: hash };\n}\n","import { getContracts, getGatingServiceAddress } from \"@zkp2p/sdk\";\n\nexport const BASE_CHAIN_ID = 8453;\nexport const RUNTIME_ENV = \"production\" as const;\nexport const API_BASE_URL = \"https://api.zkp2p.xyz\";\nexport const BASE_RPC_URL = \"https://mainnet.base.org\";\n\nconst contracts = getContracts(BASE_CHAIN_ID, RUNTIME_ENV);\nconst addresses = contracts.addresses;\n\nconst addrs = addresses as unknown as Record<string, string>;\nexport const USDC_ADDRESS = (addrs.token || \"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913\") as `0x${string}`;\nexport const ESCROW_ADDRESS = (addrs.escrowV2 || addrs.escrow || \"\") as `0x${string}`;\nexport const GATING_SERVICE_ADDRESS = getGatingServiceAddress(BASE_CHAIN_ID, RUNTIME_ENV) as `0x${string}`;\n\nexport const DELEGATE_RATE_MANAGER_ID =\n \"0x8666d6fb0f6797c56e95339fd7ca82fdd348b9db200e10a4c4aa0a0b879fc41c\" as `0x${string}`;\nexport const RATE_MANAGER_REGISTRY_ADDRESS =\n \"0xeed7db23e724ac4590d6db6f78fda6db203535f3\" as `0x${string}`;\n\nexport const REFERRER = \"galleonlabs\";\n\nexport const MIN_DEPOSIT_USDC = 1;\nexport const MIN_ORDER_USDC = 1;\nexport const MAX_ORDER_USDC = 2500;\n\nexport const INDEXER_MAX_ATTEMPTS = 12;\nexport const INDEXER_INITIAL_DELAY_MS = 1000;\nexport const INDEXER_MAX_DELAY_MS = 10_000;\n\nexport const PAYEE_REGISTRATION_TIMEOUT_MS = 8000;\n","import {\n currencyInfo,\n getCurrencyInfoFromHash,\n getPaymentMethodsCatalog,\n resolvePaymentMethodHash,\n} from \"@zkp2p/sdk\";\nimport { z } from \"zod\";\nimport { BASE_CHAIN_ID, RUNTIME_ENV } from \"./config\";\nimport type { Currency, Platform, PlatformInfo } from \"./types\";\nimport { PLATFORMS } from \"./types\";\n\ntype CurrencyCode = keyof typeof currencyInfo;\n\nconst ZELLE_HASH_LOOKUP_NAMES = [\"zelle\", \"zelle-bofa\", \"zelle-chase\", \"zelle-citi\"] as const;\ntype PaymentMethodLookupName = Platform | (typeof ZELLE_HASH_LOOKUP_NAMES)[number];\n\ninterface PlatformConfig {\n id: Platform;\n name: string;\n identifierLabel: string;\n placeholder: string;\n helperText: string;\n currencies: string[];\n validation: z.ZodType<string>;\n transform?: (value: string) => string;\n}\n\ntype CatalogEntry = { currencies?: string[]; paymentMethodHash?: `0x${string}` };\nconst PAYMENT_CATALOG = getPaymentMethodsCatalog(BASE_CHAIN_ID, RUNTIME_ENV) as Record<string, CatalogEntry>;\n\nconst FALLBACK_CURRENCIES: Record<Platform, string[]> = {\n venmo: [\"USD\"],\n cashapp: [\"USD\"],\n chime: [\"USD\"],\n revolut: [\"USD\", \"EUR\", \"GBP\", \"SGD\", \"NZD\", \"AUD\", \"CAD\", \"HKD\", \"MXN\", \"SAR\", \"AED\", \"THB\", \"TRY\", \"PLN\", \"CHF\", \"ZAR\", \"CZK\", \"CNY\", \"DKK\", \"HUF\", \"NOK\", \"RON\", \"SEK\"],\n wise: [\"USD\", \"CNY\", \"EUR\", \"GBP\", \"AUD\", \"NZD\", \"CAD\", \"AED\", \"CHF\", \"ZAR\", \"SGD\", \"ILS\", \"HKD\", \"JPY\", \"PLN\", \"TRY\", \"IDR\", \"KES\", \"MYR\", \"MXN\", \"THB\", \"VND\", \"UGX\", \"CZK\", \"DKK\", \"HUF\", \"INR\", \"NOK\", \"PHP\", \"RON\", \"SEK\"],\n mercadopago: [\"ARS\"],\n zelle: [\"USD\"],\n paypal: [\"USD\", \"EUR\", \"GBP\", \"SGD\", \"NZD\", \"AUD\", \"CAD\"],\n monzo: [\"GBP\"],\n n26: [\"EUR\"],\n};\n\nfunction gatherCatalogHashes(platform: Platform): string[] {\n if (platform === \"zelle\") {\n return Object.entries(PAYMENT_CATALOG)\n .filter(([key]) => key.startsWith(\"zelle\"))\n .flatMap(([, entry]) => entry.currencies ?? []);\n }\n return PAYMENT_CATALOG[platform]?.currencies ?? [];\n}\n\nfunction resolveSupportedCurrencies(platform: Platform): string[] {\n const codes = new Set<string>();\n for (const hash of gatherCatalogHashes(platform)) {\n const info = getCurrencyInfoFromHash(hash);\n if (info?.currencyCode && currencyInfo[info.currencyCode as CurrencyCode]) {\n codes.add(info.currencyCode);\n }\n }\n if (!codes.size) {\n for (const code of FALLBACK_CURRENCIES[platform] ?? []) codes.add(code);\n }\n return Array.from(codes).sort();\n}\n\nconst BLUEPRINT: Record<Platform, Omit<PlatformConfig, \"currencies\">> = {\n venmo: {\n id: \"venmo\", name: \"Venmo\", identifierLabel: \"Username\", placeholder: \"venmo username (no @)\",\n helperText: \"Username without @ (publicly discoverable)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n transform: (v) => v.replace(/^@+/, \"\"),\n },\n cashapp: {\n id: \"cashapp\", name: \"Cash App\", identifierLabel: \"Cashtag\", placeholder: \"cashtag (no $)\",\n helperText: \"Cashtag without $ (publicly discoverable)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9]+$/),\n transform: (v) => v.replace(/^\\$+/, \"\"),\n },\n chime: {\n id: \"chime\", name: \"Chime\", identifierLabel: \"ChimeSign\", placeholder: \"$chimesign\",\n helperText: \"ChimeSign with $ (must be discoverable)\",\n validation: z.string().min(2).regex(/^\\$[a-zA-Z0-9]+$/),\n transform: (v) => {\n const t = v.trim().toLowerCase();\n return t.startsWith(\"$\") ? t : `$${t}`;\n },\n },\n revolut: {\n id: \"revolut\", name: \"Revolut\", identifierLabel: \"Revtag\", placeholder: \"revtag (no @)\",\n helperText: \"Revtag without @ (must be public)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9]+$/),\n transform: (v) => v.replace(/^@+/, \"\").trim(),\n },\n wise: {\n id: \"wise\", name: \"Wise\", identifierLabel: \"Wisetag\", placeholder: \"wisetag (no @)\",\n helperText: \"Your Wise @wisetag (no @)\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n transform: (v) => v.replace(/^@+/, \"\").trim(),\n },\n mercadopago: {\n id: \"mercadopago\", name: \"Mercado Pago\", identifierLabel: \"CVU\", placeholder: \"22-digit CVU\",\n helperText: \"CVU must be exactly 22 digits\",\n validation: z.string().length(22).regex(/^\\d{22}$/),\n },\n zelle: {\n id: \"zelle\", name: \"Zelle\", identifierLabel: \"Email\", placeholder: \"email\",\n helperText: \"Registered Zelle email\",\n validation: z.string().email(),\n },\n paypal: {\n id: \"paypal\", name: \"PayPal\", identifierLabel: \"Email\", placeholder: \"email\",\n helperText: \"Email linked to PayPal account\",\n validation: z.string().email(),\n },\n monzo: {\n id: \"monzo\", name: \"Monzo\", identifierLabel: \"Username\", placeholder: \"monzo.me username\",\n helperText: \"Your Monzo.me username\",\n validation: z.string().min(1).regex(/^[a-zA-Z0-9_-]+$/),\n },\n n26: {\n id: \"n26\", name: \"N26\", identifierLabel: \"IBAN\", placeholder: \"IBAN (e.g. DE89...)\",\n helperText: \"Your IBAN (spaces will be removed)\",\n validation: z.string().min(15).max(34).regex(/^[A-Z]{2}[0-9]{2}[A-Z0-9]+$/i),\n transform: (v) => v.replace(/\\s/g, \"\").toUpperCase(),\n },\n};\n\nconst CONFIGS: Record<Platform, PlatformConfig> = Object.fromEntries(\n Object.entries(BLUEPRINT).map(([p, bp]) => {\n const key = p as Platform;\n return [key, { ...bp, currencies: resolveSupportedCurrencies(key) }];\n }),\n) as Record<Platform, PlatformConfig>;\n\nexport function getPlatformConfig(platform: Platform): PlatformConfig {\n return CONFIGS[platform];\n}\n\nexport function getPlatforms(): PlatformInfo[] {\n return PLATFORMS.map((id) => {\n const cfg = CONFIGS[id];\n return {\n id,\n name: cfg.name,\n currencies: cfg.currencies as Currency[],\n identifierLabel: cfg.identifierLabel,\n identifierPlaceholder: cfg.placeholder,\n helperText: cfg.helperText,\n };\n });\n}\n\nexport function getCurrencies(platform: Platform): string[] {\n return CONFIGS[platform]?.currencies ?? [];\n}\n\nexport function validateIdentifier(\n platform: Platform,\n value: string,\n): { valid: boolean; normalized: string; error?: string } {\n const cfg = CONFIGS[platform];\n if (!cfg) return { valid: false, normalized: value, error: \"Unsupported platform\" };\n const transformed = cfg.transform ? cfg.transform(value) : value;\n const result = cfg.validation.safeParse(transformed);\n if (!result.success) {\n return { valid: false, normalized: transformed, error: result.error.issues[0]?.message || \"Invalid input\" };\n }\n return { valid: true, normalized: transformed };\n}\n\nexport function isSupportedCurrency(platform: Platform, currency: string): boolean {\n return CONFIGS[platform]?.currencies.includes(currency) ?? false;\n}\n\nfunction normalizePaymentMethodLookupName(platform: string): PaymentMethodLookupName | null {\n const normalized = platform.trim().toLowerCase();\n if (!normalized) return null;\n if (ZELLE_HASH_LOOKUP_NAMES.includes(normalized as (typeof ZELLE_HASH_LOOKUP_NAMES)[number])) {\n return normalized as PaymentMethodLookupName;\n }\n return PLATFORMS.includes(normalized as Platform) ? (normalized as Platform) : null;\n}\n\nfunction resolveCanonicalZelleHash(): `0x${string}` | null {\n const direct = PAYMENT_CATALOG.zelle?.paymentMethodHash;\n if (direct) return direct;\n const variant = Object.entries(PAYMENT_CATALOG).find(\n ([name, entry]) => name.startsWith(\"zelle\") && Boolean(entry.paymentMethodHash),\n );\n return variant?.[1]?.paymentMethodHash ?? null;\n}\n\nexport function getPaymentMethodHash(platform: Platform): `0x${string}` | null {\n const name = normalizePaymentMethodLookupName(platform);\n if (!name) return null;\n const catalogEntry = PAYMENT_CATALOG[name];\n if (catalogEntry?.paymentMethodHash) return catalogEntry.paymentMethodHash;\n if (name === \"zelle\" || name.startsWith(\"zelle-\")) return resolveCanonicalZelleHash();\n const sdkHash = resolvePaymentMethodHash(name);\n return sdkHash ? (sdkHash as `0x${string}`) : null;\n}\n\nexport function getPaymentMethodHashes(platform: Platform): `0x${string}`[] {\n if (platform !== \"zelle\") {\n const hash = getPaymentMethodHash(platform);\n return hash ? [hash] : [];\n }\n const hashes = new Set<`0x${string}`>();\n const generic = resolvePaymentMethodHash(\"zelle\") as `0x${string}` | undefined;\n if (generic) hashes.add(generic);\n const canonical = resolveCanonicalZelleHash();\n if (canonical) hashes.add(canonical);\n for (const [name, entry] of Object.entries(PAYMENT_CATALOG)) {\n if (name.startsWith(\"zelle\") && entry.paymentMethodHash) {\n hashes.add(entry.paymentMethodHash);\n }\n }\n return Array.from(hashes);\n}\n\nexport function buildDepositData(\n platform: Platform,\n identifier: string,\n): Record<string, string> {\n switch (platform) {\n case \"venmo\": return { venmoUsername: identifier, telegramUsername: \"\" };\n case \"cashapp\": return { cashtag: identifier, telegramUsername: \"\" };\n case \"chime\": return { chimesign: identifier.toLowerCase(), telegramUsername: \"\" };\n case \"revolut\": return { revolutUsername: identifier, telegramUsername: \"\" };\n case \"wise\": return { wisetag: identifier, telegramUsername: \"\" };\n case \"mercadopago\": return { cvu: identifier, telegramUsername: \"\" };\n case \"zelle\": return { zelleEmail: identifier, telegramUsername: \"\" };\n case \"paypal\": return { paypalEmail: identifier, telegramUsername: \"\" };\n case \"monzo\": return { monzoMeUsername: identifier, telegramUsername: \"\" };\n case \"n26\": return { iban: identifier, telegramUsername: \"\" };\n default: return { identifier, telegramUsername: \"\" };\n }\n}\n","import type { OfframpStep } from \"./types\";\n\nexport type OfframpErrorCode =\n | \"VALIDATION\"\n | \"APPROVAL_FAILED\"\n | \"REGISTRATION_FAILED\"\n | \"DEPOSIT_FAILED\"\n | \"CONFIRMATION_FAILED\"\n | \"DELEGATION_FAILED\"\n | \"USER_CANCELLED\"\n | \"UNSUPPORTED\";\n\nexport class OfframpError extends Error {\n readonly code: OfframpErrorCode;\n readonly step?: OfframpStep;\n override readonly cause?: unknown;\n readonly txHash?: string;\n readonly depositId?: string;\n\n constructor(\n message: string,\n code: OfframpErrorCode,\n step?: OfframpStep,\n cause?: unknown,\n details?: { txHash?: string; depositId?: string },\n ) {\n super(message);\n this.name = \"OfframpError\";\n this.code = code;\n this.step = step;\n this.cause = cause;\n this.txHash = details?.txHash;\n this.depositId = details?.depositId;\n }\n}\n\nexport function isUserCancellation(error: unknown): boolean {\n if (!(error instanceof Error)) return false;\n const msg = error.message.toLowerCase();\n return (\n msg.includes(\"user rejected\") ||\n msg.includes(\"user denied\") ||\n msg.includes(\"user cancelled\") ||\n msg.includes(\"rejected the request\") ||\n msg.includes(\"action_rejected\")\n );\n}\n"],"mappings":"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","names":["import_viem","import_sdk","import_sdk","import_sdk"]}
|