Integrates with the Things 3 personal task manager on macOS, allowing AI agents to read project structures via SQLite, create items using the official URL scheme, and manage tasks, headings, and areas.
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., "@SupaThings MCPSummarize my 'Home Renovation' project and suggest some headings"
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.
SupaThings MCP
SupaThings MCP is a Things 3 MCP server for macOS.
It was built to solve a practical gap: AI agents can write to Things via things:///, but they cannot reliably understand your real project structure from URL commands alone.
SupaThings combines SQLite-based reads with official URL-scheme writes, so agents can both understand and act safely.
Table of Contents
Quick Start
1) Run with npx (no install)
npx -y supathings-mcp2) Global install from npm
npm install -g supathings-mcpAlias also available:
things-mcp3) Build from source
npm install
npm run build
node dist/index.js4) MCP config example
{
"mcpServers": {
"supathings": {
"command": "npx",
"args": ["-y", "supathings-mcp"]
}
}
}5) Configure MCP in your client (copy/paste)
Codex:
codex mcp add supathings -- npx -y supathings-mcpClaude Code:
claude mcp add --transport stdio supathings -- npx -y supathings-mcpGemini CLI:
gemini mcp add -s user supathings npx -y supathings-mcpWhat This MCP Server Does (and Why It Exists)
MCP servers expose tools over a standard protocol so AI clients can call them programmatically.
In Things, there are two realities:
The
things:///URL scheme is excellent for creating/updating/navigating items.URL commands alone do not expose full structural context (project hierarchy, headings, checklist relationships, planning summaries).
SupaThings was built to bridge that split.
Technical approach:
Read path: query local Things SQLite data for structure and context.
Write path: execute official
things:///URL actions for safe interoperability.Planning path: add semantic tools for heading inference, validation, project summaries, and task placement.
Why this is useful in practice:
Better decisions: agents can place tasks under the right heading.
Lower token usage: compact structural answers instead of large raw dumps.
Safer automation: writes stay on official Things-supported surfaces.
More predictable workflows: clear split between data understanding and data mutation.
Current Scope (v0.4.0)
Current release: 0.4.0
Shipped scope today:
Tool surface:
37MCP toolsRead model: local Things SQLite database (areas, projects, headings, todos, tags, checklist items)
Write model: official
things:///URL schemeSemantic layer: heading inference, heading validation, project structure summaries, task placement suggestions
Optional AppleScript actions: runtime-gated
Current boundaries:
macOS + local Things installation required
recurring template rows are intentionally excluded from read queries
headings are easiest to guarantee at project creation time
adding missing headings to existing projects remains constrained by Things capabilities
How It Works
Three-layer model:
SQLite layer for rich reads of local Things data
things:///layer for writes, updates, moves, and navigationAppleScript layer for optional lightweight app actions (
show-quick-entry,log-completed,empty-trash)
This split is deliberate: read from local truth, write through supported Things APIs.
Things-Native Philosophy
SupaThings is opinionated here: Things should be treated like Things.
Headings are modeled as semantic groupings (categories, work blocks, deliverables), not as a Jira-style workflow board by default.
That changes:
how headings are inferred
how project summaries are generated
how task placement is suggested
Recommended Workflows
New project with headings
Use when the project does not exist yet:
suggest-headingscreate-project-with-headingsoptionally verify with
get-projectsorget-project-structure
Existing project missing headings
Use when the project already exists but needs structure:
get-headingsorsuggest-headingscreate missing headings manually in Things
validate-headingscreate or move tasks into those headings
Why: creating headings is most reliable during brand-new project creation.
Existing project with structure already in place
get-project-structuresummarize-projectsuggest-task-placementcreate or move tasks into the chosen headings
Available Tools
Current exposed tools: 37
Category | Tools |
Read and inspection |
|
Semantic planning |
|
Write and navigation |
|
Optional AppleScript |
|
If Apple Events are unavailable, these fail gracefully.
Token and Context Efficiency
SupaThings is designed to reduce context burn in AI workflows.
Current efficiency features:
concise text responses
structured payloads without duplicating full JSON in text output
detail: "compact" | "full"on major read/search toolslimiton major list/search toolsget-project-structurefor lightweight structural inspectionsummarize-projectfor planning-focused summariessuggest-task-placementfor semantic placement suggestions
Requirements
macOS
Things 3 installed locally
Node.js 22+
npm 10+
Apple Events permission only if you want optional AppleScript actions
Build and Smoke Tests
npm run build
npm run smoke
npm run smoke:mcpSmoke coverage includes:
server startup over stdio
tool listing
Things app availability
SQLite access
project and heading inspection
semantic tools (
suggest-headings,get-project-structure,suggest-task-placement,summarize-project)
Packaging and Release
Create local tarball
npm packFull release guide
See:
docs/PUBLISHING_GUIDE.md
Quick release summary:
Validate build and smoke tests.
Commit and push to your GitHub repo.
Create and push an annotated tag (for example
v0.4.0).Create a GitHub release from that tag.
Publish to npm (
npm publish --access public).Verify
npx -y supathings-mcpand client setup commands.
Project Structure
src/index.ts: MCP server entrypoint
src/views.ts: compact/full serializers
src/headings.ts: heading semantics and inference
src/project-structure.ts: project structural analysis
src/task-placement.ts: heading placement suggestions
src/project-summary.ts: planning-oriented summaries
scripts/smoke-test.mjs: structural environment smoke test
scripts/mcp-smoke.mjs: MCP protocol smoke test
scripts/install-clients.sh: multi-client MCP installer
scripts/uninstall-clients.sh: multi-client MCP uninstall helper
docs/PUBLISHING_GUIDE.md: GitHub + npm publication guide
Attribution
This project builds on prior work and ideas from:
Licensing and attribution details are included in LICENSE and NOTICE.
Support
🐛 Bug Reports: Open an issue on GitHub (Issues)
💡 Feature Requests: Open an issue with enhancement label (New issue)
📚 Documentation: Check the Things URL scheme docs (Things URL Scheme)
💬 Questions: Open a discussion on GitHub (Discussions)
License
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.