Enables persistent agent workspaces by storing tasks, files, and activity logs in MongoDB Atlas, featuring user isolation and real-time progress tracking for autonomous agents.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@TTG Scratchpad MCP Serversave my research notes to a file called draft.md"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
TTG Scratchpad MCP Server
Production-ready MCP server for agent workspace/scratchpad functionality with MongoDB persistence and user isolation.
Features
Persistent Workspaces: Tasks and files stored in MongoDB Atlas
User Isolation: Each user has their own isolated workspace (via X-User-ID header)
File Management: Create, read, update, delete files in workspace
Progress Tracking: Real-time progress updates visible in chat widget
Activity Logging: Full audit trail of workspace operations
Bearer Authentication: Secure API access via MCP_API_KEYS
Tools
Workspace Management
scratchpad_start- Start a new task workspacescratchpad_update- Update progress during taskscratchpad_complete- Mark task as completescratchpad_demo- Demo widget with sample data
File Management
scratchpad_write_file- Save file to workspacescratchpad_read_file- Read file from workspacescratchpad_list_files- List all workspace filesscratchpad_delete_file- Delete file from workspace
Local Development
Prerequisites
Python 3.11+
MongoDB Atlas cluster (ttg-workspaces)
Setup
# 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 keyRun Locally
cd C:\Users\Adam\Desktop\ttgeco\scratchpad-mcp
.\venv\Scripts\activate
python server.pyServer runs on http://localhost:8001/mcp
Test Without Database
The server runs in demo/stateless mode if MONGODB_URI is not set. Useful for UI testing.
Deployment (Render)
1. Push to GitHub
git add .
git commit -m "Add MongoDB persistence and file management"
git push origin main2. Configure Render Environment Variables
In Render dashboard, add these environment variables:
Variable | Value | Notes |
|
| Your ttg-workspaces connection string |
|
| Must match LibreChat SCRATCHPAD_MCP_TOKEN |
Do NOT set PORT - Render provides it automatically.
3. Verify Deployment
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"LibreChat Configuration
librechat.yaml
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: trueLibreChat .env
SCRATCHPAD_MCP_TOKEN=your-token-hereDatabase Schema
Collections
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"
}Security
Bearer token authentication via
MCP_API_KEYSUser isolation via
X-User-IDheader (provided by LibreChat)All database queries scoped by user_id
Input validation on file paths and content
Troubleshooting
"No HTTP request context available"
Tool called outside of request context. Ensure using FastMCP 0.5.0+.
"X-User-ID header required"
LibreChat not sending user ID. Check librechat.yaml headers config.
"MONGODB_URI environment variable required"
Set MONGODB_URI in Render dashboard or local .env.
Connection timeout
Check MongoDB Atlas network access - ensure Render IP is whitelisted or use 0.0.0.0/0 for all access.