LibreOffice MCP Tools
Enables AI agents to read, write, and edit Office documents via LibreOffice with token-efficient design. Supports multiple formats including DOCX, XLSX, PPTX, and legacy formats through LibreOffice bridge.
README
LibreOffice MCP Tools
[!WARNING] This project was written by GitHub Copilot and has not been fully reviewed by a human. Code may contain bugs, security issues, or unexpected behavior. Use at your own risk. Do not use in production without thorough review.
A Model Context Protocol (MCP) server that gives AI agents (Claude, Copilot, Gemini, Cursor, etc.) the ability to read, write, and edit Office documents via LibreOffice โ with a token-efficient design that minimizes LLM context usage.
Inspired by the architecture of chrome-devtools-mcp.
โจ Features
- 22 MCP tools covering reading, writing, spreadsheets, and presentations
- Token-efficient design: outline-first navigation, range-based access, pagination
- Broad format support: DOCX, DOC, XLSX, XLS, PPTX, PPT, ODT, ODS, ODP, RTF, CSV, TXT, PDF
- Legacy format bridge:
.doc,.xls,.pptauto-converted via LibreOffice before parsing - No LibreOffice required for basic reads: native parsers handle DOCX, XLSX, PPTX directly
- LibreOffice required for: legacy formats, PDF export, format conversion
๐ Supported Formats
| Format | Extensions | Read | Write | Method |
|---|---|---|---|---|
| Word 2007+ | .docx, .dotx |
โ | โ | Native (mammoth read / JSZip OOXML write) |
| Word 97-2003 | .doc, .dot |
โ | โ | LibreOffice bridge |
| Excel 2007+ | .xlsx, .xlsm |
โ | โ | Native (ExcelJS) |
| Excel 97-2003 | .xls |
โ | โ | LibreOffice bridge |
| PowerPoint 2007+ | .pptx |
โ | โ | Native (JSZip OOXML) |
| PowerPoint 97-2003 | .ppt |
โ | โ | LibreOffice bridge |
| OpenDocument Text | .odt |
โ | โ | LibreOffice bridge |
| OpenDocument Spreadsheet | .ods |
โ | โ | LibreOffice bridge |
| OpenDocument Presentation | .odp |
โ | โ | LibreOffice bridge |
| Rich Text Format | .rtf |
โ | โ | LibreOffice bridge |
| CSV | .csv |
โ | โ | Native |
.pdf |
โ (text) | โ | LibreOffice CLI | |
| Plain text | .txt |
โ | โ | Native |
๐ Quick Start
Prerequisites
- Node.js 20+
- LibreOffice (optional for basic DOCX/XLSX/PPTX reads; required for .doc/.xls/.ppt and format conversion)
- Windows: Download LibreOffice
- macOS:
brew install --cask libreoffice - Linux:
sudo apt install libreofficeorsudo dnf install libreoffice
Installation
Using npx (recommended โ no install needed):
{
"mcpServers": {
"libreoffice": {
"command": "npx",
"args": ["-y", "@passerbyflutter/libreoffice-mcp-tools"]
}
}
}
Global install:
npm install -g @passerbyflutter/libreoffice-mcp-tools
From source:
git clone https://github.com/passerbyflutter/libreoffice-mcp-tools
cd libreoffice-mcp-tools
npm install
npm run build
Configure your MCP client
Add to your MCP client configuration (e.g., Claude Desktop claude_desktop_config.json):
{
"mcpServers": {
"libreoffice": {
"command": "npx",
"args": ["-y", "@passerbyflutter/libreoffice-mcp-tools"],
"env": {
"SOFFICE_PATH": "/path/to/soffice"
}
}
}
}
Or use .mcp.json at your project root:
{
"mcpServers": {
"libreoffice": {
"command": "npx",
"args": ["-y", "@passerbyflutter/libreoffice-mcp-tools"]
}
}
}
CLI Options
node build/bin/libreoffice-mcp.js [options]
--libreoffice-path <path> Path to soffice executable
(default: auto-detected or SOFFICE_PATH env)
๐ Tool Reference
Document Management
| Tool | Description |
|---|---|
document_open |
Open a file โ returns docId handle. Auto-bridges legacy formats. |
document_close |
Release document handle and temp files |
document_list |
List all open documents |
document_create |
Create new empty document (writer/calc/impress) |
document_save |
Save to current or new path |
document_export |
Export via LibreOffice (PDF, HTML, CSV, etc.) |
document_convert |
Convert file format (DOCโDOCX, XLSXโCSV, etc.) |
Reading (Token-Efficient)
| Tool | Description |
|---|---|
document_get_metadata |
Title, author, word/page count, dates |
document_get_outline |
Headings (Writer) / sheet names (Calc) / slide titles (Impress) |
document_read_text |
Paginated document text as Markdown |
document_read_range |
Specific paragraph or slide range |
document_search |
Find text with surrounding context |
Writing (Writer)
| Tool | Description |
|---|---|
document_insert_text |
Insert at start/end/after heading |
document_replace_text |
Find & replace (first or all occurrences) |
document_insert_paragraph |
Insert paragraph at specific index |
document_apply_style |
Apply heading/paragraph style |
Spreadsheet (Calc)
| Tool | Description |
|---|---|
spreadsheet_list_sheets |
Sheet names with row/col counts |
spreadsheet_get_range |
Cell range as JSON + markdown table |
spreadsheet_set_cell |
Set cell value or formula |
spreadsheet_set_range |
Set 2D range of values |
spreadsheet_add_sheet |
Add new sheet |
spreadsheet_get_formulas |
Get formula expressions in range |
Presentation (Impress)
| Tool | Description |
|---|---|
presentation_list_slides |
Slide titles with index |
presentation_get_slide |
Full slide content (title, body, notes) |
presentation_get_notes |
Speaker notes |
presentation_add_slide |
Add new slide (requires LibreOffice) |
presentation_update_slide |
Update slide content |
๐ก Token-Saving Workflow
For maximum token efficiency, follow this pattern:
1. document_open(filePath) โ get docId
2. document_get_metadata(docId) โ understand size/type
3. document_get_outline(docId) โ see structure
4. document_read_range(docId, startIndex=N, endIndex=M) โ read specific section
Instead of dumping the entire document, you navigate to exactly what you need.
Spreadsheet workflow:
1. document_open(path) โ docId
2. spreadsheet_list_sheets(docId) โ see all sheets
3. spreadsheet_get_range(docId, sheetName="Sales", range="A1:D20") โ targeted data
๐ Architecture
src/
โโโ index.ts # createMcpServer() โ MCP server factory
โโโ LibreOfficeAdapter.ts # soffice subprocess manager
โโโ DocumentContext.ts # Open document registry
โโโ DocumentSession.ts # Per-document state + format bridge
โโโ McpResponse.ts # Response builder (text/JSON/markdown)
โโโ Mutex.ts # Serializes LibreOffice subprocess calls
โโโ parsers/
โ โโโ DocxParser.ts # DOCX read โ {paragraphs, outline, metadata} (mammoth)
โ โโโ DocxOoxmlEditor.ts # DOCX write โ direct JSZip OOXML manipulation (format-preserving)
โ โโโ XlsxParser.ts # XLSX read/write via ExcelJS
โ โโโ PptxParser.ts # PPTX read โ {slides[]} (JSZip XML)
โ โโโ PptxOoxmlEditor.ts # PPTX write โ add/update slides, create PPTX (JSZip OOXML)
โโโ formatters/
โ โโโ MarkdownFormatter.ts
โ โโโ JsonFormatter.ts
โ โโโ TableFormatter.ts # Spreadsheet โ Markdown table
โโโ tools/
โโโ documents.ts # open/close/list/create
โโโ reader.ts # metadata/outline/read/search
โโโ writer.ts # insert/replace/style
โโโ spreadsheet.ts # get/set cells/ranges/sheets
โโโ presentation.ts # slides/notes
โโโ converter.ts # save/export/convert
๐งช Testing
# Create sample fixtures
node tests/create-fixtures.mjs
# Run smoke tests
npm test
๐ Environment Variables
| Variable | Description |
|---|---|
SOFFICE_PATH |
Path to LibreOffice soffice executable |
DEBUG |
Set to lo-mcp:* for verbose logging |
๐ 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.