Skip to main content
Glama
Zerg00s

SharePoint Online MCP Server

by Zerg00s

SharePoint Online MCP Server šŸš€

Node.js Version SharePoint REST API npx License SharePoint Online Windows Linux macOS

SharePoint MCP Server

Most powerful SharePoint MCP server enabling seamless interaction with SharePoint Online through the SharePoint REST API.

This MCP server is designed to be used with the Claude Desktop app, but could be used by other MCP clients such as Cline as well.

Table of Contents

Related MCP server: Webflow MCP Server

SharePoint Operations Availability

Users

Operation

Available

Notes

List Site Users

āœ…

List Site Groups

āœ…

Get Group Members

āœ…

Add Group Member

āœ…

Remove Group Member

āœ…

Get User Profile

āŒ

/_api/SP.UserProfiles.PeopleManager

Update User Profile

āŒ

Sites

Operation

Available

Get Site Details

āœ…

Update Site Properties

āœ…

Get Global Navigation Links

āœ…

Get Quick Navigation Links

āœ…

Add Navigation Link

āœ…

Update Navigation Link

āœ…

Delete Navigation Link

āœ…

Get Subsites

āœ…

Create Subsite

āŒ

Delete Subsite

āœ…

Regional Settings

Operation

Available

Get Regional Settings

āœ…

Update Regional Settings

āŒ

Features

Operation

Available

Get Site Collection Features

āœ…

Get All Site Features

āœ…

Get Site Feature

āœ…

Get All Site Feature

āœ…

Activate Feature

āŒ

Deactivate Feature

āŒ

Lists

Operation

Available

Notes

Get All Lists

āœ…

Create List

āœ…

Add Site Content Type to list

āœ…

Remove Content Type from list

āœ…

Add Field to List Content Type

āŒ

Remove Field from List Content Type

āŒ

Update List

āœ…

Get List Fields

āœ…

Create List Field

āœ…

Basic scenarios only

Update List Field

āœ…

Delete List Field

āœ…

Set List Field formatting

āŒ

Set List View formatting

āŒ

Delete List

āœ…

List Views

Operation

Available

Get List Views

āœ…

Delete List View

āœ…

Create List View

āœ…

Update List View

āœ…

Get View Fields

āœ…

Add View Field

āœ…

Remove View Field

āœ…

Remove All View Fields

āœ…

Move View Field

āœ…

List Content Types

Operation

Available

Notes

Get All List Content Types

āœ…

Get List Content Type

āœ…

Create List Content Type

āŒ

Update List Content Type

āœ…

Change CT title and group only

Delete List Content Type

āœ…

List Items

Operation

Available

Get All List Items

āœ…

Create List Item

āœ…

Update List Item

āœ…

Delete List Item

āœ…

Site Content Types

Operation

Available

Notes

Get All Site Content Types

āœ…

Get Site Content Type

āœ…

Create Site Content Type

āŒ

Update Site Content Type

āœ…

Change CT title and group only

Delete Site Content Type

āœ…

Pages

Operation

Available

Create Modern Page

āœ…

Delete Modern Page

āœ…

List Modern Pages

āœ…

Add Page Web Part

āŒ

Delete Page Web Part

āŒ

Move Page Web Part

āŒ

Update Page Web Part

āŒ

Documents

Operation

Available

Create Document

āŒ

Upload Document

āŒ

Move Document

āŒ

Copy Document

āŒ

Taxonomy

Operation

Available

Get Taxonomy Group

āŒ

Create Taxonomy Label

āŒ

Update Taxonomy Label

āŒ

Delete Taxonomy Label

āŒ

Operation

Available

Search within SharePoint Site

āœ…


Authentication Options

The server supports two authentication methods:

  1. Client Secret Authentication - Traditional client ID and secret. It's the App-only authentication that is deprecated and will not work after April 2026.

  2. Certificate Authentication - More modern method using Azure AD App Registration with certificate

Option 1: Client Secret Authentication (Will not work after April 2026)

This option requires the SharePoint administrator role.

Configuration steps

āš ļø You need to be a SharePoint tenant admin or a global admin to create a SharePoint app.

Allow SharePoint-only apps

  • Download and install the SharePoint Online Management Shell from here.

  • Open PowerShell and run the following command to make sure the SharePoint-only apps are enabled:

Connect-SPOService -Url https://<your-tenant>-admin.sharepoint.com/ Set-SPOTenant -DisableCustomAppAuthentication $false

Create SharePoint-only App with Client Secret

  • Open https://<your-tenant>.sharepoint.com/_layouts/15/appregnew.aspx

  • Click Generate to create a new client ID and secret.

  • Fill in the following fields:

    • App Domain: www.example.com (or any domain you own)

    • Redirect URL: http://example.com App registration

  • Click Create to create the app.

  • Copy the Client ID and Client Secret values to a safe place. You will need them later.

Grant App Permissions

  • Open https://<your-tenant>.sharepoint.com/_layouts/15/appinv.aspx

  • Paste the Client ID value in the App ID field and click Lookup. Lookup

  • Paste the following XML in the App Permission Request XML field:

