Bridges Claude directly to your OmniFocus database through AppleScript automation, letting you query, create, and modify tasks and projects with natural language. The server exposes tools for targeted queries with filters (due dates, tags, flags), bulk operations, and full database dumps. Solid for processing meeting transcripts into action items, converting PDFs into structured projects with dates and tags, or getting custom task views without switching apps. Also provides MCP resources for common perspectives like inbox, today's agenda, and flagged items that Claude can preload as conversation context.
A Model Context Protocol (MCP) server that connects OmniFocus to Claude and other MCP-compatible AI assistants.

This server bridges AI assistants and your OmniFocus database. Through natural conversation, an assistant can query, create, edit, and remove tasks and projects — including bulk operations. Some things you can do with it:
npx)The first time the server talks to OmniFocus, macOS will ask you to allow automation access. Grant it once and you're set.
Add the server to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"omnifocus": {
"command": "npx",
"args": ["-y", "omnifocus-mcp"]
}
}
}
Then restart Claude Desktop.
claude mcp add omnifocus -- npx -y omnifocus-mcp
Other MCP clients work the same way: launch npx -y omnifocus-mcp over stdio.
Targeted queries:
"Show me all my flagged tasks due this week"
"What are my next actions in the Work folder?"
"Count how many tasks are in each project"
Reorganizing:
"I want every task to have an energy level tag. Show me a list of all the tasks that don't have one and your suggestions for what tag to add. I'll make any changes I think are appropriate. Then make the changes in OmniFocus."
Capturing from anywhere:
"Ok, thanks for the detailed explanation of why the rule of law is important. Add a recurring task to my activism project that reminds me to call my representative weekly. Include a summary of this conversation in the notes field."
Working with perspectives:
"What perspectives do I have available?"
"Show me what's in my Inbox perspective"
Processing transcripts or PDFs:
"I'm pasting in the transcript from today's meeting. Please analyze it and create tasks in OmniFocus for any action items assigned to me. Put them in my 'Product Development' project."
The server provides 12 tools. Optional parameters are marked.
query_omnifocusQuery tasks, projects, or folders with targeted filters — much faster and lighter than dumping the whole database. See QUERY_TOOL_REFERENCE.md for the full reference and QUERY_TOOL_EXAMPLES.md for worked examples.
| Parameter | Description |
|---|---|
entity | What to query: tasks, projects, or folders |
filters (optional) | Combine with AND logic; array filters (tags, status) use OR within the array |
fields (optional) | Only return the listed fields — keeps responses small |
limit, sortBy, sortOrder (optional) | Shape the result list |
includeCompleted (optional) | Include completed/dropped items (default: false) |
summary (optional) | Return only the match count |
Available filters:
projectName (case-insensitive partial match; "inbox" targets the inbox), projectId, folderId (includes subfolders)taskName (case-insensitive partial match)tags (exact match, case-sensitive)status — tasks: Next, Available, Blocked, DueSoon, Overdue, Completed, Dropped; projects: Active, OnHold, Done, DroppeddueWithin, deferredUntil, plannedWithin (ranges), dueOn, deferOn, plannedOn (exact day). Accept a number of days, "today", "tomorrow", "this week", "next week", or an ISO dateaddedWithin, addedOn, completedWithin, completedOn, droppedWithin, droppedOn (completed/dropped filters require includeCompleted: true)flagged, inbox, hasNote, isRepeating, reviewDue (projects only)dump_databaseGet the complete state of your database. Use for comprehensive analysis; prefer query_omnifocus for anything targeted.
hideCompleted (optional): hide completed/dropped tasks (default: true)hideRecurringDuplicates (optional): hide duplicate instances of recurring tasks (default: true)add_omnifocus_taskCreate a new task.
nameprojectName (optional): project to add the task to (defaults to inbox)parentTaskId / parentTaskName (optional): nest under an existing tasknote, dueDate, deferDate, plannedDate, flagged, estimatedMinutes, tags (all optional)add_projectCreate a new project.
namefolderName (optional): folder to place the project insequential (optional): whether tasks must be completed in ordernote, dueDate, deferDate, flagged, estimatedMinutes, tags (all optional)edit_itemEdit an existing task or project. Also the way to move items — set newProjectName to move a task into a project, or to ""/"inbox" to send it to the inbox.
id or name: which item to edit (id takes precedence)itemType: task or projectnewName, newNote, newDueDate, newDeferDate, newFlagged, newEstimatedMinutes (dates in ISO format; empty string clears)newStatus (incomplete, completed, dropped, skipped — skipped only for repeating tasks), addTags, removeTags, replaceTags, newProjectName, newPlannedDatenewProjectStatus (active, completed, dropped, onHold), newFolderName, newSequential, markReviewed (sets the next review date based on the project's review interval)remove_itemRemove a task or project.
id or name: which item to removeitemType: task or projectbatch_add_itemsCreate multiple tasks and projects in one operation. Each item accepts the same fields as add_omnifocus_task / add_project, plus type (task or project) and optional hierarchy helpers:
tempId: a temporary ID other items in the same batch can referenceparentTempId: nest this item under another batch item's tempId{
"items": [
{ "type": "project", "name": "My Project", "tempId": "proj1" },
{ "type": "task", "name": "First task", "parentTempId": "proj1" },
{ "type": "task", "name": "Parent task", "parentTempId": "proj1", "tempId": "t1" },
{ "type": "task", "name": "Subtask", "parentTempId": "t1" }
]
}
batch_remove_itemsRemove multiple tasks or projects in one operation. Each item takes id or name, plus itemType.
list_perspectivesList available perspectives, both built-in and custom (custom perspectives are an OmniFocus Pro feature).
includeBuiltIn, includeCustom (optional, default: true)get_perspective_viewGet the items visible in a named perspective.
perspectiveName: e.g. Inbox, Flagged, or a custom perspective namelimit (optional, default: 100), includeMetadata (optional), fields (optional)list_tagsList all tags with their hierarchy, active status, and task counts.
includeDropped (optional, default: false)create_tagCreate a tag, optionally nested under an existing parent.
nameparentTagName / parentTagID (optional; ID takes precedence)Resources let MCP clients attach OmniFocus data to a conversation as context, without tool calls. In Claude Code, type @ to browse them; Claude Desktop and other resource-aware clients can attach them directly. All resources return JSON.
| URI | Description |
|---|---|
omnifocus://inbox | Current inbox items |
omnifocus://today | Today's agenda — due today, planned for today, and overdue |
omnifocus://flagged | All flagged items |
omnifocus://stats | Database statistics (task counts, overdue, flagged, etc.) |
omnifocus://project/{name} | Tasks in a specific project |
omnifocus://perspective/{name} | Items visible in a named perspective |
The two template resources support listing all available values and autocompleting the {name} parameter.
Instructions: during the MCP handshake the server sends usage guidance to the client — tool-selection advice (prefer query_omnifocus over dump_database), filter tips, and the resource catalog. No configuration needed.
Logging: the server emits structured logs via the MCP logging protocol. Clients can adjust verbosity with logging/setLevel (debug, info, warning, error, ...). Script execution timing and errors are logged automatically.
The server communicates with OmniFocus through osascript, using JXA (JavaScript for Automation) and OmniFocus's embedded Omni Automation (OmniJS) where appropriate. It's built on the official MCP TypeScript SDK and talks to clients over stdio.
prompt supportContributions are welcome! Please feel free to submit a pull request. CI runs type checking, unit tests, and a build on every PR.
npm install
npm test # unit tests
npm run build # compile to dist/
npm run test:integration # requires OmniFocus; creates and removes TEST:-prefixed items
MIT
hovecapital/read-only-local-postgres-mcp-server
cocaxcode/database-mcp
io.github.infoinlet-marketplace/mcp-mysql
io.github.cybeleri/database-admin
io.github.yash-0620/postgres-mcp-secured