https://github.com/celo-org/celo-mcp
  
  
    MCP server that provides AI agents with access to Celo blockchain data and functionality 
    https://github.com/celo-org/celo-mcp
  
        Last synced: 17 days ago 
        JSON representation
    
MCP server that provides AI agents with access to Celo blockchain data and functionality
- Host: GitHub
 - URL: https://github.com/celo-org/celo-mcp
 - Owner: celo-org
 - License: other
 - Created: 2025-05-26T13:08:04.000Z (5 months ago)
 - Default Branch: main
 - Last Pushed: 2025-07-20T08:04:05.000Z (4 months ago)
 - Last Synced: 2025-07-29T05:47:02.023Z (3 months ago)
 - Language: Python
 - Size: 551 KB
 - Stars: 4
 - Watchers: 0
 - Forks: 4
 - Open Issues: 4
 - 
            Metadata Files:
            
- Readme: README.md
 - License: LICENSE
 
 
Awesome Lists containing this project
- awesome-mcp-servers - **celo-mcp** - MCP server that provides AI agents with access to Celo blockchain data and functionality `python` `mcp` `server` `ai` `pip install git+https://github.com/celo-org/celo-mcp` (🤖 AI/ML)
 - awesome-mcp-servers - **celo-mcp** - MCP server that provides AI agents with access to Celo blockchain data and functionality `python` `mcp` `server` `ai` `pip install git+https://github.com/celo-org/celo-mcp` (AI/ML)
 
README
          # Celo MCP Server
A Model Context Protocol (MCP) server for interacting with the Celo blockchain. This server provides comprehensive access to Celo blockchain data, token operations, NFT management, smart contract interactions, transaction handling, and governance operations.
## Installation
1. Clone the repository:
```bash
git clone https://github.com/celo-org/celo-mcp
cd celo-mcp
```
2. Install dependencies:
```bash
pip install -e .
```
3. Set up environment variables (optional):
```bash
export CELO_RPC_URL="https://forno.celo.org"  # Default: Celo mainnet
export CELO_TESTNET_RPC_URL="https://alfajores-forno.celo-testnet.org"  # Alfajores testnet
```
## MCP Integration
### Cursor IDE Integration
To use this MCP server with Cursor IDE, add the following configuration to your MCP settings file (`~/.cursor/mcp.json`):
```json
{
  "mcpServers": {
    "celo-mcp": {
      "command": "uvx",
      "args": ["--refresh", "celo-mcp"]
    }
  }
}
```
The `--refresh` flag ensures that the latest code is always loaded when the MCP server starts.
### Claude Desktop Integration
For Claude Desktop, add this configuration to your MCP settings file (`~/Library/Application Support/Claude/claude_desktop_config.json` on macOS):
```json
{
  "mcpServers": {
    "celo-mcp": {
      "command": "uvx",
      "args": ["--refresh", "celo-mcp"]
    }
  }
}
```
## Usage
### Running the Server
```bash
# Run the MCP server
python -m celo_mcp.server
# Or use the CLI entry point
celo-mcp-server
```
### Available Tools
#### Blockchain Data Operations
1. **get_network_status**
   - Get current network status and connection information
   - No parameters required
2. **get_block**
   - Fetch block information by number, hash, or "latest"
   - Parameters: `block_identifier`, `include_transactions` (optional)
3. **get_transaction**
   - Get transaction details by hash
   - Parameters: `tx_hash`
4. **get_account**
   - Get account information including balance and nonce
   - Parameters: `address`
5. **get_latest_blocks**
   - Get information about recent blocks
   - Parameters: `count` (optional, default: 10, max: 100)
#### Token Operations
6. **get_token_info**
   - Get detailed token information (name, symbol, decimals, supply)
   - Parameters: `token_address`
7. **get_token_balance**
   - Get token balance for a specific address
   - Parameters: `token_address`, `address`
8. **get_celo_balances**
   - Get CELO and stable token balances for an address
   - Parameters: `address`
#### NFT Operations
9. **get_nft_info**
   - Get NFT information including metadata and collection details
   - Parameters: `contract_address`, `token_id`
10. **get_nft_balance**
    - Get NFT balance for an address (supports ERC721 and ERC1155)
    - Parameters: `contract_address`, `address`, `token_id` (optional for ERC1155)
