Portfolio Manager MCP Server
A server providing tools and resources for managing and analyzing investment portfolios.
Portfolio Manager MCP Server
A Model Context Protocol (MCP) server that provides tools and resources for managing and analyzing investment portfolios.
Features
- Portfolio Management: Create and update investment portfolios with stocks and bonds
- Market Data: Fetch real-time stock price information and relevant news
- Analysis: Generate comprehensive portfolio reports and performance analysis
- Recommendations: Get personalized investment recommendations based on portfolio composition
- Visualization: Create visual representations of portfolio allocation
Installation
-
Clone this repository:
git clone https://github.com/ikhyunAn/portfolio-manager-mcp.git cd portfolio-manager-mcp
-
Install the required dependencies:
pip install -r requirements.txt
-
Set up API keys (optional):
export ALPHA_VANTAGE_API_KEY="your_key_here" export NEWS_API_KEY="your_key_here"
Alternatively, create a
.env
file in the root of the directory and store the API keys
Usage
Running the Server
You can run the server in two different modes:
-
Stdio Transport (default, for Claude Desktop integration):
python main.py # alternate commands: i.e.) python3, python3.11
-
SSE Transport (for HTTP-based clients):
python main.py --sse
Integration with Claude Desktop
Add the server to your Claude Desktop configuration file:
{
"mcpServers": {
"portfolio-manager": {
"command": "python", // may use different command
"args": ["/path/to/portfolio-manager-mcp/main.py"],
"env": {
"ALPHA_VANTAGE_API_KEY": "your_key_here",
"NEWS_API_KEY": "your_key_here"
}
}
}
}
If you choose to run your server in a virtual environment, then your configuration file will look like:
{
"mcpServers": {
"portfolio-manager": {
"command": "/path/to/portfolio-manager-mcp/venv/bin/python",
"args": ["/path/to/portfolio-manager-mcp/main.py"],
"env": {
"PYTHONPATH": "/path/to/portfolio-manager-mcp",
"ALPHA_VANTAGE_API_KEY": "your_key_here",
"NEWS_API_KEY": "your_key_here"
}
}
}
}
To run it in a virtual environment:
# Create a virtual environment
python3 -m venv venv
# Activate the virtual environment
source venv/bin/activate # On macOS/Linux
# or
# venv\Scripts\activate # On Windows
# Install dependencies
pip install -r requirements.txt
# Run the server
python3 main.py
Or use the MCP CLI for easier installation:
mcp install main.py
Example Queries
Once the server is running and connected to Claude, you can interact with it using natural language:
- "Create a portfolio with 30% AAPL, 20% MSFT, 15% AMZN, and 35% US Treasury bonds with user Id <User_ID>"
- "What's the recent performance of my portfolio?"
- "Show me news about the stocks in my portfolio"
- "Generate investment recommendations for my current portfolio"
- "Visualize my current asset allocation"
Project Structure
portfolio-manager/
├── main.py # Entry point
├── portfolio_server/ # Main package
│ ├── api/ # External API clients
│ │ ├── alpha_vantage.py # Stock market data API
│ │ └── news_api.py # News API
│ ├── data/ # Data management
│ │ ├── portfolio.py # Portfolio models
│ │ └── storage.py # Data persistence
│ ├── resources/ # MCP resources
│ │ └── portfolio_resources.py # Portfolio resource definitions
│ ├── tools/ # MCP tools
│ │ ├── analysis_tools.py # Portfolio analysis
│ │ ├── portfolio_tools.py # Portfolio management
│ │ ├── stock_tools.py # Stock data and news
│ │ └── visualization_tools.py # Visualization tools
│ └── server.py # MCP server setup
└── requirements.txt # Dependencies
Future Work
As of now, the MCP program uses manually created JSON file which keeps track of each user's investment portfolio.
This should be fixed so that it reads in the portfolio data from actual banking applications.
Tasks
- Extract JSON from a Finance or Banking Application which the user uses
- Enable modifying the investment portfolio by the client
- Implement automated portfolio rebalancing
- Add support for cryptocurrency assets
- Develop mobile application integration
License
MIT
Related Servers
Feishu/Lark OpenAPI MCP
Connect AI agents with the Feishu/Lark platform for automation, including document processing, conversation management, and calendar scheduling.
Ultimate Google Docs & Drive MCP Server
Interact with Google Docs and Google Drive for document creation, editing, and file management.
Notion ReadOnly MCP Server
An optimized, read-only MCP server for the Notion API with asynchronous processing.
Paperless-MCP
An MCP server for interacting with a Paperless-NGX API server. This server provides tools for managing documents, tags, correspondents, and document types in your Paperless-NGX instance.
Hyperspell
A spellchecker and grammar checker for developers, requiring a Hyperspell token for authentication.
PyApple MCP Tools
Python tools for MCP that integrate with native Apple applications like Messages, Notes, Mail, and more on macOS.
Trello
Interact with Trello boards, lists, and cards using the Trello API.
RevenueCat to Adapty Migration
A server for migrating subscription businesses from RevenueCat to Adapty, requiring a RevenueCat API key.
MCP-Zentao
An API integration for the Zentao project management system, supporting task management and bug tracking.
LearnMCP Server
An MCP server that enhances the Forest application with learning content extraction and summarization capabilities.