Microsoft Graph MCP Server
Read-only access to Microsoft 365 suite via Model Context Protocol.
Architecture
The diagram shows the complete system architecture including Claude Code integration, MCP server components, Azure AD authentication, Microsoft Graph API gateway, and M365 services (SharePoint, OneDrive, Outlook, Teams, Calendar).
Features
SharePoint: Search sites, list files, get content
OneDrive: Browse user files, search
Outlook: Search emails, read messages
Teams: List teams/channels, read messages
Calendar: View events, search calendar
Setup
📖 For detailed setup instructions, see
Quick Start
Azure AD App Registration: Register app with Application permissions
Install:
pip install -r requirements.txtConfigure: Add credentials to
~/.claude.jsonTest:
msgraph.test_connection()
Required Azure AD Permissions
Register an Azure AD app with these Application permissions:
Sites.Read.All- SharePointFiles.Read.All- OneDrive/SharePoint filesMail.Read- OutlookChannelMessage.Read.All- Teams messagesChat.Read.All- Teams chatsCalendars.Read- CalendarUser.Read.All- User directoryGroup.Read.All- Teams/Groups
Grant admin consent for all permissions.
2. Install Dependencies
3. Configure Claude
Add to ~/.claude.json:
Usage
Access via msgraph module in code execution:
Available Functions
Connection
test_connection()- Test API connectivitylist_users(query, limit)- Search usersget_user(email)- User details
SharePoint
search_sites(query, limit)- Find siteslist_site_contents(site_id, path)- Browse folderssearch_files(query, site_id, limit)- Search filesget_file_content(site_id, item_id)- Read fileget_file_metadata(site_id, item_id)- File info
OneDrive
list_user_files(email, path)- Browse OneDrivesearch_user_files(email, query, limit)- Search files
Outlook
search_emails(query, email, limit)- Search maillist_recent_emails(email, limit, folder)- Recent mailget_email(email, message_id)- Full email
Teams
list_teams(limit)- List teamslist_channels(team_id)- Team channelsget_channel_messages(team_id, channel_id, limit)- Messagessearch_channel_messages(team_id, channel_id, query)- Search
Calendar
list_events(email, days_ahead)- Upcoming eventssearch_events(email, query, limit)- Search calendarget_event(email, event_id)- Event details
Security
Read-only: No write permissions
Sandboxed: Limited Python builtins
App-only auth: No user credentials stored
Token managed: Automatic refresh, never exposed