Supports storing API keys in .env files for secure configuration management, enabling access to external data services without hardcoding credentials.
Enables source code retrieval through git clone commands for initial setup.
Hosts the repository for the MCP server, allowing users to clone and access the codebase through git.
Supports Linux environments with specific instructions for setup and virtual environment activation.
Provides specific instructions for running in macOS environments, including virtual environment activation commands.
Built on Python, supporting various execution environments including virtual environments for dependency management.
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
Related MCP server: Twelve Data MCP Server
Installation
Clone this repository:
git clone https://github.com/ikhyunAn/portfolio-manager-mcp.git cd portfolio-manager-mcpInstall the required dependencies:
pip install -r requirements.txtSet up API keys (optional):
export ALPHA_VANTAGE_API_KEY="your_key_here" export NEWS_API_KEY="your_key_here"Alternatively, create a
.envfile 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.11SSE Transport (for HTTP-based clients):
python main.py --sse
Integration with Claude Desktop
Add the server to your Claude Desktop configuration file:
If you choose to run your server in a virtual environment, then your configuration file will look like:
To run it in a virtual environment:
Or use the MCP CLI for easier installation:
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
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