voiceos-todoist
Offers optional one-way sync from Apple Reminders to Todoist, copying due dates and notes, auto-creating Todoist projects per Reminders list, and closing Todoist tasks when reminders are completed or removed.
Provides voice-controlled task management for Todoist, including adding, listing, completing, and updating tasks with natural-language due dates, priorities, projects, and filters, as well as fuzzy completion matching.
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., "@voiceos-todoistAdd milk to my shopping list tomorrow"
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.
Todoist for VoiceOS
Voice-control Todoist from VoiceOS β and optionally keep Apple Reminders in sync with it.
A local Model Context Protocol server that adds Todoist to VoiceOS, plus a one-way Apple Reminders β Todoist sync. Your API token stays on your Mac β nothing is sent anywhere except Todoist's own API.
ποΈ "Add buy milk to Todoist tomorrow at 9am"
ποΈ "What's on my Todoist for today?"
ποΈ "Mark the expenses task done"β¨ Features
Add / list / complete / update tasks by voice
Natural-language due dates β "tomorrow at 9am", "every friday"
Priorities (p1βp4), projects, and filters ("today", "overdue")
Fuzzy completion β "mark the milk task done" matches
Buy milkOptional Reminders sync β anything you drop in Apple Reminders lands in Todoist
One-command installer with guided token setup
No keys in code β token lives at
~/.config/todoist/token(chmod 600)
Related MCP server: Todoist MCP Server
π Quick start
git clone https://github.com/gabeperez/voiceos-todoist.git
cd voiceos-todoist
./setup.shThe installer will:
Walk you through getting your Todoist API token and validate + save it securely.
Install dependencies.
Register the integration in VoiceOS automatically.
Optionally set up the Reminders β Todoist sync (with a dry-run preview first).
Then restart VoiceOS (or toggle the Todoist integration) and start talking.
Prefer not to clone? Grab
todoist-voiceos.zipfrom the latest release, unzip, and run./setup.sh.
π Requirements
Getting your API token
Todoist β Settings β Integrations β Developer β API token (https://app.todoist.com/app/settings/integrations/developer). The setup script links you straight there and validates the token before saving.
π οΈ Tools
Tool | What it does |
| Create a task β NL due date, priority p1βp4, project, description. |
| List active tasks; filter by project or query ( |
| Close a task by id or content substring ( |
| Change text / due date / priority / description. |
| List your projects and their ids. |
Priority is UI-style: p1 = highest, p4 = none.
π Apple Reminders β Todoist sync (optional)
Mirrors incomplete reminders into Todoist on a 5-minute timer:
Due dates + notes are copied; each Reminders list maps to a Todoist project (auto-created).
Dedupe + completion state in
~/.config/todoist/sync-state.json.When a synced reminder is completed or removed, its Todoist task is closed.
One-way only β Todoist changes never flow back to Reminders.
npm run sync:dry # preview what would sync β writes nothing
sync/install-launchd.sh # enable the 5-minute background timer
sync/uninstall-launchd.sh # stop itThe first run triggers a macOS Automation β Reminders permission prompt β approve it.
Sync options
Set these in sync/run-sync.sh:
Env | Effect |
| Only sync these Reminders lists (default: all). |
| Force everything into one project (default: listβproject). |
| Don't close Todoist tasks on completion/removal. |
| Don't copy due dates. |
| Report what would sync; write nothing. |
π§Ή Uninstall
./uninstall.shUnregisters from VoiceOS, stops the sync timer, and offers to delete your saved token + state.
π How it works
βββββββββββββββββββββββββββββ
VoiceOS βββββββΊ mcp-server.ts (stdio) ββββΊ Todoist API v1
(voice) βββββββββββββββββββββββββββββ
βββββββββββββββββββββββββββββ
Apple RemindersββΊ sync (launchd, every 5m) ββββΊ Todoist API v1
βββββββββββββββββββββββββββββmcp-server.tsβ the MCP server VoiceOS launches over stdio (viastart.sh).sync/sync-reminders-to-todoist.mjsβ reads Reminders via JXA, pushes to Todoist.register-voiceos.mjsβ adds/removes the entry in VoiceOS'sconfig.json.Uses the Todoist unified API v1 (
/api/v1); the old/rest/v2is deprecated.
π Privacy
Your token is stored locally at ~/.config/todoist/token (chmod 600) and used only
to call Todoist's API directly from your Mac. Nothing is proxied through any third
party. The Reminders sync reads your local Reminders via macOS scripting and writes
only to your Todoist.
License
MIT Β© Gabe Perez
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/gabeperez/voiceos-todoist'
If you have feedback or need assistance with the MCP directory API, please join our Discord server