skills/apple-mail/mail-subscriptions/SKILL.md
Find and list all active subscriptions and recurring charges from email history. Show renewal dates, amounts, and services. Use when user asks about subscriptions, recurring charges, what they're paying for monthly, or wants to audit their subscriptions. Arguments: optional time range to search (default: last 13 months to catch all annual subs).
npx skillsauth add aashari/ai-agent-skills mail-subscriptionsInstall 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.
Scanning: $ARGUMENTS (default: last 13 months)
DB="$HOME/Library/Mail/V10/MailData/Envelope Index"
SINCE=$(($(date +%s) - 34214400)) # 13 months = 396 days
sqlite3 "$DB" "
SELECT datetime(m.date_received,'unixepoch','localtime') as dt,
s.subject, a.address as sender, a.comment as name,
mb.url, m.ROWID
FROM messages m
JOIN subjects s ON m.subject = s.ROWID
JOIN addresses a ON m.sender = a.ROWID
JOIN mailboxes mb ON m.mailbox = mb.ROWID
WHERE m.date_received >= ${SINCE}
AND m.deleted = 0
AND mb.url NOT LIKE '%Spam%' AND mb.url NOT LIKE '%Trash%'
AND (
s.subject LIKE '%subscription%'
OR s.subject LIKE '%renewal%'
OR s.subject LIKE '%renew%'
OR s.subject LIKE '%auto-renew%'
OR s.subject LIKE '%billing%'
OR s.subject LIKE '%monthly%'
OR s.subject LIKE '%annual%'
OR s.subject LIKE '%your plan%'
OR s.subject LIKE '%membership%'
OR s.subject LIKE '%your invoice%'
OR s.subject LIKE '%receipt for%'
OR s.subject LIKE '%charged%'
OR s.subject LIKE '%continued%'
OR s.subject LIKE '%successfully renewed%'
)
ORDER BY m.date_received DESC;" 2>/dev/null
sqlite3 "$DB" "
SELECT a.address, a.comment, COUNT(*) as occurrences,
MIN(datetime(m.date_received,'unixepoch','localtime')) as first_charge,
MAX(datetime(m.date_received,'unixepoch','localtime')) as last_charge
FROM messages m
JOIN subjects s ON m.subject = s.ROWID
JOIN addresses a ON m.sender = a.ROWID
JOIN mailboxes mb ON m.mailbox = mb.ROWID
WHERE m.date_received >= ${SINCE}
AND m.deleted = 0
AND (s.subject LIKE '%subscription%' OR s.subject LIKE '%renewal%'
OR s.subject LIKE '%receipt%' OR s.subject LIKE '%invoice%'
OR s.subject LIKE '%billing%' OR s.subject LIKE '%charged%')
GROUP BY a.address
HAVING COUNT(*) >= 1
ORDER BY occurrences DESC;" 2>/dev/null
python3 ~/.claude/skills/_mail-shared/parser.py <ROWID1> <ROWID2> ...
From bodies, extract:
From occurrence count and date spread:
Your Subscriptions (inferred from email)
| Service | Cycle | Amount | Last Charged | Next Due | |---|---|---|---|---|
Group by: Monthly | Annual | Unknown cycle
Total monthly spend (annualize annual charges for comparison). Flag: subscriptions not charged in >14 months (possibly cancelled). Flag: any subscription with price changes between charges. Offer to find cancel links for any service.
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.