Apple Calendar CLI
This skill should be used when interacting with Apple Calendar on macOS. Use it for listing calendars, viewing events, creating/updating/deleting calendar events, and checking availability/free-busy t
This skill should be used when interacting with Apple Calendar on macOS. Use it for listing calendars, viewing events, creating/updating/deleting calendar events, and checking availability/free-busy t
Real data. Real impact.
Emerging
Developers
Per week
Open source
Skills give you superpowers. Install in 30 seconds.
npm install -g @joargp/accli
Requirements: macOS only (uses JavaScript for Automation)
The accli tool provides command-line access to macOS Apple Calendar. It enables listing calendars, querying events, creating/updating/deleting events, and checking availability across calendars.
accli calendars [--json]
Lists all available calendars with names and persistent IDs. Run this first to discover available calendars and their IDs.
accli events <calendarName> [options]
Options:
Examples:
# Events from Work calendar for this week accli events Work --jsonEvents in January
accli events Work --from 2025-01-01 --to 2025-01-31 --json
Search for specific events
accli events Work --query "standup" --max 10 --json
accli event <calendarName> <eventId> [--json]
Retrieves details for a specific event by its ID.
accli create <calendarName> --summary <s> --start <datetime> --end <datetime> [options]
Required Options:
Optional:
Examples:
# Create a timed meeting accli create Work --summary "Team Standup" --start 2025-01-15T09:00 --end 2025-01-15T09:30 --jsonCreate an all-day event
accli create Personal --summary "Vacation" --start 2025-07-01 --end 2025-07-05 --all-day --json
Create with location and description
accli create Work --summary "Client Meeting" --start 2025-01-15T14:00 --end 2025-01-15T15:00
--location "Conference Room A" --description "Q1 planning discussion" --json
accli update <calendarName> <eventId> [options]
Options (all optional - only provide what to change):
Example:
accli update Work event-id-123 --summary "Updated Meeting Title" --start 2025-01-15T15:00 --end 2025-01-15T16:00 --json
accli delete <calendarName> <eventId> [--json]
Permanently deletes an event. Confirm with user before executing.
accli freebusy --calendar <name> --from <datetime> --to <datetime> [options]
Options:
Shows busy time slots, excluding cancelled, declined, and transparent events.
Examples:
# Check availability across calendars accli freebusy --calendar Work --calendar Personal --from 2025-01-15 --to 2025-01-16 --jsonCheck specific hours
accli freebusy --calendar Work --from 2025-01-15T09:00 --to 2025-01-15T18:00 --json
# Set default calendar (interactive) accli config set-defaultSet default by name
accli config set-default --calendar Work
Show current config
accli config show
Clear default
accli config clear
When a default calendar is set, commands automatically use it if no calendar is specified.
Find a free slot and schedule:
# 1. Check availability accli freebusy --calendar Work --from 2025-01-15T09:00 --to 2025-01-15T18:00 --json2. Create event in available slot
accli create Work --summary "Meeting" --start 2025-01-15T14:00 --end 2025-01-15T15:00 --json
View today's schedule:
accli events Work --from $(date +%Y-%m-%d) --to $(date -v+1d +%Y-%m-%d) --json
No automatic installation available. Please visit the source repository for installation instructions.
View Installation Instructions1,500+ AI skills, agents & workflows. Install in 30 seconds. Part of the Torly.ai family.
© 2026 Torly.ai. All rights reserved.