MCP Wallet Signer
Non-custodial MCP server that routes blockchain transactions to your browser wallet (MetaMask, Rabby, etc.) for signing — private keys never leave your browser.
README
MCP Wallet Signer
Your private keys never leave your browser. Every transaction requires explicit user approval in your wallet.
Most blockchain MCPs require you to paste a private key into a config file — giving the AI agent full, unsupervised access to your funds. MCP Wallet Signer takes a different approach: it routes every transaction to your actual browser wallet (MetaMask, Rabby, etc.) via EIP-6963, so you review and approve each action just like any other dapp interaction. No keys in config files, no risk of silent transactions.
Compatible With
<a href="https://claude.ai/download"><img src="https://img.shields.io/badge/Claude_Desktop-available-blue" alt="Claude Desktop"></a> <a href="https://docs.anthropic.com/en/docs/claude-code"><img src="https://img.shields.io/badge/Claude_Code-available-blue" alt="Claude Code"></a> <a href="https://cursor.com"><img src="https://img.shields.io/badge/Cursor-available-blue" alt="Cursor"></a> <a href="https://windsurf.com"><img src="https://img.shields.io/badge/Windsurf-available-blue" alt="Windsurf"></a>
Works with any MCP-compatible client via stdio transport.
Installation
Claude Code CLI
claude mcp add evm-wallet -- npx -y mcp-wallet-signer
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"evm-wallet": {
"command": "npx",
"args": ["-y", "mcp-wallet-signer"]
}
}
}
Run directly
npx -y mcp-wallet-signer
pnpx mcp-wallet-signer
bunx mcp-wallet-signer
MCP Tools
| Tool | Description | Browser Required |
|---|---|---|
connect_wallet |
Connect wallet, return address | Yes |
send_transaction |
Send ETH/tokens, call contracts | Yes |
sign_message |
Sign arbitrary message (personal_sign) | Yes |
sign_typed_data |
Sign EIP-712 typed data | Yes |
get_balance |
Read ETH balance (via RPC) | No |
How It Works
- Agent calls an MCP tool (e.g.,
send_transaction) - Server opens browser to a local signing page
- User connects wallet and approves the action
- Result (address, tx hash, signature) returned to agent
Supported Chains
Built-in RPC URLs for:
- Ethereum (1)
- Sepolia (11155111)
- Polygon (137)
- Arbitrum One (42161)
- Optimism (10)
- Base (8453)
- Avalanche (43114)
- BNB Smart Chain (56)
Configuration
Environment variables (optional):
| Variable | Description | Default |
|---|---|---|
EVM_MCP_PORT |
HTTP server port | 3847 |
EVM_MCP_DEFAULT_CHAIN |
Default chain ID | 1 |
Development
Requires Deno v2.0+.
# Install dependencies
deno install
cd web && deno install && cd ..
# Run MCP server in dev mode
deno task dev
# Run web UI dev server (separate terminal)
deno task dev:web
# Run tests
deno task test
# Build web UI
deno task build:web
# Build for npm
deno task build:npm
# Format code
deno task fmt
# Lint code
deno task lint
Project Structure
Developed with Deno, published to npm via dnt. Source in src/ uses
node: builtins (no Deno-specific APIs) so the npm bundle runs under Node.js.
deno.jsonc # Deno config + npm package metadata (single source of truth for version)
server.json # MCP registry manifest (read by LobeHub etc. from git)
scripts/build-npm.ts # dnt build: reads deno.jsonc, transforms src/ → npm/
├── src/ # Server source (TypeScript, runs under both Deno and Node)
│ ├── index.ts # CLI entry point
│ ├── mcp-server.ts # MCP tool definitions
│ ├── http-server.ts # Lazy-started HTTP server for browser approval UI
│ ├── wallet-signer.ts # Core signing orchestration
│ ├── pending-store.ts # Promise-based request tracking
│ ├── schemas.ts # Zod schemas for MCP tool inputs
│ ├── transport.ts # viem custom transport
│ ├── viem-account.ts # viem local account adapter
│ ├── mod.ts # Library export (npm: "mcp-wallet-signer")
│ ├── wallet-only.ts # Library export (npm: "mcp-wallet-signer/wallet-only")
│ └── version.ts # Reads version from package.json at runtime
├── web/ # Svelte UI (wallet approval pages)
│ └── src/
│ ├── App.svelte
│ └── components/ # ConnectWallet, TransactionSigner, MessageSigner
├── tests/
│ ├── *.test.ts # Unit tests
│ ├── e2e/ # E2E tests (HTTP API)
│ └── e2e-browser/ # E2E tests (Playwright, real browser wallet)
└── npm/ # Generated — dnt output + built web assets
Build pipeline
deno task build:npm runs scripts/build-npm.ts which:
- Transforms
src/to ESM JavaScript via dnt →npm/esm/ - Generates
npm/package.jsonfrom metadata indeno.jsonc - Builds the Svelte web UI (
web/→web/dist/) - Copies web assets into
npm/web/
Dev workflow
deno task dev # Run MCP server directly with Deno
deno task dev:web # Vite dev server for web UI (separate terminal)
deno task test # Unit + E2E API tests
deno task check # Type check + lint + format check
License
MIT
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。