Dropbox Manager
Manage Dropbox files securely with OAuth 2.0 PKCE via CLI or MCP server, supporting upload, download, search, delete, and account info operations.
Manage Dropbox files securely with OAuth 2.0 PKCE via CLI or MCP server, supporting upload, download, search, delete, and account info operations.
Real data. Real impact.
Growing
Developers
Per week
Open source
Skills give you superpowers. Install in 30 seconds.
Manage Dropbox files via MCP server and CLI. Swift-native implementation using SwiftyDropbox SDK with OAuth 2.0 PKCE and secure Keychain token storage.
# Clone and build Dropbook git clone https://github.com/RyanLisse/Dropbook.git cd Dropbook make build
Use the interactive OAuth flow with secure Keychain storage:
export DROPBOX_APP_KEY="your_dropbox_app_key" export DROPBOX_APP_SECRET="your_dropbox_app_secret" make login # or: swift run dropbook login
This will:
~/.dropbook/auth.json if Keychain unavailableSecurity Features (RFC 9700 compliant):
kSecAttrAccessibleWhenUnlockedexport DROPBOX_APP_KEY="your_dropbox_app_key" export DROPBOX_APP_SECRET="your_dropbox_app_secret" export DROPBOX_ACCESS_TOKEN="your_dropbox_access_token"
Note: Manual tokens don't support automatic refreshing. Use OAuth login for production use.
Clear stored tokens from both Keychain and file storage:
make logout # or: swift run dropbook logout
Start the MCP server:
make mcp # or: ./.build/debug/dropbook mcp
| Tool | Description |
|---|---|
| List files and folders in a Dropbox directory |
| Search for files by name or content |
| Upload a file to Dropbox |
| Download a file from Dropbox |
| Delete a file or folder (moves to trash) |
| Get account name and email |
| Read contents of a text file |
List files and folders in a Dropbox directory.
Parameters:
path (string, optional): Directory path. Default: "/"Response:
{ "files": [ {"type": "file", "name": "doc.pdf", "path": "/Docs/doc.pdf", "size": 1024}, {"type": "folder", "name": "Projects", "path": "/Projects"} ] }
Search for files by name or content.
Parameters:
query (string, required): Search termpath (string, optional): Path to search within. Default: "/"Response:
{ "count": 2, "results": [ {"matchType": "filename", "metadata": {"name": "report.pdf", "path": "/Docs/report.pdf"}} ] }
Upload a file to Dropbox.
Parameters:
localPath (string, required): Absolute path to local fileremotePath (string, required): Destination in Dropboxoverwrite (boolean, optional): Replace if exists. Default: falseResponse:
{ "uploaded": true, "name": "file.txt", "path": "/Uploads/file.txt", "size": 5000 }
Download a file from Dropbox.
Parameters:
remotePath (string, required): File path in DropboxlocalPath (string, required): Local destination pathResponse:
{ "downloaded": true, "to": "/tmp/report.pdf" }
Delete a file or folder from Dropbox (moves to trash).
Parameters:
path (string, required): Path to delete in DropboxResponse:
{ "deleted": true, "path": "/Docs/old-file.pdf" }
Get Dropbox account information.
Parameters: None
Response:
{ "name": "Ryan Lisse", "email": "user@example.com" }
Read and return the contents of a text file from Dropbox.
Parameters:
path (string, required): Path to file in DropboxResponse: Returns the file contents as text. Only works with UTF-8 encoded text files.
# Authentication make login # OAuth login with Keychain storage make logout # Clear stored tokensFile operations
make list # List root directory swift run dropbook list /path
Search files
swift run dropbook search "query" [path]
Upload file
swift run dropbook upload /local/path /remote/path [--overwrite]
Download file
swift run dropbook download /remote/path /local/path
Start MCP server
make mcp
The project includes a
.mcp.json file that configures the MCP server:
{ "mcpServers": { "dropbox": { "command": "/path/to/Dropbook/.build/debug/dropbook", "args": ["mcp"], "env": { "DROPBOX_APP_KEY": "${DROPBOX_APP_KEY}", "DROPBOX_APP_SECRET": "${DROPBOX_APP_SECRET}" } } } }
Enable project MCP servers in Claude Code settings.json:
{ "enableAllProjectMcpServers": true }
{ "mcpServers": { "dropbox": { "command": "/path/to/dropbook/.build/debug/dropbook", "args": ["mcp"], "env": { "DROPBOX_APP_KEY": "${DROPBOX_APP_KEY}", "DROPBOX_APP_SECRET": "${DROPBOX_APP_SECRET}" } } } }
| Error | Cause | Solution |
|---|---|---|
| Missing env vars | Set DROPBOX_APP_KEY, DROPBOX_APP_SECRET |
| Missing required params | Check tool parameters |
| Path doesn't exist | Use to verify paths |
| No token in Keychain | Run to authenticate |
Dropbook/ ├── Sources/ │ ├── DropbookCore/ # Business logic (actor-based) │ │ ├── Auth/ # Keychain & file token storage │ │ ├── Config/ # Configuration management │ │ ├── Models/ # Domain models │ │ └── Services/ # DropboxService actor │ ├── DropbookCLI/ # CLI adapter │ │ └── Commands/ # Login, logout, file commands │ └── DropbookMCP/ # MCP server ├── dropbox-skill/ # Skill documentation ├── Makefile # Build automation ├── .mcp.json # MCP server configuration └── Package.swift
For large-scale operations like backups, syncing, or bulk transfers, use rclone - a powerful cloud sync tool with native Dropbox support.
brew install rclone
# Interactive setup (opens browser for OAuth) rclone authorize dropboxSave the token output to config
mkdir -p ~/.config/rclone cat > ~/.config/rclone/rclone.conf << 'EOF' [dropbox] type = dropbox token = {"access_token":"...paste token here..."} EOF
# Full backup with progress rclone copy dropbox: /Volumes/TimeCapsule/Dropbox-Backup \ --progress \ --transfers 4 \ --checkers 8 \ --retries 10 \ --log-file /tmp/dropbox-backup.logSync (mirror - deletes files not in source)
rclone sync dropbox: /Volumes/Backup/Dropbox --progress
Check what would be copied (dry run)
rclone copy dropbox: /Volumes/Backup --dry-run
# List remote contents rclone lsd dropbox: # List directories rclone ls dropbox: # List all files rclone size dropbox: # Calculate total sizeCopy operations
rclone copy dropbox:folder /local/path # Download folder rclone copy /local/path dropbox:folder # Upload folder
Sync (bidirectional)
rclone bisync dropbox: /local/path --resync
Mount as filesystem (macOS - requires macFUSE)
rclone mount dropbox: /mnt/dropbox --vfs-cache-mode full
| Flag | Description |
|---|---|
| Show real-time transfer progress |
| Number of parallel transfers |
| Number of parallel checkers |
| Retry failed operations |
| Retry low-level errors |
| Write logs to file |
| Show what would be done |
| Verify with checksums |
Dropbox has strict API rate limits. If you see
too_many_requests errors:
# Use bandwidth limiting rclone copy dropbox: /backup --bwlimit 1MOr add delays between operations
rclone copy dropbox: /backup --tpslimit 2
rclone handles rate limits automatically with exponential backoff.
list_directory before operationsbrew install rclone)No automatic installation available. Please visit the source repository for installation instructions.
View Installation Instructions1,500+ AI skills, agents & workflows. Install in 30 seconds. Part of the Torly.ai family.
© 2026 Torly.ai. All rights reserved.