The MCP Aruba Email & Calendar Server enables AI assistants like Claude or GitHub Copilot to manage Aruba email and calendar services through secure IMAP/SMTP/CalDAV connections.
Email Management:
๐ง List emails โ Browse your mailbox with optional sender/folder filters and result limits
๐ Read emails โ Retrieve full email content by ID (HTML converted to clean text)
๐ Search emails โ Find emails by subject/body content with optional date and folder filters
โ๏ธ Send emails โ Compose and send emails via SMTP with CC recipients, custom sender names, and signatures
๐ Handle attachments โ List and download email attachments (PDFs, images, documents)
๐พ Export emails โ Save emails in RFC822 format for backup
๐ฌ Check bounced emails โ Detect delivery failures and bounce-back notifications
Email Signature Features:
Create, save, retrieve, and list professional HTML signatures with photos, colors, and styles (professional, minimal, or colorful)
Calendar Management:
๐ Create events โ Schedule events with title, time, description, location, and attendees
๐ List events โ View upcoming events within a specified date range
โ /โ/โ Respond to invitations โ Accept, decline, or mark events as tentative with optional comments
๐๏ธ Delete events โ Remove events from your calendar by UID
Security & Integration:
๐ Runs locally โ credentials never leave your machine
๐ก๏ธ SSL/TLS encryption over IMAPS (993), SMTPS (465), and HTTPS
๐ค Integrates with Claude Desktop, VS Code Copilot, and MCP Registry (Smithery)
โก Efficient connection pooling with configurable result limits
Supports automatic uploading of profile and brand photos to Imgur for use in custom email signatures.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MCP Aruba Email & Calendar ServerList my recent emails and check my calendar for upcoming meetings today"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Aruba Email & Calendar Server
Italiano | English
Server MCP (Model Context Protocol) per accedere a email e calendario Aruba tramite IMAP/SMTP/CalDAV. Integra facilmente email e calendario Aruba con assistenti AI come Claude!
๐ฆ Come Installare
Opzione 1: Estensione VS Code (Piรน Semplice) โญ
Per usare con GitHub Copilot in VS Code:
Installa l'estensione dal VS Code Marketplace
Configura le credenziali con
โ+Shift+Pโ "Aruba Email: Configure Credentials"Usa direttamente in Copilot Chat!
๐ Guida completa estensione VS Code
Opzione 2: Da Smithery (Registro MCP) ๐
Per usare con @mcp aruba in VS Code o altri client MCP:
Il server รจ disponibile su Smithery
In VS Code Copilot Chat, digita
@mcp arubae segui le istruzioniOppure installa da CLI:
smithery install io.github.jackfioru92/aruba-email
Opzione 3: Installazione Manuale (Per Claude Desktop)
Per usare con Claude Desktop:
Funzionalitร
๐ง Elenca email - Naviga nella casella con filtri per mittente
๐ Cerca email - Ricerca per oggetto/corpo con filtri data
๐ Leggi email - Ottieni il contenuto completo (HTML convertito in testo pulito)
โ๏ธ Invia email - Invia email via SMTP con firma personalizzata
โ๏ธ Firma email - Crea firme professionali con foto e colori brand
๐ Allegati - Lista e scarica allegati email (PDF, immagini, documenti)
๐พ Esporta .eml - Esporta email in formato RFC822 per backup
Calendario
๐ Crea eventi - Crea eventi calendario con partecipanti
๐ Elenca eventi - Visualizza eventi futuri
โ Accetta inviti - Accetta inviti calendario
โ Declina inviti - Declina inviti calendario
โ Forse - Rispondi "forse" agli inviti calendario
๐๏ธ Elimina eventi - Rimuovi eventi dal calendario
Generale
๐ Sicuro - Usa IMAP/SMTP/CalDAV su SSL/TLS
โก Veloce - Gestione efficiente delle connessioni con context manager
๐ค Pronto per AI - Funziona perfettamente con Claude Desktop e altri client MCP
Configurazione (Solo per Installazione Manuale)
Copia
.env.examplein.env:
cp .env.example .envModifica
.envcon le tue credenziali Aruba:
# Configurazione Email
IMAP_HOST=imaps.aruba.it
IMAP_PORT=993
IMAP_USERNAME=tua_email@aruba.it
IMAP_PASSWORD=tua_password
SMTP_HOST=smtps.aruba.it
SMTP_PORT=465
# Configurazione Calendario
CALDAV_URL=https://syncdav.aruba.it/calendars/tua_email@aruba.it/
CALDAV_USERNAME=tua_email@aruba.it
CALDAV_PASSWORD=tua_password(Opzionale) Configura la tua firma email personalizzata:
Metodo 1: Script Interattivo (Consigliato)
# Esegui lo script interattivo python setup_signature.pyLo script ti guiderร nella creazione di una firma professionale con:
๐ Informazioni personali (nome, ruolo, azienda, contatti)
๐จ Scelta dello stile (professional, minimal, colorful)
๐ Personalizzazione colori
๐ธ Upload automatico foto su Imgur (opzionale)
Metodo 2: Tramite Claude (Ancora piรน semplice!)
Dopo aver configurato Claude Desktop, chiedi direttamente: "Crea una firma email per me con nome Mario Rossi, ruolo Software Developer, azienda TechCorp e colore #0066cc" "Configura la mia firma con questa foto: /path/to/photo.jpg" "Imposta una firma minimal con solo nome e email"Claude userร automaticamente i tool MCP per creare la tua firma!
La firma verrร inclusa automaticamente in tutte le email inviate.
Nota: Le credenziali sono memorizzate localmente e non lasciano mai il tuo computer. Il server MCP viene eseguito localmente e si connette direttamente ai server Aruba.
Utilizzo
๐ Inizio Rapido: Visualizza le Ultime Email
Il modo piรน veloce per iniziare:
# Installa dipendenze
pip install -e .
# Configura credenziali (copia e modifica .env.example)
cp .env.example .env
# Modifica .env con le tue credenziali Aruba
# Mostra le ultime email
python cli.py emails 5
# Oppure usa lo script demo
python demo_list_emails.pyVuoi usare Claude? Dopo la configurazione, chiedi semplicemente:
Mostrami le ultime 5 email
Dammi le email piรน recenti
Quali email ho ricevuto oggi?๐ Guida completa: Vedi GUIDA_UTILIZZO_EMAIL.md per tutti i metodi disponibili.
Esegui il server direttamente
python -m mcp_aruba.serverConfigura con Claude Desktop
Vedi CLAUDE_SETUP.md per istruzioni dettagliate.
Configurazione rapida per ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"aruba-email-calendar": {
"command": "python",
"args": ["-m", "mcp_aruba.server"],
"env": {
"IMAP_HOST": "imaps.aruba.it",
"IMAP_PORT": "993",
"IMAP_USERNAME": "tua_email@aruba.it",
"IMAP_PASSWORD": "tua_password",
"SMTP_HOST": "smtps.aruba.it",
"SMTP_PORT": "465",
"CALDAV_URL": "https://syncdav.aruba.it/calendars/tua_email@aruba.it/",
"CALDAV_USERNAME": "tua_email@aruba.it",
"CALDAV_PASSWORD": "tua_password"
}
}
}
}Configura con VS Code Copilot
Vedi VSCODE_SETUP.md per istruzioni dettagliate sull'uso di questo server con l'estensione Copilot MCP di VS Code.
Usa la CLI rapida
# Attiva ambiente virtuale
source .venv/bin/activate
# Mostra ultime 5 email
python cli.py emails
# Mostra ultime 10 email
python cli.py emails 10
# Mostra eventi prossimi 7 giorni
python cli.py calendar
# Mostra eventi prossimi 14 giorni
python cli.py calendar 14Strumenti Disponibili
Strumenti Email
list_emails
Elenca email recenti con filtri opzionali.
Parametri:
folder(str, default: "INBOX") - Cartella email da leggeresender_filter(str, opzionale) - Filtra per email mittentelimit(int, default: 10, max: 50) - Numero di email da restituire
Esempi:
Mostra le ultime 5 email da john@example.com
Elenca email recenti nella mia inbox
Dammi le 10 email piรน recenti dal mio caporead_email
Leggi il contenuto completo di un'email specifica.
Parametri:
email_id(str) - ID email da list_emailsfolder(str, default: "INBOX") - Cartella email
Esempi:
Leggi l'email 123
Mostrami il contenuto completo dell'email 456search_emails
Cerca email per oggetto o contenuto corpo.
Parametri:
query(str) - Query di ricercafolder(str, default: "INBOX") - Cartella dove cercarefrom_date(str, opzionale) - Solo email da questa data (formato: DD-MMM-YYYY)limit(int, default: 10, max: 50) - Numero massimo di risultati
Esempi:
Cerca email che parlano di "API" dalla settimana scorsa
Trova tutte le email su "fattura" da dicembresend_email
Invia un'email via SMTP.
Parametri:
to(str) - Indirizzo email destinatariosubject(str) - Oggetto emailbody(str) - Corpo email (testo semplice)cc(str, opzionale) - Indirizzi email in CC, separati da virgolafrom_name(str, default: "Giacomo Fiorucci") - Nome visualizzato mittenteuse_signature(bool, default: True) - Include la firma email se configurataverify_recipient(bool, default: True) - Verifica che l'email destinatario esista
Esempi:
Invia un'email a colleague@example.com ringraziando per l'aggiornamento
Rispondi a john@example.com con lo stato del progetto
Invia un'email a client@example.com con CC a manager@company.comNota sulla firma: Se hai configurato una firma usando setup_signature.py, verrร automaticamente inclusa nelle email. Puoi disabilitarla temporaneamente con use_signature=False.
set_email_signature
Configura una firma email personalizzata.
Parametri:
name(str) - Nome completoemail(str) - Indirizzo emailrole(str, opzionale) - Ruolo/posizionecompany(str, opzionale) - Nome aziendaphone(str, opzionale) - Numero di telefonowebsite(str, opzionale) - Sito webphoto_input(str, opzionale) - Percorso file foto o URL (upload automatico su Imgur)style(str, default: "professional") - Stile: professional, minimal, colorfulcolor(str, default: "#0066cc") - Colore principale (formato esadecimale)signature_name(str, default: "default") - Nome identificativo firma
Esempi:
Crea una firma con il mio nome, ruolo e foto del profilo
Configura una firma professionale con logo aziendaleget_email_signature
Ottieni la firma email corrente.
Parametri:
signature_name(str, default: "default") - Nome firma da recuperare
list_email_signatures
Elenca tutte le firme email salvate.
Strumenti Calendario
create_calendar_event
Crea un nuovo evento calendario.
Parametri:
summary(str) - Titolo eventostart(str) - Data/ora inizio in formato ISO (YYYY-MM-DDTHH:MM:SS)end(str) - Data/ora fine in formato ISOdescription(str, opzionale) - Descrizione eventolocation(str, opzionale) - Luogo eventoattendees(str, opzionale) - Lista email partecipanti separati da virgola
Esempi:
Crea un meeting chiamato "Riunione Team" domani alle 15 per 1 ora
Programma un "Project Review" il 10 dicembre alle 14 con john@example.comlist_calendar_events
Elenca eventi calendario in un intervallo di date.
Parametri:
start_date(str, opzionale) - Data inizio in formato ISO (default: oggi)end_date(str, opzionale) - Data fine in formato ISO (default: 30 giorni da ora)limit(int, default: 50) - Eventi massimi da restituire
Esempi:
Mostrami il mio calendario per questa settimana
Quali eventi ho a dicembre?
Elenca tutti i miei meeting per i prossimi 7 giorniaccept_calendar_event
Accetta un invito calendario.
Parametri:
event_uid(str) - UID dell'eventocomment(str, opzionale) - Commento opzionale
Esempi:
Accetta l'invito al meeting "Team Standup"
Accetta l'evento abc123@aruba.it con commento "Non vedo l'ora!"decline_calendar_event
Declina un invito calendario.
Parametri:
event_uid(str) - UID dell'eventocomment(str, opzionale) - Commento opzionale
Esempi:
Declina l'evento abc123@aruba.it
Declina il meeting con commento "Mi dispiace, ho un conflitto"tentative_calendar_event
Rispondi "forse" a un invito calendario.
Parametri:
event_uid(str) - UID dell'eventocomment(str, opzionale) - Commento opzionale
Esempi:
Rispondi forse all'evento abc123@aruba.it
Segna come "forse" il meeting di domani
Forse partecipo al meeting di domanidelete_calendar_event
Elimina un evento calendario.
Parametri:
event_uid(str) - UID dell'evento da eliminare
Esempi:
Elimina l'evento abc123@aruba.it
Cancella il mio meeting delle 14Casi d'Uso
๐ฌ Comunicazione Team
Mostrami le ultime email dai membri del mio team
Elenca email non lette da project@company.com๐ Tracking Progetti
Cerca email che menzionano "modifiche API" dall'ultima settimana
Trova tutte le email su "fattura" dal 1ยฐ dicembre๐ Riepilogo Email Giornaliero
Riassumi tutte le email che ho ricevuto oggi
Mostrami le email importanti di stamattinaโ๏ธ Risposte Rapide
Invia un'email a colleague@example.com ringraziandoli per l'aggiornamento
Rispondi a john@example.com con lo stato del progetto๐ Gestione Calendario
Quali meeting ho questa settimana?
Crea una riunione team per domani alle 15
Accetta l'invito calendario per la review di venerdรฌ
Declina il meeting di lunedรฌ, sono in vacanza
Mostrami il mio programma per la prossima settimana๐ค Gestione Email & Calendario con AI
Con Claude Desktop o VS Code Copilot, puoi:
Chiedere a Claude di riassumere piรน email
Creare risposte basate sul contenuto email
Estrarre task da thread email
Organizzare e categorizzare email automaticamente
Programmare meeting basati su conversazioni email
Gestire conflitti calendario e trovare fasce orarie disponibili
Stack Tecnologico
Python 3.10+ - Python moderno
MCP SDK 1.2.0+ - Model Context Protocol per integrazione AI
imaplib - Client IMAP libreria standard (supporto SSL/TLS)
smtplib - Client SMTP libreria standard (supporto SSL/TLS)
email - Parsing email e gestione MIME
caldav - Protocollo CalDAV per accesso calendario
icalendar - Parsing e generazione formato iCalendar
python-dotenv - Gestione variabili ambiente
Sicurezza & Privacy
๐ Esecuzione locale - Il server gira sul tuo computer, le credenziali non lasciano mai la tua macchina
๐ก๏ธ Crittografia SSL/TLS - Tutte le connessioni usano protocolli sicuri (IMAPS porta 993, SMTPS porta 465, HTTPS per CalDAV)
๐ Variabili ambiente - Credenziali salvate nel file
.env(gitignored di default)๐ Troncamento corpo - Corpo email limitato a 5000 caratteri per prevenire overflow del contesto
โ Nessun servizio esterno - Connessione diretta solo ai server Aruba
Best Practice Sicurezza
Non committare mai il file
.envnel controllo versioneUsa password forti e uniche per il tuo account email
Considera l'abilitazione 2FA sul tuo account Aruba
Ruota regolarmente le tue credenziali
Rivedi i log del server MCP per attivitร sospette
Performance
โก Connection pooling via context manager
๐ Limiti risultati configurabili per prevenire problemi di memoria
๐ Connessioni on-demand (nessun processo in background)
๐พ Footprint di memoria minimo
Sviluppo
Eseguire i Test
# Attiva ambiente virtuale
source .venv/bin/activate
# Esegui test connessione email
python test_connection.py
# Esegui test connessione calendario
python test_calendar.py
# Test creazione evento
python test_create_event.py
# Test invio invito calendario
python send_invite.pyQualitร Codice
# Formatta codice
black src/
# Type checking
mypy src/
# Linting
pylint src/Abilitare Sincronizzazione CalDAV
Per usare le funzionalitร calendario, devi abilitare la sincronizzazione CalDAV in Aruba Webmail:
Vai su https://webmail.aruba.it
Naviga alla sezione Calendario
Clicca su "Sincronizza calendario"
Scegli "Calendari" โ "Procedi"
Seleziona "Lettura e modifica" (CalDAV) โ "Procedi"
Seleziona i calendari da sincronizzare โ "Procedi"
Una volta abilitato, potrai gestire completamente i tuoi calendari tramite il server MCP!
Risoluzione Problemi
Calendario non disponibile
Se vedi "No calendar available", devi abilitare la sincronizzazione CalDAV (vedi sezione sopra).
Errori connessione
Verifica che le credenziali in
.envsiano corretteControlla che le porte 993 (IMAP), 465 (SMTP), 443 (CalDAV) non siano bloccate
Verifica le impostazioni firewall
Prova a eseguire gli script di test
Email o eventi non visualizzati
Verifica di avere i permessi corretti sull'account
Controlla i filtri applicati (sender_filter, date filters)
Aumenta il limite di risultati
FAQ
Q: ร sicuro memorizzare le mie credenziali nel file .env?
A: Sรฌ, finchรฉ il file .env non viene committato nel controllo versione. ร giร incluso in .gitignore. Le credenziali rimangono sul tuo computer locale.
Q: Posso usare questo con altri provider email?
A: Il server รจ ottimizzato per Aruba, ma puoi adattarlo per altri provider che supportano IMAP/SMTP/CalDAV modificando le configurazioni.
Q: Quanto costano i server MCP?
A: I server MCP sono gratuiti! Questo รจ software open-source. Hai solo bisogno di un abbonamento Claude o GitHub Copilot per usarlo con quegli AI.
Q: I miei dati vengono inviati a terze parti?
A: No! Il server gira localmente e si connette direttamente ai server Aruba. Nessun dato passa attraverso servizi terzi.
Q: Posso contribuire al progetto?
A: Assolutamente! Vedi CONTRIBUTING.md per linee guida.
Contribuire
I contributi sono benvenuti! Per favore:
Fai un fork del repository
Crea un feature branch (
git checkout -b feature/funzionalita-fantastica)Committa le modifiche (
git commit -m 'Aggiungi funzionalitร fantastica')Pusha al branch (
git push origin feature/funzionalita-fantastica)Apri una Pull Request
Vedi CONTRIBUTING.md per dettagli completi.
Roadmap
Supporto IMAP IDLE per notifiche real-time
Gestione allegati email
Composizione email HTML
Suite test pytest
Supporto account multipli
Eventi calendario ricorrenti
Notifiche calendario
Integrazione con altri calendari (Google Calendar, Outlook)
Documentazione
README.md - Documentazione principale (Italiano)
README_EN.md - Documentation in English
GUIDA_UTILIZZO_EMAIL.md - Guida completa: Come vedere le ultime email ๐ง
EXAMPLES.md - Esempi d'uso
CLAUDE_SETUP.md - Setup Claude Desktop
VSCODE_SETUP.md - Setup VS Code Copilot MCP
docs/VSCODE_EXTENSION.md - Estensione VS Code Marketplace
docs/MCP_REGISTRY.md - Pubblicazione MCP Registry
SIGNATURE_EXAMPLES.md - Esempi firme email
CONTRIBUTING.md - Guida contribuzioni
LICENSE - Licenza MIT
Installazione Rapida
Da PyPI
pip install mcp-arubaDa VS Code Marketplace
Cerca "MCP Aruba Email" nel marketplace VS Code o installa direttamente:
code --install-extension jackfioru92.mcp-aruba-emailDa MCP Registry
Il server รจ disponibile su MCP Registry
Supporto
Se incontri problemi:
Controlla la sezione Risoluzione Problemi
Esegui gli script di test per verificare la connessione
Controlla i log per messaggi d'errore
Apri un issue su GitHub
Licenza
Questo progetto รจ rilasciato sotto licenza MIT. Vedi il file LICENSE per dettagli.
Autore
Giacomo Fiorucci - giacomo.fiorucci@emotion-team.com
Ringraziamenti
Model Context Protocol per il framework MCP
Anthropic per Claude Desktop
GitHub per Copilot
Aruba per i servizi email e calendario affidabili
โญ Se questo progetto ti รจ utile, considera di dargli una stella su GitHub!