Notre avis
Recherche dans Apple Mail sur tous les comptes synchronisés par mot-clé, sujet, expéditeur ou combinaison, et retourne les courriels récents correspondants.
Points forts
- Recherche en texte intégral sur tous les comptes
- Prend en charge les filtres par expéditeur, sujet, compte et date
- Peut afficher le contenu complet des courriels
Limites
- Fonctionne uniquement avec Apple Mail sur macOS
- Nécessite que la base de données des courriels soit indexée et accessible
- Limitée aux 50 derniers résultats sans affinage supplémentaire
Utilisez-le lorsque vous devez retrouver rapidement un courriel spécifique parmi plusieurs comptes Apple Mail.
Ne l'utilisez pas si vous n'utilisez pas Apple Mail ou si vous devez rechercher dans des services de messagerie web ou côté serveur.
Analyse de sécurité
SûrThe skill only performs read-only local database queries and file parsing using sqlite3 and python3. It does not invoke network operations, destructive commands, or exfiltrate data. User input is limited to search terms and filters, and the skill is user-invocable, so no external attack vector exists.
Aucun point d'attention détecté
Exemples
Find an email from alice@example.com about the quarterly reportSearch for emails containing 'budget' from the last 30 daysFind all emails from John Smithname: mail-search description: >- Search Apple Mail across all synced accounts by keyword, subject, sender, or any combination. Use when user asks to find an email, search for a message, or look for something in their mail. Arguments: search terms, optionally with sender:, subject:, from:, account: prefixes, and time filters like "last 30 days" or "this year". disable-model-invocation: false user-invocable: true allowed-tools: Bash metadata: openclaw: requires: bins: [sqlite3, python3]
Mail Search — Full-Text Search Across All Accounts
Search query: $ARGUMENTS
Argument Parsing
Parse $ARGUMENTS for modifiers:
from:name@domain.comorsender:→ filter by sendersubject:keyword→ filter subject onlyaccount:gmailoraccount:work→ restrict to account typelast N days/weeks→ time filter- Anything else → search both subject and sender
Query
DB="$HOME/Library/Mail/V10/MailData/Envelope Index"
TERM="<extracted search term>" # URL-encode % as %% in shell
sqlite3 "$DB" "
SELECT datetime(m.date_received,'unixepoch','localtime') as dt,
s.subject, a.address as sender, a.comment as name,
mb.url as mailbox, m.ROWID, m.read,
CASE WHEN m.size > 0 THEN m.size ELSE 0 END as size
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.deleted = 0
AND mb.url NOT LIKE '%Spam%'
AND mb.url NOT LIKE '%Trash%'
AND mb.url NOT LIKE '%Junk%'
AND (
s.subject LIKE '%TERM%'
OR a.address LIKE '%TERM%'
OR a.comment LIKE '%TERM%'
)
ORDER BY m.date_received DESC
LIMIT 50;" 2>/dev/null
For sender-only search:
WHERE a.address LIKE '%TERM%' OR a.comment LIKE '%TERM%'
For subject-only search:
WHERE s.subject LIKE '%TERM%'
For recipient search (TO/CC):
JOIN recipients r ON r.message = m.ROWID
JOIN addresses ra ON r.address = ra.ROWID
WHERE ra.address LIKE '%TERM%'
Reading Email Bodies
If user wants to read specific results, find the emlx and parse:
python3 ~/.claude/skills/_mail-shared/parser.py <ROWID>
Output Format
Show results as a table: | Date | From | Subject | Account | Read | |---|---|---|---|---|
If more than 20 results, summarize by sender/thread and ask if they want to narrow down. For each result, note the account it belongs to (extract UUID from mailbox URL to identify account). Offer to read any specific email if user asks.
Priorisation de Tâches
Productivite
Priorise vos tâches avec les frameworks Eisenhower, ICE et RICE.
Generateur de Rapport Hebdomadaire
Productivite
Generez des rapports de statut hebdomadaires structures et concis.
Rapport de Daily Standup
Productivite
Génère des rapports de daily standup structurés et concis.