abdullahMASHUK/nextcloud-mcp-server
If you are the rightful owner of nextcloud-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
The NextCloud MCP Server is a professional Model Context Protocol server designed for seamless integration with NextCloud, providing AI agents with comprehensive file management and sharing capabilities.
๐ NextCloud MCP Server
A professional Model Context Protocol (MCP) server for seamless NextCloud integration
Empower your AI agents with comprehensive NextCloud file management and sharing capabilities
Installation โข Quick Start โข Features โข Documentation โข Security
๐ Features
๐ File Management | ๐ Sharing | ๐ Security | ๐ ๏ธ Developer Experience |
---|---|---|---|
List, upload, download | Public links | App passwords | Full TypeScript support |
Create directories | User/group shares | Environment variables | Comprehensive tests |
Delete files/folders | Password protection | Secure authentication | Professional documentation |
Move and rename | Expiration dates | HTTPS enforcement | Easy integration |
โจ Key Capabilities
- ๐ฏ 14 Comprehensive Tools - Complete file operations and sharing management
- ๐ Enhanced Security - Built-in app password support and best practices
- ๐๏ธ Professional Architecture - TypeScript-first with full type safety
- ๐ Rich Documentation - Detailed guides and examples
- ๐ WebDAV Integration - Native NextCloud protocol support
- โก High Performance - Optimized for speed and reliability
- ๐ Universal Compatibility - Works with any NextCloud instance
๐ฆ Installation
From NPM (Recommended)
# Install globally for CLI usage
npm install -g nextcloud-mcp-server
# Or install locally in your project
npm install nextcloud-mcp-server
From Source
git clone https://github.com/abdullahMASHUK/nextcloud-mcp-server.git
cd nextcloud-mcp-server
npm install
npm run build
๐ Quick Start
1. ๐ Setup App Password (Recommended)
Click to expand security setup instructions
For enhanced security, create a dedicated app password:
-
Navigate to NextCloud Settings
NextCloud โ Settings โ Security โ App passwords
-
Create New App Password
- Enter name:
MCP Server
- Click "Create new app password"
- Copy the generated password:
xxxxx-xxxxx-xxxxx-xxxxx-xxxxx
- Enter name:
-
Why App Passwords?
- โ Limited scope and permissions
- โ Can be revoked independently
- โ No access to your main account
- โ Auditable access logs
2. โ๏ธ Configuration
# Copy the environment template
cp .env.example .env
Edit your .env
file:
NEXTCLOUD_URL=https://your-nextcloud-server.com
NEXTCLOUD_USERNAME=your-username
NEXTCLOUD_PASSWORD=your-app-password-here # Use app password!
3. ๐ฎ Usage with MCP Clients
Claude Desktop Configuration
Add to your claude_desktop_config.json
:
{
"mcpServers": {
"nextcloud": {
"command": "nextcloud-mcp-server",
"env": {
"NEXTCLOUD_URL": "https://your-nextcloud-server.com",
"NEXTCLOUD_USERNAME": "your-username",
"NEXTCLOUD_PASSWORD": "your-app-password"
}
}
}
}
Direct Usage
# Run the MCP server
nextcloud-mcp-server
# Or with Node.js
node build/index.js
๐ ๏ธ Available Tools
๐ File Operations
๐ test-connection | Test connectivity to your NextCloud server |
๐ list-files | List files and directories with metadata |
๐ create-directory | Create new directories in NextCloud |
๐๏ธ delete-file | Delete files or directories |
โฌ๏ธ upload-file | Upload files with base64 encoding |
โฌ๏ธ download-file | Download files from NextCloud |
๐ move-file | Move or rename files and directories |
๐ copy-file | Copy files and directories to new locations |
๐ search-files | Search for files and directories by name or content |
๐ get-file-versions | Get version history of a file |
๐ restore-file-version | Restore a specific version of a file |
๐ Sharing Operations
๐ create-share | Create public links, user, or group shares |
๐ค list-shares | List and filter existing shares |
๐๏ธ delete-share | Remove shares by ID |
๐ Documentation
๐ฏ Tool Examples
๐ List Files
{
"name": "list-files",
"arguments": {
"path": "/Documents"
}
}
Response: Returns array of files with metadata (name, size, type, modification date)
โฌ๏ธ Upload File
{
"name": "upload-file",
"arguments": {
"remotePath": "/documents/report.pdf",
"content": "JVBERi0xLjQK..." // base64 encoded content
}
}
๐ Move File
{
"name": "move-file",
"arguments": {
"sourcePath": "/old-location/document.pdf",
"destinationPath": "/new-location/document.pdf",
"overwrite": false
}
}
Response: Confirmation message with source and destination paths
๐ Copy File
{
"name": "copy-file",
"arguments": {
"sourcePath": "/Documents/template.docx",
"destinationPath": "/Projects/new-document.docx",
"overwrite": true
}
}
Response: Confirmation message with copy operation details
๐ Search Files
{
"name": "search-files",
"arguments": {
"query": "quarterly report",
"path": "/Documents",
"limit": 20,
"type": "file"
}
}
Response: Array of matching files with full metadata
Type Options: file
, directory
, all
๐ Get File Versions
{
"name": "get-file-versions",
"arguments": {
"path": "/Documents/important-document.pdf"
}
}
Response: Array of file versions with timestamps, sizes, and user information
๐ Restore File Version
{
"name": "restore-file-version",
"arguments": {
"path": "/Documents/important-document.pdf",
"versionId": "1672531200"
}
}
Response: Confirmation of version restoration
๐ Create Share
{
"name": "create-share",
"arguments": {
"path": "/Documents/presentation.pptx",
"shareType": 3,
"password": "secure123",
"expireDate": "2024-12-31",
"note": "Shared for team review"
}
}
Share Types:
0
- User share1
- Group share3
- Public link4
- Email share
๐๏ธ Development
Setup Development Environment
# Clone and install
git clone https://github.com/abdullahMASHUK/nextcloud-mcp-server.git
cd nextcloud-mcp-server
npm install
# Development commands
npm run dev # Run with auto-reload
npm run build # Build TypeScript
npm run test # Run test suite
npm run lint # Check code quality
npm run format # Format code
Project Structure:
src/
โโโ index.ts # Main MCP server
โโโ services/
โ โโโ nextcloud.ts # NextCloud API client
โโโ types.ts # TypeScript definitions
โโโ utils/ # Utility functions
__tests__/ # Test suites
build/ # Compiled output
๐ Security
๐ก๏ธ Best Practices
โ Do | โ Don't |
---|---|
Use app passwords | Use main account password |
Store in environment variables | Hardcode credentials |
Use HTTPS URLs | Use HTTP connections |
Rotate passwords regularly | Keep old passwords |
Monitor access logs | Ignore security events |
๐ Security Features
- ๐ App Password Integration - Dedicated authentication tokens
- ๐ HTTPS Enforcement - Secure connections required
- ๐ Environment Variables - Safe credential storage
- ๐ Error Handling - No credential exposure in logs
- ๐ก๏ธ Permission Scoping - Limited access rights
โ ๏ธ Security Checklist
- App password created and configured
- HTTPS enabled on NextCloud server
- Environment variables properly set
-
.env
file added to.gitignore
- Regular password rotation scheduled
License
MIT License - see LICENSE file for details.
๐ค Contributing
๐ How to Contribute
- ๐ด Fork the repository
- ๐ฟ Create your feature branch
git checkout -b feature/amazing-feature
- ๐ป Make your changes
- โ Add tests for new features
- ๐งช Run the test suite
npm run test npm run lint
- ๐ Commit your changes
git commit -m "โจ Add amazing feature"
- ๐ Push to your branch
git push origin feature/amazing-feature
- ๐ Open a Pull Request
๐ก Ways to Contribute
๐ Bug Reports | โจ Feature Requests | ๐ Documentation | ๐งช Testing |
Found an issue? Report it! | Have an idea? Share it! | Improve docs and examples | Add tests and improve coverage |
๐ Support
Show Your Support! โญ
If this project helped you, please consider giving it a โญ on GitHub!
๐ฃ๏ธ Get Help
- ๐ Documentation
- ๐ Report Issues
- ๐ฌ Discussions
- ๐ง Contact Maintainer
๐ Connect With Us
๐ License
MIT License ยฉ 2024 Abdullah MASHUK
Permission is hereby granted, free of charge, to any person obtaining a copy of this software...
๐ Changelog
Version History
๐ v1.0.3
- ๐จ Beautified README with professional formatting and visual enhancements
- ๐ Added interactive tables, badges, and collapsible sections
- ๐ค Updated author information and git configuration
- ๐ Enhanced navigation with emojis and better organization
- โจ Improved user experience for npm and GitHub viewers
๐ v1.0.2
- โจ Enhanced documentation and README
- ๐ Added comprehensive security guidelines
- ๐ Improved TypeScript definitions
- ๐ Bug fixes and stability improvements
๐ v1.0.1
- ๐ Updated documentation
- ๐ง Configuration improvements
- ๐ ๏ธ Build process optimization
๐ v1.0.0
- ๐ Initial release
- ๐ Basic file operations (list, upload, download, delete)
- ๐ Share management (create, list, delete)
- ๐ง TypeScript implementation
- โ Comprehensive test coverage
- ๐ Full documentation