MCP Personal Assistant Agent
A versatile AI personal assistant for managing your calendar, tasks, emails, web searches, and smart home.
MCP Personal Assistant Agent
A versatile personal assistant AI agent built with the Model Context Protocol (MCP) that helps with calendar, tasks, emails, and more.
Overview
This project is a Model Context Protocol (MCP) server that provides a set of tools for a personal assistant agent. It can be integrated with MCP clients like Claude for Desktop to give AI assistants the ability to:
- Manage calendar events
- Track tasks and to-dos
- Read and send emails
- Search the web and retrieve information
- Control smart home devices
Requirements
⚠️ IMPORTANT: Python 3.10 or higher is required for the MCP SDK. The server will not work with earlier Python versions.
- Python 3.10+
- MCP SDK 1.2.0+
- Required Python packages (see requirements.txt)
Installation
- Clone the repository:
git clone https://github.com/yourusername/mcp-pa-ai-agent.git
cd mcp-pa-ai-agent
- Ensure you have Python 3.10+:
python --version
- If your system Python is older than 3.10, set up a compatible environment:
# Using conda
conda create -n mcp-env python=3.10
conda activate mcp-env
# OR using venv (if Python 3.10+ is installed elsewhere)
python3.10 -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
- Install dependencies:
pip install -r requirements.txt
- Configure environment variables by copying the example file:
cp .env.example .env
- Edit the
.envfile with your API credentials and settings.
Running the Server
Start the MCP server with:
python mcp_server.py
The server will start and listen for MCP client connections.
Connecting to Claude for Desktop
-
Install Claude for Desktop
-
Configure Claude for Desktop to use this MCP server by editing the configuration file at:
- MacOS/Linux:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
- MacOS/Linux:
-
Add the following configuration:
{
"mcpServers": {
"personal-assistant": {
"command": "/path/to/python",
"args": [
"/absolute/path/to/mcp-pa-ai-agent/mcp_server.py"
]
}
}
}
If you're using a virtual environment, make sure to point to the Python executable in that environment.
- Restart Claude for Desktop
Available Tools
Calendar
get_events: Retrieve upcoming calendar eventscreate_event: Schedule a new calendar event
Tasks
list_tasks: View all tasks or filter by statusadd_task: Create a new taskupdate_task_status: Mark tasks as pending, in-progress, or completed
get_emails: List recent emails from your inboxread_email: View the full content of a specific emailsend_email: Compose and send a new email
Knowledge
web_search: Search the web for informationget_weather: Get current weather informationget_news: Retrieve latest news articles
Smart Home
list_devices: View all smart home devicescontrol_device: Control smart home devices (lights, thermostats, etc.)get_device_state: Get detailed information about a device's current state
Configuration
The server requires various API keys and credentials to access different services:
- Google API: For calendar and email functionality (OAuth2 credentials)
- Weather API: For weather information
- News API: For news retrieval
- Home Assistant: For smart home control
Refer to the .env.example file for all configurable options.
Troubleshooting
Python Version Issues
If you see an error like:
Error: Python 3.10 or higher is required for the MCP server.
You need to upgrade your Python version or use a virtual environment with Python 3.10+.
MCP SDK Installation Issues
If you encounter problems installing the MCP SDK:
ERROR: Could not find a version that satisfies the requirement mcp>=1.2.0
Make sure you're using Python 3.10+ and pip is updated:
pip install --upgrade pip
Development
To add new functionality to the server, you can:
- Create a new module in the
modules/directory - Implement functions with the
@mcp.tool()decorator - Import your module in
mcp_server.py
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
相关服务器
Evernote
Connects your Evernote account to an LLM, enabling natural language search and queries over your notes.
Sheet-Cello
A specialized Google Sheets integration server that allows the LLM to read, write, and manage spreadsheet data in real-time. This server supports cell-level manipulation, bulk range updates, and full worksheet retrieval, enabling the model to perform data analysis, logging, and automated reporting directly within Google Worksheets.If you have functions which take range value then first read the sheet and decide where user is asking to add data and define range by your own.Provides 46 tools for Gsheet
Intugle MCP
Generate automated semantic models using data engineering agents and built data products on demand
OneNote MCP Server
An MCP server for Microsoft OneNote, allowing AI models to interact with notebooks, sections, and pages. Requires Azure credentials.
Agile Luminary
Connects AI clients to the Agile Luminary project management system via its REST API.
Handwriting OCR
Recognize and extract text from handwritten documents using the Handwriting OCR service.
mindpm
Persistent project & task management for AI coding assistants. Track tasks, decisions, and notes across sessions with a real-time Kanban board. Works with Claude Code, Cursor, Cline, Copilot, and Windsurf.
Obsidian Local REST API
Interact with your local Obsidian vault using a REST API.
Bakaláři
Access data from the Bakaláři school system, including schedules, absences, and grades, through a standardized API.
Rememberizer Common Knowledge
Access personal and team knowledge repositories, including documents and Slack discussions.