A comprehensive Model Context Protocol (MCP) server for stock analysis and trading insights. This server provides advanced stock screening, fundamental analysis, insider trading data, social media sentiment, and news analysis capabilities.
trading-mcp.mp4
See the Trading MCP Server in action - from stock screening to comprehensive analysis
Add this to your MCP configuration file (typically ~/.cursor/mcp.json
or your IDE's MCP settings):
{
"mcpServers": {
"trading-mcp": {
"command": "node",
"args": ["/path/to/trading-mcp/dist/server.js"],
"env": {
"OPENAI_API_KEY": "sk-your-openai-api-key-here",
"REDDIT_CLIENT_ID": "your-reddit-client-id",
"REDDIT_CLIENT_SECRET": "your-reddit-client-secret",
"REDDIT_USERNAME": "your-reddit-username",
"REDDIT_PASSWORD": "your-reddit-password"
}
}
}
}
- π Stock Screening: Technical pattern recognition and advanced multi-criteria filtering
- π Fundamental Analysis: Comprehensive metrics, valuation comparison, and AI health scoring
- π’ Insider Trading: Real-time insider activity tracking and sentiment analysis
- π Options Analysis: Put/call ratio data and options market sentiment analysis
- π Social Media Research: Reddit integration with AI-powered sentiment analysis
- π° News Analysis: AI-curated news with market impact assessment
- π― Comprehensive Analysis: All-in-one stock analysis combining multiple data sources
Note:
- OpenAI API key is required for news analysis and social sentiment analysis
- Reddit credentials are required for social media research features
Advanced stock screening using Finviz filters with support for technical patterns, fundamental criteria, and multi-parameter filtering. Returns stocks matching specific criteria with key metrics.
Parameters:
filters
(object): Finviz format filters. Use "f" for basic filters, "o" for ordering. Example:{"f": "cap_large,fa_pe_profitable,ta_pattern_channeldown", "o": "marketcap"}
limit
(number, default: 50): Maximum results to return
Retrieves comprehensive financial metrics including P/E ratios, PEG, ROE, debt ratios, growth rates, and profitability margins.
Parameters:
ticker
(string, required): Stock ticker symbolmetrics
(array, optional): Specific metrics to retrieve (returns all if not specified)
Compares valuation metrics across multiple stocks to identify relative value opportunities. Perfect for peer analysis and sector comparisons.
Parameters:
tickers
(array, required): Stock ticker symbols to comparemetrics
(array, default: ['pe', 'forwardPE', 'peg', 'priceToBook']): Valuation metrics to compare
Calculates a comprehensive financial health score (0-100) based on profitability, liquidity, leverage, efficiency, and growth metrics with customizable weightings.
Parameters:
ticker
(string, required): Stock ticker symbolweights
(object, optional): Custom weights for health factorsprofitability
(default: 0.3),liquidity
(default: 0.2),leverage
(default: 0.2),efficiency
(default: 0.15),growth
(default: 0.15)
Monitors insider transactions and analyzes sentiment patterns. Returns transaction history with sentiment analysis and confidence scores.
Parameters:
ticker
(string, required): Stock ticker symbollimit
(number, default: 10): Maximum transactions to returntransaction_types
(array, optional): Filter by transaction typesanalysis_period
(number, default: 90): Analysis period in daysmin_transaction_value
(number, default: 10000): Minimum transaction value threshold
Retrieves put/call ratio data from Barchart to assess options market sentiment. Returns ratios by expiration with sentiment analysis.
Parameters:
ticker
(string, required): Stock ticker symbol
All-in-one stock analysis combining fundamental metrics, financial health scoring, insider analysis, options sentiment, news analysis, and social sentiment when configured.
Parameters:
ticker
(string, required): Stock ticker symbol to analyze
Requires Reddit API configuration
Identifies stocks gaining attention across Reddit investing communities. Returns trending tickers with mention frequency and engagement metrics.
Parameters:
subreddits
(array, default: ['wallstreetbets', 'stocks']): Subreddits to analyzelimit
(number, default: 20): Maximum trending tickers to return
Requires both Reddit and OpenAI APIs
Searches Reddit discussions and uses AI to analyze retail investor sentiment. Returns posts with sentiment analysis and confidence scores.
Parameters:
ticker
(string, required): Stock ticker symbolsubreddits
(array, default: ['stocks', 'wallstreetbets', 'investing', 'ValueInvesting']): Subreddits to searchtime_filter
(string, default: 'week'): Time period ('hour', 'day', 'week', 'month', 'year')limit
(number, default: 25): Maximum posts to retrievesort
(string, default: 'hot'): Sort order ('relevance', 'hot', 'top', 'new')max_posts_for_sentiment
(number, default: 50): Posts to use for sentiment analysisinclude_comments
(boolean, default: false): Include comments from specific postpost_id_for_comments
(string, optional): Post ID for comment retrievalcomment_limit
(number, default: 100): Maximum comments if including comments
Requires OpenAI API configuration
Combines news sentiment analysis, market impact assessment, and sector context analysis. Returns analyzed articles with sentiment scores and market predictions.
Parameters:
ticker
(string, required): Stock ticker symboldays_back
(number, default: 7): Days to look back for newsmax_articles
(number, default: 10): Maximum articles to analyzeinclude_sentiment
(boolean, default: true): Include sentiment analysissector
(string, optional): Stock sector for enhanced contextnews_items
(array, optional): Specific headlines to analyze
- Clone and install dependencies:
git clone <repository-url>
cd trading-mcp
npm install
- Build the project:
npm run build
- Configure in your MCP client: Add the MCP configuration shown above to your MCP client settings with your API credentials.
- OpenAI: Required for news analysis and social sentiment analysis
- Reddit: Required for social media research features
- Visit OpenAI API
- Create an account or sign in
- Generate a new API key
- Add to your MCP configuration as
OPENAI_API_KEY
- Visit Reddit App Preferences
- Click "Create App" or "Create Another App"
- Choose "script" as the app type
- Note your
client_id
andclient_secret
- Add your Reddit credentials to your MCP configuration
trading-mcp/
βββ src/
β βββ server.ts # Main MCP server
β βββ config.ts # Configuration management
β βββ types/ # TypeScript interfaces
β β βββ index.ts
β βββ adapters/ # External API adapters
β β βββ finviz.ts # Finviz web scraping
β β βββ barchart.ts # Barchart options data scraping
β β βββ reddit.ts # Reddit API integration
β β βββ openai.ts # OpenAI API integration
β βββ tools/ # Tool implementations
β βββ screening.ts # Stock screening tools
β βββ fundamentals.ts # Fundamental analysis
β βββ insider.ts # Insider trading analysis
β βββ options.ts # Options analysis tools
β βββ social.ts # Social media research
β βββ news.ts # News analysis
β βββ comprehensive.ts # Comprehensive analysis
βββ dist/ # Compiled JavaScript
βββ package.json
βββ tsconfig.json
βββ README.md
- Finviz web scraping may occasionally fail due to rate limiting or site changes
- Barchart web scraping may occasionally fail due to site changes or rate limiting
- Reddit API has rate limits that may affect high-volume usage
- OpenAI API usage incurs costs based on tokens consumed
Once configured, you can use the tools through your MCP-enabled client:
# Screen for stocks with specific technical patterns
Use screen_stocks_advanced_filters with filters: {"f": "ta_pattern_channeldown,cap_large,geo_usa"}
# Get comprehensive fundamental analysis
Use get_fundamental_stock_metrics for "AAPL" to see detailed financial data
# Compare multiple stocks
Use compare_stock_valuations for ["AAPL", "MSFT", "GOOGL"] to compare valuations
# Calculate financial health score
Use calculate_financial_health_score for "TSLA" to get AI-powered health assessment
# Analyze insider activity
Use analyze_insider_activity for "NVDA" to see insider trading patterns and sentiment
# Get options market sentiment
Use get_put_call_ratio for "SPY" to see put/call ratios and options sentiment
# Comprehensive analysis (all-in-one)
Use comprehensive_stock_analysis for "AMZN" to get complete multi-dimensional analysis
# Analyze social sentiment (requires Reddit + OpenAI)
Use analyze_reddit_sentiment for "GME" to see Reddit community sentiment
# Get trending stocks (requires Reddit)
Use discover_trending_stocks to find stocks gaining social media momentum
# Analyze news and market context (requires OpenAI)
Use analyze_news_and_market_context for "META" to get news analysis and market context
This software is for educational and research purposes only. It is not intended as financial advice. Always do your own research and consider consulting with a qualified financial advisor before making investment decisions.
The data provided by this server comes from third-party sources and may not always be accurate or up-to-date. Users should verify information independently before making any trading decisions.
Stock trading and investing involves risk, including the potential loss of principal. Past performance does not guarantee future results.
For questions or support, please open an issue on GitHub.