滴答清单任务管理
STDIO滴答清单任务管理集成工具
滴答清单任务管理集成工具
A Model Context Protocol (MCP) server that provides tools for integrating TickTick task management tools. Using Python and the MCP SDK.
This repository contains a Model Context Protocol (MCP) server implementation for TickTick. It provides a standardized way for AI assistants and applications to interact with TickTick's task management functionality, allowing operations like:
With this MCP, AI systems can act as task masters to help manage your to-do lists and tasks in TickTick with natural language.
Clone this repository
git clone https://github.com/ekkyarmandi/ticktick-mcp.git cd ticktick-mcp
Install dependencies
pip install -r requirements.txt
This MCP uses TickTick's OpenAPI scheme, which requires registering an app through TickTick's developer portal:
Manage Apps
in the top right corner and login with your TickTick credentials+App Name
buttonClient ID
and Client Secret
OAuth Redirect URL
, enter a URL where you'll be redirected after authorization (e.g., http://127.0.0.1:8080
)After registering your app, use the ticktick-py library to get your access token:
from ticktick.oauth2 import OAuth2 # Replace with your details from the developer portal client_id = "YOUR_CLIENT_ID" client_secret = "YOUR_CLIENT_SECRET" redirect_uri = "YOUR_REDIRECT_URI" # e.g., http://127.0.0.1:8080 auth_client = OAuth2(client_id=client_id, client_secret=client_secret, redirect_uri=redirect_uri) # This will open a web browser for authorization # Follow the instructions in the terminal to authorize auth_client.get_access_token()
After authorizing, the access token will be saved to a .token-oauth
file by default. You can extract the token from this file or use:
print(auth_client.token_info["access_token"])
.env
file in the root directory with your TickTick API key:
TICKTICK_API_KEY=your_access_token_here
Run the MCP server:
python main.py
This will start the MCP server on port 8000. You can now connect to it using any MCP client.
The server provides the following tools:
get_projects
: Get a list of all projectsproject_details
: Get details of a specific projectget_task_details
: Get details of a specific taskcreate_project
: Create a new projectcreate_task
: Create a new task in a projectupdate_task
: Update an existing taskcomplete_task
: Mark a task as completedelete_task
: Delete a taskOnce your MCP server is running, AI systems can help manage your tasks with natural language commands like:
This server can be used with any MCP-compatible client, such as:
To extend or modify this MCP server:
tools.py
main.py
using mcp.add_tool()
MIT
Contributions are welcome! Please feel free to submit a Pull Request.