OneNote MCP Server
A Model Context Protocol (MCP) server that provides AI assistants with access to Microsoft OneNote. This server enables AI models to read from and write to OneNote notebooks, sections, and pages.
Project Overview
This project implements an MCP server that connects to Microsoft OneNote using the Microsoft Graph API. It provides tools for:
- Reading notebooks, sections, and pages from OneNote
- Creating new notebooks, sections, and pages in OneNote
- Converting HTML content to text for better RAG processing
Project Structure
onenote/
├── dist/ # Compiled JavaScript files (generated)
├── src/ # TypeScript source files
│ ├── index.ts # Main entry point and server implementation
│ └── types/ # Custom TypeScript type definitions
├── .vscode/ # VS Code configuration
│ ├── launch.json # Debug configurations
│ └── tasks.json # Build tasks
├── package.json # Project dependencies and scripts
├── tsconfig.json # TypeScript configuration
├── Dockerfile # Docker configuration
├── .env.local.example # Example environment variables
└── README.md # This file
Authentication
The server uses Microsoft Authentication Library (MSAL) with device code flow for authentication:
- When first run, the server generates a device code and URL
- The code is saved to
device-code.txt
in the project directory - You must visit the URL and enter the code to authenticate
- After authentication, tokens are cached in
token-cache.json
for future use
MCP Tools
The server provides the following MCP tools:
onenote-read
Read content from Microsoft OneNote notebooks, sections, or pages.
Parameters:
type
: "read_content"pageId
: (optional) ID of the specific page to readsectionId
: (optional) ID of the section to list pages fromnotebookId
: (optional) ID of the notebook to list sections fromincludeContent
: (optional) Whether to include the content of the page (default: true)includeMetadata
: (optional) Whether to include metadata about the page (default: false)
onenote-create
Create new content in Microsoft OneNote.
Parameters:
type
: "create_page", "create_section", or "create_notebook"title
: Title of the content to createcontent
: Content in HTML format (for pages)parentId
: (optional) ID of the parent section or notebook
Getting Started
Prerequisites
- Node.js (v14 or higher)
- npm (v6 or higher)
- Microsoft Azure account with a registered application
- OneNote account (Microsoft 365 subscription)
Azure Setup
- Register a new application in the Azure Portal
- Add the following API permissions:
- Microsoft Graph > Notes.Read
- Microsoft Graph > Notes.ReadWrite
- Note your Application (client) ID for configuration
Installation
- Clone the repository
- Install dependencies:
1npm install
- Create a
.env.local
file with your Azure client ID:
CLIENT_ID=your-client-id-from-azure
Development
To run the application in development mode:
1npm run dev
Building
To compile TypeScript to JavaScript:
1npm run build
Running
To run the compiled application:
1npm start
Docker Support
You can build and run the application using Docker:
1# Create a data directory for persistence 2mkdir -p data 3 4# Build the Docker image 5docker build -t onenote-mcp-server . 6 7# Run the container 8docker run -d \ 9 --name onenote-mcp-server \ 10 -e CLIENT_ID=your-client-id \ 11 -v $(pwd)/data:/app/dist \ 12 onenote-mcp-server
Authentication with Docker
When running in Docker, the authentication flow works as follows:
- Start the container as shown above
- Check the device code file:
1cat data/device-code.txt
- Follow the instructions to authenticate with Microsoft
- The token will be cached in
data/token-cache.json
for future use
Setup with Claude Desktop
- Clone this repository
- Run
npm install
to install dependencies - In Claude Desktop, add a new MCP server:
- Set the server directory to your cloned repository
- Set the command to:
npm run build && npm start
- Add the following environment variable:
- Name: CLIENT_ID
- Value: [Your Microsoft Azure Application Client ID]
- Save the configuration and connect to the server
Authentication Flow
- On first run, the server will generate a device code and URL
- The code is saved to
device-code.txt
in the project directory - Visit the URL and enter the code to authenticate
- After authentication, tokens are cached in
token-cache.json
- Subsequent runs will use the cached token if valid
Troubleshooting
- Authentication Issues: Delete
token-cache.json
to force re-authentication - Module Errors: Ensure you're using Node.js 14+ with ES modules support
- TypeScript Errors: Run
npm run build
to check for compilation errors