loading…
Search for a command to run...
loading…
Provides persistent agent workspaces with MongoDB storage for file management and real-time task progress tracking. It enables secure, isolated user environment
Provides persistent agent workspaces with MongoDB storage for file management and real-time task progress tracking. It enables secure, isolated user environments with full activity logging for workspace operations.
Production-ready MCP server for agent workspace/scratchpad functionality with MongoDB persistence and user isolation.
scratchpad_start - Start a new task workspacescratchpad_update - Update progress during taskscratchpad_complete - Mark task as completescratchpad_demo - Demo widget with sample datascratchpad_write_file - Save file to workspacescratchpad_read_file - Read file from workspacescratchpad_list_files - List all workspace filesscratchpad_delete_file - Delete file from workspace# Create virtual environment
python -m venv venv
.\venv\Scripts\activate
# Install dependencies
pip install -r requirements.txt
# Copy and configure environment
copy .env.template .env
# Edit .env with your MongoDB URI and API key
cd C:\Users\Adam\Desktop\ttgeco\scratchpad-mcp
.\venv\Scripts\activate
python server.py
Server runs on http://localhost:8001/mcp
The server runs in demo/stateless mode if MONGODB_URI is not set. Useful for UI testing.
git add .
git commit -m "Add MongoDB persistence and file management"
git push origin main
In Render dashboard, add these environment variables:
| Variable | Value | Notes |
|---|---|---|
MONGODB_URI |
mongodb+srv://... |
Your ttg-workspaces connection string |
MCP_API_KEYS |
scratchpad-mcp-ttg-2026-... |
Must match LibreChat SCRATCHPAD_MCP_TOKEN |
Do NOT set PORT - Render provides it automatically.
After deploy, test the /mcp endpoint:
curl -X POST https://scratchpad-mcp-18ab.onrender.com/mcp \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR_TOKEN"
mcpServers:
scratchpad:
type: streamable-http
url: "https://scratchpad-mcp-18ab.onrender.com/mcp"
headers:
Authorization: "Bearer ${SCRATCHPAD_MCP_TOKEN}"
X-User-ID: "{{LIBRECHAT_USER_ID}}"
timeout: 60000
initTimeout: 30000
serverInstructions: true
SCRATCHPAD_MCP_TOKEN=your-token-here
workspaces
{
"_id": "ObjectId",
"user_id": "string",
"conversation_id": "string (optional)",
"task": "string",
"status": "idle|active|complete",
"progress": {"current": 0, "total": 10},
"working_on": "string",
"created_at": "datetime",
"updated_at": "datetime"
}
files
{
"_id": "ObjectId",
"user_id": "string",
"workspace_id": "ObjectId",
"name": "string",
"path": "string",
"type": "file|folder",
"content": "string",
"updated": true,
"created_at": "datetime",
"updated_at": "datetime"
}
activity_logs
{
"_id": "ObjectId",
"user_id": "string",
"workspace_id": "ObjectId",
"action": "string",
"icon": "write|read|complete|delete",
"timestamp": "datetime"
}
MCP_API_KEYSX-User-ID header (provided by LibreChat)Tool called outside of request context. Ensure using FastMCP 0.5.0+.
LibreChat not sending user ID. Check librechat.yaml headers config.
Set MONGODB_URI in Render dashboard or local .env.
Check MongoDB Atlas network access - ensure Render IP is whitelisted or use 0.0.0.0/0 for all access.
Добавь это в claude_desktop_config.json и перезапусти Claude Desktop.
{
"mcpServers": {
"ttg-scratchpad-mcp-server": {
"command": "npx",
"args": []
}
}
}