Seafile MCP Server
Connects Claude to your self-hosted or cloud-based Seafile storage for managing libraries and files through natural language. It enables users to browse directories, read file contents, and perform file operations like moving, renaming, or searching across their private infrastructure.
README
Seafile MCP Server
A Model Context Protocol (MCP) server that connects Claude to your Seafile file storage. This lets you ask Claude to browse, search, read, and manage files on your self-hosted Seafile server using natural language.
What is Seafile?
Seafile is an open-source, self-hosted file sync and share platform - similar to Dropbox or Google Drive, but you control your own data. It's popular for personal use, teams, and enterprises who want privacy and control over their files.
Why Seafile?
- Self-hosted: Your files stay on your own server
- Privacy-focused: No third-party access to your data
- Fast sync: Efficient file synchronization across devices
- Libraries: Organize files into encrypted or unencrypted libraries
- Cross-platform: Apps for Windows, Mac, Linux, iOS, Android
Don't have Seafile yet? Here's how to get started:
| Option | Description | Link |
|---|---|---|
| Seafile Cloud | Hosted by Seafile (easiest) | cloud.seafile.com |
| Docker Install | Self-host with Docker (recommended) | Docker Guide |
| Manual Install | Self-host on Linux server | Manual Guide |
| Synology NAS | Run on Synology NAS | Synology Package |
| UGREEN NAS | Run on UGREEN NAS via Docker | Docker Guide |
| Raspberry Pi | Self-host on a Pi | Pi Guide |
Why This MCP Server?
- Direct connection - Connects straight to your Seafile server, no middleman
- Privacy-first - Your data never leaves your infrastructure
- Free & open source - No subscriptions, no vendor lock-in
- Full control - Inspect, modify, and extend the code as needed
- Self-hosted - Runs locally alongside your self-hosted Seafile
What can you do with this MCP server?
Once set up, you can ask Claude things like:
Document Lookups
- "What are my flight details for the Hawaii trip?"
- "When is my car rental pickup?"
- "Find my tax files from 2024"
- "What's in my Immigration folder?"
- "Show me my recent receipts"
- "List all of Mom's travel folders"
- "Find Dad's visa documents"
Organization
- "Create a new folder called '2025 Taxes'"
- "Move the completed trip to Archive"
- "What's in my 'Ideas' folder?"
Quick Search
- "Find all PDFs related to insurance"
- "Which folders were modified this month?"
- "Do I have a copy of my lease agreement?"
Features
| Feature | Description |
|---|---|
| Browse Libraries | List all libraries, view library details |
| Navigate Folders | List directory contents at any path |
| Read Files | Read text file contents directly |
| File Operations | Create, rename, move, copy, delete files and folders |
| Download Links | Generate download links for any file |
| Upload Links | Get upload links for directories |
| Search | Search for files across libraries (if enabled on your server) |
Prerequisites
Before you start, make sure you have:
- Python 3.10 or higher - Check with
python3 --version - A Seafile server - Either self-hosted or a Seafile cloud account
- Claude Desktop app or Claude Code CLI - Where you'll use this MCP server
Installation
Step 1: Clone or Download This Repository
# Option A: Clone with git
git clone https://github.com/setugk/seafile-mcp.git
cd seafile-mcp
# Option B: Or download and extract the ZIP, then cd into it
Step 2: Create a Virtual Environment
A virtual environment keeps this project's dependencies isolated from your system Python.
# Create the virtual environment
python3 -m venv venv
# Activate it
# On macOS/Linux:
source venv/bin/activate
# On Windows:
venv\Scripts\activate
You should see (venv) at the start of your terminal prompt. This means the virtual environment is active.
Step 3: Install Dependencies
pip install -r requirements.txt
This installs:
mcp- The Model Context Protocol libraryhttpx- For making HTTP requests to Seafilepython-dotenv- For loading configuration from.env
Step 4: Get Your Seafile API Token
You need an API token to authenticate with your Seafile server.
Option A: Using the Seafile Web Interface
- Log into your Seafile web interface
- Click your avatar/profile icon in the top right
- Go to Settings → Web API Auth Token
- Click Generate Token or copy your existing token
Option B: Using curl (Command Line)
curl -d "username=YOUR_EMAIL&password=YOUR_PASSWORD" \
https://YOUR_SEAFILE_SERVER/api2/auth-token/
Replace:
YOUR_EMAIL- Your Seafile login emailYOUR_PASSWORD- Your Seafile passwordYOUR_SEAFILE_SERVER- Your Seafile server URL (e.g.,cloud.seafile.com)
The response will look like:
{"token": "a]1b2c3d4e5f6g7h8i9j0..."}
Copy the token value (without quotes).
Step 5: Configure Your Credentials
# Copy the example config
cp .env.example .env
# Edit .env with your favorite editor
nano .env # or vim, code, etc.
Fill in your values:
SEAFILE_URL=https://your-seafile-server.com
SEAFILE_TOKEN=your-api-token-here
Important:
- No trailing slash on the URL
- No quotes around values
- Keep this file secret (it's already in
.gitignore)
Step 6: Test the Server
python src/server.py
If everything is set up correctly, the server will start without errors. Press Ctrl+C to stop it.
Connecting to Claude
Choose the method that matches how you use Claude:
Option A: Claude Desktop App
-
Find your Claude Desktop config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
Or in Claude Desktop:
Claudemenu →Settings→Developer→Edit Config - macOS:
-
Add the MCP server configuration:
If the file is empty or doesn't exist, create it with:
{ "mcpServers": { "seafile": { "command": "/FULL/PATH/TO/seafile-mcp/venv/bin/python", "args": ["/FULL/PATH/TO/seafile-mcp/src/server.py"] } } }If you already have other MCP servers, add
seafileinside the existingmcpServersobject.Important: Replace
/FULL/PATH/TO/with the actual absolute path to where you cloned this repo.Example paths:
- macOS:
/Users/yourname/projects/seafile-mcp/venv/bin/python - Windows:
C:\\Users\\yourname\\projects\\seafile-mcp\\venv\\Scripts\\python.exe
- macOS:
-
Restart Claude Desktop completely:
- Quit Claude Desktop (Cmd+Q on Mac, Alt+F4 on Windows)
- Reopen Claude Desktop
-
Verify it works:
- Start a new conversation
- Look for the hammer/tools icon - "seafile" should be listed
- Ask: "Use the hello tool" or "List my Seafile libraries"
Option B: Claude Code (CLI)
-
Create a
.mcp.jsonfile in your project directory:{ "mcpServers": { "seafile": { "command": "/FULL/PATH/TO/seafile-mcp/venv/bin/python", "args": ["/FULL/PATH/TO/seafile-mcp/src/server.py"] } } } -
Start Claude Code in that directory - it will automatically load the MCP server.
-
Test with: "List my Seafile libraries"
Available Tools
Once connected, Claude has access to these tools:
| Tool | Description |
|---|---|
hello |
Test that the MCP server is working |
ping_server |
Test connection to your Seafile server |
get_account_info |
Get your Seafile account information |
list_libraries |
List all your libraries/repos |
get_library |
Get details of a specific library |
list_directory |
List contents of a folder |
create_library |
Create a new library |
delete_library |
Delete a library (permanent!) |
create_directory |
Create a new folder |
delete_item |
Delete a file or folder |
rename_item |
Rename a file or folder |
move_item |
Move a file or folder |
copy_item |
Copy a file or folder |
get_file_content |
Read a text file's contents |
get_file_download_link |
Get a download URL for a file |
get_upload_link |
Get an upload URL for a folder |
search_files |
Search for files (requires search enabled on server) |
Troubleshooting
"Server not appearing in Claude Desktop"
- Double-check the paths in your config are absolute paths (start with
/on Mac/Linux orC:\on Windows) - Make sure you fully restarted Claude Desktop (not just closed the window)
- Check for JSON syntax errors in your config file (missing commas, brackets)
"SEAFILE_URL or SEAFILE_TOKEN not configured"
- Make sure you created the
.envfile (not just.env.example) - Make sure the
.envfile is in the project root directory (same folder assrc/) - Check there are no extra spaces or quotes in your
.envvalues
"Connection error: Could not reach server"
- Verify your Seafile server URL is correct and accessible
- Try opening the URL in a browser
- Check if your server requires VPN access
"Authentication failed" or "401 Unauthorized"
- Your API token may have expired - generate a new one
- Make sure you copied the full token with no extra spaces
"Module not found" errors
- Make sure you're using the Python from the virtual environment in your config
- Run
venv/bin/pip listto verifymcpandhttpxare installed
Check server logs
Run the server manually to see any errors:
source venv/bin/activate
python src/server.py
Roadmap
Features planned for future releases:
| Feature | Status | Description |
|---|---|---|
| PDF reading | Planned | Extract text from PDF files so Claude can answer questions about receipts, contracts, etc. |
| Image OCR | Idea | Extract text from images using OCR |
| File upload | Idea | Upload files to Seafile via Claude |
Have a feature request? Open an issue!
Security & Privacy
Important: Please read SECURITY.md for full security considerations.
Protecting Your Credentials
- Never commit your
.envfile - It contains your API token - Secure file permissions - Run
chmod 600 .envto restrict access - Rotate tokens periodically - Generate new tokens and revoke old ones
- Use HTTPS - Always connect to your Seafile server over HTTPS
What Claude Can See
When using this MCP server:
- Claude sees file and folder names when you browse
- Claude sees file contents when you ask to read them
- Conversations are processed by Anthropic's servers
Best practice: Avoid asking Claude to read highly sensitive files (passwords, private keys, financial account numbers).
What Claude Can Do
The MCP server allows Claude to:
- Browse, read, and search files
- Create, rename, move, copy, and delete files/folders
Be careful with destructive commands. Consider using a read-only API token if your Seafile server supports scoped permissions.
Local Machine Security
- The MCP server runs locally with your user permissions
- Anyone with access to your machine could read your
.envfile - Use standard device security (lock screen, disk encryption)
Reporting vulnerabilities: See SECURITY.md for responsible disclosure guidelines.
Contributing
Contributions are welcome! Please read CONTRIBUTING.md for guidelines.
By participating in this project, you agree to abide by our Code of Conduct.
License
MIT License - See LICENSE file for details.
Author
Setu Kathawate
- GitHub: @setugk
Acknowledgments
- Built with FastMCP for easy MCP server development
- Uses the Seafile Web API
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。