PortalMCP
Universal AI gateway that enables interaction with Ethereum blockchain through natural language across multiple AI platforms (Claude, ChatGPT, Gemini, etc.). Supports contract deployment, token operations, NFT minting, DeFi operations, and general blockchain transactions.
README
PortalMCP - Universal AI Gateway to Ethereum
A multi-platform AI integration layer for Ethereum blockchain. Works with Claude, ChatGPT, Gemini, LLaMA, Mistral, and any LangChain-supported model. Deploy contracts, swap tokens, mint NFTs, and more - all through natural language.
π Supported AI Platforms
| Platform | Integration | Status |
|---|---|---|
| Claude Desktop | Native MCP | β Full Support |
| ChatGPT | REST API / Custom GPT | β Full Support |
| Cursor | Native MCP | β Full Support |
| Windsurf | Native MCP | β Full Support |
| OpenAI API | Function Calling | β Full Support |
| Google Gemini | LangChain | β Full Support |
| Mistral | LangChain | β Full Support |
| Ollama | LangChain | β Full Support |
| Any LLM | REST API | β Full Support |
Architecture Overview
βββββββββββββββββββ
β Claude/MCP βββββ Native MCP Protocol
ββββββββββ¬βββββββββ
β
βββββββββββββββ ββββββββββΌβββββββββ βββββββββββββββββββ
β ChatGPT βββββΆβ βββββΆβ β
β Gemini β β PortalMCP β β Ethereum β
β Mistral βββββΆβ βββββΆβ Blockchain β
β Ollama β β (Adapters) β β β
βββββββββββββββ βββββββββββββββββββ βββββββββββββββββββ
β β
βββ LangChain βββββββ
βββ REST API ββββββββ
PortalMCP bridges the gap between AI and blockchain, allowing you to perform complex Ethereum operations through simple natural language requests with ANY AI model.
Features
Contract Generation & Deployment
- Generate Solidity code via Claude
- Compile Solidity to bytecode
- Deploy to network (user signs via wallet)
Token Operations (ERC-20)
- Full ERC-20 creation flow
- Check token balances
- Transfer tokens
NFT Operations
- Deploy NFT contracts
- Mint NFTs
- Check NFT ownership
DeFi Operations
- Simple staking contracts
- Stake tokens
- DEX interactions
General Blockchain
- Get ETH balance
- Call any contract function
- Send transactions
Installation
Prerequisites
- Node.js v16 or higher
- npm or yarn
- An Ethereum wallet (MetaMask recommended)
- Access to Claude API
Setup
-
Clone the repository
git clone https://github.com/PortalFnd/portalmcp.git cd portalmcp -
Install dependencies
npm install -
Create a
.envfile based on.env.examplecp .env.example .env -
Add your API keys to the
.envfileANTHROPIC_API_KEY=your_claude_api_key INFURA_API_KEY=your_infura_key # or ALCHEMY_API_KEY=your_alchemy_key -
Build the project
npm run build -
Start the MCP server
npm start
Quick Start by Platform
π£ Claude Desktop (Native MCP)
Add to claude_desktop_config.json (~/Library/Application Support/Claude/ on macOS):
{
"mcpServers": {
"portalmcp": {
"command": "node",
"args": ["/absolute/path/to/portalmcp/dist/index.js"],
"env": {
"ETHEREUM_NETWORK": "mainnet",
"INFURA_API_KEY": "your_infura_key",
"DEPLOYER_PRIVATE_KEY": "your_private_key"
}
}
}
}
π’ ChatGPT (Custom GPT)
-
Start the REST API server:
npm run start:api -
Create a Custom GPT in ChatGPT
-
Add an Action with the OpenAPI spec from
http://localhost:3001/openapi.json -
For production, deploy to a public URL and use that instead
π΅ OpenAI Assistants API
import OpenAI from 'openai';
import { getOpenAITools, executeOpenAIToolCall } from 'portalmcp/adapters';
const openai = new OpenAI();
// Create assistant with Ethereum tools
const assistant = await openai.beta.assistants.create({
name: 'Ethereum Assistant',
model: 'gpt-4-turbo',
tools: getOpenAITools()
});
// Handle function calls
const result = await executeOpenAIToolCall('eth_get_balance', { address: '0x...' });
π‘ LangChain (Any LLM Provider)
import { getLangChainTools } from 'portalmcp/adapters';
import { ChatOpenAI } from '@langchain/openai';
import { ChatAnthropic } from '@langchain/anthropic';
import { ChatGoogleGenerativeAI } from '@langchain/google-genai';
const tools = getLangChainTools();
// Works with ANY provider!
const openai = new ChatOpenAI({ model: 'gpt-4-turbo' }).bindTools(tools);
const claude = new ChatAnthropic({ model: 'claude-3-opus' }).bindTools(tools);
const gemini = new ChatGoogleGenerativeAI({ model: 'gemini-pro' }).bindTools(tools);
π REST API (Universal)
# Start server
npm run start:api
# Check balance
curl http://localhost:3001/eth/balance/0x742d35Cc6634C0532925a3b844Bc9e7595f...
# Swap tokens
curl -X POST http://localhost:3001/swap \
-H "Content-Type: application/json" \
-d '{"tokenIn":"ETH","tokenOut":"USDT","amount":"0.01"}'
# Get OpenAPI spec (for any integration)
curl http://localhost:3001/openapi.json
Note: Replace paths and keys with your actual values. For testnet development, change
ETHEREUM_NETWORKtosepolia.
Example Conversations
Creating a Token
User: "Create an ERC-20 token called 'MyToken' with symbol 'MTK' and supply of 1 million"
Claude (using MCP tools):
- Uses
eth_generate_contractto create Solidity code - Shows you the code for review
- Uses
eth_deploy_contractafter your approval - Returns contract address and details
Checking Balances
User: "What's my USDC balance on Ethereum?"
Claude: Uses eth_get_token_balance and responds: "Your USDC balance is 1,250.50 USDC"
NFT Creation
User: "Deploy an NFT collection called 'Digital Art' and mint token #1 to my address"
Claude:
- Uses
eth_create_nft_collection - Uses
eth_mint_nft - Provides transaction hashes and opensea links
Security Model
- Non-custodial: Never handle private keys
- User approval: All transactions require user wallet signature
- Code review: Show generated contracts before deployment
- Network isolation: Support testnets for development
Available MCP Tools
Contract Operations
eth_generate_contract- Generate Solidity code via Claudeeth_compile_contract- Compile Solidity to bytecodeeth_deploy_contract- Deploy to network
Token Operations
eth_create_token- Create ERC-20 tokeneth_get_token_balance- Check token balanceeth_transfer_token- Transfer tokens
NFT Operations
eth_create_nft_collection- Create NFT collectioneth_mint_nft- Mint NFTeth_get_nft_owner- Check NFT ownership
DeFi Operations
eth_create_staking_contract- Create staking contracteth_stake_tokens- Stake tokenseth_swap_tokens- Swap tokens on DEX
General Operations
eth_get_balance- Get ETH balanceeth_call_contract- Call contract functioneth_send_transaction- Send transaction
Security
β οΈ Important Security Notes:
- Never commit your
.envfile - It contains sensitive API keys and private keys - Use testnets first - Always test on Sepolia before mainnet
- Review transactions - Always review transaction details before signing
- Private key safety - The
DEPLOYER_PRIVATE_KEYgives full control over that wallet
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
MIT
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
E2B
Using MCP to run code via e2b.