dida-mcp-server
Provides tools for managing tasks, projects, and tags in TickTick/Dida365, including creating, reading, updating, deleting, moving tasks and projects, batch operations, and GTD-based organization.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@dida-mcp-serverList my tasks from inbox"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Dida MCP Server
A Model Context Protocol (MCP) server for interacting with TickTick/Dida365 task management service. This server provides tools to manage tasks, projects, and tags through the TickTick API.
Overview
Dida MCP Server is built on the Model Context Protocol framework, enabling AI assistants to interact with your TickTick/Dida365 account. It provides a comprehensive set of tools for task and project management, allowing AI assistants to help organize your tasks according to GTD (Getting Things Done) principles.
Related MCP server: Dida365 MCP Server
Features
Authentication: OAuth-based authentication with TickTick/Dida365 API
Task Management: Create, read, update, delete, and move tasks
Project Management: Create, read, update, and delete projects
Batch Operations: Efficiently manage multiple tasks at once
GTD Assistant: Built-in system prompt for GTD-based task organization
Cached Data: Efficient caching of projects and tags data
Prerequisites
Node.js (v16 or higher)
npm (v7 or higher)
TickTick/Dida365 account
Client ID and Client Secret from Dida365 Developer Center (for OAuth authentication)
Installation
Option 1: Install from npm (Recommended)
# Install globally
npm install -g dida-mcp-server
# Or install locally in your project
npm install dida-mcp-serverOption 2: Install from source
# Clone the repository
git clone https://github.com/zhongwencool/dida-mcp-server.git
cd dida-mcp-server
# Install dependencies
npm install
# Build the project
npm run buildAuthentication
Before using the server, you need to authenticate with TickTick/Dida365. The server supports two authentication methods:
OAuth Authentication (V1 API): Uses the Dida365 Open API with OAuth tokens
Username/Password Authentication (V2 API): Uses the internal API with session tokens
Using get-access-token
The get-access-token script handles the authentication process for both API versions. To use it:
# If installed globally
dida-get-token
# If installed locally or from source
npm run get-tokenThe script will:
Prompt you for your TickTick/Dida365 username and password (for V2 API)
Prompt you for your Client ID and Client Secret ([for V1 API OAuth])
Start a local server on port 3000 to handle the OAuth callback
Open your browser to authorize the application
Exchange the authorization code for an access token
Store both tokens in the configuration file at
~/.dida-mcp-config.jsonDisplay a success page with token information and MCP server configuration
Prerequisites for OAuth Authentication
To use OAuth authentication, you need to:
Register your application in the Dida365 Developer Center
Set your redirect URI to
http://localhost:3000/oauth/callbackObtain a Client ID and Client Secret
Configuration File
The authentication process creates a configuration file at ~/.dida-mcp-config.json with the following structure:
{
"access_token": "your-v1-oauth-token",
"refresh_token": "your-refresh-token",
"expires_at": 1234567890000,
"token_type": "bearer",
"v2_access_token": "your-v2-session-token",
"inboxId": "your-inbox-project-id"
}This file is automatically detected and used by the server when it starts.
Usage
Starting the Server
# If installed globally
dida-mcp-server
# If installed locally or from source
npm startThe server will automatically attempt to authenticate using stored tokens and display the authentication status.
Connecting with an MCP Client
You can connect to the server using any MCP-compatible client. The server provides a configuration that can be added to your MCP client configuration:
{
"mcpServers": {
"dida": {
"command": "dida-mcp-server"
}
}
}Or if you installed it locally:
{
"mcpServers": {
"dida": {
"command": "node",
"args": [
"/path/to/node_modules/dida-mcp-server/dist/index.js"
]
}
}
}Available Tools
Authentication Tools
check-auth-status: Check the current authentication status
Project Management Tools
list-projects: Get all projectscreate-project: Create a new projectupdate-project: Update an existing projectdelete-project: Delete a projectrefresh-project-cache: Manually refresh the project cache
Task Management Tools
list-tasks: Get tasks from a project (defaults to inbox)create-task: Create a new taskget-task: Get a specific task by IDupdate-task: Update a taskbatch-update-tasks: Update multiple tasks at oncecomplete-task: Mark a task as completeddelete-task: Delete a taskbatch-delete-tasks: Delete multiple tasks at oncemove-task: Move a task to a different projectbatch-move-tasks: Move multiple tasks to different projects
Data Query Tools
list-cached-data: View cached projects and tags data
System Prompts
The server includes two built-in prompts:
GTD Assistant Prompt: A system prompt that provides guidance on using the tools to implement GTD methodology
Process Inbox Prompt: A user-level prompt that helps organize tasks in the inbox according to GTD principles
Development
Running in Development Mode
npm run devThis will start the server in watch mode, automatically recompiling and restarting when changes are made.
Running Tests
npm testOr to run tests in watch mode:
npm run test:watchProject Structure
├── dist/ # Compiled JavaScript files
├── src/
│ ├── auth/ # Authentication-related code
│ ├── projects/ # Project management tools
│ ├── resources/ # Resource definitions (cached data)
│ ├── tasks/ # Task management tools
│ ├── types/ # TypeScript type definitions
│ ├── utils/ # Utility functions
│ ├── config.ts # Configuration management
│ ├── get-access-token.ts # Token acquisition script
│ ├── index.ts # Main server entry point
│ └── systemPrompt.ts # GTD assistant system prompt
├── tests/ # Test files
├── package.json # Project metadata and dependencies
├── LICENSE # ISC License file
└── tsconfig.json # TypeScript configurationAPI Documentation
This project uses the Dida365 Open API. For more information, see the Dida365 Open API Documentation.
License
ISC
Publishing to NPM
To publish the package to NPM, follow these steps:
# Login to npm (if not already logged in)
npm login
# Build the project
npm run build
# Test the package
npm test
# Publish to npm
npm publishTo update the package:
Update the version in
package.jsonRun
npm publish
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Acknowledgements
Model Context Protocol for the MCP framework
TickTick/Dida365 for the task management service
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/zhongwencool/dida-mcp-server'
If you have feedback or need assistance with the MCP directory API, please join our Discord server