loading…
Search for a command to run...
loading…
Enables AI agents to interact with Microsoft Outlook via the Microsoft Graph API for managing emails and calendar events. It allows users to read and send email
Enables AI agents to interact with Microsoft Outlook via the Microsoft Graph API for managing emails and calendar events. It allows users to read and send emails, list messages, and create calendar appointments with automatic Teams links.
Un serveur Model Context Protocol (MCP) pour Microsoft Outlook, permettant à des agents IA comme Claude Desktop d'interagir avec ta boîte mail et ton calendrier via l'API Microsoft Graph.
| Outil | Description | Paramètres |
|---|---|---|
list_messages |
Liste les 10 derniers emails de la boîte de réception | — |
get_message |
Lit le contenu complet d'un email | message_id |
send_message |
Envoie un email | subject, toRecipients, content, contentType |
list_events |
Liste les événements des 7 prochains jours | — |
create_event |
Crée un événement (avec lien Teams automatique) | subject, startDateTime, endDateTime, location, content, attendees |
git clone https://github.com/FRESHSK/mcp_outlook_01.git
cd mcp_outlook_01
npm install
MCP OutlookPublic client/native → http://localhost| Permission | Type | Description |
|---|---|---|
User.Read |
Delegated | Lire le profil de l'utilisateur connecté |
Mail.Read |
Delegated | Lire les emails |
Mail.Read.Shared |
Delegated | Lire les emails partagés |
Mail.ReadBasic |
Delegated | Lire les infos de base des emails |
Mail.ReadWrite |
Delegated | Lire et modifier les emails |
Mail.ReadWrite.Shared |
Delegated | Lire et modifier les emails partagés |
Mail.Send |
Delegated | Envoyer des emails |
Mail.Send.Shared |
Delegated | Envoyer des emails au nom d'autres |
Calendars.Read |
Delegated | Lire les calendriers |
Calendars.Read.Shared |
Delegated | Lire les calendriers partagés |
Calendars.ReadBasic |
Delegated | Lire les infos de base des calendriers |
Calendars.ReadWrite |
Delegated | Lire et modifier les calendriers |
Calendars.ReadWrite.Shared |
Delegated | Lire et modifier les calendriers partagés |
Résultat attendu dans Azure Portal :
✅ User.Read (Delegated) - Granted
✅ Mail.Read (Delegated) - Granted
✅ Mail.Read.Shared (Delegated) - Granted
✅ Mail.ReadBasic (Delegated) - Granted
✅ Mail.ReadWrite (Delegated) - Granted
✅ Mail.ReadWrite.Shared (Delegated) - Granted
✅ Mail.Send (Delegated) - Granted
✅ Mail.Send.Shared (Delegated) - Granted
✅ Calendars.Read (Delegated) - Granted
✅ Calendars.Read.Shared (Delegated) - Granted
✅ Calendars.ReadBasic (Delegated) - Granted
✅ Calendars.ReadWrite (Delegated) - Granted
✅ Calendars.ReadWrite.Shared (Delegated) - Granted
cp .env.example .env
Éditer .env :
MICROSOFT_CLIENT_ID=ton-client-id-azure
MICROSOFT_TENANT_ID=common
⚠️ Ne jamais committer le fichier
.env— il est dans.gitignore
ℹ️ Utilise
commonpour un compte personnel, ou ton Tenant ID pour un compte organisation.
node server.js
Tu verras dans le terminal :
To sign in, use a web browser to open the page
https://microsoft.com/devicelogin and enter the code XXXXXXXX
token_cache.json sera créé automatiquement✅ Cette étape n'est nécessaire qu'une seule fois. Le token se renouvelle automatiquement.
Éditer le fichier claude_desktop_config.json de Claude Desktop :
C:\Users\<user>\AppData\Roaming\Claude\claude_desktop_config.json~/Library/Application Support/Claude/claude_desktop_config.json{
"mcpServers": {
"outlook": {
"command": "node",
"args": [
"C:\\chemin\\absolu\\vers\\mcp_outlook_01\\server.js"
]
}
}
}
Fermer et relancer Claude Desktop. Tu peux maintenant demander à Claude :
mcp_outlook_01/
├── server.js # Serveur MCP principal
├── .env # Variables d'environnement (non commité)
├── .env.example # Template des variables d'environnement
├── .gitignore # Fichiers ignorés par Git
├── token_cache.json # Cache du token MSAL (non commité)
└── package.json # Dépendances Node.js
| Package | Usage |
|---|---|
@modelcontextprotocol/sdk |
Serveur MCP |
@azure/msal-node |
Authentification Microsoft |
node-fetch |
Requêtes HTTP vers Graph API |
dotenv |
Variables d'environnement |
zod |
Validation des paramètres des outils |
.env contenant les clés est dans .gitignoretoken_cache.json contenant les tokens Microsoft est dans .gitignoreLe MCP ne répond pas dans Claude Desktop ?
→ Vérifier les logs : AppData\Roaming\Claude\logs\mcp-server-outlook.log
Erreur d'authentification ou nouvelles permissions ?
→ Supprimer token_cache.json et relancer node server.js pour se réauthentifier
Erreur fetch is not a function ?
→ Vérifier que node-fetch est bien installé : npm install node-fetch
Erreur lors de l'envoi d'email ?
→ Le code gère les réponses 202 Accepted — vérifier que server.js est à jour
MIT
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"mcp-outlook-server": {
"command": "npx",
"args": []
}
}
}