Provides tools for interacting with Ethereum blockchain data via Etherscan's API, including checking ETH balances, viewing transaction history, tracking ERC20 token transfers, fetching contract ABIs and code, monitoring gas prices, and resolving ENS names.
MCP Etherscan Server
An MCP (Model Context Protocol) server that provides Ethereum blockchain data tools via Etherscan's API. Features include checking ETH balances, viewing transaction history, tracking ERC20 transfers, fetching contract ABIs, monitoring gas prices, and resolving ENS names.
Features
Balance Checking: Get ETH balance for any Ethereum address
Transaction History: View recent transactions with detailed information
Token Transfers: Track ERC20 token transfers with token details
Contract ABI: Fetch smart contract ABIs for development
Contract Code: Fetch smart contract code for development
Gas Prices: Monitor current gas prices (Safe Low, Standard, Fast)
ENS Resolution: Resolve Ethereum addresses to ENS names
Prerequisites
Node.js >= 18
An Etherscan API key (obtain one at https://etherscan.io/apis)
Installation
Installing via Smithery
To install MCP Etherscan Server for Claude Desktop automatically via Smithery:
Clone the repository:
Install dependencies:
Create a
.envfile in the root directory:
Build the project:
Running the Server
Start the server:
The server runs on stdio, making it compatible with MCP clients like Cursor and Claude Desktop.
How It Works
This server implements the Model Context Protocol (MCP) to provide tools for interacting with Ethereum blockchain data through Etherscan's API. Each tool is exposed as an MCP endpoint that can be called by compatible clients.
Available Tools
check-balanceInput: Ethereum address
Output: ETH balance in both Wei and ETH
get-transactionsInput: Ethereum address, optional limit
Output: Recent transactions with timestamps, values, and addresses
get-token-transfersInput: Ethereum address, optional limit
Output: Recent ERC20 token transfers with token details
get-contract-abiInput: Contract address
Output: Contract ABI in JSON format
get-contract-codeInput: Contract address
Output: Contract code in string format
get-gas-pricesInput: None
Output: Current gas prices in Gwei
get-ens-nameInput: Ethereum address
Output: Associated ENS name if available
Using with Cursor
To add this server to Cursor:
Open
Cursorand go toCursor settings->MCPSelect the option to either add the MCP Server
locallyorglobally, which will open a JSON configuration file.Add the configuration details. You can either add the MCP server via Smithery or via this repo locally:
Smithery
Using smithery.ai (This step requires a smithery.ai account)
Navigate to this URL in your web browser: https://smithery.ai/server/@ThirdGuard/mcp-etherscan-server
Enter your Etherscan API key in the field
etherscanApiKeyand click theconnectbuttonNavigate to the
Cursortab, copy the command, and run it in your terminal.
Manual
Paste the following configuration in the JSON file and replace
ETHERSCAN-API-KEY-HEREwith your Etherscan API key:{ "Etherscan Tools": { "command": "npx", "args": [ "-y", "@smithery/cli@latest", "run", "@ThirdGuard/mcp-etherscan-server", "--config", "\"{\\\"etherscanApiKey\\\":\\\"ETHERSCAN-API-KEY-HERE\\\"}\"" ] } }Local
Paste the following configuration in the JSON file and replace
ABSOLUTE-PATH-HERE/mcp-etherscan-server/start.shwith the absolute path to thestart.shin this repo:{ "Etherscan Tools (local)": { "command": "ABSOLUTE-PATH-HERE/mcp-etherscan-server/start.sh", "args": [] } }Save the configuration
The Etherscan tools will now be available in your Cursor AI conversations
Example Usage in Cursor
You can use commands like:
or
Development
To add new features or modify existing ones:
The main server logic is in
src/server.tsEtherscan API interactions are handled in
src/services/etherscanService.tsRun
npm run buildafter making changes
License
MIT License - See LICENSE file for details
This server cannot be installed