Omnifocus MCP Enhanced
Enhanced Model Context Protocol (MCP) server for OmniFocus with complete subtask support, perspective views (Inbox/Flagged/Forecast/Tags), ultimate task filtering, and direct access to custom perspectives. Seamlessly integrate OmniFocus with Claude AI for intelligent task management.
Installation
npx omnifocus-mcp-enhancedAsk AI about Omnifocus MCP Enhanced
Powered by Claude ยท Grounded in docs
I know everything about Omnifocus MCP Enhanced. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
๐ OmniFocus MCP Enhanced
๐ NEW: Native Custom Perspective Access with Hierarchical Display!
Transform OmniFocus into an AI-powered productivity powerhouse with custom perspective support
Enhanced Model Context Protocol (MCP) server for OmniFocus featuring native custom perspective access, hierarchical task display, AI-optimized tool selection, and comprehensive task management.
In plain English: this lets your AI assistant read your OmniFocus data, create tasks/projects, organize subtasks, review perspectives, and help you plan work without you manually jumping between apps.
๐ Why This Project Exists
OmniFocus is already powerful, but it is still mostly a tool you drive by hand.
The bigger idea behind this project is simple:
- less clicking, more conversation
- less manual cleanup, more AI-assisted planning
- less tool memorization, more natural task management
The goal is not just to expose more OmniFocus commands. The goal is to let you work with OmniFocus like this:
Plan my day.
Clean up my Inbox.
Turn these notes into a project.
Show me what is blocked.
Reorganize these tasks safely.
If that feels natural, this MCP server is doing its job.
Want to see where the project is heading next? See the roadmap.
๐ Latest Release
- v1.6.10 - Fixed Inbox task completion via
edit_item, fixed AppleScript special-character handling for apostrophes/backslashes, fixed JSON result escaping for special characters, and clarifiedbatch_add_items/mcporterusage with working examples. - v1.6.9 - Added task attachment support:
get_task_by_idnow lists attachment metadata,dump_databaseexports attachment/link metadata, and newread_task_attachmentreturns image attachments as MCP image content when possible. - v1.6.8 - Added stable task move support via
move_taskandedit_item(newProjectId/newProjectName/newParentTaskId/newParentTaskName/moveToInbox) with duplicate-name protection and cycle-prevention checks. - v1.6.6 - Added full Planned Date support (create/edit/read/filter/sort/export), including
plannedDate/newPlannedDateand updated task displays.
โจ Key Features
๐ NEW: Native Custom Perspective Access
- ๐ฏ Direct Integration - Native access to your OmniFocus custom perspectives via
Perspective.CustomAPI - ๐ณ Hierarchical Display - Tree-style task visualization with parent-child relationships
- ๐ง AI-Optimized - Enhanced tool descriptions prevent AI confusion between perspectives and tags
- โก Zero Setup - Works with your existing custom perspectives instantly
๐๏ธ Complete Task Management
- ๐๏ธ Complete Subtask Support - Create hierarchical tasks with parent-child relationships
- ๐ Built-in Perspectives - Access Inbox, Flagged, Forecast, and Tag-based views
- ๐ Ultimate Task Filter - Advanced filtering beyond OmniFocus native capabilities
- ๐ฏ Batch Operations - Add/remove multiple tasks efficiently
- ๐ Smart Querying - Find tasks by ID, name, or complex criteria
- ๐ Full CRUD Operations - Create, read, update, delete tasks and projects
- ๐ Time Management - Due, defer, planned dates, estimates, and scheduling
- ๐ท๏ธ Advanced Tagging - Tag-based filtering with exact/partial matching
- ๐ค AI Integration - Seamless Claude AI integration for intelligent workflows
- ๐ผ๏ธ Attachment-Aware Reads - Surface note attachments and linked files before deciding whether AI should inspect them
๐ฆ Installation
Quick Install (Recommended)
# One-line installation
claude mcp add omnifocus-enhanced -- npx -y omnifocus-mcp-enhanced
Alternative Installation Methods
# Upgrade to latest
npm install -g omnifocus-mcp-enhanced@latest
# Global installation
npm install -g omnifocus-mcp-enhanced
claude mcp add omnifocus-enhanced -- omnifocus-mcp-enhanced
# Local project installation
git clone https://github.com/jqlts1/omnifocus-mcp-enhanced.git
cd omnifocus-mcp-enhanced
npm install && npm run build
claude mcp add omnifocus-enhanced -- node "/path/to/omnifocus-mcp-enhanced/dist/server.js"
๐ Requirements
- macOS 10.15+ - OmniFocus is macOS-only
- OmniFocus 3+ - The application must be installed and running
- OmniFocus Pro - Required for custom perspectives (new features in v1.6.0)
- Node.js 18+ - For running the MCP server
- Any MCP-capable client - Claude Code,
mcporter, or another MCP host
๐ฆ Start Here
If you only want the fastest way to understand this project, remember this:
- Connect the MCP server to your AI client.
- Talk to the AI naturally.
- Let it read, plan, create, move, or update your OmniFocus tasks for you.
You do not need to memorize all tool names first.
๐ What This Is Good For
- Daily planning: ask your AI what is due today, what is flagged, and what you can finish in 30 minutes.
- Project setup: give the AI a rough goal, then let it create a project and break it into subtasks.
- Inbox cleanup: ask it to review Inbox tasks and sort them into next actions, projects, or someday/later buckets.
- Perspective reviews: ask it to open one of your custom perspectives and summarize what matters.
- Batch capture: paste meeting notes or a brainstorm list and let the AI create multiple tasks at once.
- Attachment-aware review: let the AI inspect task attachments only when needed.
๐ฌ Example AI Conversations
These work well in Claude Code or any MCP client that can call the same tools.
1. Daily Planning
Try saying:
Check my Forecast and flagged tasks, then tell me the 3 most important things to do today.
Prefer tasks that take under 60 minutes first.
2. Inbox Cleanup
Try saying:
Review my Inbox and group the tasks into:
1. do today
2. schedule later
3. turn into projects
Then help me clean up the obvious ones.
3. Turn an Idea Into a Project
Try saying:
Create a project called "Launch spring newsletter".
Add the main subtasks, estimated minutes, and mark the most important step as flagged.
4. Use a Custom Perspective
Try saying:
Open my custom perspective "ไปๆฅๅทฅไฝๅฎๆ" and summarize:
- what is due soon
- what looks blocked
- what I can finish quickly
5. Batch Add From Notes
Try saying:
Turn these meeting notes into OmniFocus tasks under the project "Website Refresh".
Use subtasks where it makes sense and keep the task names short.
6. Review Attachments Only When Needed
Try saying:
Find the task called "Review design draft".
Show me what attachments it has first.
Only open the image attachment if there is one.
๐งญ Practical Usage Tips
- Ask the AI to look first, then change things if you want safer workflows.
- Use task IDs when you have duplicate task names.
- For subtasks, let the parent task determine the project. Do not also pass
projectName. - For
mcporter, complex arrays are much more reliable with--args '{...}'.
๐ฏ Core Capabilities
1. ๐๏ธ Subtask Management
Create complex task hierarchies with ease:
// Create subtask by parent task name
{
"name": "Analyze competitor keywords",
"parentTaskName": "SEO Strategy",
"note": "Focus on top 10 competitors",
"dueDate": "2025-01-15",
"estimatedMinutes": 120,
"tags": ["SEO", "Research"]
}
// Create subtask by parent task ID
{
"name": "Write content outline",
"parentTaskId": "loK2xEAY4H1",
"flagged": true,
"estimatedMinutes": 60
}
2. ๐ Perspective Views
Access all major OmniFocus perspectives programmatically:
# Inbox perspective
get_inbox_tasks {"hideCompleted": true}
# Flagged tasks
get_flagged_tasks {"projectFilter": "SEO Project"}
# Forecast (next 7 days)
get_forecast_tasks {"days": 7, "hideCompleted": true}
# Tasks by tag
get_tasks_by_tag {"tagName": "AI", "exactMatch": false}
3. ๐ Ultimate Task Filter
Create any perspective imaginable with advanced filtering:
# Time management view (30min tasks due this week)
filter_tasks {
"taskStatus": ["Available", "Next"],
"estimateMax": 30,
"dueThisWeek": true
}
# Deep work view (60+ minute tasks with notes)
filter_tasks {
"estimateMin": 60,
"hasNote": true,
"taskStatus": ["Available"]
}
# Planned work view (tasks planned for today)
filter_tasks {
"plannedToday": true,
"sortBy": "plannedDate"
}
# Project overdue tasks
filter_tasks {
"projectFilter": "Website Redesign",
"taskStatus": ["Overdue", "DueSoon"]
}
4. ๐ NEW: Native Custom Perspective Access
Access your OmniFocus custom perspectives with hierarchical task display:
# ๐ NEW: List all your custom perspectives
list_custom_perspectives {"format": "detailed"}
# ๐ณ NEW: Project tree view (default)
get_custom_perspective_tasks {
"perspectiveName": "ไปๆฅๅทฅไฝๅฎๆ", # Your custom perspective name
"displayMode": "project_tree", # project_tree | task_tree | flat
"hideCompleted": true
}
# Global task tree (legacy showHierarchy=true equivalent)
get_custom_perspective_tasks {
"perspectiveName": "Today Review",
"displayMode": "task_tree"
}
# Flat list (legacy groupByProject=false equivalent)
get_custom_perspective_tasks {
"perspectiveName": "Weekly Planning",
"displayMode": "flat"
}
Why This Is Powerful:
- โ
Native Integration - Uses OmniFocus
Perspective.CustomAPI directly - โ Tree Structure - Visual parent-child task relationships with โโ, โโ symbols
- โ Project-First Grouping - Project header first, then nested subtasks
- โ
Readable Metadata - Full notes and
#tagsin tree output - โ AI-Friendly - Enhanced descriptions prevent tool selection confusion
- โ Professional Output - Clean, readable task hierarchies
5. ๐ฏ Batch Operations
Efficiently manage multiple tasks:
{
"items": [
{
"type": "task",
"name": "Website Technical SEO",
"projectName": "SEO Project",
"note": "Optimize technical aspects"
},
{
"type": "task",
"name": "Page Speed Optimization",
"parentTaskName": "Website Technical SEO",
"estimatedMinutes": 180,
"flagged": true
},
{
"type": "task",
"name": "Mobile Responsiveness",
"parentTaskName": "Website Technical SEO",
"estimatedMinutes": 90
}
]
}
CLI tip for mcporter:
# Prefer explicit JSON args for complex arrays / nested objects
mcporter call omnifocus.batch_add_items --args '{
"items": [
{
"type": "task",
"name": "Website Technical SEO",
"projectName": "SEO Project"
}
]
}'
If you pass a subtask with parentTaskId or parentTaskName, do not also pass projectName. Subtasks inherit the project from their parent task.
Working mcporter examples:
# 1) Batch-create top-level tasks in a project
mcporter call omnifocus.batch_add_items --args '{
"items": [
{
"type": "task",
"name": "Parent: Category A",
"projectName": "OmniFocus MCP Batch Test"
},
{
"type": "task",
"name": "Parent: Category B",
"projectName": "OmniFocus MCP Batch Test"
}
]
}'
# 2) Create parent + child in one batch
mcporter call omnifocus.batch_add_items --args '{
"items": [
{
"type": "task",
"name": "Parent: Category A",
"projectName": "OmniFocus MCP Batch Test"
},
{
"type": "task",
"name": "Child: A1",
"parentTaskName": "Parent: Category A"
}
]
}'
# 3) Safer two-step flow when adding many subtasks to existing parents
mcporter call omnifocus.batch_add_items --args '{
"items": [
{
"type": "task",
"name": "Child: A1",
"parentTaskName": "Parent: Category A"
},
{
"type": "task",
"name": "Child: A2",
"parentTaskName": "Parent: Category A"
},
{
"type": "task",
"name": "Child: B1",
"parentTaskName": "Parent: Category B"
}
]
}'
This will fail, by design:
mcporter call omnifocus.batch_add_items --args '{
"items": [
{
"type": "task",
"name": "Child: A1",
"projectName": "OmniFocus MCP Batch Test",
"parentTaskName": "Parent: Category A"
}
]
}'
Because a subtask must inherit its project from the parent task.
6. ๐ผ๏ธ Attachment Inspection
Discover images and linked files on a task first, then read only the attachment you need:
# List task details plus attachment metadata
get_task_by_id {
"taskId": "abc123"
}
# Open an attachment returned by get_task_by_id
read_task_attachment {
"taskId": "abc123",
"attachmentId": "embedded-1"
}
get_task_by_id now reports attachment IDs, names, MIME guesses, source (embedded vs linked), and sizes when available. read_task_attachment returns images as MCP image content when possible, so AI clients can inspect the image directly instead of parsing base64 from plain text.
๐ ๏ธ Complete Tool Reference
๐ Database & Task Management
- dump_database - Get OmniFocus database state
- add_omnifocus_task - Create tasks (enhanced with subtask support)
- add_project - Create projects
- remove_item - Delete tasks or projects
- edit_item - Edit tasks or projects (now supports task moves: project/parent/inbox)
- move_task - Move an existing task to project/parent task/inbox
- batch_add_items - Bulk add (enhanced with subtask support)
- batch_remove_items - Bulk remove
- get_task_by_id - Query task information, including attachment metadata
- read_task_attachment - Read an attachment reported by
get_task_by_id
๐ Built-in Perspective Tools
- get_inbox_tasks - Inbox perspective
- get_flagged_tasks - Flagged perspective
- get_forecast_tasks - Forecast perspective (due/deferred/planned task data included)
- get_tasks_by_tag - Tag-based filtering
- filter_tasks - Ultimate filtering with unlimited combinations
๐ Custom Perspective Tools (NEW)
- list_custom_perspectives - ๐ NEW: List all custom perspectives with details
- get_custom_perspective_tasks - ๐ NEW: Access custom perspective with hierarchical display
๐ Analytics & Tracking
- get_today_completed_tasks - View today's completed tasks
Batch move feature roadmap (future): docs/roadmap/2026-02-25-batch-move-tasks-plan.md
๐ Quick Start Examples
Basic Task Creation
# Simple task
add_omnifocus_task {
"name": "Review quarterly goals",
"projectName": "Planning",
"dueDate": "2025-01-31",
"plannedDate": "2025-01-28"
}
Advanced Task Management
# Create parent task
add_omnifocus_task {
"name": "Launch Product Campaign",
"projectName": "Marketing",
"dueDate": "2025-02-15",
"tags": ["Campaign", "Priority"]
}
# Add subtasks
add_omnifocus_task {
"name": "Design landing page",
"parentTaskName": "Launch Product Campaign",
"estimatedMinutes": 240,
"flagged": true
}
Task Move Operations
# Move task to a project
move_task {
"id": "task-id-123",
"targetProjectName": "Planning"
}
# Move task under another task
move_task {
"id": "task-id-123",
"targetParentTaskId": "parent-task-id-456"
}
# Move task back to inbox
move_task {
"id": "task-id-123",
"targetInbox": true
}
Task move safety rules:
- Name lookups fail fast on duplicates and ask you to use IDs.
- Destination must be exactly one type: project OR parent task OR inbox.
- Moving a task into itself/its descendants is blocked to prevent cycles.
You can also move with edit_item and combine move + field updates:
edit_item {
"itemType": "task",
"id": "task-id-123",
"newProjectName": "Planning",
"newName": "Review tmux workflow",
"newFlagged": true
}
Smart Task Discovery
# Find high-priority work
filter_tasks {
"flagged": true,
"taskStatus": ["Available"],
"estimateMax": 120,
"hasEstimate": true
}
# Today's completed work
filter_tasks {
"completedToday": true,
"taskStatus": ["Completed"],
"sortBy": "project"
}
๐ Custom Perspective Usage
# List your custom perspectives
list_custom_perspectives {"format": "detailed"}
# Access a custom perspective with project tree
get_custom_perspective_tasks {
"perspectiveName": "Today Review",
"displayMode": "project_tree",
"hideCompleted": true
}
# Quick flat view of weekly planning
get_custom_perspective_tasks {
"perspectiveName": "Weekly Planning",
"displayMode": "flat"
}
๐ง Configuration
Verify Installation
# Check MCP status
claude mcp list
# Test basic connection
get_inbox_tasks
# Test new custom perspective features
list_custom_perspectives
Troubleshooting
- Ensure OmniFocus 3+ is installed and running
- Verify Node.js 18+ is installed
- Check Claude Code MCP configuration
- Enable accessibility permissions for terminal apps if needed
๐ฏ Use Cases
- Project Management - Create detailed project hierarchies with subtasks
- GTD Workflow - Leverage perspectives for Getting Things Done methodology
- Time Blocking - Filter by estimated time for schedule planning
- Review Process - Use custom perspectives for weekly/monthly reviews
- Team Coordination - Batch operations for team task assignment
- AI-Powered Planning - Let Claude analyze and organize your tasks
๐ Performance
- Fast Filtering - Native AppleScript performance
- Batch Efficiency - Single operation for multiple tasks
- Memory Optimized - Minimal resource usage
- Scalable - Handles large task databases efficiently
๐ค Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if applicable
- Submit a pull request
๐ License
MIT License - see LICENSE file for details.
๐ Links
- NPM Package: https://www.npmjs.com/package/omnifocus-mcp-enhanced
- GitHub Repository: https://github.com/jqlts1/omnifocus-mcp-enhanced
- OmniFocus: https://www.omnigroup.com/omnifocus/
- Model Context Protocol: https://modelcontextprotocol.io/
- Claude Code: https://docs.anthropic.com/en/docs/claude-code
๐ Acknowledgments
Based on the original OmniFocus MCP server by themotionmachine. Enhanced with perspective views, advanced filtering, and complete subtask support.
โญ Star this repo if it helps boost your productivity!
