MCP GetBlock Server

MCP GetBlock Server

Enables querying blockchain data from Ethereum and Solana via GetBlock.io API, including wallet balances, transactions, gas prices, and account information.

Category
Visit Server

README

MCP GetBlock Server

Model Context Protocol (MCP) server for interacting with GetBlock.io API.

Features

  • Blockchain data requests from various networks (ETH, Solana)
  • Real-time blockchain statistics
  • Wallet balance checking
  • Transaction status monitoring
  • Getting Solana account information
  • Getting current gas price in Ethereum
  • JSON-RPC interface to blockchain nodes
  • Environment-based configuration for API tokens

Installation

Option 1: Standard Node.js Installation

  1. Install dependencies:
npm install
  1. Compile TypeScript:
npm run build
  1. Create a .env file with access tokens for different blockchains (optional):
# Access tokens for different blockchains
ETH_ACCESS_TOKEN=your_eth_access_token_here
SOLANA_ACCESS_TOKEN=your_solana_access_token_here
  1. Start the server:
npm start

Option 2: Using Docker

  1. Build the Docker image:
docker build -t mcp/getblock:latest .
  1. Run the container with environment variables:
docker run -i --rm \
  -e ETH_ACCESS_TOKEN=your_eth_access_token_here \
  -e SOLANA_ACCESS_TOKEN=your_solana_access_token_here \
  mcp/getblock:latest

Development

For development, you can use the command:

npm run dev

This command will compile TypeScript and start the server.

Use with Claude Desktop, Cursor, or other IDE

Option 1: Direct Launch via Node.js

  1. Configure Claude Desktop to use this server by editing claude_desktop_config.json:
{
    "mcpServers": {
        "getblock": {
            "command": "npm",
            "args": [
                "start",
                "--prefix",
                "/ABSOLUTE/PATH/TO/mcp-getblock"
            ],
            "env": {
                "ETH_ACCESS_TOKEN": "your_eth_access_token_here",
                "SOLANA_ACCESS_TOKEN": "your_solana_access_token_here"
            }
        }
    }
}

Option 2: Launch via Docker

  1. Configure Claude Desktop to use the Docker container:
{
    "mcpServers": {
        "getblock": {
            "command": "docker",
            "args": [
                "run",
                "-i",
                "--rm",
                "-e",
                "ETH_ACCESS_TOKEN",
                "-e",
                "SOLANA_ACCESS_TOKEN",
                "mcp/getblock:latest"
            ],
            "env": {
                "ETH_ACCESS_TOKEN": "your_eth_access_token_here",
                "SOLANA_ACCESS_TOKEN": "your_solana_access_token_here"
            }
        }
    }
}
  1. Restart Claude Desktop
  2. You should see the available tools in the toolbar

Available Tools

  1. get-chain-info - get general information about a blockchain network (ETH, Solana)
  2. get-wallet-balance - check wallet balance on the blockchain
  3. get-transaction - get details about a specific transaction
  4. get-latest-blocks - get information about the latest blocks
  5. get-solana-account - get information about a Solana account
  6. get-eth-gas-price - get current gas price in the Ethereum network

Detailed Tool Descriptions

get-chain-info

{
  "name": "get-chain-info",
  "description": "Get general information about a blockchain network",
  "inputSchema": {
    "properties": {
      "chain": {
        "type": "string",
        "description": "Blockchain network (e.g., eth, solana)",
        "default": "eth"
      }
    }
  }
}

get-wallet-balance

{
  "name": "get-wallet-balance",
  "description": "Get the balance of a wallet address on a blockchain",
  "inputSchema": {
    "properties": {
      "address": {
        "type": "string",
        "description": "The wallet address to check"
      },
      "chain": {
        "type": "string",
        "description": "Blockchain network (e.g., eth, solana)",
        "default": "eth"
      }
    },
    "required": ["address"]
  }
}

get-transaction

{
  "name": "get-transaction",
  "description": "Get details of a specific transaction",
  "inputSchema": {
    "properties": {
      "txid": {
        "type": "string",
        "description": "Transaction ID/hash"
      },
      "chain": {
        "type": "string",
        "description": "Blockchain network (e.g., eth, solana)",
        "default": "eth"
      }
    },
    "required": ["txid"]
  }
}

Access Token Priority Order

Access tokens are used in the following priority order:

  1. Tokens passed through environment variables (env in claude_desktop_config.json)
  2. Tokens from the .env file
  3. Default values (if not specified in items 1 and 2)

Architecture & Technology Stack

  • Language: TypeScript (compiled to JavaScript)
  • Runtime: Node.js
  • Communication Protocol: Model Context Protocol (MCP)
  • API Integration: GetBlock.io JSON-RPC API
  • Authentication: Token-based API authentication
  • Transport Layer: Standard I/O (stdio) for communication with Claude Desktop
  • Dependencies:
    • @modelcontextprotocol/sdk: For MCP implementation
    • axios: HTTP client for API requests
    • dotenv: Environment variable management

Supported Networks

As of June 2025, this MCP server supports the following blockchain networks:

Primary Networks

  • Ethereum (ETH) - Full support for balance, transaction, block, and gas price queries
  • Solana (SOL) - Support for balance, account info, transaction, and block queries

Future Expansions

Support for additional networks from GetBlock.io's infrastructure (which includes over 75+ blockchain networks [1]) can be implemented by extending the current codebase.

Examples of Usage

Checking ETH Balance

You can ask Claude to check the balance of an Ethereum wallet by using the get-wallet-balance tool:

What is the balance of this Ethereum wallet: 0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045?

Viewing Transaction Details

To get information about a specific transaction:

Can you show me the details of this Ethereum transaction: 0x0ac94a788a79e3eaa72a33f1da97b79728b570054fe156a7f60e06f5791aaf36?

Getting Current Gas Price

To check the current gas prices on Ethereum:

What are the current gas prices on Ethereum?

Implementation Details

Server Architecture

The server follows a simple architecture:

  1. Initialization: The server initializes using the MCP SDK and configures the supported tools
  2. Tool Registration: Each blockchain operation is registered as a separate tool with its own input schema
  3. Request Handling: Incoming requests are processed by the main handler which:
    • Extracts the tool name and arguments
    • Validates input parameters
    • Constructs the appropriate JSON-RPC call to GetBlock API
    • Processes the response and returns formatted results
  4. Authentication: API tokens are managed with a priority system using environment variables

Code Structure

  • Tool Definitions: Each blockchain operation is defined as a separate tool with metadata
  • Request Handler: Main logic for processing tool invocations
  • API Integration: Helper functions for constructing and sending requests to GetBlock
  • Response Processing: Formatting and conversion of blockchain data (e.g., wei to ether)

Troubleshooting

API Connection Issues

If you encounter connection issues to the GetBlock API:

  1. Verify that your access tokens are correctly set in environment variables or .env file
  2. Check if the GetBlock service is operational
  3. Ensure your network can reach the GetBlock API servers

Invalid Response Format

If you receive error messages about invalid response format:

  1. Verify that the blockchain and method you're using are supported by GetBlock
  2. Check if your access token has sufficient permissions
  3. Ensure the parameters are correctly formatted for the specific blockchain

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

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.

Official
Featured