Trade-MCP
A modular trading automation project using the Zerodha Kite Connect API for tool-based and resource-based automation.
Trade-MCP
A modular trading automation project using Zerodha Kite Connect and MCP (Modular Command Platform) for tool-based and resource-based automation. This project exposes trading actions (like placing orders and fetching holdings) as MCP tools, making them accessible to Claude Desktop and other MCP-compatible clients.
Features
- Zerodha Integration: Place buy/sell orders and fetch holdings using the Kite Connect API.
- MCP Tools: Expose trading actions as callable tools for automation and AI agents.
- Environment-based Secrets: API keys and secrets are loaded from a
.env
file for security. - Extensible: Easily add new tools or resources for more trading actions.
Setup
1. Clone the Repository
git clone <your-repo-url>
cd Trade-MCP
2. Create and Activate a Virtual Environment
uv venv
.venv\Scripts\activate # On Windows
# or
source .venv/bin/activate # On Linux/Mac
3. Install Dependencies
uv pip install -r requirements.txt
# or, if using pyproject.toml:
uv pip install .
4. Configure Environment Variables
Create a .env
file in the project root:
API_KEY=your_zerodha_api_key
API_SECRET=your_zerodha_api_secret
5. Get Your Zerodha Access Token
To use the Zerodha API, you need an access token. Follow these steps:
-
Get Your API Key and Secret
- Obtain these from the Zerodha developer console.
-
Generate the Login URL
In a Python shell or script, run:from kiteconnect import KiteConnect kite = KiteConnect(api_key="your_api_key") print(kite.login_url())
- Open the printed URL in your browser and log in with your Zerodha credentials.
-
Extract the
request_token
- After login, you will be redirected to your redirect URL (set in the Zerodha app settings).
- The URL will look like:
http://localhost:8000/?request_token=REQUEST_TOKEN_HERE&action=login&status=success
- Copy the
request_token
value from the URL.
-
Exchange the
request_token
for anaccess_token
In a Python shell or script, run:data = kite.generate_session("REQUEST_TOKEN_HERE", api_secret="your_api_secret") print(data["access_token"])
- Replace
"REQUEST_TOKEN_HERE"
and"your_api_secret"
with your actual values. - The printed value is your
access_token
.
- Replace
-
Set the Access Token
- You can set this as an environment variable or use it directly in your code as needed.
Usage
Run the MCP Server
uv run --with mcp[cli] mcp run server.py
Or, if MCP CLI is installed in your environment:
mcp run server.py
Claude Desktop Integration
-
Add a server entry in your
claude_desktop_config.json
:{ "mcpServers": { "Trade-MCP": { "command": "uv.EXE", # Exact Path to uv executable "args": [ "run", "--with", "mcp[cli]", "mcp", "run", "server.py" # Exact Path to your server script ] } } }
-
Restart Claude Desktop.
-
The tools will appear in Claude's tool list.
Exposed Tools
add(a: int, b: int)
: Add two numbers.place_zerodha_buy_order(symbol: str, quantity: int)
: Place a buy order.place_zerodha_sell_order(symbol: str, quantity: int)
: Place a sell order.get_zerodha_holdings()
: Get all holdings from Zerodha.
Extending
To add a new tool, define a function in server.py
and decorate it with @mcp.tool()
:
@mcp.tool()
def my_tool(...):
...
License
MIT License
Related Servers
PydanticRPC
A Python library for building gRPC/ConnectRPC services with Pydantic models, featuring automatic protobuf generation and AI assistant tool exposure.
AILint
AI-powered code quality analysis to detect best practice violations, security issues, and architectural problems in real-time.
Petclinic
Interacts with the Swagger Petstore API using Petclinic v3 APIs, exposing tools for OpenAI models.
Lifecycle MCP Server
An MCP server for managing the software development lifecycle, with support for an optional external SQLite database.
Cisco NSO MCP Server
An MCP server for Cisco NSO that exposes its data and operations as MCP primitives.
Clangaroo
Provides fast C++ code intelligence for LLMs using the clangd language server.
Placid.app
Generate images and videos from templates using the Placid.app API.
AI Studio MCP Server
Integrates with Google AI Studio/Gemini API for PDF to Markdown conversion and content generation.
My MCP Server
A remote MCP server example deployable on Cloudflare Workers without authentication.
BaseCreative MCP
A template for deploying a remote MCP server on Cloudflare Workers without authentication.