StocksMCP
AI-powered stock research MCP server with real-time data, CRUD operations, and interactive dashboard for fundamental analysis and comparisons.
README
š MCP Stock Research Agent & Dashboard
An AI-powered stock research platform built using the Model Context Protocol (MCP). It implements a fully compliant FastMCP server exposing fundamental analysis, local file-based database CRUD tools, and a dynamic dashboard layout via the Prefab UI protocol, combined with a standalone FastAPI + HTML5 interactive browser terminal.
šļø Architecture
User Prompt (e.g., "Analyze National Aluminium")
ā
ā¼
āāāāāāāāāāāāāāāā
ā MCP Client ā
ā (Agent) ā
āāāāāāāā¬āāāāāāāā
ā (stdio connection)
ā¼
āāāāāāāāāāāāāāāā
ā MCP Server ā
ā (FastMCP) ā
āāāāāāāā¬āāāāāāāā
ā
āāāāāāāāāāāāāāāāāāāāāāāāāāāāā¼āāāāāāāāāāāāāāāāāāāāāāāāāāāā
ā¼ ā¼ ā¼
āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā
ā Internet Tool ā ā CRUD Tool ā ā UI Tool ā
ā ā ā ā ā (Prefab UI) ā
ā yfinance API ā ā local reports/ ā ā Generative App ā
āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā āāāāāāāāāāāāāāāāāāā
The system is split into two access interfaces:
- MCP Protocol Interface: For AI agent clients (like Claude Desktop) using Stdio transport and Prefab UI.
- Standalone Web Terminal: A browser interface at
http://localhost:8000presenting a fully responsive dark-themed terminal with real-time Plotly.js charts, quarterly indicators, and side-by-side stock comparisons.
ā” Key Features
- Internet Data Tool: Real-time fundamentals, quarterly statement retrieval, and historical OHLCV pricing via
yfinance. - Local CRUD Tool: Persistent JSON storage for analyzed stocks under
reports/. - UI Communication (Prefab UI): Exposes structural layout component trees (
show_dashboard) to MCP-compatible rendering clients. - Valuation Estimation Model: Calculates growth-adjusted fair PE, EPS, and valuation gap percentage.
- Growth Scoring System: Evaluates companies out of 10 points based on quarterly revenue/PAT trends, ROE, debt-to-equity, and promoter holdings.
- Interactive Candlestick Charts: Fully interactive Plotly.js charting (Zoom, Pan, Hover details, Date range slider).
- Stock Comparison: Compare two stocks side-by-side on all fundamental metrics.
š ļø Setup Instructions
1. Prerequisites
- Python 3.8 or higher installed on your system.
2. Project Directory Installation
Clone or navigate to the project directory:
cd /Users/pawanthanay/Project/StocksMCP
3. Create a Virtual Environment and Install Dependencies
Initialize a Python virtual environment, activate it, and install all required modules (this also installs prefab-ui, the rendering engine behind the show_dashboard Prefab UI tool):
python3 -m venv venv
source venv/bin/activate
pip install -r requirements.txt
macOS / Homebrew Python troubleshooting: If
pip installfails withImportError: ... Symbol not found: _XML_SetAllocTrackerActivationThreshold(a known Homebrew Python 3.12 ā systemlibexpatmismatch), prefix yourpip/python3commands with the Homebrew expat lib path, e.g.:export DYLD_LIBRARY_PATH="$(brew --prefix expat)/lib:$DYLD_LIBRARY_PATH" pip install -r requirements.txt
4. Configuration
Create a .env file from the example:
cp .env.example .env
š Running the Application
Option A: Running the Standalone Web Dashboard (Recommended)
This starts the FastAPI web server. You can view the dashboard in any standard browser:
python3 -m src.web_dashboard
Once started, open your browser and go to: š http://localhost:8000
Select stocks from the dropdown (e.g. National Aluminium, TCS, Infosys) to perform live analysis, view interactive Plotly candlestick charts, read AI-generated summaries, and run comparisons.
Option B: Running the MCP Client Agent (Automatic Workflow)
Run the client script to execute the agentic loop. The agent connects to the server, fetches data, performs calculations, saves the JSON report, and registers the Prefab dashboard:
python3 -m src.client "Analyze National Aluminium stock"
To run a different stock, pass it in the prompt:
python3 -m src.client "Analyze TCS stock"
Option C: Testing the MCP Server Directly
To run the server in stdio mode (for Claude Desktop or testing):
python3 -m src.server
āļø Deploying the Web Dashboard (Render)
The web dashboard is a standard FastAPI app and can be deployed for free on Render:
- Fork or push this repo to your own GitHub account.
- On Render, choose New + ā Blueprint and point it at your repo ā it will
pick up
render.yamlautomatically and configure the build (pip install -r requirements.txt) and start (uvicorn src.web_dashboard:app --host 0.0.0.0 --port $PORT) commands. - Click Apply / Create Web Service. Render builds and deploys
automatically, and redeploys on every push to
main. - Once live, share the
https://<your-service>.onrender.comURL ā every visitor gets the same live Yahoo Finance data, fetched fresh per request.
No server-side secrets are required: each visitor supplies their own optional
Gemini API key directly in the dashboard UI (used only for that request, never
stored server-side ā see gemini_client.py).
Note: Render's free tier spins the service down after periods of inactivity, so the first request after idling can take ~30ā60 seconds to wake up.
š Growth Scoring System
Ratios are checked and scored out of 10 points:
- Revenue Growth QoQ: Growing = 2 points, Flat = 1 point, Declining = 0 points
- PAT Growth QoQ: Growing = 2 points, Flat = 1 point, Declining = 0 points
- ROE (Return on Equity): >15% = 2 points, 10-15% = 1 point, <10% = 0 points
- Debt-to-Equity: <50% (0.5) = 2 points, 50-100% (0.5-1.0) = 1 point, >100% = 0 points
- Promoter Holdings: >=50% = 2 points, 30-50% = 1 point, <30% = 0 points
Growth Categories:
- 0-4 Points: š“ Weak
- 5-7 Points: š” Neutral
- 8-10 Points: š¢ Growth
š Project Structure
StocksMCP/
āāā requirements.txt # Python dependencies (fastmcp, yfinance, fastapi, etc.)
āāā .env.example # Template for server & dashboard config
āāā .gitignore # Git rules (ignoring .env and reports/*.json)
āāā reports/ # Directory where local JSON reports are saved
ā āāā NATIONALUM_NS.json # Sample generated report
āāā src/
ā āāā __init__.py # Package init
ā āāā server.py # FastMCP Server containing tool endpoints
ā āāā client.py # MCP client agent running automatic pipelines
ā āāā data_fetcher.py # yfinance scraper & parser
ā āāā analyzer.py # Computes fair value, growth scores, & AI summaries
ā āāā dashboard.py # Prefab UI layout compiler
ā āāā web_dashboard.py # FastAPI server backend
āāā templates/
āāā dashboard.html # HTML5 terminal dashboard with Plotly charts
š Verification Checklist
To verify all requirements are met:
- Tool 1: fetch_stock_data: Call
fetch_stock_data("NATIONALUM.NS")ā returns raw stock fundamentals, financials, and historical price history. - Tool 2: save_stock_report: Call
save_stock_report("NATIONALUM", report)ā createsreports/NATIONALUM_NS.jsonwith calculated metrics, AI summary, and raw data. - Tool 3: show_dashboard: Call
show_dashboard("NATIONALUM.NS")ā registers and returns structural generative UI. - CRUD CRUD CRUD: Test update/delete tools (
update_stock_reportanddelete_stock_report). - FastAPI Web Server: Run
python3 -m src.web_dashboardand inspect interactive elements athttp://localhost:8000.
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.
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.
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.
E2B
Using MCP to run code via e2b.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.