tasks-mcp
Enables AI assistants to manage Notion tasks, projects, and courses through MCP, allowing creation, retrieval, and filtering of tasks.
README
<p align="center"> <a href="#"> <img width="130" height="130" src="https://github.com/markmusic27/tasks-mcp/blob/main/demo/logo.png?raw=true" alt="Logo"> </a> <h1 align="center"><b>tasks-mcp</b></h1> <p align="center"> ✶ An MCP server for seamless Notion task management ✶ <br /> <a href="https://tasks-mcp-280200773515.us-west1.run.app/mcp/">Explore Tasks MCP »</a> <br /> <br /> <b>Available for </b> MCP-compatible clients & Claude Desktop <br /> </p> </p>
Tasks MCP is a Model Context Protocol (MCP) server that provides seamless integration with your Notion workspace for task management. It enables AI assistants to create, retrieve, and manage tasks, projects, and courses directly from your Notion databases.
NOTE: Tasks MCP is currently in active development. Features may evolve, and we're continually working to enhance the experience.
Features
With Tasks MCP, you can:
- Retrieve Tasks: Get pending tasks filtered by time range (today, tomorrow, or this week) with "Not Started" status
- Create Tasks: Add new tasks with title, due date, priority, and optional project/course associations
- Manage Projects: Fetch active projects from your Notion workspace for task organization
- Manage Courses: Access active courses to associate academic tasks
- Smart Filtering: Automatically filters tasks based on status and time ranges
- Rich Context: Tasks include associated project and course information for better context
Available Tools
The MCP server provides four main tools:
get-tasks
Fetches pending tasks from Notion based on time range filtering.
- Parameters:
time_range(required) - One of "today", "tomorrow", or "week_from_today" - Returns: List of tasks with title, due date, and associated project/course information
create-task
Creates a new task in your Notion Tasks database.
- Parameters:
title(required) - Task descriptiondue_date(required) - ISO date format (YYYY-MM-DD)priority(required) - Integer 1-3 (1=highest, 3=lowest)project_id(optional) - Related project IDcourse_id(optional) - Related course ID
- Returns: URL to the created task in Notion
get-projects
Fetches active projects from your Notion workspace.
- Parameters: None
- Returns: List of active projects with ID and title
get-courses
Fetches active courses from your Notion workspace.
- Parameters: None
- Returns: List of active courses with ID, title, and description
uv run python src/__main__.py
Motivation
Tasks MCP was created to bridge the gap between AI assistants and personal productivity systems. By providing direct access to Notion task databases through the Model Context Protocol, it enables AI assistants to understand your task context and help manage your workflow more effectively.
Technical Overview
Tasks MCP is built using modern Python technologies and follows MCP best practices:
- MCP Framework: Built on the official MCP Python SDK for reliable protocol compliance
- Notion Integration: Uses the official Notion API client for robust database interactions
- Starlette Web Framework: Provides HTTP endpoints with CORS support and authentication
- Authentication: Bearer token authentication for secure API access
- Environment Configuration: Flexible configuration through environment variables and .env files
- Error Handling: Comprehensive error handling with detailed logging
- Data Source Management: Automatic retrieval of Notion database data source IDs
Setup
-
Environment Variables:
API_AUTH_TOKEN=your-api-auth-token NOTION_AUTH_TOKEN=your-notion-integration-token TASK_DATABASE=your-notion-tasks-database-id PROJECT_DATABASE=your-notion-projects-database-id COURSE_DATABASE=your-notion-courses-database-id -
Installation:
uv sync -
Running:
uv run python -m src --port 8000
Docker Deployment
Prerequisites
# Login to gcloud
gcloud auth login
# Configure Docker to use gcloud credentials for Artifact Registry
gcloud auth configure-docker us-west1-docker.pkg.dev
Deploy Steps
-
Build the image (for linux/amd64 since Cloud Run runs on Linux):
docker buildx build --platform linux/amd64 . -t tasks-mcp -
Tag for Artifact Registry:
docker tag tasks-mcp:latest us-west1-docker.pkg.dev/stanford-mcp/stanford-mcp/tasks-mcp:latest -
Push to Artifact Registry:
docker push us-west1-docker.pkg.dev/stanford-mcp/stanford-mcp/tasks-mcp:latest
MCP Endpoint
The server is deployed and available at: https://tasks-mcp-280200773515.us-west1.run.app/mcp/
For MCP client configuration, use this endpoint with proper authentication headers.
Client Usage
For MCP Inspector
Use these headers when connecting to the MCP server:
{
"Authorization": "Bearer YJAna9RQePF@-uVw7_qBQt*apMF4*bZZfbTcybLobw*nGKCwteJMGh",
"Accept": "application/json, text/event-stream"
}
For Claude Desktop
Add this configuration to your Claude Desktop claude_desktop_config.json:
"mcpServers": {
"stanford-mcp": {
"command": "npx",
"args": [
"mcp-remote",
"https://tasks-mcp-280200773515.us-west1.run.app/mcp/",
"--header", "Authorization: Bearer YJAna9RQePF@-uVw7_qBQt*apMF4*bZZfbTcybLobw*nGKCwteJMGh",
"--header", "Accept: application/json, text/event-stream"
]
}
},
Made with 🫶 by @markmusic27
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.