facinet 2.2.2 → 2.4.1
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 +248 -244
- package/dist/browser.js +2773 -27534
- package/dist/browser.js.map +4 -4
- package/dist/commands/connect.d.ts.map +1 -1
- package/dist/commands/connect.js +7 -8
- package/dist/commands/connect.js.map +1 -1
- package/dist/commands/facilitator.d.ts +4 -15
- package/dist/commands/facilitator.d.ts.map +1 -1
- package/dist/commands/facilitator.js +40 -36
- package/dist/commands/facilitator.js.map +1 -1
- package/dist/commands/pay.d.ts +1 -8
- package/dist/commands/pay.d.ts.map +1 -1
- package/dist/commands/pay.js +47 -35
- package/dist/commands/pay.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +659 -92
- package/dist/index.js.map +7 -1
- package/dist/sdk/Facinet.d.ts +21 -5
- package/dist/sdk/Facinet.d.ts.map +1 -1
- package/dist/sdk/Facinet.js +165 -62
- package/dist/sdk/Facinet.js.map +1 -1
- package/dist/sdk/types.d.ts +8 -2
- package/dist/sdk/types.d.ts.map +1 -1
- package/dist/sdk.d.ts +1 -1
- package/dist/sdk.d.ts.map +1 -1
- package/dist/sdk.js +386 -25
- package/dist/sdk.js.map +7 -1
- package/dist/sdk.mjs +140 -45
- package/dist/sdk.mjs.map +2 -2
- package/dist/utils/api.d.ts +18 -13
- package/dist/utils/api.d.ts.map +1 -1
- package/dist/utils/api.js +33 -40
- package/dist/utils/api.js.map +1 -1
- package/dist/utils/config.d.ts +2 -9
- package/dist/utils/config.d.ts.map +1 -1
- package/dist/utils/config.js +0 -1
- package/dist/utils/config.js.map +1 -1
- package/package.json +4 -2
package/dist/index.js.map
CHANGED
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/index.ts", "../src/commands/pay.ts", "../src/utils/config.ts", "../src/utils/api.ts", "../src/commands/facilitator.ts", "../src/commands/connect.ts"],
|
|
4
|
+
"sourcesContent": ["#!/usr/bin/env node\n/**\n * Facinet CLI - x402 Facilitator Network\n *\n * Command-line tool for making payments and managing facilitators\n * on the x402 payment network.\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { payCommand } from './commands/pay';\nimport { facilitatorCommand } from './commands/facilitator';\nimport { connectCommand } from './commands/connect';\n\nconst program = new Command();\n\n// ASCII Art Banner\nconsole.log(\n chalk.cyan(`\n\\u2554\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2557\n\\u2551 \\u2551\n\\u2551 \\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2557 \\u2588\\u2588\\u2588\\u2588\\u2588\\u2557 \\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2557\\u2588\\u2588\\u2557\\u2588\\u2588\\u2588\\u2557 \\u2551\n\\u2551 \\u2588\\u2588\\u2554\\u2550\\u2550\\u2550\\u2550\\u255D\\u2588\\u2588\\u2554\\u2550\\u2550\\u2588\\u2588\\u2557\\u2588\\u2588\\u2554\\u2550\\u2550\\u2550\\u2550\\u255D\\u2588\\u2588\\u2551\\u2588\\u2588\\u2588\\u2588\\u2557 \\u2551\n\\u2551 \\u2588\\u2588\\u2588\\u2588\\u2588\\u2557 \\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2551\\u2588\\u2588\\u2551 \\u2588\\u2588\\u2551\\u2588\\u2588\\u2554\\u2588\\u2588\\u2557 \\u2551\n\\u2551 \\u2588\\u2588\\u2554\\u2550\\u2550\\u255D \\u2588\\u2588\\u2554\\u2550\\u2550\\u2588\\u2588\\u2551\\u2588\\u2588\\u2551 \\u2588\\u2588\\u2551\\u2588\\u2588\\u2551\\u255A\\u2588\\u2588\\u2557\\u2551\n\\u2551 \\u2588\\u2588\\u2551 \\u2588\\u2588\\u2551 \\u2588\\u2588\\u2551\\u255A\\u2588\\u2588\\u2588\\u2588\\u2588\\u2588\\u2557\\u2588\\u2588\\u2551\\u2588\\u2588\\u2551 \\u255A\\u2588\\u2588\\u2551\n\\u2551 \\u255A\\u2550\\u255D \\u255A\\u2550\\u255D \\u255A\\u2550\\u255D \\u255A\\u2550\\u2550\\u2550\\u2550\\u2550\\u255D\\u255A\\u2550\\u255D\\u255A\\u2550\\u255D \\u255A\\u2550\\u2551\n\\u2551 \\u2551\n\\u2551 x402 Facilitator Network CLI \\u2551\n\\u2551 \\u2551\n\\u255A\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u2550\\u255D\n`)\n);\n\nprogram\n .name('facinet')\n .description('CLI tool for x402 Facilitator Network')\n .version('2.4.0');\n\n// Connect wallet command\nprogram\n .command('connect')\n .description('Connect your wallet to Facinet')\n .action(connectCommand);\n\n// Pay command\nprogram\n .command('pay')\n .description('Make a payment via x402 facilitator network')\n .option('-a, --amount <amount>', 'Payment amount in USDC', '1')\n .option('-t, --to <address>', 'Recipient address')\n .option('-c, --chain <chain>', 'Blockchain network (avalanche, ethereum, base, polygon)', 'avalanche')\n .option('-n, --network <url>', 'Custom network URL')\n .action(payCommand);\n\n// Facilitator commands\nconst facilitator = program\n .command('facilitator')\n .alias('fac')\n .description('Manage facilitators');\n\nfacilitator\n .command('create')\n .description('Create a new facilitator')\n .option('-n, --name <name>', 'Facilitator name')\n .option('-r, --recipient <address>', 'Payment recipient address')\n .option(\n '-u, --url <url>',\n 'API URL',\n 'https://x402-avalanche-chi.vercel.app'\n )\n .action(facilitatorCommand.create);\n\nfacilitator\n .command('list')\n .description('List all active facilitators')\n .option(\n '-u, --url <url>',\n 'API URL',\n 'https://x402-avalanche-chi.vercel.app'\n )\n .action(facilitatorCommand.list);\n\nfacilitator\n .command('status <id>')\n .description('Check facilitator status')\n .option(\n '-u, --url <url>',\n 'API URL',\n 'https://x402-avalanche-chi.vercel.app'\n )\n .action(facilitatorCommand.status);\n\nfacilitator\n .command('balance <id>')\n .description('Check facilitator gas balance')\n .option(\n '-u, --url <url>',\n 'API URL',\n 'https://x402-avalanche-chi.vercel.app'\n )\n .action(facilitatorCommand.balance);\n\n// Help command\nprogram.on('--help', () => {\n console.log('');\n console.log(chalk.cyan('Examples:'));\n console.log('');\n console.log(' $ facinet connect');\n console.log(' $ facinet pay --amount 1 --to 0x123... --chain base');\n console.log(' $ facinet facilitator create --name \"MyNode\"');\n console.log(' $ facinet facilitator list');\n console.log(' $ facinet facilitator status fac_xyz123');\n console.log('');\n console.log(chalk.cyan('Supported Chains:'));\n console.log(' avalanche - Avalanche Fuji (Testnet)');\n console.log(' ethereum - Ethereum Sepolia (Testnet)');\n console.log(' base - Base Sepolia (Testnet)');\n console.log(' polygon - Polygon Amoy (Testnet)');\n console.log('');\n});\n\nprogram.parse(process.argv);\n\nif (!process.argv.slice(2).length) {\n program.outputHelp();\n}\n", "/**\n * Pay Command\n *\n * Make a payment via x402 facilitator network\n */\n\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { Wallet, JsonRpcProvider } from 'ethers';\nimport { getConfig } from '../utils/config';\nimport { selectRandomFacilitator } from '../utils/api';\n\nconst CHAINS: Record<string, any> = {\n avalanche: {\n name: 'Avalanche Fuji',\n rpcUrl: 'https://api.avax-test.network/ext/bc/C/rpc',\n usdcAddress: '0x5425890298aed601595a70AB815c96711a31Bc65',\n chainId: 43113,\n apiUrl: 'https://x402-avalanche-chi.vercel.app',\n },\n ethereum: {\n name: 'Ethereum Sepolia',\n rpcUrl: 'https://ethereum-sepolia-rpc.publicnode.com',\n usdcAddress: '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238',\n chainId: 11155111,\n apiUrl: 'https://x402-ethereum-chi.vercel.app',\n },\n base: {\n name: 'Base Sepolia',\n rpcUrl: 'https://sepolia.base.org',\n usdcAddress: '0x036CbD53842c5426634e7929541eC2318f3dCF7e',\n chainId: 84532,\n apiUrl: 'https://x402-base-chi.vercel.app',\n },\n polygon: {\n name: 'Polygon Amoy',\n rpcUrl: 'https://rpc-amoy.polygon.technology',\n usdcAddress: '0x41E94Eb019C0762f9Bfcf9Fb1E58725BfB0e7582',\n chainId: 80002,\n apiUrl: 'https://x402-polygon-chi.vercel.app',\n },\n};\n\nexport async function payCommand(options: any) {\n console.log(chalk.cyan('\\n\\uD83D\\uDCB3 Make Payment via x402 Network\\n'));\n\n const config = getConfig();\n if (!config.privateKey) {\n console.log(chalk.red('\\u274C No wallet connected. Run `facinet connect` first.'));\n process.exit(1);\n }\n\n let recipient = options.to;\n if (!recipient) {\n const answer = await inquirer.prompt([\n {\n type: 'input',\n name: 'recipient',\n message: 'Recipient address:',\n validate: (input: string) => {\n if (!input.match(/^0x[a-fA-F0-9]{40}$/)) {\n return 'Invalid Ethereum address';\n }\n return true;\n },\n },\n ]);\n recipient = answer.recipient;\n }\n\n const chain = CHAINS[options.chain];\n if (!chain) {\n console.log(chalk.red(`\\u274C Unsupported chain: ${options.chain}. Supported: ${Object.keys(CHAINS).join(', ')}`));\n process.exit(1);\n }\n\n console.log(chalk.gray(`\\n\\uD83D\\uDCCA Payment Details:`));\n console.log(chalk.gray(` Amount: ${options.amount} USDC`));\n console.log(chalk.gray(` To: ${recipient}`));\n console.log(chalk.gray(` Chain: ${chain.name}`));\n console.log(chalk.gray(` Your Address: ${config.address}\\n`));\n\n const { confirm } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message: 'Proceed with payment?',\n default: true,\n },\n ]);\n\n if (!confirm) {\n console.log(chalk.yellow('Payment cancelled.'));\n process.exit(0);\n }\n\n let spinner = ora('Selecting random facilitator...').start();\n\n try {\n // Use network-specific API URL\n const apiUrl = config.apiUrl || chain.apiUrl || 'https://x402-avalanche-chi.vercel.app';\n const facilitator = await selectRandomFacilitator(apiUrl, chain.chainId);\n spinner.succeed(`Selected facilitator: ${chalk.green(facilitator.name || facilitator.id)}`);\n\n spinner = ora('Preparing transaction...').start();\n const wallet = new Wallet(config.privateKey);\n const provider = new JsonRpcProvider(chain.rpcUrl);\n const connectedWallet = wallet.connect(provider);\n\n const amount = BigInt(parseFloat(options.amount) * 1000000);\n const validAfter = Math.floor(Date.now() / 1000) - 60;\n const validBefore = validAfter + 3600;\n const nonce =\n '0x' +\n Array.from({ length: 64 }, () =>\n Math.floor(Math.random() * 16).toString(16)\n ).join('');\n\n const domain = {\n name: 'USD Coin',\n version: '2',\n chainId: chain.chainId,\n verifyingContract: chain.usdcAddress,\n };\n\n const types = {\n TransferWithAuthorization: [\n { name: 'from', type: 'address' },\n { name: 'to', type: 'address' },\n { name: 'value', type: 'uint256' },\n { name: 'validAfter', type: 'uint256' },\n { name: 'validBefore', type: 'uint256' },\n { name: 'nonce', type: 'bytes32' },\n ],\n };\n\n const value = {\n from: wallet.address,\n to: recipient,\n value: amount,\n validAfter,\n validBefore,\n nonce,\n };\n\n spinner.text = 'Signing authorization...';\n const signature = await connectedWallet.signTypedData(domain, types, value);\n spinner.succeed('Authorization signed!');\n\n spinner = ora('Submitting to facilitator...').start();\n\n const paymentPayload = {\n signature,\n authorization: {\n from: wallet.address,\n to: recipient,\n value: amount.toString(),\n validAfter: validAfter.toString(),\n validBefore: validBefore.toString(),\n nonce,\n },\n };\n\n const axios = require('axios');\n // Reuse the apiUrl variable defined above\n const response = await axios.post(`${apiUrl}/api/x402/settle-custom`, {\n facilitatorId: facilitator.id,\n paymentPayload,\n });\n\n if (!response.data.success) {\n throw new Error(response.data.error || 'Payment failed');\n }\n\n spinner.succeed('Payment submitted!');\n\n const txHash = response.data.txHash;\n console.log(chalk.green('\\n\\u2705 Payment processed successfully!'));\n console.log(chalk.gray(`\\n\\uD83D\\uDCC4 Payment Details:`));\n console.log(chalk.gray(` Facilitator: ${facilitator.name || facilitator.id}`));\n console.log(chalk.gray(` Facilitator ID: ${facilitator.id}`));\n console.log(chalk.gray(` Amount: ${options.amount} USDC`));\n console.log(chalk.gray(` Recipient: ${recipient}`));\n console.log(chalk.gray(` Chain: ${chain.name} (Chain ID: ${chain.chainId})`));\n console.log(chalk.gray(` Transaction: ${txHash}\\n`));\n\n console.log(chalk.cyan(`\\uD83D\\uDD17 View on explorer: ${chain.name.includes('Avalanche')\n ? `https://testnet.snowtrace.io/tx/${txHash}`\n : chain.name.includes('Base')\n ? `https://sepolia.basescan.org/tx/${txHash}`\n : chain.name.includes('Polygon')\n ? `https://amoy.polygonscan.com/tx/${txHash}`\n : `https://sepolia.etherscan.io/tx/${txHash}`\n }\\n`));\n } catch (error: any) {\n spinner.fail('Payment failed');\n console.log(chalk.red(`\\n\\u274C Error: ${error.message}\\n`));\n process.exit(1);\n }\n}\n", "/**\n * Configuration Management\n *\n * Save and load user configuration\n */\n\nimport fs from 'fs';\nimport path from 'path';\nimport os from 'os';\n\nconst CONFIG_DIR = path.join(os.homedir(), '.facinet');\nconst CONFIG_FILE = path.join(CONFIG_DIR, 'config.json');\n\n/**\n * Get configuration\n */\nexport function getConfig(): Record<string, any> {\n try {\n if (!fs.existsSync(CONFIG_FILE)) {\n return {};\n }\n const data = fs.readFileSync(CONFIG_FILE, 'utf8');\n return JSON.parse(data);\n } catch (error) {\n return {};\n }\n}\n\n/**\n * Save configuration\n */\nexport function saveConfig(config: Record<string, any>): void {\n try {\n if (!fs.existsSync(CONFIG_DIR)) {\n fs.mkdirSync(CONFIG_DIR, { recursive: true });\n }\n const existingConfig = getConfig();\n const newConfig = { ...existingConfig, ...config };\n fs.writeFileSync(CONFIG_FILE, JSON.stringify(newConfig, null, 2), 'utf8');\n } catch (error: any) {\n throw new Error(`Failed to save configuration: ${error.message}`);\n }\n}\n\n/**\n * Clear configuration\n */\nexport function clearConfig(): void {\n try {\n if (fs.existsSync(CONFIG_FILE)) {\n fs.unlinkSync(CONFIG_FILE);\n }\n } catch (error: any) {\n throw new Error(`Failed to clear configuration: ${error.message}`);\n }\n}\n", "/**\n * API Client\n *\n * Interact with x402 backend APIs\n */\n\nimport axios from 'axios';\n\n/**\n * Get all active facilitators\n * @param apiUrl - API URL for the facilitator network\n * @param chainId - Optional chain ID to filter facilitators by network\n */\nexport async function listFacilitators(apiUrl: string, chainId?: number) {\n try {\n const response = await axios.get(`${apiUrl}/api/facilitator/list`, {\n timeout: 10000,\n headers: {\n 'User-Agent': 'Facinet-CLI/2.3.0',\n },\n });\n\n if (response.data.success && Array.isArray(response.data.facilitators)) {\n return response.data.facilitators.filter((f: any) => {\n // Must be active\n if (f.status !== 'active') {\n return false;\n }\n \n // If chainId is provided, filter by it\n if (chainId !== undefined && f.chainId !== undefined) {\n return f.chainId === chainId;\n }\n \n // If facilitator has network property, it should match (handled by SDK)\n return true;\n });\n }\n return [];\n } catch (error: any) {\n throw new Error(\n `Failed to fetch facilitators from ${apiUrl}: ${error.message || error.code || 'Unknown error'}`\n );\n }\n}\n\n/**\n * Select a random active facilitator\n * @param apiUrl - API URL for the facilitator network\n * @param chainId - Optional chain ID to filter facilitators by network\n */\nexport async function selectRandomFacilitator(apiUrl: string, chainId?: number) {\n const facilitators = await listFacilitators(apiUrl, chainId);\n\n if (facilitators.length === 0) {\n const networkInfo = chainId ? ` (Chain ID: ${chainId})` : '';\n throw new Error(\n `No active facilitators available${networkInfo}. API URL: ${apiUrl}`\n );\n }\n\n const randomIndex = Math.floor(Math.random() * facilitators.length);\n const facilitator = facilitators[randomIndex];\n \n // Ensure facilitator has a name\n if (!facilitator.name) {\n facilitator.name = `Facilitator ${facilitator.id?.slice(0, 8) || 'Unknown'}`;\n }\n \n return facilitator;\n}\n\n/**\n * Get facilitator by ID\n */\nexport async function getFacilitatorById(apiUrl: string, id: string) {\n try {\n const response = await axios.get(`${apiUrl}/api/facilitator/list`);\n if (response.data.success) {\n const facilitator = response.data.facilitators.find((f: any) => f.id === id);\n if (!facilitator) {\n throw new Error('Facilitator not found');\n }\n return facilitator;\n }\n throw new Error('Failed to fetch facilitator');\n } catch (error: any) {\n throw new Error(`Failed to get facilitator: ${error.message}`);\n }\n}\n\n/**\n * Get facilitator status\n */\nexport async function getFacilitatorStatus(apiUrl: string, id: string) {\n return getFacilitatorById(apiUrl, id);\n}\n\n/**\n * Get facilitator balance\n */\nexport async function getFacilitatorBalance(apiUrl: string, id: string) {\n try {\n const response = await axios.post(`${apiUrl}/api/facilitator/balance`, {\n facilitatorId: id,\n });\n\n if (response.data.success) {\n return {\n name: response.data.name,\n wallet: response.data.wallet,\n balance: response.data.balance,\n status: response.data.status,\n };\n }\n throw new Error('Failed to fetch balance');\n } catch (error: any) {\n throw new Error(`Failed to get balance: ${error.message}`);\n }\n}\n\n/**\n * Create a new facilitator\n */\nexport async function createFacilitator(apiUrl: string, payload: any) {\n try {\n throw new Error(\n 'Facilitator creation requires payment flow. Please use the web interface at ' +\n apiUrl\n );\n } catch (error: any) {\n throw new Error(`Failed to create facilitator: ${error.message}`);\n }\n}\n\n/**\n * Submit payment to facilitator\n */\nexport async function submitPayment(\n apiUrl: string,\n facilitatorId: string,\n paymentPayload: any\n) {\n try {\n const response = await axios.post(`${apiUrl}/api/x402/settle-custom`, {\n facilitatorId,\n paymentPayload,\n });\n\n if (response.data.success) {\n return {\n txHash: response.data.txHash,\n facilitatorWallet: response.data.facilitatorWallet,\n facilitatorName: response.data.facilitatorName,\n };\n }\n throw new Error('Payment submission failed');\n } catch (error: any) {\n throw new Error(`Failed to submit payment: ${error.message}`);\n }\n}\n", "/**\n * Facilitator Commands\n *\n * Create and manage facilitators\n */\n\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport ora from 'ora';\nimport { Wallet } from 'ethers';\nimport { getConfig } from '../utils/config';\nimport {\n listFacilitators,\n createFacilitator,\n getFacilitatorStatus,\n getFacilitatorBalance,\n} from '../utils/api';\n\n/**\n * Create a new facilitator\n */\nasync function create(options: any) {\n console.log(chalk.cyan('\\n\\uD83D\\uDE80 Create New Facilitator\\n'));\n\n const config = getConfig();\n if (!config.privateKey) {\n console.log(chalk.red('\\u274C No wallet connected. Run `facinet connect` first.'));\n process.exit(1);\n }\n\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'name',\n message: 'Facilitator name:',\n when: !options.name,\n validate: (input: string) => {\n if (input.length < 3 || input.length > 50) {\n return 'Name must be between 3 and 50 characters';\n }\n return true;\n },\n },\n {\n type: 'input',\n name: 'recipient',\n message: 'Payment recipient address:',\n when: !options.recipient,\n default: config.address,\n validate: (input: string) => {\n if (!input.match(/^0x[a-fA-F0-9]{40}$/)) {\n return 'Invalid Ethereum address';\n }\n return true;\n },\n },\n ]);\n\n const name = options.name || answers.name;\n const recipient = options.recipient || answers.recipient;\n\n console.log(chalk.gray(`\\n\\uD83D\\uDCCB Facilitator Details:`));\n console.log(chalk.gray(` Name: ${name}`));\n console.log(chalk.gray(` Recipient: ${recipient}`));\n console.log(chalk.gray(` Creator: ${config.address}\\n`));\n\n const { confirm } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message: 'Create facilitator? (Requires 1 USDC registration fee)',\n default: true,\n },\n ]);\n\n if (!confirm) {\n console.log(chalk.yellow('Cancelled.'));\n process.exit(0);\n }\n\n const spinner = ora('Creating facilitator...').start();\n\n try {\n const wallet = new Wallet(config.privateKey);\n const facilitatorWallet = Wallet.createRandom();\n\n spinner.text = 'Registering facilitator...';\n\n // Note: createFacilitator always throws an error directing users to web interface\n // This is intentional - facilitator creation requires payment flow\n await createFacilitator(options.url, {\n name,\n facilitatorWallet: facilitatorWallet.address,\n facilitatorPrivateKey: facilitatorWallet.privateKey,\n paymentRecipient: recipient,\n createdBy: wallet.address,\n });\n\n // This code won't be reached since createFacilitator throws\n spinner.succeed('Facilitator created!');\n\n console.log(chalk.green('\\n\\u2705 Facilitator created successfully!'));\n console.log(chalk.gray(`\\n\\uD83D\\uDCC4 Details:`));\n console.log(chalk.gray(` Name: ${name}`));\n console.log(chalk.gray(` Wallet: ${facilitatorWallet.address}`));\n console.log(chalk.yellow(`\\n\\u26A0\\uFE0F IMPORTANT: Save facilitator wallet private key!`));\n console.log(chalk.gray(` Private Key: ${facilitatorWallet.privateKey}\\n`));\n\n console.log(chalk.cyan('\\uD83D\\uDCA1 Next steps:'));\n console.log(chalk.gray(` 1. Fund facilitator wallet with gas token`));\n console.log(chalk.gray(` 2. Use the web interface to complete facilitator registration`));\n console.log(chalk.gray(` 3. Check status: facinet facilitator list\\n`));\n } catch (error: any) {\n spinner.fail('Failed to create facilitator');\n console.log(chalk.red(`\\n\\u274C Error: ${error.message}\\n`));\n process.exit(1);\n }\n}\n\n/**\n * List all facilitators\n */\nasync function list(options: any) {\n console.log(chalk.cyan('\\n\\uD83D\\uDCCB Active Facilitators\\n'));\n\n const spinner = ora('Loading facilitators...').start();\n\n try {\n const facilitators = await listFacilitators(options.url);\n spinner.stop();\n\n if (facilitators.length === 0) {\n console.log(chalk.yellow('No active facilitators found.\\n'));\n return;\n }\n\n console.log(chalk.gray(`Found ${facilitators.length} active facilitator(s):\\n`));\n\n facilitators.forEach((fac: any, index: number) => {\n const facilitatorName = fac.name || `Facilitator ${fac.id?.slice(0, 8) || 'Unknown'}`;\n console.log(chalk.cyan(`${index + 1}. ${facilitatorName}`));\n console.log(chalk.gray(` ID: ${fac.id}`));\n console.log(chalk.gray(` Wallet: ${fac.facilitatorWallet}`));\n console.log(\n chalk.gray(` Status: ${getStatusEmoji(fac.status)} ${fac.status.toUpperCase()}`)\n );\n if (fac.network) {\n console.log(chalk.gray(` Network: ${fac.network}`));\n }\n if (fac.chainId) {\n console.log(chalk.gray(` Chain ID: ${fac.chainId}`));\n }\n console.log(chalk.gray(` Payments: ${fac.totalPayments || 0}`));\n console.log(chalk.gray(` Created by: ${fac.createdBy || 'Unknown'}`));\n console.log('');\n });\n } catch (error: any) {\n spinner.fail('Failed to load facilitators');\n console.log(chalk.red(`\\n\\u274C Error: ${error.message}\\n`));\n process.exit(1);\n }\n}\n\n/**\n * Check facilitator status\n */\nasync function status(id: string, options: any) {\n console.log(chalk.cyan(`\\n\\uD83D\\uDCCA Facilitator Status\\n`));\n\n const spinner = ora('Checking status...').start();\n\n try {\n const fac = await getFacilitatorStatus(options.url, id);\n spinner.stop();\n\n console.log(chalk.cyan(`${fac.name}`));\n console.log(chalk.gray(`ID: ${fac.id}\\n`));\n console.log(\n chalk.gray(\n `Status: ${getStatusEmoji(fac.status)} ${chalk.bold(fac.status.toUpperCase())}`\n )\n );\n console.log(chalk.gray(`Wallet: ${fac.facilitatorWallet}`));\n console.log(chalk.gray(`Recipient: ${fac.paymentRecipient}`));\n console.log(chalk.gray(`Total Payments: ${fac.totalPayments}`));\n console.log(chalk.gray(`Gas Balance: ${fac.gasBalance || 'Unknown'}`));\n console.log(chalk.gray(`Created: ${new Date(fac.lastUsed).toLocaleString()}\\n`));\n\n if (fac.status === 'needs_funding') {\n console.log(chalk.yellow('\\u26A0\\uFE0F Facilitator needs gas token for fees'));\n console.log(chalk.gray(` Send gas token to: ${fac.facilitatorWallet}\\n`));\n }\n } catch (error: any) {\n spinner.fail('Failed to get status');\n console.log(chalk.red(`\\n\\u274C Error: ${error.message}\\n`));\n process.exit(1);\n }\n}\n\n/**\n * Check facilitator balance\n */\nasync function balance(id: string, options: any) {\n console.log(chalk.cyan(`\\n\\uD83D\\uDCB0 Facilitator Balance\\n`));\n\n const spinner = ora('Checking balance...').start();\n\n try {\n const result = await getFacilitatorBalance(options.url, id);\n spinner.stop();\n\n console.log(chalk.gray(`Facilitator: ${result.name}`));\n console.log(chalk.gray(`Wallet: ${result.wallet}\\n`));\n console.log(chalk.cyan(`Balance: ${chalk.bold(result.balance)}`));\n console.log(\n chalk.gray(`Status: ${getStatusEmoji(result.status)} ${result.status.toUpperCase()}\\n`)\n );\n\n if (parseFloat(result.balance) < 0.1) {\n console.log(chalk.yellow('\\u26A0\\uFE0F Low balance! Facilitator may become inactive.\\n'));\n }\n } catch (error: any) {\n spinner.fail('Failed to check balance');\n console.log(chalk.red(`\\n\\u274C Error: ${error.message}\\n`));\n process.exit(1);\n }\n}\n\nfunction getStatusEmoji(status: string): string {\n switch (status) {\n case 'active':\n return '\\u2705';\n case 'needs_funding':\n return '\\u26A0\\uFE0F';\n case 'inactive':\n return '\\u274C';\n default:\n return '\\u2753';\n }\n}\n\nexport const facilitatorCommand = {\n create,\n list,\n status,\n balance,\n};\n", "/**\n * Connect Command\n *\n * Connect wallet to Facinet CLI\n */\n\nimport inquirer from 'inquirer';\nimport chalk from 'chalk';\nimport { Wallet } from 'ethers';\nimport { getConfig, saveConfig } from '../utils/config';\nimport ora from 'ora';\n\nexport async function connectCommand() {\n console.log(chalk.cyan('\\n\\uD83D\\uDD17 Connect Wallet to Facinet\\n'));\n\n const { method } = await inquirer.prompt([\n {\n type: 'list',\n name: 'method',\n message: 'How would you like to connect?',\n choices: [\n { name: 'Enter Private Key (for testing)', value: 'privateKey' },\n { name: 'Generate New Wallet', value: 'generate' },\n ],\n },\n ]);\n\n if (method === 'privateKey') {\n const { privateKey } = await inquirer.prompt([\n {\n type: 'password',\n name: 'privateKey',\n message: 'Enter your private key:',\n mask: '*',\n },\n ]);\n\n try {\n const wallet = new Wallet(privateKey);\n saveConfig({ privateKey, address: wallet.address });\n console.log(chalk.green('\\n\\u2705 Wallet connected successfully!'));\n console.log(chalk.gray(`Address: ${wallet.address}`));\n } catch (error) {\n console.log(chalk.red('\\n\\u274C Invalid private key'));\n process.exit(1);\n }\n } else {\n const spinner = ora('Generating new wallet...').start();\n const wallet = Wallet.createRandom();\n spinner.succeed('Wallet generated!');\n\n console.log(chalk.green('\\n\\u2705 New wallet created!'));\n console.log(chalk.yellow('\\n\\u26A0\\uFE0F IMPORTANT: Save your private key securely!'));\n console.log(chalk.gray(`\\nAddress: ${wallet.address}`));\n console.log(chalk.gray(`Private Key: ${wallet.privateKey}`));\n console.log(chalk.gray(`Mnemonic: ${wallet.mnemonic?.phrase}\\n`));\n\n const { confirm } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message: 'Have you saved your private key?',\n default: false,\n },\n ]);\n\n if (!confirm) {\n console.log(chalk.red('\\nPlease save your private key before continuing.'));\n process.exit(0);\n }\n\n saveConfig({ privateKey: wallet.privateKey, address: wallet.address });\n console.log(chalk.green('\\u2705 Configuration saved!'));\n }\n\n const config = getConfig();\n console.log(chalk.cyan('\\n\\uD83D\\uDCE1 Network Configuration:'));\n console.log(chalk.gray(`Network: ${config.network || 'avalanche-fuji'}`));\n console.log(chalk.gray(`API URL: ${config.apiUrl || 'http://localhost:3000'}\\n`));\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["import_chalk", "path", "os", "fs", "axios", "facilitator", "chalk", "inquirer", "ora", "facilitator", "axios", "import_inquirer", "import_chalk", "import_ora", "import_ethers", "chalk", "inquirer", "ora", "status", "import_inquirer", "import_chalk", "import_ethers", "import_ora", "chalk", "inquirer", "ora", "chalk"]
|
|
7
|
+
}
|
package/dist/sdk/Facinet.d.ts
CHANGED
|
@@ -2,19 +2,32 @@
|
|
|
2
2
|
* Facinet SDK - Main Class
|
|
3
3
|
*
|
|
4
4
|
* JavaScript/TypeScript SDK for integrating x402 payments
|
|
5
|
+
* Supports multichain: Avalanche Fuji, Ethereum Sepolia, Base Sepolia, Polygon Amoy
|
|
5
6
|
*/
|
|
6
|
-
import type { FacinetConfig, PaymentParams, PaymentResult, Facilitator } from './types';
|
|
7
|
+
import type { FacinetConfig, PaymentParams, PaymentResult, Facilitator, ChainConfig } from './types';
|
|
7
8
|
export declare class Facinet {
|
|
8
9
|
private config;
|
|
9
10
|
private chain;
|
|
10
11
|
private wallet?;
|
|
11
12
|
constructor(config?: FacinetConfig);
|
|
13
|
+
/**
|
|
14
|
+
* Get the current chain configuration
|
|
15
|
+
*/
|
|
16
|
+
getChain(): ChainConfig;
|
|
17
|
+
/**
|
|
18
|
+
* Get all supported chains
|
|
19
|
+
*/
|
|
20
|
+
static getSupportedChains(): ChainConfig[];
|
|
21
|
+
/**
|
|
22
|
+
* Get supported network names
|
|
23
|
+
*/
|
|
24
|
+
static getSupportedNetworks(): string[];
|
|
12
25
|
/**
|
|
13
26
|
* Make a payment via x402 facilitator network
|
|
14
27
|
*
|
|
15
28
|
* @example
|
|
16
29
|
* ```typescript
|
|
17
|
-
* const facinet = new Facinet();
|
|
30
|
+
* const facinet = new Facinet({ network: 'base-sepolia' });
|
|
18
31
|
* const result = await facinet.pay({
|
|
19
32
|
* amount: '1',
|
|
20
33
|
* recipient: '0xMerchantAddress',
|
|
@@ -25,11 +38,11 @@ export declare class Facinet {
|
|
|
25
38
|
*/
|
|
26
39
|
pay(params: PaymentParams): Promise<PaymentResult>;
|
|
27
40
|
/**
|
|
28
|
-
* Get all active facilitators
|
|
41
|
+
* Get all active facilitators for the current network
|
|
29
42
|
*/
|
|
30
43
|
getFacilitators(): Promise<Facilitator[]>;
|
|
31
44
|
/**
|
|
32
|
-
* Select a random active facilitator
|
|
45
|
+
* Select a random active facilitator for the current network
|
|
33
46
|
*/
|
|
34
47
|
selectRandomFacilitator(): Promise<Facilitator>;
|
|
35
48
|
/**
|
|
@@ -37,15 +50,18 @@ export declare class Facinet {
|
|
|
37
50
|
*
|
|
38
51
|
* @example
|
|
39
52
|
* ```typescript
|
|
53
|
+
* // Pay on Base Sepolia
|
|
40
54
|
* await Facinet.quickPay({
|
|
41
55
|
* amount: '1',
|
|
42
56
|
* recipient: '0xMerchantAddress',
|
|
43
|
-
* privateKey: process.env.PRIVATE_KEY
|
|
57
|
+
* privateKey: process.env.PRIVATE_KEY,
|
|
58
|
+
* network: 'base-sepolia'
|
|
44
59
|
* });
|
|
45
60
|
* ```
|
|
46
61
|
*/
|
|
47
62
|
static quickPay(params: PaymentParams & {
|
|
48
63
|
privateKey?: string;
|
|
64
|
+
network?: FacinetConfig['network'];
|
|
49
65
|
}): Promise<PaymentResult>;
|
|
50
66
|
}
|
|
51
67
|
//# sourceMappingURL=Facinet.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Facinet.d.ts","sourceRoot":"","sources":["../../src/sdk/Facinet.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"Facinet.d.ts","sourceRoot":"","sources":["../../src/sdk/Facinet.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,aAAa,EAAE,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAwFrG,qBAAa,OAAO;IAClB,OAAO,CAAC,MAAM,CAAgF;IAC9F,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,MAAM,CAAC,CAA8B;gBAEjC,MAAM,GAAE,aAAkB;IA0BtC;;OAEG;IACH,QAAQ,IAAI,WAAW;IAIvB;;OAEG;IACH,MAAM,CAAC,kBAAkB,IAAI,WAAW,EAAE;IAI1C;;OAEG;IACH,MAAM,CAAC,oBAAoB,IAAI,MAAM,EAAE;IAIvC;;;;;;;;;;;;;OAaG;IACG,GAAG,CAAC,MAAM,EAAE,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;IAoKxD;;OAEG;IACG,eAAe,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IA0C/C;;OAEG;IACG,uBAAuB,IAAI,OAAO,CAAC,WAAW,CAAC;IAqBrD;;;;;;;;;;;;;OAaG;WACU,QAAQ,CACnB,MAAM,EAAE,aAAa,GAAG;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,OAAO,CAAC,EAAE,aAAa,CAAC,SAAS,CAAC,CAAA;KAAE,GAClF,OAAO,CAAC,aAAa,CAAC;CAY1B"}
|
package/dist/sdk/Facinet.js
CHANGED
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
* Facinet SDK - Main Class
|
|
4
4
|
*
|
|
5
5
|
* JavaScript/TypeScript SDK for integrating x402 payments
|
|
6
|
+
* Supports multichain: Avalanche Fuji, Ethereum Sepolia, Base Sepolia, Polygon Amoy
|
|
6
7
|
*/
|
|
7
8
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
9
|
if (k2 === undefined) k2 = k;
|
|
@@ -44,42 +45,130 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
44
45
|
exports.Facinet = void 0;
|
|
45
46
|
const axios_1 = __importDefault(require("axios"));
|
|
46
47
|
const ethers_1 = require("ethers");
|
|
48
|
+
// All 4 supported chains
|
|
47
49
|
const CHAINS = {
|
|
48
|
-
avalanche: {
|
|
49
|
-
name: '
|
|
50
|
+
'avalanche-fuji': {
|
|
51
|
+
name: 'avalanche-fuji',
|
|
52
|
+
displayName: 'Avalanche Fuji',
|
|
50
53
|
chainId: 43113,
|
|
51
54
|
rpcUrl: 'https://api.avax-test.network/ext/bc/C/rpc',
|
|
52
55
|
usdcAddress: '0x5425890298aed601595a70AB815c96711a31Bc65',
|
|
56
|
+
usdcDecimals: 6,
|
|
53
57
|
gasToken: 'AVAX',
|
|
54
58
|
blockExplorer: 'https://testnet.snowtrace.io',
|
|
59
|
+
erc3009DomainName: 'USD Coin',
|
|
60
|
+
erc3009DomainVersion: '2',
|
|
55
61
|
},
|
|
62
|
+
'ethereum-sepolia': {
|
|
63
|
+
name: 'ethereum-sepolia',
|
|
64
|
+
displayName: 'Ethereum Sepolia',
|
|
65
|
+
chainId: 11155111,
|
|
66
|
+
rpcUrl: 'https://ethereum-sepolia-rpc.publicnode.com',
|
|
67
|
+
usdcAddress: '0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238',
|
|
68
|
+
usdcDecimals: 6,
|
|
69
|
+
gasToken: 'ETH',
|
|
70
|
+
blockExplorer: 'https://sepolia.etherscan.io',
|
|
71
|
+
erc3009DomainName: 'USDC',
|
|
72
|
+
erc3009DomainVersion: '2',
|
|
73
|
+
},
|
|
74
|
+
'base-sepolia': {
|
|
75
|
+
name: 'base-sepolia',
|
|
76
|
+
displayName: 'Base Sepolia',
|
|
77
|
+
chainId: 84532,
|
|
78
|
+
rpcUrl: 'https://sepolia.base.org',
|
|
79
|
+
usdcAddress: '0x036CbD53842c5426634e7929541eC2318f3dCF7e',
|
|
80
|
+
usdcDecimals: 6,
|
|
81
|
+
gasToken: 'ETH',
|
|
82
|
+
blockExplorer: 'https://sepolia.basescan.org',
|
|
83
|
+
erc3009DomainName: 'USDC',
|
|
84
|
+
erc3009DomainVersion: '2',
|
|
85
|
+
},
|
|
86
|
+
'polygon-amoy': {
|
|
87
|
+
name: 'polygon-amoy',
|
|
88
|
+
displayName: 'Polygon Amoy',
|
|
89
|
+
chainId: 80002,
|
|
90
|
+
rpcUrl: 'https://rpc-amoy.polygon.technology',
|
|
91
|
+
usdcAddress: '0x41E94Eb019C0762f9Bfcf9Fb1E58725BfB0e7582',
|
|
92
|
+
usdcDecimals: 6,
|
|
93
|
+
gasToken: 'MATIC',
|
|
94
|
+
blockExplorer: 'https://amoy.polygonscan.com',
|
|
95
|
+
erc3009DomainName: 'USDC',
|
|
96
|
+
erc3009DomainVersion: '2',
|
|
97
|
+
},
|
|
98
|
+
};
|
|
99
|
+
// Legacy aliases for backwards compatibility
|
|
100
|
+
const NETWORK_ALIASES = {
|
|
101
|
+
'avalanche': 'avalanche-fuji',
|
|
102
|
+
'ethereum': 'ethereum-sepolia',
|
|
103
|
+
'polygon': 'polygon-amoy',
|
|
104
|
+
'base': 'base-sepolia',
|
|
105
|
+
};
|
|
106
|
+
// Network-specific API URLs
|
|
107
|
+
const NETWORK_API_URLS = {
|
|
108
|
+
'avalanche-fuji': 'https://x402-avalanche-chi.vercel.app',
|
|
109
|
+
'ethereum-sepolia': 'https://x402-ethereum-chi.vercel.app',
|
|
110
|
+
'base-sepolia': 'https://x402-base-chi.vercel.app',
|
|
111
|
+
'polygon-amoy': 'https://x402-polygon-chi.vercel.app',
|
|
56
112
|
};
|
|
113
|
+
/**
|
|
114
|
+
* Resolve network name (handles legacy aliases)
|
|
115
|
+
*/
|
|
116
|
+
function resolveNetwork(network) {
|
|
117
|
+
return NETWORK_ALIASES[network] || network;
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Get API URL for a network
|
|
121
|
+
*/
|
|
122
|
+
function getApiUrlForNetwork(network, customApiUrl) {
|
|
123
|
+
if (customApiUrl) {
|
|
124
|
+
return customApiUrl.replace(/\/$/, '');
|
|
125
|
+
}
|
|
126
|
+
const resolvedNetwork = resolveNetwork(network);
|
|
127
|
+
return NETWORK_API_URLS[resolvedNetwork] || NETWORK_API_URLS['avalanche-fuji'];
|
|
128
|
+
}
|
|
57
129
|
class Facinet {
|
|
58
130
|
constructor(config = {}) {
|
|
59
|
-
|
|
60
|
-
const apiUrl = (config.apiUrl
|
|
131
|
+
const resolvedNetwork = resolveNetwork(config.network || 'avalanche-fuji');
|
|
132
|
+
const apiUrl = getApiUrlForNetwork(resolvedNetwork, config.apiUrl);
|
|
61
133
|
this.config = {
|
|
62
|
-
apiUrl
|
|
134
|
+
apiUrl,
|
|
63
135
|
privateKey: config.privateKey || '',
|
|
64
|
-
network:
|
|
136
|
+
network: resolvedNetwork,
|
|
65
137
|
rpcUrl: config.rpcUrl || '',
|
|
66
138
|
};
|
|
67
|
-
this.chain = CHAINS[
|
|
139
|
+
this.chain = CHAINS[resolvedNetwork];
|
|
68
140
|
if (!this.chain) {
|
|
69
|
-
throw new Error(`Unsupported network: ${
|
|
141
|
+
throw new Error(`Unsupported network: ${config.network}. Supported networks: ${Object.keys(CHAINS).join(', ')}`);
|
|
70
142
|
}
|
|
71
|
-
// Initialize wallet if private key provided (Node.js)
|
|
72
143
|
if (this.config.privateKey) {
|
|
73
144
|
const provider = new ethers_1.JsonRpcProvider(this.config.rpcUrl || this.chain.rpcUrl);
|
|
74
145
|
this.wallet = new ethers_1.Wallet(this.config.privateKey, provider);
|
|
75
146
|
}
|
|
76
147
|
}
|
|
148
|
+
/**
|
|
149
|
+
* Get the current chain configuration
|
|
150
|
+
*/
|
|
151
|
+
getChain() {
|
|
152
|
+
return { ...this.chain };
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Get all supported chains
|
|
156
|
+
*/
|
|
157
|
+
static getSupportedChains() {
|
|
158
|
+
return Object.values(CHAINS);
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Get supported network names
|
|
162
|
+
*/
|
|
163
|
+
static getSupportedNetworks() {
|
|
164
|
+
return Object.keys(CHAINS);
|
|
165
|
+
}
|
|
77
166
|
/**
|
|
78
167
|
* Make a payment via x402 facilitator network
|
|
79
168
|
*
|
|
80
169
|
* @example
|
|
81
170
|
* ```typescript
|
|
82
|
-
* const facinet = new Facinet();
|
|
171
|
+
* const facinet = new Facinet({ network: 'base-sepolia' });
|
|
83
172
|
* const result = await facinet.pay({
|
|
84
173
|
* amount: '1',
|
|
85
174
|
* recipient: '0xMerchantAddress',
|
|
@@ -89,21 +178,19 @@ class Facinet {
|
|
|
89
178
|
* ```
|
|
90
179
|
*/
|
|
91
180
|
async pay(params) {
|
|
92
|
-
// Validate parameters
|
|
93
181
|
if (!params.amount || parseFloat(params.amount) <= 0) {
|
|
94
182
|
throw new Error('Invalid amount');
|
|
95
183
|
}
|
|
96
184
|
if (!params.recipient.match(/^0x[a-fA-F0-9]{40}$/)) {
|
|
97
185
|
throw new Error('Invalid recipient address');
|
|
98
186
|
}
|
|
99
|
-
//
|
|
187
|
+
// Resolve payer address
|
|
100
188
|
let payerAddress = params.payerAddress || '';
|
|
101
189
|
if (!payerAddress) {
|
|
102
190
|
if (this.wallet) {
|
|
103
191
|
payerAddress = this.wallet.address;
|
|
104
192
|
}
|
|
105
193
|
else if (typeof window !== 'undefined' && window.ethereum) {
|
|
106
|
-
// Browser - get from MetaMask
|
|
107
194
|
const accounts = await window.ethereum.request({
|
|
108
195
|
method: 'eth_requestAccounts',
|
|
109
196
|
});
|
|
@@ -113,21 +200,20 @@ class Facinet {
|
|
|
113
200
|
throw new Error('No payer address provided and no wallet available. Provide payerAddress or privateKey in config.');
|
|
114
201
|
}
|
|
115
202
|
}
|
|
116
|
-
// CRITICAL: Use lowercase addresses for EIP-712 signing (per spec)
|
|
117
203
|
payerAddress = payerAddress.toLowerCase();
|
|
118
204
|
const recipientAddress = params.recipient.toLowerCase();
|
|
119
205
|
// Select random facilitator
|
|
120
206
|
const facilitator = await this.selectRandomFacilitator();
|
|
121
207
|
// Create ERC-3009 authorization
|
|
122
|
-
const amount = BigInt(parseFloat(params.amount) *
|
|
208
|
+
const amount = BigInt(parseFloat(params.amount) * 1e6); // 6 decimals for USDC
|
|
123
209
|
const validAfter = Math.floor(Date.now() / 1000) - 60;
|
|
124
|
-
const validBefore = validAfter + 3600; // 1 hour
|
|
210
|
+
const validBefore = validAfter + 3600; // 1 hour validity
|
|
125
211
|
const nonce = '0x' +
|
|
126
212
|
Array.from({ length: 64 }, () => Math.floor(Math.random() * 16).toString(16)).join('');
|
|
127
|
-
// EIP-712 Domain
|
|
213
|
+
// EIP-712 Domain - uses chain-specific domain name
|
|
128
214
|
const domain = {
|
|
129
|
-
name:
|
|
130
|
-
version:
|
|
215
|
+
name: this.chain.erc3009DomainName,
|
|
216
|
+
version: this.chain.erc3009DomainVersion,
|
|
131
217
|
chainId: this.chain.chainId,
|
|
132
218
|
verifyingContract: this.chain.usdcAddress,
|
|
133
219
|
};
|
|
@@ -142,35 +228,28 @@ class Facinet {
|
|
|
142
228
|
],
|
|
143
229
|
};
|
|
144
230
|
const value = {
|
|
145
|
-
from: payerAddress,
|
|
146
|
-
to: recipientAddress,
|
|
231
|
+
from: payerAddress,
|
|
232
|
+
to: recipientAddress,
|
|
147
233
|
value: amount,
|
|
148
|
-
validAfter
|
|
149
|
-
validBefore
|
|
150
|
-
nonce
|
|
234
|
+
validAfter,
|
|
235
|
+
validBefore,
|
|
236
|
+
nonce,
|
|
151
237
|
};
|
|
152
|
-
// Sign authorization
|
|
238
|
+
// Sign the authorization
|
|
153
239
|
let signature;
|
|
154
240
|
if (this.wallet) {
|
|
155
|
-
// Node.js - sign with wallet (ethers handles BigInt)
|
|
156
241
|
signature = await this.wallet.signTypedData(domain, types, value);
|
|
157
242
|
}
|
|
158
243
|
else if (typeof window !== 'undefined' && window.ethereum) {
|
|
159
|
-
// Browser - Use ethers to format the typed data EXACTLY like CLI
|
|
160
244
|
const { TypedDataEncoder } = await Promise.resolve().then(() => __importStar(require('ethers')));
|
|
161
|
-
// Convert BigInt to string for JSON serialization, but keep structure identical to Node.js
|
|
162
245
|
const messageForSigning = {
|
|
163
246
|
from: payerAddress,
|
|
164
247
|
to: recipientAddress,
|
|
165
248
|
value: amount.toString(),
|
|
166
249
|
validAfter: validAfter.toString(),
|
|
167
250
|
validBefore: validBefore.toString(),
|
|
168
|
-
nonce
|
|
251
|
+
nonce,
|
|
169
252
|
};
|
|
170
|
-
// Use ethers TypedDataEncoder to get the exact hash
|
|
171
|
-
const hash = TypedDataEncoder.hash(domain, types, messageForSigning);
|
|
172
|
-
console.log('🔐 Signing hash:', hash);
|
|
173
|
-
// Create the exact same structure that ethers uses, with EIP712Domain explicitly defined
|
|
174
253
|
const typedDataPayload = JSON.stringify({
|
|
175
254
|
types: {
|
|
176
255
|
EIP712Domain: [
|
|
@@ -181,7 +260,7 @@ class Facinet {
|
|
|
181
260
|
],
|
|
182
261
|
TransferWithAuthorization: types.TransferWithAuthorization,
|
|
183
262
|
},
|
|
184
|
-
domain
|
|
263
|
+
domain,
|
|
185
264
|
primaryType: 'TransferWithAuthorization',
|
|
186
265
|
message: messageForSigning,
|
|
187
266
|
});
|
|
@@ -189,36 +268,27 @@ class Facinet {
|
|
|
189
268
|
method: 'eth_signTypedData_v4',
|
|
190
269
|
params: [payerAddress, typedDataPayload],
|
|
191
270
|
});
|
|
192
|
-
console.log('🔐 Signature:', signature, 'Length:', signature.length);
|
|
193
271
|
}
|
|
194
272
|
else {
|
|
195
273
|
throw new Error('No signing method available');
|
|
196
274
|
}
|
|
197
|
-
|
|
198
|
-
from: payerAddress, // Checksummed
|
|
199
|
-
to: recipientAddress, // Checksummed
|
|
200
|
-
value: amount.toString(),
|
|
201
|
-
validAfter: validAfter.toString(),
|
|
202
|
-
validBefore: validBefore.toString(),
|
|
203
|
-
nonce: nonce,
|
|
204
|
-
signature: signature?.slice(0, 20) + '...',
|
|
205
|
-
});
|
|
206
|
-
// Submit to facilitator
|
|
275
|
+
// Build payment payload
|
|
207
276
|
const paymentPayload = {
|
|
208
277
|
signature,
|
|
209
278
|
authorization: {
|
|
210
|
-
from: payerAddress,
|
|
211
|
-
to: recipientAddress,
|
|
279
|
+
from: payerAddress,
|
|
280
|
+
to: recipientAddress,
|
|
212
281
|
value: amount.toString(),
|
|
213
282
|
validAfter: validAfter.toString(),
|
|
214
283
|
validBefore: validBefore.toString(),
|
|
215
|
-
nonce
|
|
284
|
+
nonce,
|
|
216
285
|
},
|
|
217
286
|
};
|
|
287
|
+
// Submit to facilitator
|
|
218
288
|
try {
|
|
219
289
|
const response = await axios_1.default.post(`${this.config.apiUrl}/api/x402/settle-custom`, {
|
|
220
290
|
facilitatorId: facilitator.id,
|
|
221
|
-
paymentPayload
|
|
291
|
+
paymentPayload,
|
|
222
292
|
});
|
|
223
293
|
if (!response.data.success) {
|
|
224
294
|
throw new Error(response.data.error || response.data.message || 'Payment failed');
|
|
@@ -228,19 +298,18 @@ class Facinet {
|
|
|
228
298
|
txHash: response.data.txHash,
|
|
229
299
|
facilitator: {
|
|
230
300
|
id: facilitator.id,
|
|
231
|
-
name: facilitator.name,
|
|
301
|
+
name: facilitator.name || `Facilitator ${facilitator.id.slice(0, 8)}`,
|
|
232
302
|
wallet: facilitator.facilitatorWallet,
|
|
233
303
|
},
|
|
234
304
|
payment: {
|
|
235
|
-
from: payerAddress,
|
|
236
|
-
to: recipientAddress,
|
|
305
|
+
from: payerAddress,
|
|
306
|
+
to: recipientAddress,
|
|
237
307
|
amount: params.amount,
|
|
238
308
|
network: this.config.network,
|
|
239
309
|
},
|
|
240
310
|
};
|
|
241
311
|
}
|
|
242
312
|
catch (error) {
|
|
243
|
-
// Enhanced error handling with backend error details
|
|
244
313
|
if (error.response?.data) {
|
|
245
314
|
const backendError = error.response.data.message || error.response.data.error;
|
|
246
315
|
throw new Error(`Payment failed: ${backendError}`);
|
|
@@ -249,41 +318,75 @@ class Facinet {
|
|
|
249
318
|
}
|
|
250
319
|
}
|
|
251
320
|
/**
|
|
252
|
-
* Get all active facilitators
|
|
321
|
+
* Get all active facilitators for the current network
|
|
253
322
|
*/
|
|
254
323
|
async getFacilitators() {
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
324
|
+
try {
|
|
325
|
+
const response = await axios_1.default.get(`${this.config.apiUrl}/api/facilitator/list`, {
|
|
326
|
+
timeout: 10000,
|
|
327
|
+
headers: {
|
|
328
|
+
'User-Agent': 'Facinet-SDK/2.3.0',
|
|
329
|
+
},
|
|
330
|
+
});
|
|
331
|
+
if (response.data.success && Array.isArray(response.data.facilitators)) {
|
|
332
|
+
// Filter by status and network/chainId
|
|
333
|
+
return response.data.facilitators.filter((f) => {
|
|
334
|
+
// Must be active
|
|
335
|
+
if (f.status !== 'active') {
|
|
336
|
+
return false;
|
|
337
|
+
}
|
|
338
|
+
// If facilitator has network or chainId, match it with current chain
|
|
339
|
+
if (f.network) {
|
|
340
|
+
return f.network === this.config.network;
|
|
341
|
+
}
|
|
342
|
+
if (f.chainId !== undefined) {
|
|
343
|
+
return f.chainId === this.chain.chainId;
|
|
344
|
+
}
|
|
345
|
+
// If no network/chainId specified, include it (backwards compatibility)
|
|
346
|
+
return true;
|
|
347
|
+
});
|
|
348
|
+
}
|
|
349
|
+
return [];
|
|
350
|
+
}
|
|
351
|
+
catch (error) {
|
|
352
|
+
throw new Error(`Failed to fetch facilitators for ${this.chain.displayName} (${this.config.network}): ${error.message || 'Unknown error'}`);
|
|
258
353
|
}
|
|
259
|
-
return [];
|
|
260
354
|
}
|
|
261
355
|
/**
|
|
262
|
-
* Select a random active facilitator
|
|
356
|
+
* Select a random active facilitator for the current network
|
|
263
357
|
*/
|
|
264
358
|
async selectRandomFacilitator() {
|
|
265
359
|
const facilitators = await this.getFacilitators();
|
|
266
360
|
if (facilitators.length === 0) {
|
|
267
|
-
throw new Error(
|
|
361
|
+
throw new Error(`No active facilitators available for ${this.chain.displayName} (${this.config.network}, Chain ID: ${this.chain.chainId}). ` +
|
|
362
|
+
`Please check that facilitators are registered for this network. API URL: ${this.config.apiUrl}`);
|
|
268
363
|
}
|
|
269
364
|
const randomIndex = Math.floor(Math.random() * facilitators.length);
|
|
270
|
-
|
|
365
|
+
const selectedFacilitator = facilitators[randomIndex];
|
|
366
|
+
// Ensure facilitator has a name
|
|
367
|
+
if (!selectedFacilitator.name) {
|
|
368
|
+
selectedFacilitator.name = `Facilitator ${selectedFacilitator.id.slice(0, 8)}`;
|
|
369
|
+
}
|
|
370
|
+
return selectedFacilitator;
|
|
271
371
|
}
|
|
272
372
|
/**
|
|
273
373
|
* Quick payment helper (static method)
|
|
274
374
|
*
|
|
275
375
|
* @example
|
|
276
376
|
* ```typescript
|
|
377
|
+
* // Pay on Base Sepolia
|
|
277
378
|
* await Facinet.quickPay({
|
|
278
379
|
* amount: '1',
|
|
279
380
|
* recipient: '0xMerchantAddress',
|
|
280
|
-
* privateKey: process.env.PRIVATE_KEY
|
|
381
|
+
* privateKey: process.env.PRIVATE_KEY,
|
|
382
|
+
* network: 'base-sepolia'
|
|
281
383
|
* });
|
|
282
384
|
* ```
|
|
283
385
|
*/
|
|
284
386
|
static async quickPay(params) {
|
|
285
387
|
const facinet = new Facinet({
|
|
286
388
|
privateKey: params.privateKey,
|
|
389
|
+
network: params.network,
|
|
287
390
|
});
|
|
288
391
|
return facinet.pay({
|
|
289
392
|
amount: params.amount,
|
package/dist/sdk/Facinet.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Facinet.js","sourceRoot":"","sources":["../../src/sdk/Facinet.ts"],"names":[],"mappings":";AAAA
|
|
1
|
+
{"version":3,"file":"Facinet.js","sourceRoot":"","sources":["../../src/sdk/Facinet.ts"],"names":[],"mappings":"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"}
|