This server provides comprehensive AI-powered task management for OmniFocus through Claude AI, featuring native custom perspective access with hierarchical display and advanced filtering capabilities beyond native OmniFocus limits.
Core Task Management:
Full CRUD operations for tasks and projects with complete metadata (due dates, defer dates, tags, notes, time estimates, flags)
Complex task hierarchies with parent-child relationships and subtask creation
Batch operations for efficient bulk add/remove/edit of multiple items
Query specific tasks by ID, name, or complex criteria
Perspective Views:
Custom Perspectives: Native access via
Perspective.CustomAPI with hierarchical tree display showing parent-child relationshipsBuilt-in Perspectives: Inbox, Flagged, and Forecast (1-30 days)
Tag-based Views: Filter tasks by tags with exact or partial matching
List all available custom perspectives in your OmniFocus setup
Advanced Filtering:
Ultimate task filter supporting unlimited combinations of criteria including status (Available, Next, Blocked, DueSoon, Overdue, Completed, Dropped), dates, projects, tags, search text, time estimates, and flags
Date-based filtering with relative (today, this week, this month) or absolute ranges for due/defer/completion dates
Flexible sorting options (name, dates, project, flagged status)
Analytics & Tracking:
View today's completed tasks with configurable limits
Database dump with options to hide/show completed tasks and recurring duplicates
Key Features: Hierarchical tree-style visualization (├─, └─ symbols), AI-optimized tool descriptions, seamless Claude AI integration for intelligent workflows
Required for running OmniFocus, which is a macOS-only application.
Required runtime environment (v18+) for the MCP server.
Used for package distribution and installation of the OmniFocus MCP server.
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., "@OmniFocus MCP Enhancedshow me tasks from my Today Review perspective with hierarchy"
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.
🚀 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.
Related MCP server: Agentic Tools MCP Server
🆕 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-enhancedAlternative 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 quickly5. 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_perspectivesTroubleshooting
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!
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.