osa-mcp
v0.2.8
Published
MCP server that discovers macOS scriptable apps and generates tools from sdef files
Readme
osa-mcp
Give your AI access to every scriptable app on your Mac.
osa-mcp is an MCP server that automatically discovers all scriptable macOS apps (Mail, Calendar, Finder, Music, Notes, Safari, &c.) and generates tools for them. No configuration, no hardcoded app list. Just connect and go.
Setup
npx
claude mcp add my-mac -- npx -y osa-mcpbunx
claude mcp add my-mac -- bunx osa-mcpHomebrew
brew install MayCXC/osa-mcp/osa-mcp
claude mcp add my-mac -- osa-mcpRemote Mac via SSH
If your AI runs on a different machine, connect to your Mac over SSH. Enable Remote Login in System Settings > General > Sharing first.
claude mcp add my-mac -- npx -y osa-mcp --ssh [email protected]JSON config
All of the above can also be added to your MCP settings file directly:
{
"mcpServers": {
"my-mac": {
"type": "stdio",
"command": "npx",
"args": ["-y", "osa-mcp"]
}
}
}For SSH, add "--ssh", "[email protected]" to the args.
What you get
On a typical Mac, osa-mcp generates ~700 tools in ~4 seconds. Every tool includes descriptions pulled from the app's scripting dictionary, so your AI knows what each tool does, what parameters it accepts, and what values are valid.
Commands let your AI perform actions:
mail_send,mail_reply,mail_forwardfinder_reveal,finder_move,finder_duplicatemusic_play,music_pause,music_searchcalendar_show,reminders_show,notes_showsafari_do_javascript,safari_search_the_webmessages_send,terminal_do_script
Lists and gets let your AI read data:
mail_list_messages,mail_get_messagecalendar_list_events,calendar_list_calendarsfinder_list_files,finder_list_disksnotes_list_notes,reminders_list_reminderssafari_list_tabs,safari_list_documents
Application properties expose app settings:
mail_get_applicationreturns inbox, fetch interval, primary email, etc.finder_get_applicationreturns desktop, trash, home, startup disk, etc.music_get_applicationreturns current track, player state, etc.
Execute runs arbitrary JXA or AppleScript for anything the generated tools don't cover.
Navigating the object hierarchy
Many tools accept a parent parameter for navigating into nested objects:
// List events in a specific calendar
{ "parent": ["calendars", "byName", ["Work"]] }
// List messages in the inbox
{ "parent": ["inbox"] }
// Get the first window's current tab
{ "parent": ["windows", 0] }Path steps: "key" accesses a property, 0 accesses by index, [] calls a method, ["arg"] calls with arguments.
Install from source
git clone https://github.com/MayCXC/osa-mcp.git
cd osa-mcp
bun install
bun link
claude mcp add my-mac -- osa-mcpRequires Bun.
License
BSD 3-Clause. See LICENSE.
