MCP Server - Microsoft 365 File Search (SharePoint & OneDrive)

MCP Server - Microsoft 365 File Search (SharePoint & OneDrive)

By godwin3737 GitHub

-

mcp-server microsoft365
Overview

MCP Server is a Model Context Protocol server implementation that provides advanced file search capabilities within Microsoft 365, specifically for SharePoint and OneDrive. It enables efficient file discovery and metadata analysis, integrating seamlessly with business workflows.

How to use MCP Server?

To use the MCP Server, you need to register an application in the Azure Portal, configure your environment variables, and integrate it with Claude Desktop by updating the configuration file. You can perform file searches and retrieve file content using the provided tools.

Key features of MCP Server?

  • Advanced file search within Microsoft 365 environment.
  • Metadata analysis for efficient file discovery.
  • Local caching for improved performance and reduced API calls.

Use cases of MCP Server?

  1. Searching for specific files in SharePoint or OneDrive.
  2. Analyzing file metadata for business insights.
  3. Integrating file search capabilities into business workflows.

FAQ from MCP Server?

  • What permissions are required to use MCP Server?

You need to grant permissions such as Sites.Read.All and Files.Read.All in the Azure Portal.

  • Is there a caching mechanism?

Yes, the server caches downloaded files locally to improve performance.

  • What programming language is used for this project?

The MCP Server is implemented in Python.

Content

MCP Server - Microsoft 365 File Search (SharePoint & OneDrive)

Overview

A Model Context Protocol (MCP) server implementation that provides advanced file search capabilities within Microsoft 365. This server enables efficient file discovery, metadata analysis, and integration with business workflows by making available the content from SharePoint/OneDrive.

https://github.com/user-attachments/assets/bbe63c02-f6d9-4c9b-8f98-36fc22a081cc

Components

Tools

The server offers 2 core tools:

  • search_m365_files
    Perform a file search within the M365 environment.
    Input:

    • query (string): The search term or criteria.
      Returns: Array of file metadata objects. Metadata includes the file content summary, drive ID, and file ID, among other details.
  • get_file_content
    Retrieve content from a specific file.
    Input:

    • driveid (string): The unique identifier of the parent drive.
    • fileid (string): The unique identifier of the file.
      Returns: File content as a binary stream.
      Note: Uses a local cache to speed up repeat access.

Caching

To improve performance and reduce redundant API calls, the server caches downloaded files locally. This is particularly useful when working with large documents or frequently accessed files.

  • Cached files are stored in the ./src/mcp_m365_filesearch/.local/downloads directory (relative to the project root).
  • When a file is requested via get_file_content, the server first checks the cache.
  • If the file is already cached, it is returned directly from disk without a new API call.

This feature ensures faster response times and efficient use of API rate limits.

Usage with Claude Desktop

To integrate the server with Claude Desktop, update your claude_desktop_config.json:

"mcpServers": {
  "M365 File Search (SharePoint/OneDrive)": {
    "command": "uv",
    "args": [
      "--directory",
      "full_path_to_parent_directory",
      "run",
      ".\\src\\mcp_m365_filesearch\\server.py"
    ],
    "env": {
      "CLIENT_ID": "MSGraph Client ID",
      "CLIENT_SECRET": "MS Graph Client Secret",
      "TENANT_ID": "TENANT ID",
      "REGION": "SEARCH REGION"
    }
  }
}

Microsoft Graph App Registration

To use this server, you'll need to register an application in the Azure Portal:

  1. Register a new application.
  2. Note down the Client ID and Tenant ID.
  3. Create a Client Secret under Certificates & Secrets.
  4. Under API permissions, add the following delegated or application permissions:
    • Sites.Read.All
    • Files.Read.All
  5. Click Grant admin consent for these permissions.

Ensure these values are correctly set in your env configuration for the MCP server.

License

This project is licensed under the MIT License.
You are free to use, modify, and distribute it with proper attribution.

No tools information available.

-

mcp-server v2ex
View Details

my-mcp-server(without auth)

mcp-server cloudflare
View Details
mcp-server
mcp-server by iyerrama29

MCP demo

mcp-server demo
View Details
Next MCP server
Next MCP server by Collaborne

-

mcp-server NEXT
View Details
MCP-Server
MCP-Server by fmpoliveira

-

mcp-server meteostat
View Details

Mirror of

mcp-server timelock-encryption
View Details

-

mcp-server minio
View Details