o365-Admin MCP
A skill-based Microsoft 365 admin MCP server that exposes 4 base tools to execute Graph and Power Platform API calls, enabling administrative tasks via natural language.
README
o365-Admin MCP
A skill-based Microsoft 365 admin MCP server organized around APIs rather than applications. Capabilities are lazy-loaded from instruction files rather than exposed as a large tool manifest.
Architecture
This MCP exposes only 4 base tools:
| Tool | Purpose |
|---|---|
list_skills |
Returns available skills and resource references |
read_skill |
Loads a skill or resource reference into context |
graph_api_call |
Generic Graph API executor |
powerplatform_api_call |
Generic Power Platform API executor |
No domain-specific tools. Claude reads skills/resources to learn what API calls to construct, then executes via the generic tools.
Directory Structure
o365-Admin/
├── src/
│ └── index.ts # MCP server with 4 base tools
├── skills/
│ ├── graph-api.md # Core: auth, request patterns, pagination, errors
│ └── powerplatform-api.md # Core: auth, environments, request patterns
├── resources/
│ ├── graph/
│ │ ├── sites.md # SharePoint: sites, drives, lists, permissions
│ │ ├── teams.md # Teams: teams, channels, tabs, apps
│ │ ├── users.md # Entra: users, groups, directory roles
│ │ └── mail.md # Exchange: messages, folders, rules, calendars
│ └── powerplatform/
│ ├── flows.md # Flow definitions, runs, connections
│ └── environments.md # Environment management, DLP policies
├── README.md
├── package.json
└── tsconfig.json
Prerequisites
- Node.js 18+
- Azure AD App Registration with appropriate permissions
- Access to Microsoft 365 tenant
Azure AD App Registration
Step 1: Create App Registration
- Go to Azure Portal > Azure Active Directory > App registrations
- Click "New registration"
- Name:
o365-Admin-MCP - Supported account types: Single tenant (or multi-tenant if needed)
- Click "Register"
Step 2: Create Client Secret
- In your app registration, go to "Certificates & secrets"
- Click "New client secret"
- Add description and expiry
- Copy the secret value immediately (shown only once)
Step 3: Add API Permissions
Go to "API permissions" > "Add a permission" > "Microsoft Graph" > "Application permissions"
Add the following permissions based on your needs:
SharePoint/OneDrive:
Sites.ReadWrite.AllSites.Manage.All
Teams:
Team.CreateTeamSettings.ReadWrite.AllChannel.CreateChannelSettings.ReadWrite.AllTeamsApp.ReadWrite.All
Users/Directory:
Directory.Read.AllDirectory.ReadWrite.AllUser.ReadWrite.AllGroup.ReadWrite.AllRoleManagement.ReadWrite.Directory
Mail/Calendar:
Mail.ReadWriteMail.SendCalendars.ReadWriteMailboxSettings.ReadWrite
Step 4: Grant Admin Consent
Click "Grant admin consent for [Your Tenant]" and confirm.
Step 5: Note Your IDs
From the app registration "Overview" page, copy:
- Application (client) ID
- Directory (tenant) ID
Environment Configuration
Set the following environment variables:
export AZURE_CLIENT_ID="your-client-id"
export AZURE_CLIENT_SECRET="your-client-secret"
export AZURE_TENANT_ID="your-tenant-id"
Or create a .env file (remember to add to .gitignore):
AZURE_CLIENT_ID=your-client-id
AZURE_CLIENT_SECRET=your-client-secret
AZURE_TENANT_ID=your-tenant-id
Installation
# Clone the repository
git clone https://github.com/yourusername/o365-Admin.git
cd o365-Admin
# Install dependencies
npm install
# Build TypeScript
npm run build
# Run the server
npm start
Development
# Run in development mode (no build step)
npm run dev
Usage with Claude
MCP Configuration
Add to your Claude MCP settings:
{
"mcpServers": {
"o365-admin": {
"command": "node",
"args": ["path/to/o365-Admin/dist/index.js"],
"env": {
"AZURE_CLIENT_ID": "your-client-id",
"AZURE_CLIENT_SECRET": "your-client-secret",
"AZURE_TENANT_ID": "your-tenant-id"
}
}
}
}
Example Workflow
-
List available resources:
Use list_skills to see what's available -
Load relevant documentation:
Use read_skill with type="resource" and name="graph/sites" -
Execute API calls:
Use graph_api_call with method="GET" and endpoint="/sites/root"
Example Conversation
User: Create a new SharePoint document library called "Project Files" in the IT site
Claude:
1. [Uses read_skill to load graph/sites resource]
2. [Uses graph_api_call GET /sites/contoso.sharepoint.com:/sites/IT to get site ID]
3. [Uses graph_api_call POST /sites/{site-id}/lists with library config]
Result: Document library "Project Files" created successfully.
Adding New Resources
To extend the MCP with new capabilities:
-
Create a new
.mdfile in the appropriate directory:skills/for core API patternsresources/graph/for Graph API endpointsresources/powerplatform/for Power Platform endpoints
-
Follow the existing format:
- Start with "# Title"
- Include "## Required Permissions" section
- Document each endpoint with method, URL, and example body
- Mark incomplete sections with TODO:
-
The new file will automatically appear in
list_skillsoutput
Resource Template
# Resource Name
Brief description of what this resource covers.
## Required Permissions
| Permission | Type | Description |
|------------|------|-------------|
| Permission.Name | Application | What it allows |
## Operation Name
Description of the operation.
\`\`\`
METHOD /endpoint/path
Content-Type: application/json
{
"property": "value"
}
\`\`\`
Security Considerations
- Never commit credentials to version control
- Use environment variables or secure secret management
- Apply principle of least privilege when assigning permissions
- Regularly rotate client secrets
- Monitor API usage for anomalies
License
MIT
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.