loading…
Search for a command to run...
loading…
Dropbox MCP server to recover deleted files, list revisions, search content, and force-download cloud-only files via server-side API.
Dropbox MCP server to recover deleted files, list revisions, search content, and force-download cloud-only files via server-side API.
An MCP (Model Context Protocol) server that exposes the Dropbox API as tools for LLM agents. Built on the TypeScript MCP SDK and the official dropbox npm SDK.
Focus: recovery and discovery on an existing Dropbox account — restoring deleted files, listing revisions, searching content, and force-downloading cloud-only files. The server talks to the Dropbox server-side API, not the local sync folder, so it can see and restore files that local sync has already deleted.
All tool names are prefixed dropbox_ to avoid collisions with other MCP servers.
| Tool | Behavior | Read-only |
|---|---|---|
dropbox_restore |
Restore the most recent server-side revision of a deleted file. | No |
dropbox_restore_batch |
Restore multiple files in one call; reports per-path result. | No |
dropbox_restore_revision |
Restore a specific revision ID (e.g., a known-good earlier version). | No |
dropbox_download |
Force-download a file from Dropbox to the local sync folder, bypassing Smart Sync cloud-only state. | No |
dropbox_upload |
Upload a single local file to Dropbox. Source defaults to the local-folder mirror of the destination path; mode add/overwrite. Rejects files >150 MB. |
No |
dropbox_move |
Move or rename a file/folder server-side (no download). autorename to avoid collisions. |
No |
dropbox_delete |
Delete a file or folder (goes to trash; recoverable via dropbox_restore for ~30 days). |
No |
dropbox_search |
Search by filename or content across the account. Returns path, size, modified date. | Yes |
dropbox_list_deleted |
List deleted entries in a folder (optionally recursive). Input for restore workflows. | Yes |
dropbox_file_info |
Return size, modified time, revision ID, and content hash for a path. | Yes |
dropbox_list_revisions |
List up to 100 revisions of a file with rev ID, size, and modified time. | Yes |
Atomic single-file ops vs. bulk sync: these tools are for one-file or interactive operations. For syncing or sorting whole folders (10s–1000s of files), use the companion dropbox skill's dbx_sync.py (bulk, move-aware, plan→review→execute). The split: this server is the atomic + recovery layer; the skill is the orchestration layer.
files.content.read, files.content.write, and files.metadata.read scopesgit clone https://github.com/danielsimonjr/dropbox-mcp.git
cd dropbox-mcp
npm install
npm run build
The build emits dist/index.js, which is the entry point used below.
The server loads credentials from ~/.claude/channels/dropbox/.env on startup,
with process.env taking precedence over the file (so the MCP host can override
via .mcp.json env). Create the file and paste in the template below, then
fill in your values:
mkdir -p ~/.claude/channels/dropbox
touch ~/.claude/channels/dropbox/.env
Template:
# --- Option A: OAuth 2 refresh token (recommended) ---
# Create an app at https://www.dropbox.com/developers/apps, enable the scopes
# files.content.read, files.content.write, files.metadata.read, then run the
# OAuth flow once to obtain a refresh token.
DROPBOX_REFRESH_TOKEN=
DROPBOX_APP_KEY=
DROPBOX_APP_SECRET=
# --- Option B: Long-lived access token (fallback) ---
# Leave blank if you are using Option A above.
DROPBOX_ACCESS_TOKEN=
# --- Optional ---
# Local Dropbox sync folder. Used by dropbox_download to write files.
# Defaults to ~/Dropbox if unset.
# DROPBOX_LOCAL_PATH=C:\Users\you\Dropbox
Two auth modes are supported, tried in order:
DROPBOX_REFRESH_TOKEN,
DROPBOX_APP_KEY, and DROPBOX_APP_SECRET. Access tokens are refreshed
automatically, so credentials do not expire.DROPBOX_ACCESS_TOKEN only.
Simpler to obtain, but tokens expire after a few hours for newer apps.node dist/index.js
The server communicates over stdio, so there is no interactive output — it waits
for MCP protocol messages on stdin. On connect it logs "dropbox-mcp: connected on stdio" to stderr.
npx @modelcontextprotocol/inspector node dist/index.js
Add an entry to your .mcp.json:
{
"mcpServers": {
"dropbox-mcp": {
"type": "stdio",
"command": "node",
"args": ["C:/path/to/dropbox-mcp/dist/index.js"]
}
}
}
Restart Claude Code (or run /reload-plugins) for the registration to take effect.
Restore a file deleted by accident:
Agent: dropbox_restore(path="/Projects/report-final.docx")
Result: Restored: /Projects/report-final.docx (rev: abc123, size: 45678 bytes)
Find a file without knowing its exact location:
Agent: dropbox_search(query="RSP consciousness paper", max_results=5)
Result: Found 3 results for 'RSP consciousness paper':
1.25 MB 2026-02-18 /Misc/Philosophy/Beyond the Bat/paper.pdf
0.31 MB 2026-02-10 /Misc/Philosophy/Beyond the Bat/drafts/outline.md
...
Roll back to a specific earlier revision:
Agent: dropbox_list_revisions(path="/report.docx", limit=5)
Agent: dropbox_restore_revision(path="/report.docx", rev="0123abc")
Upload, move, and delete a single file:
Agent: dropbox_upload(path="/Misc/notes.md", mode="overwrite")
Result: Uploaded: /Misc/notes.md (2048 bytes, mode: overwrite)
Agent: dropbox_move(from_path="/Misc/notes.md", to_path="/Misc/Archive/notes.md")
Result: Moved: /Misc/notes.md -> /Misc/Archive/notes.md
Agent: dropbox_delete(path="/Misc/Archive/old-draft.md")
Result: Deleted: /Misc/Archive/old-draft.md (recoverable via dropbox_restore for ~30 days)
.env file holds long-lived credentials — keep it out of version control
(the default .gitignore already excludes .env files).dropbox_delete on a folder (removes all contents) and dropbox_restore_batch.
Deletes go to Dropbox trash and are recoverable via dropbox_restore for ~30 days.api.dropbox.com over HTTPS.npm run typecheck # tsc --noEmit
npm test # vitest run (full suite)
npm run build # emit dist/
The test suite covers config loading, every output formatter, the 8 tool handlers
(both read-only and mutating), and a smoke test asserting TOOLS↔HANDLERS symmetry.
For changes to the tool surface, update both this README and CHANGELOG.md in the
same commit.
MIT — see LICENSE.
Выполни в терминале:
claude mcp add dropbox-mcp -- npx CSA PROJECT - FZCO © 2026 IFZA Business Park, DDP, Premises Number 31174 - 001
Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.