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., "@Things MCPshow me my tasks for today"
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.
Things MCP
A Model Context Protocol (MCP) server for Things 3 integration. Enables Claude Desktop and Claude Code to interact with Things 3 on macOS.
Features
Create to-dos and projects with full metadata
Update existing to-dos and projects
List items from any Things list (Inbox, Today, Logbook, Trash, etc.)
Retrieve all projects, areas, and tags
Navigate to specific items or lists
Search within Things
Secure AppleScript execution
Comprehensive error handling
Requirements
macOS with Things 3 installed
Node.js 18 or later
Things URL scheme enabled (automatic on first use)
Installation
Quick Start with npx (Recommended)
npx github:hildersantos/things-mcpThis will automatically download, build, and start the MCP server.
Manual Installation
Clone this repository:
git clone https://github.com/hildersantos/things-mcp.git cd things-mcpInstall dependencies:
npm installBuild the project:
npm run buildStart the server:
npm start
Configuration
Claude Desktop Setup
Get your Things auth token (required for update operations):
Open Things → Settings → General
Enable Things URLs
Click Manage → Copy Token
Configure Claude Desktop:
Open your Claude Desktop configuration file:
~/Library/Application Support/Claude/claude_desktop_config.jsonAdd the Things MCP server to the
mcpServerssection:{ "mcpServers": { "things-mcp": { "command": "npx", "args": ["github:hildersantos/things-mcp"], "env": { "THINGS_AUTH_TOKEN": "your-token-here" } } } }Replace
your-token-herewith your actual Things auth token from step 1.Restart Claude Desktop to apply the configuration changes.
Alternative: Local Installation
If you prefer to install locally instead of using npx:
{
"mcpServers": {
"things-mcp": {
"command": "node",
"args": ["/absolute/path/to/things-mcp/dist/index.js"],
"env": {
"THINGS_AUTH_TOKEN": "your-token-here"
}
}
}
}Usage Examples
Create a To-Do
Create a task "Buy milk" for today with tag "errands" in ThingsCreate a Simple Project
Create a "Website Redesign" project in Things in my Work areaCreate a Complex Project
Plan a vacation to Japan in Things with research about destinations, booking flights and hotels,
creating a packing list, and planning daily activitiesAnother Project Example
Set up a new employee onboarding project in Things with IT setup tasks, HR paperwork,
training schedule, and first week activitiesUpdate a To-Do
Mark task ABC-123 as completed in ThingsAdd Items to Existing Project
Add new tasks to my "Website Redesign" project in Things: create wireframes, design mockups, and user testingList Tasks
Show me all tasks in my Things inboxView Projects
List all my projects in ThingsNavigate
Open my Today list in ThingsGet Task Details
Get full details for task TBeaUrcGH1zKoMmS7wwHVD from ThingsSearch
Search for "meeting" in ThingsView Completed Tasks
Show me my completed tasks from the Things logbookAvailable Tools
Creation Tools
things_add_todo- Create a to-do with all optionsthings_add_project- Create a project with sections (headings), todos, and hierarchical organization
Update Tools (requires auth token)
things_update_todo- Update an existing to-do using JSON API for full feature supportthings_update_project- Update an existing project using JSON API for full feature supportthings_add_items_to_project- Add structured todos and headings to an existing project
Reading Tools
things_get_inbox- List inbox itemsthings_get_today- List today's itemsthings_get_upcoming- List scheduled itemsthings_get_anytime- List anytime itemsthings_get_someday- List someday itemsthings_get_logbook- List completed itemsthings_get_trash- List trashed itemsthings_get_projects- List all active projectsthings_get_areas- List all areasthings_get_tags- List all tagsthings_get_project- List items in a specific project (requires project_id)things_get_area- List items in a specific area (requires area_id)things_get_list- Get items from a specific list by namethings_get_todo_details- Get detailed information about a specific to-do
All list tools support an optional max_results parameter to limit output.
Navigation Tools
things_show- Navigate to item or list
Development
# Development mode with watch
npm run dev
# Run linter
npm run lint
# Format code
npm run format
# Run tests
npm test
# Run tests in watch mode
npm run test:watchTroubleshooting
"Things 3 does not appear to be running"
Make sure Things 3 is installed and has been opened at least once.
"Authentication failed"
Check that your THINGS_AUTH_TOKEN is correctly set in the MCP configuration.
AppleScript Permissions
On first run, macOS may ask for permission to control Things. Grant this permission for the MCP to work.
Performance Issues
Use the max_results parameter when listing large collections:
Use things_get_projects with max_results 10License
MIT
Credits
Built with the Model Context Protocol SDK. Things is a trademark of Cultured Code GmbH & Co. KG.
This server cannot be installed
Resources
Looking for Admin?
Admins can modify the Dockerfile, update the server description, and track usage metrics. If you are the server author, to access the admin panel.