<AppPermissionRequests AllowAppOnlyPolicy="true"> <AppPermissionRequest Scope="http://sharepoint/content/tenant" Right="FullControl" /> </AppPermissionRequests>
  • Click Create and then Trust It to grant the app permissions. Trust it

Option 2: Certificate Authentication

Certificate-based authentication provides better security than client secrets. It uses a certificate to prove the identity of the application instead of a shared secret.

āš ļø This option requires the Global administrator role to provide the necessary permissions to the app.

Clone the repo

git clone https://github.com/Zerg00s/server-sharepoint.git

Create Azure AD App with Certificate

Navigate to the cloned repo and use the provided PowerShell script to create the Azure AD app with certificate:

.\Create-SPAppCertificate.ps1 -AppName "SharePoint-Server-MCP" -CertName "SharePoint-Server-MCP-Cert" -CertPassword "YourSecureP@ssw0rd!"

This script will

  1. Create a self-signed certificate in your certificate store

  2. Register an Azure AD application

  3. Add the certificate to the application

  4. Configure the required SharePoint permissions

  5. Generate configuration files with the necessary settings

  6. Output the claude_desktop_config.json that is compatible with Claude Desktop

After running the script, you'll get an Admin Consent URL. Open it in a browser and sign in as a Global Admin to grant consent for the permissions.


Install Node.js

Install Node.js version: 22.14.0 or later

Install and Configure Claude Desktop

  • Download Claude Desktop and install it.

  • In Claude Desktop, go to File > Settings > Developer. File > Settings

  • Click Edit Config Config

  • Open the claude_desktop_config.json config file in the editor. You can also use the claude_desktop_config.json file generated by the PowerShell script earlier.

  • Paste the following to the config and update the mcpServers section with your own values:

Config for Certificate Authentication

{ "mcpServers": { "server-sharepoint": { "command": "npx", "args": [ "-y", "server-sharepoint" ], "env": { "AZURE_APPLICATION_ID": "<your-app-id>", "AZURE_APPLICATION_CERTIFICATE_THUMBPRINT": "<your-certificate-thumbprint>", "AZURE_APPLICATION_CERTIFICATE_PASSWORD": "<your-certificate-password>", "M365_TENANT_ID": "<your-tenant-id>" } } } }
{ "mcpServers": { "server-sharepoint": { "command": "npx", "args": [ "-y", "server-sharepoint" ], "env": { "SHAREPOINT_CLIENT_ID": "<your-client-id>", "SHAREPOINT_CLIENT_SECRET": "<your-client-secret>", "M365_TENANT_ID": "<your-tenant-id>" } } } }

šŸ’”Learn how to get the tenant ID from Entra ID

  • Save the config file and restart Claude Desktop. Make sure to quit the app completely via the tasks tray icon: Quick Claude App

How to "talk" to the MCP Server

  • Open Claude Desktop and ask a question like Get me the list of lists from https://<your-tenant>.sharepoint.com/sites/Dashboard-Communication. Present the results in a table form. don't use code.

Sample result


For Contributors

Build a new npm package

npm run build npm publish npx clear-npx-cache npm cache clean --force

Run MCP Inspector locally

npx @modelcontextprotocol/inspector node build/src/index.js

MCP Server Context 7 Documentation for LLMs

MCP Server Context 7 Documentation for LLMs

SharePoint REST API Documentation

Local Development

  • Clone the repo

  • nvm use 22.14.0

  • npm install

  • Update MCP config in claude_desktop_config.json file. Sample:

For client secret authentication (Will not work after April 2026)

{ "mcpServers": { "sharepoint": { "command": "node", "args": [ "C:\\trash\\server-sharepoint\\build\\index.js" ], "env": { "SHAREPOINT_CLIENT_ID": "aaa2ce0f-7c97-4e51-acd9-4ac99e6831d0", "SHAREPOINT_CLIENT_SECRET": "bbb0OFF+aWkua2NJRERUMGduMmhsWDhGUTVPUHJZLXd5dldSemNPUw==", "M365_TENANT_ID": "22bcd981-eaa6-475f-aac3-3afca0c35261" } } } }

For certificate authentication (Recommended)

{ "mcpServers": { "sharepoint": { "command": "node", "args": [ "C:\\trash\\server-sharepoint\\build\\index.js" ], "env": { "AZURE_APPLICATION_ID": "5bc793c7-3eb0-4b86-88bf-b464b2459c4c", "AZURE_APPLICATION_CERTIFICATE_THUMBPRINT": "3D38D1D8AC3228CAD35E527D1105101B0B90CE86", "AZURE_APPLICATION_CERTIFICATE_PASSWORD": "TemporaryP@ssw0rd", "M365_TENANT_ID": "11bcd981-eaa6-475f-aac3-3afca0c35261" } } } }
  • Make changes to the code

  • Build the code npm run build

  • Test with MCP Inspector: npx @modelcontextprotocol/inspector node build/src/index.js -y

Install Server
A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Zerg00s/server-sharepoint'

If you have feedback or need assistance with the MCP directory API, please join our Discord server