Enables reading, writing, and searching documents, as well as managing collections through the Outline API with full support for Markdown formatting.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Outline MCP Serversearch for the onboarding guide in my documents"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
Outline MCP Server
A Model Context Protocol (MCP) server for Outline that enables reading and writing documents through the Outline API.
Features
Read Documents: Get individual documents, search, and list documents
Write Documents: Create, update, and delete documents
Collection Management: List and retrieve collection information
Full Text Search: Search across all documents in your Outline instance
Markdown Support: Create and edit documents with full Markdown formatting
Installation
Clone or download this repository
Install dependencies:
npm installBuild the project:
npm run build
Configuration
Before using the server, you need to set up your Outline API credentials:
Get your Outline API token:
Log into your Outline instance (e.g., https://app.getoutline.com)
Go to Settings → API Tokens
Create a new token
Set environment variables:
export OUTLINE_BASE_URL="https://your-outline-instance.com" export OUTLINE_API_KEY="your-api-token-here"
Usage
Running the Server
Start the MCP server:
The server communicates via stdio and is compatible with any MCP client.
Available Tools
Document Operations
outline_get_document
Get a specific document by ID
Parameters:
id(string, required)
outline_search_documents
Search for documents across your Outline instance
Parameters:
query(string, required),limit(number, optional, default: 25)
outline_list_documents
List documents, optionally filtered by collection
Parameters:
collectionId(string, optional),limit(number, optional, default: 25)
outline_create_document
Create a new document
Parameters:
title(string, required)text(string, required) - Markdown contentcollectionId(string, optional)parentDocumentId(string, optional)publish(boolean, optional, default: false)
outline_update_document
Update an existing document
Parameters:
id(string, required)title(string, optional)text(string, optional) - Markdown contentpublish(boolean, optional)
outline_delete_document
Delete a document
Parameters:
id(string, required)
Collection Operations
outline_list_collections
List all collections in your Outline instance
Parameters: none
outline_get_collection
Get information about a specific collection
Parameters:
id(string, required)
Example Usage
Here are some example tool calls:
Development
Project Structure
Scripts
npm run build- Compile TypeScript to JavaScriptnpm run dev- Build and run the servernpm run watch- Watch for changes and rebuildnpm start- Run the compiled server
Building
The compiled JavaScript will be output to the dist/ directory.
Configuration with MCP Clients
To use this server with an MCP client, you'll need to configure it to run this server. The exact configuration depends on your client, but generally you'll need to:
Specify the command to run:
node /path/to/outline-mcp-server/dist/index.jsSet the environment variables for your Outline instance
Configure the client to use stdio transport
Client Configuration Examples
Claude
For clients like Claude that use a JSON configuration file, you can add the following to your mcp-servers.json:
Make sure to replace the args path with the absolute path to the index.js file in your project, and fill in your actual credentials in the env block.
Cursor
For clients like Cursor, you can typically set environment variables directly within the client's settings or by launching the client from a terminal where you have already exported the variables.
API Rate Limits
Be aware that Outline may have API rate limits. The server doesn't implement rate limiting internally, so you may need to handle this at the client level if you're making many requests.
Error Handling
The server includes comprehensive error handling and will return descriptive error messages for common issues like:
Missing or invalid API credentials
Network connectivity problems
Invalid document IDs
API rate limit errors
Security Notes
Store your API token securely using environment variables
Never commit your API token to version control
Consider using restricted API tokens with minimal required permissions
Be cautious when allowing others to use your MCP server as it has full access to your Outline instance
License
MIT License - see LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit issues and pull requests.