USDCx Bridge
A conversational MCP server that enables bridging USDC between Ethereum and Stacks through natural language interactions with ChatGPT, handling deposits, withdrawals, and live status tracking via React widgets.
README
USDCx Bridge
Bridge USDC to Stacks using ChatGPT. No contracts. No complexity. Just conversation.
The first conversational bridge interface built on ChatGPT's Apps SDK and Model Context Protocol.
What It Does
Talk to ChatGPT, connect your wallets (MetaMask + Leather), and bridge USDC between Ethereum and Stacks—all without leaving the chat interface.
Why It Exists
Bridging USDC to Stacks today requires manual smart contract calls, complex address encoding (c32 → bytes32), and waiting 15-60 minutes with zero visibility.
USDCx Bridge makes it as easy as describing what you want in plain English.
How It Works
- Natural language - "Bridge 50 USDC to Stacks"
- Widget appears - React component renders in ChatGPT
- Connect wallets - MetaMask for Ethereum, Leather for Stacks
- Sign & bridge - One click, you sign with your wallet
- Track live - See confirmations and ETA in real-time
Features
- ✅ Conversational interface - No technical knowledge required
- ✅ Your wallets, your control - We never custody funds
- ✅ Live status tracking - Know exactly what's happening
- ✅ Built on official protocols - Circle xReserve + Stacks attestation
- ✅ Open source - Verify everything
- ✅ First MCP blockchain app - Sets the standard
Quick Start
1. Enable Developer Mode in ChatGPT settings
2. Create a custom app and add this MCP server:
https://usdcxbridge.fly.dev/mcp
3. Type in ChatGPT:
"Bridge USDC to Stacks"
That's it. The widget will appear and guide you through the rest.
Tech Stack
Backend
- @modelcontextprotocol/sdk - MCP server
- viem - Ethereum contract interactions
- @stacks/transactions - Stacks operations
- Node.js + TypeScript
Frontend (Widgets)
- React + TypeScript
- viem - Ethereum wallet connections
- @stacks/connect - Stacks wallet integration
Bridge Infrastructure
- Circle xReserve (Ethereum smart contracts)
- Stacks attestation service
Security
- ✅ You connect your own wallets
- ✅ You sign every transaction
- ✅ We never custody your funds
- ✅ We never access your private keys
- ✅ Uses official Circle xReserve protocol
Development
Prerequisites
- Node.js 18+
- npm or pnpm
Installation
# Clone repo
git clone https://github.com/yourusername/usdcx-bridge.git
cd usdcx-bridge
# Install dependencies
npm install
# Build everything (server + widgets)
npm run build
# Run MCP server locally (stdio mode)
npm start
# Run HTTP server (for ChatGPT integration)
npm run start:http
# Test with MCP inspector
npm test
Environment Variables
Create a .env file:
# Ethereum Network (mainnet or testnet)
ETHEREUM_NETWORK=testnet
ETHEREUM_RPC_URL=https://ethereum-sepolia.publicnode.com
# Stacks Network
STACKS_NETWORK=testnet
# Contract Addresses (Testnet)
XRESERVE_CONTRACT=0x008888878f94C0d87defdf0B07f46B93C1934442
USDC_CONTRACT=0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238
STACKS_USDCX_CONTRACT=ST1PQHQKV0RJXZFY1DGX8MNSNYVE3VGZJSRTPGZGM.usdcx-v1
# HTTP Server
PORT=3001
BASE_URL=http://localhost:3001
Project Structure
usdcx-bridge/
├── src/
│ ├── server/
│ │ ├── index.ts # MCP server (stdio mode)
│ │ ├── http-server.ts # HTTP wrapper for ChatGPT
│ │ └── lib/
│ │ ├── ethereum.ts # Ethereum/xReserve logic
│ │ ├── stacks.ts # Stacks/USDCx logic
│ │ └── helpers.ts # Address encoding utilities
│ └── widgets/
│ ├── DepositWidget.tsx # Ethereum → Stacks
│ ├── WithdrawalWidget.tsx # Stacks → Ethereum
│ ├── StatusWidget.tsx # Transaction tracking
│ └── hooks/
│ ├── useMetaMask.ts # MetaMask integration
│ └── useLeather.ts # Leather wallet integration
├── dist/ # Built files
├── package.json
├── tsconfig.json
└── README.md
Architecture
ChatGPT
↓
MCP Server (tools: prepareDeposit, prepareWithdrawal, checkStatus)
↓
React Widgets (wallet connection + transaction signing)
↓
Smart Contracts (xReserve on Ethereum, usdcx-v1 on Stacks)
MCP Tools
The server exposes these tools to ChatGPT:
prepareDeposit
Prepares USDC → USDCx bridge transaction (Ethereum to Stacks)
Parameters:
amount- Amount of USDC to bridgestacksRecipient- Destination Stacks addressuserEthereumAddress- User's Ethereum address
Returns: Widget URL for MetaMask signing
prepareWithdrawal
Prepares USDCx → USDC withdrawal transaction (Stacks to Ethereum)
Parameters:
amount- Amount of USDCx to withdraw (minimum 4.80)ethereumRecipient- Destination Ethereum addressstacksAddress- User's Stacks address
Returns: Widget URL for Leather signing
checkStatus
Checks transaction status on either chain
Parameters:
txHash- Transaction hashchain- Either "ethereum" or "stacks"
Returns: Status widget with live updates
getBalances
Gets USDC and USDCx balances
Parameters:
ethereumAddress(optional)stacksAddress(optional)
Returns: Balance information
healthCheck
Verifies bridge contracts are operational
Returns: System status
Deployment
Docker
# Build image
docker build -t usdcx-bridge .
# Run container
docker run -p 3001:3001 usdcx-bridge
Fly.io
# Install flyctl
curl -L https://fly.io/install.sh | sh
# Deploy
fly deploy
Manual
# Build
npm run build
# Start
NODE_ENV=production npm run start:http
Testing
Local Testing with MCP Inspector
npm test
This opens the MCP inspector for testing tools locally.
Test Deposit Flow
- Get testnet USDC from Sepolia faucet
- In ChatGPT: "Bridge 5 USDC to ST1PQHQKV0RJXZFY1DGX8MNSNYVE3VGZJSRTPGZGM"
- Click widget link
- Connect MetaMask
- Approve USDC (if needed)
- Sign bridge transaction
- Wait ~15 minutes
- Check USDCx balance on Stacks
Test Withdrawal Flow
- Ensure you have USDCx on Stacks testnet
- In ChatGPT: "Withdraw 5 USDCx to 0xYourEthereumAddress"
- Click widget link
- Connect Leather wallet
- Sign burn transaction
- Wait ~25-45 minutes
- Check USDC balance on Ethereum
Troubleshooting
Widget not loading
- Check that
npm run buildcompleted successfully - Verify HTTP server is running on correct port
- Check browser console for errors
MetaMask connection fails
- Install MetaMask extension
- Switch to Sepolia testnet
- Refresh page and try again
Leather connection fails
- Install Leather wallet
- Create/import Stacks wallet
- Ensure on testnet mode
Transaction stuck
- Check transaction on block explorer
- For Ethereum: https://sepolia.etherscan.io
- For Stacks: https://explorer.hiro.so (testnet)
- Bridge can take 15-60 minutes depending on attestation
Contributing
Contributions welcome! Please:
- Fork the repo
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
License
MIT License - see LICENSE file
Links
- Documentation: MCP Protocol Docs
- Circle xReserve: Official Docs
- Stacks USDCx: GitHub
- Report Issues: GitHub Issues
Acknowledgments
Built with:
- ChatGPT Apps SDK
- Model Context Protocol
- Circle's xReserve Protocol
- Stacks Blockchain
- Viem & wagmi
- React
Made with ❤️ for the Bitcoin & Ethereum ecosystems
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.