skills/apple-calendar/calendar-recurring/SKILL.md
List all recurring meetings and meeting series. Use when user asks about standing meetings, recurring events, weekly syncs, or wants to see their regular meeting cadence.
npx skillsauth add aashari/ai-agent-skills calendar-recurringInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
List all active recurring events, grouped by frequency.
$ARGUMENTS — optional filter:
"weekly" → only weekly recurring"standup" → search by nameDB="$HOME/Library/Group Containers/group.com.apple.calendar/Calendar.sqlitedb"
FILTER="$ARGUMENTS"
NOW_CD=$(( $(date +%s) - 978307200 ))
KEYWORD_FILTER=""
if [ -n "$FILTER" ] && ! echo "$FILTER" | grep -qiE '^(weekly|daily|monthly|yearly)$'; then
KEYWORD_FILTER="AND ci.summary LIKE '%${FILTER}%'"
fi
FREQ_FILTER=""
case "$(echo $FILTER | tr '[:upper:]' '[:lower:]')" in
daily) FREQ_FILTER="AND r.frequency = 1" ;;
weekly) FREQ_FILTER="AND r.frequency = 2" ;;
monthly) FREQ_FILTER="AND r.frequency = 3" ;;
yearly) FREQ_FILTER="AND r.frequency = 4" ;;
esac
sqlite3 -separator '|' "$DB" "
SELECT
ci.summary as title,
CASE r.frequency
WHEN 1 THEN 'Daily'
WHEN 2 THEN 'Weekly'
WHEN 3 THEN 'Monthly'
WHEN 4 THEN 'Yearly'
ELSE 'Unknown'
END as freq,
r.interval as every_n,
COALESCE(
strftime('%H:%M', oc_next.occurrence_start_date + 978307200, 'unixepoch', 'localtime'),
strftime('%H:%M', oc_next.occurrence_date + 978307200, 'unixepoch', 'localtime')
) as time_of_day,
date(oc_next.occurrence_date + 978307200, 'unixepoch', 'localtime') as next_occurrence,
COALESCE(l.title, '') as location,
COALESCE(ci.conference_url, '') as conf_url,
c.title as calendar,
ci.has_attendees,
ci.ROWID as id
FROM CalendarItem ci
JOIN Recurrence r ON r.owner_id = ci.ROWID
LEFT JOIN (
SELECT event_id, MIN(occurrence_date) as occurrence_date, occurrence_start_date
FROM OccurrenceCache
WHERE occurrence_date >= $NOW_CD
GROUP BY event_id
) oc_next ON oc_next.event_id = ci.ROWID
LEFT JOIN Calendar c ON ci.calendar_id = c.ROWID
LEFT JOIN Store s ON c.store_id = s.ROWID
LEFT JOIN Location l ON ci.location_id = l.ROWID
WHERE ci.hidden = 0
AND ci.status != 2
AND s.type != 5
AND s.disabled = 0
AND oc_next.occurrence_date IS NOT NULL
$FREQ_FILTER
$KEYWORD_FILTER
ORDER BY r.frequency, r.interval, COALESCE(oc_next.occurrence_start_date, oc_next.occurrence_date);
"
Group by frequency:
Daily (N)
Weekly (N)
Monthly (N)
Show has_attendees flag so user knows which are solo vs. group meetings.
Note next occurrence date for each.
data-ai
Show work emails only, filtered to Exchange/EWS accounts and corporate email domains. Digest with priorities. Use when user asks about work email, work inbox, or wants to separate work from personal mail. Arguments: optional date range or "today", "yesterday", "this week".
testing
Intelligent inbox triage — surface the most important emails across all accounts, prioritized by urgency and requiring attention. Use when user wants a smart overview of what needs their attention, asks "what's important in my email", or wants help deciding what to read first. Arguments: optional time window (default: last 48 hours) or account filter.
data-ai
Find flight bookings, hotel reservations, travel itineraries, and booking confirmations from email. Use when user asks about upcoming trips, travel plans, booking references, flight details, or hotel reservations. Arguments: optional destination, airline, date range, or booking service.
testing
Show who sends the most email, communication frequency analysis, and relationship mapping. Use when user asks who emails them most, top contacts, communication patterns, or wants to understand their email social graph. Arguments: optional time range (default: last 90 days), account filter, or "humans only" to exclude automated senders.