#### Smart Contract Operations
11. **call_contract_function**
    - Call a read-only contract function
    - Parameters: `contract_address`, `function_name`, `abi`, `function_args` (optional), `from_address` (optional)
12. **estimate_contract_gas**
    - Estimate gas for a contract function call
    - Parameters: `contract_address`, `function_name`, `abi`, `from_address`, `function_args` (optional), `value` (optional)
#### Transaction Operations
13. **estimate_transaction**
    - Estimate gas and cost for a transaction
    - Parameters: `to`, `from_address`, `value` (optional), `data` (optional)
14. **get_gas_fee_data**
    - Get current gas fee data including EIP-1559 fees
    - No parameters required
#### Governance Operations
15. **get_governance_proposals**
    - Get Celo governance proposals with pagination support
    - Parameters: `include_inactive` (optional), `include_metadata` (optional), `page` (optional), `page_size` (optional), `offset` (optional), `limit` (optional)
16. **get_proposal_details**
    - Get detailed information about a specific governance proposal including content and voting history
    - Parameters: `proposal_id`
#### Staking Operations
17. **get_staking_balances**
    - Get staking balances for an address, including active and pending stakes broken down by validator group
    - Parameters: `address`
18. **get_activatable_stakes**
    - Get information about pending stakes that can be activated for earning rewards
    - Parameters: `address`
19. **get_validator_groups**
    - Get information about all validator groups, including their members, votes, capacity, and performance metrics
    - No parameters required
20. **get_validator_group_details**
    - Get detailed information about a specific validator group including its members and performance data
    - Parameters: `group_address`
21. **get_total_staking_info**
    - Get network-wide staking information including total votes and participation metrics
    - No parameters required
## Key Features
### Token Support
- **ERC20 Standard**: Full support for ERC20 tokens
- **Celo Stable Tokens**: Built-in support for cUSD, cEUR, and cREAL
- **Balance Queries**: Get token balances with proper decimal formatting
- **Token Information**: Retrieve name, symbol, decimals, and total supply
### NFT Support
- **Multi-Standard**: Support for both ERC721 and ERC1155 standards
- **Automatic Detection**: Automatically detects NFT standard using ERC165
- **Metadata Fetching**: Retrieves and parses NFT metadata from URIs
- **IPFS Support**: Built-in IPFS gateway support for metadata
- **Collection Information**: Get collection-level information
### Smart Contract Interactions
- **Function Calls**: Call read-only contract functions
- **Gas Estimation**: Estimate gas costs for contract interactions
- **ABI Management**: Parse and manage contract ABIs
- **Event Handling**: Retrieve and decode contract events
- **Transaction Building**: Build contract transactions
### Transaction Management
- **Gas Estimation**: Accurate gas estimation for transactions
- **EIP-1559 Support**: Modern fee structure with base fee and priority fee
- **Transaction Simulation**: Simulate transactions before execution
- **Fee Calculation**: Dynamic fee calculation based on network conditions
### Governance Support
- **Proposal Management**: Retrieve and analyze Celo governance proposals
- **Voting Data**: Access proposal voting history and results
- **Metadata Integration**: Fetch proposal metadata from GitHub repositories
- **Pagination Support**: Efficiently browse through large sets of proposals
### Staking Support
- **Staking Balances**: View active and pending stakes by validator group
- **Activation Tracking**: Check which pending stakes can be activated
- **Validator Information**: Comprehensive validator and validator group data
- **Performance Metrics**: Validator scores, election status, and capacity
- **Network Statistics**: Total voting power and staking participation
## Development
### Running Tests
```bash
# Install development dependencies
pip install -e ".[dev]"
# Run tests
pytest
# Run with coverage
pytest --cov=celo_mcp
```
### Code Quality
```bash
# Format code
black src/
isort src/
# Lint code
flake8 src/
mypy src/
```
## Contributing
1. Fork the repository
2. Create a feature branch
3. Make your changes
4. Add tests for new functionality
5. Ensure all tests pass
6. Submit a pull request
## License
This project is licensed under the MIT License - see the LICENSE file for details.
## Support
For questions, issues, or contributions, please:
1. Check the existing issues on GitHub
2. Create a new issue with detailed information
3. Join the community discussions
## Acknowledgments
- Built on the Model Context Protocol (MCP) framework
- Uses Web3.py for Ethereum/Celo blockchain interactions
- Supports the Celo ecosystem and its stable token infrastructure