WalletMCP

WalletMCP

0

WalletMCP is a Model Context Protocol server designed for interaction with the Solana blockchain, providing tools for transaction management and SOL transfers. It is developer-friendly and integrates tools using MCP-compatible interfaces for efficient blockchain operations.

WalletMCP - Solana Blockchain MCP Server

WalletMCP is a Model Context Protocol (MCP) server implementation for interacting with the Solana blockchain. It exposes developer-friendly tools for working with wallets, transactions, program buffers, logs, and SOL transfers through MCP-compatible interfaces.

๐Ÿ“บ Demo Video

WalletMCP Demo
Click the image above to watch the demo video

๐Ÿง  Features

  • ๐Ÿ” Retrieve wallet transactions and SOL balances.
  • ๐Ÿ“œ Access program logs from the Solana blockchain.
  • ๐Ÿงพ Claims Unused Rents (List and close BPF Upgradeable Loader buffers).
  • ๐Ÿ’ธ Send SOL transactions programmatically.
  • ๐Ÿงฉ Fully MCP-compliant tool definitions using Zod for schema validation.

๐Ÿ”ง Technologies Used

  • Solana Web3.js SDK โ€“ Solana blockchain interaction
  • Model Context Protocol (MCP) โ€“ Protocol for tool registration
  • Zod โ€“ Input validation
  • TypeScript โ€“ Strong typing and modern tooling

๐Ÿ“‹ Requirements

  • Node.js v16+
  • Yarn or npm

๐Ÿš€ Getting Started

  1. Clone the repository
    git clone https://github.com/paulfruitful/WalletMCP
    

  ```bash
  cd walletMCP
  1. Install dependencies

    npm install
    
  2. Build the MCP Server

    npm run build
    

Test The Server:

To test the server you can use Claude Desktop MCP Client. Click here to download the desktop application: Download Claude Desktop

For Claude Desktop

Run the following command this command to open the Claude Desktop Config File

On Windows:

   code $env:AppData\Claude\claude_desktop_config.json

On Mac/Linux:

   code ~/Library/Application\ Support/Claude/claude_desktop_config.json

After opening the config file, add the server:

{
  "mcpServers": {
    "walletmcp": {
      "command": "node",
      "args": [
          "YOUR_PATH_PREFIX\\WalletMCP\\build\\index.js"
      ]
  }
  }
}

It's all set! You can now use the tools provided by the server in Claude Desktop. You can activate these tools on the Claude client by asking questions relating to the Solana wallet.

Claim Rents Back

Questions & Prompts like:

  • "What are my recent transactions?"

  • "How much SOL do I have?"

  • "How many buffers do I have unused?"

  • "Can You send SOL to account [accountAddress]?"

  • "What are the logs for a specific program [programId]?"

โš™๏ธ Tools & Their Descriptions

getTransactions

Description: Retrieve recent transactions of a wallet.
Inputs:

  • walletAddress (string)
  • limit (number) - maximum number of transactions to fetch.

getBalance

Description: Fetch the SOL balance of a wallet.
Inputs:

  • walletAddress (string)

listBuffers

Description: List program buffers associated with a payer key.
Inputs:

  • payerKey (array of numbers)

closeBuffer

Description: Close a buffer and return lamports to the payer.
Inputs:

  • bufferPubkey (string)
  • payerKey (array of numbers)

getProgramLogs

Description: Fetch transaction logs from a specific program ID.
Inputs:

  • programId (string)
  • limit (number) - optional, default is 10

sendSolTransaction

Description: Send SOL from one wallet to another.
Inputs:

  • fromPrivateKey (array of numbers)
  • toPublicKeyStr (string)
  • amountSol (number)
  • mode ("main" | "dev")

๐Ÿ›ก๏ธ Security Considerations

  • Always protect your private keys.
  • Keys are not stored or logged in the server

๐Ÿค Contributing

This project is open to contributions from the Solana dev community. If you have ideas for improvements, feel free to open an issue or submit a pull request.