Claude-code-plugins-plus apple-notes-incident-runbook
install
source · Clone the upstream repo
git clone https://github.com/jeremylongshore/claude-code-plugins-plus-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/jeremylongshore/claude-code-plugins-plus-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/saas-packs/apple-notes-pack/skills/apple-notes-incident-runbook" ~/.claude/skills/jeremylongshore-claude-code-plugins-plus-apple-notes-incident-runbook && rm -rf "$T"
manifest:
plugins/saas-packs/apple-notes-pack/skills/apple-notes-incident-runbook/SKILL.mdsource content
Apple Notes Incident Runbook
Overview
This runbook covers the most common Apple Notes automation failures and their resolution procedures. Unlike cloud SaaS incidents that involve API endpoints and status pages, Apple Notes incidents are local to the macOS machine: app crashes, TCC permission revocations, iCloud sync failures, and database corruption. Each incident section follows a detect-diagnose-fix-verify structure. Keep this runbook accessible on any machine running Notes automation.
Severity Levels
| Severity | Description | Example | Response Time |
|---|---|---|---|
| P1 | All automation blocked | TCC permissions revoked, Notes.app won't launch | Immediate |
| P2 | Data inconsistency | iCloud sync stuck, notes missing | Within 1 hour |
| P3 | Degraded performance | Slow operations, intermittent timeouts | Within 4 hours |
| P4 | Cosmetic/minor | Log warnings, non-critical script errors | Next business day |
Incident 1: Notes.app Crash During Automation
# DETECT: Check if Notes is running pgrep -x Notes > /dev/null && echo "Notes: running" || echo "Notes: NOT RUNNING" # DIAGNOSE: Check crash logs ls -lt ~/Library/Logs/DiagnosticReports/Notes* 2>/dev/null | head -3 # FIX: Restart Notes with stabilization delay killall Notes 2>/dev/null sleep 3 open -a Notes sleep 5 # Wait for full launch and iCloud handshake # VERIFY: Confirm access is restored osascript -l JavaScript -e 'Application("Notes").defaultAccount.notes.length'
Incident 2: iCloud Sync Stuck
# DETECT: Compare note count with expected (from last known good) CURRENT=$(osascript -l JavaScript -e 'Application("Notes").defaultAccount.notes.length' 2>/dev/null) echo "Current note count: ${CURRENT:-ERROR}" # DIAGNOSE: Check iCloud daemons ps aux | grep -E "(bird|cloudd|nsurlsessiond)" | grep -v grep # Check sync status brctl status com.apple.Notes 2>/dev/null || echo "brctl unavailable" log show --predicate 'subsystem == "com.apple.notes"' --last 5m 2>/dev/null | tail -20 # FIX: Restart iCloud sync daemons killall bird 2>/dev/null; killall cloudd 2>/dev/null sleep 10 # Allow daemons to restart and reconnect # VERIFY: Check note count is increasing / stable sleep 30 NEW_COUNT=$(osascript -l JavaScript -e 'Application("Notes").defaultAccount.notes.length' 2>/dev/null) echo "Note count after sync restart: ${NEW_COUNT:-ERROR}"
Incident 3: TCC Permissions Revoked
# DETECT: Test Apple Events access osascript -l JavaScript -e 'Application("Notes").name()' 2>&1 | grep -q "Not authorized" && echo "TCC: DENIED" || echo "TCC: OK" # DIAGNOSE: Check TCC database (may require Full Disk Access) sqlite3 ~/Library/Application\ Support/com.apple.TCC/TCC.db \ "SELECT client, allowed FROM access WHERE service='kTCCServiceAppleEvents';" 2>/dev/null # FIX: Reset and re-prompt tccutil reset AppleEvents # Run a simple command to trigger the permission dialog osascript -l JavaScript -e 'Application("Notes").name()' # User must click "Allow" in the system dialog # VERIFY osascript -l JavaScript -e 'Application("Notes").defaultAccount.notes.length'
Incident 4: Notes Database Corruption
# DETECT: Notes.app launches but shows no notes or crashes on open # DIAGNOSE: Check database integrity NOTES_DB="$HOME/Library/Group Containers/group.com.apple.notes/NoteStore.sqlite" sqlite3 "$NOTES_DB" "PRAGMA integrity_check;" 2>/dev/null || echo "Cannot access DB (sandboxed)" # FIX: Force re-download from iCloud # 1. Quit Notes killall Notes 2>/dev/null # 2. Rename local database (iCloud will re-download) mv "$HOME/Library/Group Containers/group.com.apple.notes" \ "$HOME/Library/Group Containers/group.com.apple.notes.backup.$(date +%s)" 2>/dev/null # 3. Relaunch Notes — it will rebuild from iCloud open -a Notes # WARNING: "On My Mac" notes are NOT in iCloud and will be lost. Back up first.
Error Handling
| Issue | Cause | Solution |
|---|---|---|
| Crash loop after restart | Corrupt note triggering crash on load | Remove local DB; let iCloud rebuild |
| Sync stuck for >1 hour | Apple iCloud service outage | Check apple.com/systemstatus; wait for resolution |
| Permissions reset after macOS update | OS upgrade resets TCC database | Re-approve automation permissions post-update |
| Script hangs indefinitely | Notes.app showing modal dialog | Dismiss dialog manually; add before operations |
| Automation works for user A but not B | Per-user TCC grants | Each macOS user must approve automation separately |
Resources
Next Steps
For root cause analysis of specific errors, see
apple-notes-common-errors. For monitoring to detect incidents early, see apple-notes-observability.