# LibreOffice MCP Server
A comprehensive Model Context Protocol (MCP) server that provides tools and resources for interacting with LibreOffice documents. This server enables AI assistants and other MCP clients to create, read, convert, and manipulate LibreOffice documents programmatically.
[](https://www.python.org/downloads/)
[](https://www.libreoffice.org/)
[](https://spec.modelcontextprotocol.io/)
## π Features
### LibreOffice Extension (Plugin) - Recommended!
- **Native Integration**: Embedded MCP server directly in LibreOffice
- **Real-time Editing**: Live document manipulation with instant visual feedback
- **Performance**: 10x faster than external server (direct UNO API access)
- **9 Consolidated Tools**: Reduced from 32 individual tools for better UX
- **Track Changes Support**: Full revision tracking awareness
- **Multi-document**: Work with all open LibreOffice documents
- **HTTP API**: External AI assistant access via localhost:8765
### Document Operations
- **Create Documents**: New Writer, Calc, Impress, and Draw documents
- **Read Content**: Extract text with visible_content for Track Changes awareness
- **Navigate**: Paragraph-level navigation, cursor positioning, document outline
- **Edit**: Insert, format, select, and replace text
- **Search**: Find/replace with Track Changes awareness (skips tracked deletions)
- **Comments**: Add and retrieve document annotations
- **Track Changes**: Enable, disable, list, accept/reject revisions
## π§ 9 Consolidated MCP Tools
The MCP interface provides 9 logical tool groups (consolidated from 32 individual tools):
| Tool | Actions | Description |
|------|---------|-------------|
| `document` | create, info, list, content, status | Document management |
| `structure` | outline, paragraph, range, count | Document navigation |
| `cursor` | goto_paragraph, goto_position, position, context | Cursor control |
| `selection` | paragraph, range, delete, replace | Text selection |
| `search` | find, replace, replace_all | Search/replace (Track Changes aware) |
| `track_changes` | status, enable, disable, list, accept, reject, accept_all, reject_all | Revision tracking |
| `comments` | list, add | Comment management |
| `save` | save, export | Save/export documents |
| `text` | insert, format | Text insertion and formatting |
See [docs/TOOL_REFERENCE.md](docs/TOOL_REFERENCE.md) for complete documentation.
## π Requirements
- **LibreOffice**: 24.2+ (must be accessible via command line)
- **Python**: 3.12+
- **UV Package Manager**: For dependency management
## π Installation
### LibreOffice Extension (Recommended)
```bash
# Clone the repository
git clone https://github.com/jwingnut/mcp-libre.git
cd mcp-libre
# Build and install the LibreOffice extension
cd plugin/
./build.sh
unopkg add ../build/libreoffice-mcp-extension-1.0.0.oxt
# Restart LibreOffice
```
After installation:
1. Open LibreOffice Writer
2. Go to **Tools > MCP Server > Start MCP Server**
3. The HTTP API is now available at `http://localhost:8765`
### FastMCP Bridge (for Claude Code)
```bash
# Install FastMCP
pip install fastmcp httpx
# Configure Claude Code
claude mcp add libreoffice -- fastmcp run /path/to/libreoffice_mcp_server.py
```
## π― Quick Start
### Using with Claude Code
Once configured, you can use natural language commands:
```
"Get document info"
β document(action="info")
"Find all occurrences of 'hello'"
β search(action="find", query="hello")
"Enable track changes"
β track_changes(action="enable")
"Go to paragraph 5 and get context"
β cursor(action="goto_paragraph", n=5)
β cursor(action="context")
```
### HTTP API Examples
```bash
# Check server status
curl http://localhost:8765/health
# Get document info
curl -X POST http://localhost:8765/tools/get_document_info_live -d '{}'
# Find text
curl -X POST http://localhost:8765/tools/find_text_live \
-H "Content-Type: application/json" \
-d '{"query": "hello"}'
# Enable Track Changes
curl -X POST http://localhost:8765/tools/set_track_changes_live \
-H "Content-Type: application/json" \
-d '{"enabled": true}'
```
## π Repository Structure
```
mcp-libre/
βββ plugin/ # LibreOffice extension
β βββ pythonpath/
β β βββ uno_bridge.py # UNO API wrapper
β β βββ mcp_server.py # HTTP API server
β βββ build.sh # Build script
β βββ README.md # Plugin documentation
βββ libreoffice_mcp_server.py # FastMCP bridge (9 consolidated tools)
βββ docs/
β βββ TOOL_REFERENCE.md # Complete tool documentation
β βββ KNOWN_ISSUES_AND_ROADMAP.md
βββ src/ # Legacy external server
βββ tests/ # Test suite
βββ README.md
```
## π Documentation
- **[Tool Reference](docs/TOOL_REFERENCE.md)**: Complete documentation of all 9 tools
- **[Plugin README](plugin/README.md)**: LibreOffice extension details
- **[Known Issues & Roadmap](docs/KNOWN_ISSUES_AND_ROADMAP.md)**: Future plans
## π Recent Changes
### v0.3.0 - Tool Consolidation
- Consolidated 32 tools into 9 logical groups
- Reduced permission prompts for better UX
- Each tool uses `action` parameter for routing
### v0.2.0 - Track Changes Awareness
- Added 7 Track Changes management tools
- Search/replace now skips tracked deletions
- `get_paragraph` returns `visible_content` field
- `find_text` returns `track_changes_active` field
### v0.1.0 - Initial Release
- 25 individual MCP tools
- HTTP API on localhost:8765
- LibreOffice extension with UNO API integration
## π‘ Security
- **Local Execution**: All operations run locally
- **File Permissions**: Limited to user's file access
- **No Network**: No external network dependencies
- **Email Privacy**: Uses GitHub noreply email for commits
## π€ Contributing
1. Fork the repository
2. Create a feature branch
3. Make your changes
4. Submit a pull request
## π License
This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.
## π Links
- **Repository**: https://github.com/jwingnut/mcp-libre
- **MCP Specification**: https://spec.modelcontextprotocol.io/
- **LibreOffice**: https://www.libreoffice.org/
- **FastMCP**: https://github.com/modelcontextprotocol/python-sdk
---
*LibreOffice MCP Server v0.3.0 - AI-Powered Document Editing*