This is a non-custodial Solana interface for AI agents buying tokenized US stocks and yield products. It exposes tools to compare USDC lending yields across chains, quote xStocks like NVDAx and TSLAx via Jupiter, build unsigned transactions for buying Backed equities or depositing into Ondo USDY, and snapshot portfolio holdings valued at market prices. Every transaction returns a Phantom sign URL. You approve each one in your wallet. The server never holds keys or co-signs. Reach for this when you want Claude to execute RWA trades on Solana without giving up custody, or when you need yield comparison and timing signals baked into the tool layer instead of prompting for them manually.
A non-custodial RWA service for AI agents on Solana — yield comparison, tokenized US-equity quotes, and ready-to-sign transactions. Funds stay in your wallet; we never sign.
Connect this MCP server to Claude, Cursor, Claude Code, or any MCP-compatible client. Your AI can then:
You sign every transaction in your own Phantom (or other Solana wallet). We do not custody funds, hold keys, or co-sign. Architecturally we are a service — closer to Tradingview than to a wallet.
Signals to act on: pair this with StockWaves — pay-per-call quant signals (equities / crypto / cross-asset macro) over the x402 protocol. StockWaves tells an agent what to trade; this server lets it execute non-custodially.
Tokenized US equities (Backed's xStocks, Ondo Global Markets) and on-chain treasury products are the fastest-growing real-world-asset (RWA) category. As of mid-2026 these have real liquidity on Solana — NVDAx, TSLAx, SPYx all carry $300K-$3M each, with ~$5/share trades incurring zero detectable price impact.
Coinbase, Phantom, and Crossmint all offer "agent wallets," but they are generic. None opinionated about RWA discovery, yield aggregation, or the boring-but-correct execution that makes idle USDC actually earn. This server fills that gap, distributed via the AI tool layer.
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (Claude Desktop on macOS) or your editor's MCP config:
{
"mcpServers": {
"agent-wallet": {
"command": "npx",
"args": ["-y", "@kaditang/agent-wallet-mcp"]
}
}
}
The npm package is published as
@kaditang/agent-wallet-mcp(and listed in the official MCP Registry) — the config above runs it directly vianpx, no clone needed. Requires@kaditang/agent-wallet-mcp≥ 0.2.1 (stdio entry).To run from source instead (for development), clone this repo and run:
git clone https://github.com/kaditang/agent-wallet-mcp.git cd agent-wallet-mcp && npm install cp .env.example .env # then fill in SOL_RPC (api keys are minted via Phantom at /account) npm run mcp:http # serves on :3030Then point your MCP client at
http://localhost:3030/mcpwith anAuthorization: Bearer <your-api-key>header.
Public RPCs (api.mainnet-beta.solana.com) rate-limit aggressively and reject getTokenAccountsByOwner in some cases. For any meaningful traffic you want a paid endpoint as primary; public ones are kept as fallback automatically.
Free tier from Helius is enough for V1:
https://mainnet.helius-rpc.com/?api-key=...).env:
SOL_RPC=https://mainnet.helius-rpc.com/?api-key=YOUR_KEY
SOL_RPC_FALLBACK_1 for redundancy.The pool tries primary first; on transient failures (429, timeouts, 5xx) it falls through to fallbacks, then to the public mainnet-beta + publicnode endpoints.
Set SENTRY_DSN to ship server-side errors to Sentry. Disabled by default; no outbound network when unset. Captures 500s and broadcast failures with sanitized context — request bodies, cookies, headers (which can carry api keys) are stripped before send.
SENTRY_DSN=https://<key>@oXXXXXX.ingest.sentry.io/XXXXXX
SENTRY_RELEASE=<git-sha> # optional, for release tracking
| Tool | Purpose | Signs anything? |
|---|---|---|
compare_yields | Rank USDC lending + tokenized-treasury yields across chains, risk-adjusted (volatility / TVL / protocol / stability / reward-dependence), not headline APY. Solana protocols tagged executable: true. | No |
list_yield_tokens | List supported tokenized treasuries (USDY by Ondo). | No |
list_xstocks | List supported tokenized US equities (Backed xStocks). | No |
check_xstock_safety | Pre-trade safety check for a tokenized US stock (any issuer / mint / EVM address): is it the real token (not a copycat) and OK to buy now — verified vs the issuer's own registry, plus depeg / liquidity / market-hours / trading-halt. Catches impersonator tokens (the #1 risk). Free, read-only. Auto-run before build_buy_xstock_tx. | No |
quote_tokenized_stock | Live Jupiter quote for USDC → xStock + a best-entry-timing signal (premium vs the underlying stock, compared against a same-market-regime baseline — US market open vs closed). | No |
get_portfolio | Snapshot a wallet: SOL, USDC, xStocks + yield tokens valued via Jupiter. | No |
portfolio_health | "Should I do anything?" — holdings vs best risk-adjusted yield + per-xStock timing + actionable notes. | No |
suggest_rebalance | Given a target allocation, compute the buy/sell trades to reach it. Read-only; user executes. | No |
export_history | Export tokenized-equity / yield trade history (date, action, price, CSV) — a record for your accountant, not tax advice. | No |
track_tx | Lookup confirmation status for a Solana signature. | No |
build_deposit_yield_tx | Build unsigned USDC → USDY tx + one-click sign URL. | No — user signs in Phantom. |
build_withdraw_yield_tx | Build unsigned USDY → USDC tx + sign URL. | No |
build_buy_xstock_tx | Build unsigned USDC → xStock tx + sign URL. | No |
build_sell_xstock_tx | Build unsigned xStock → USDC tx + sign URL. | No |
[Claude / Cursor / Claude Code]
↓ MCP (stdio or HTTP)
[agent-wallet-mcp server]
├─ READ tools (DefiLlama, Jupiter quote, RPC reads)
├─ BUILD tools (Jupiter swap → unsigned VersionedTransaction)
└─ MONITOR tools (RPC signature lookup)
↓ returns tx + signUrl
[user's browser]
↓ Phantom signs + sends
[Solana mainnet]
Zero custody, zero signing keys held by the server. The service is pure intelligence + transaction construction.
User to Claude:
"I have a Solana wallet at
7QCg1LegbEE2eYDJZfgeMX7JhjtFVVZx9su3HzncuSh2. Buy me 5 USDC of NVDA tokenized."
Claude calls build_buy_xstock_tx → receives sign URL → shows it to you. You click, Phantom prompts, you approve. ~0.023 NVDAx lands in your wallet.
| Asset class | V1 | V1.5 | V2 |
|---|---|---|---|
| Backed xStocks (Solana) | ✅ | ||
| USDC lending data (cross-chain) | ✅ | ||
| Solana lending execution (Kamino / MarginFi / JLP) | ✅ | ||
| Ethereum-side RWA execution (BUIDL / OUSG / USDY) | ✅ | ||
| Cross-chain rebalance | ✅ |
This service handles a real-money path. We've documented the full security posture, threat model, audit history, and vulnerability-disclosure process in SECURITY.md — including a verifiable account of what "non-custodial" means here (i.e., what an attacker who controls our backend cannot do).
If you find a security issue, please open a private Security Advisory instead of a public issue. See SECURITY.md for the full disclosure process.
MIT
Live on Solana mainnet. First USDC → Ondo USDY transaction signed via Phantom + broadcast through this service:
55Agf6...JEusD
Building in public.
SOL_RPCsecretSolana RPC URL (e.g. a Helius endpoint). Optional — falls back to public mainnet-beta if unset.
io.github.ericm1018/skillfm-llm-cost-optimizer-openai-anthropic-usage
io.github.mikerawsonnz/llm-orchestration-agent
io.github.mikerawsonnz/authenticated-llm-agent
labforgedev/copilot-memory-mcp
csoai-org/agent-prompt-injection-firewall-mcp
io.github.mikerawsonnz/authenticated-multi-llm-agent