Nucleus Apple MCP server (macOS EventKit via Swift sidecar).
Project description
⚛️ Nucleus: macOS Life Context Server
Give your AI Agent a Hippocampus.
nucleus-apple-mcp is a Model Context Protocol (MCP) server designed to unify your digital life on macOS. It allows AI agents (like Claude Desktop, Cursor, or custom agents) to securely read and interact with your personal data ecosystem.
Unlike fragile PyObjC bridges, Nucleus uses a hybrid architecture: a Python MCP server that orchestrates lightweight, JIT-compiled native Swift workers. This ensures type-safe, performant, and reliable access to Apple's native APIs while remaining easily distributable via uvx.
For a higher-level product overview, see docs/introducing-nucleus.md.
🔌 Integrations
✅ Available (current release)
- 📅 Calendar: Fetch upcoming schedules, check availability, and create events via
EventKit. - ✅ Reminders: Read pending tasks and manage your to-do lists via
EventKit. - 📝 Notes: List/search notes, read content, and add/export attachments via Notes.app (Apple Events).
- ❤️ Health: Read exported Apple Health metrics and raw samples from an S3-compatible object store.
🏗 Architecture
- Python: Handles the MCP protocol, request routing, and distribution (pip/uv).
- Swift: Embedded source code acts as a "Sidecar." It is compiled locally on the first run (using SwiftPM
swift build) to interface directly with macOS private frameworks, bypassing the limitations of Python-Objective-C bridges.
📦 Swift Sidecar Layout
- Swift Package Root:
src/nucleus_apple_mcp/sidecar/swift/(includesPackage.swift; CLI usesswift-argument-parser) - Build Cache (macOS):
~/Library/Caches/nucleus-apple-mcp/sidecar/<build_id>/nucleus-apple-sidecar - Optional Env Vars:
NUCLEUS_APPLE_MCP_CACHE_DIR(overrides cache directory),NUCLEUS_SWIFT(swift path),NUCLEUS_SWIFTC(swiftc path)
🚀 Usage
# Run the CLI directly.
uvx --from nucleus-apple-mcp nucleus-apple health list-sample-catalog
# Or run the MCP server.
uvx nucleus-apple-mcp
🧰 CLI
Install the package once and use the unified nucleus-apple command:
uv tool install nucleus-apple-mcp
Examples:
# Calendar
nucleus-apple calendar list-events --start 2026-03-15T09:00:00+08:00 --end 2026-03-15T18:00:00+08:00 --pretty
# Reminders
nucleus-apple reminders list-reminders --due-end 2026-03-20 --pretty
# Notes
nucleus-apple notes list-notes --query project --include-plaintext-excerpt --pretty
# Health
nucleus-apple health read-daily-metrics --date 2026-03-14 --pretty
The CLI mirrors the MCP tool surface and emits JSON, which makes it suitable for shell automation and OpenClaw-style skills.
🔧 Add as an MCP server
This server uses the stdio transport (a local subprocess). The first run will compile the Swift sidecar.
Codex CLI
# Add the server (writes to ~/.codex/config.toml)
codex mcp add nucleus-apple -- uvx nucleus-apple-mcp
# Verify
codex mcp list
Claude Code
# Add the server (use --scope user to make it available globally)
claude mcp add --scope user nucleus-apple -- uvx nucleus-apple-mcp
# Verify
claude mcp list
You can also launch the server through the CLI:
nucleus-apple mcp serve
🪝 OpenClaw Skills
This repository includes OpenClaw-ready skills under skills/ for:
nucleus-apple-calendarnucleus-apple-remindersnucleus-apple-notesnucleus-apple-health
Each skill depends on the nucleus-apple binary and is designed to be contributed upstream without changing the command surface.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nucleus_apple_mcp-0.3.0.tar.gz.
File metadata
- Download URL: nucleus_apple_mcp-0.3.0.tar.gz
- Upload date:
- Size: 67.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
51377a0e47f16ad55dcea9444e94acaf5d2e2b4c970ea8131b234254e594c070
|
|
| MD5 |
fcc5b48e929eddfd5cfc5a069336f2d1
|
|
| BLAKE2b-256 |
c422751c89f13da89c311d0d8549acbfa9f233e9615800094dbc99df704ba73c
|
File details
Details for the file nucleus_apple_mcp-0.3.0-py3-none-any.whl.
File metadata
- Download URL: nucleus_apple_mcp-0.3.0-py3-none-any.whl
- Upload date:
- Size: 77.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.9 {"installer":{"name":"uv","version":"0.9.9"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6f52cc9ba61f759c849a4b86efce8257b1876a1e5c4874df1564484ec2e26671
|
|
| MD5 |
5dc08065e43edfb6004f551cd4d8a332
|
|
| BLAKE2b-256 |
b6399b9d0c729a671c853efc1f808b9bb3458e215279b48bcaaaa8ff891bdc54
|