# π Rewind MCP
Smart and lightweight checkpointing mcp server for Claude Code CLI.
## Features
- π― **Smart Checkpointing**: Automatically checkpoint project states before agent wants to make any changes
- π **Complete Undo Support**: Restore modified files, recover deleted files, or remove unwanted files
- β‘ **Fast Multi-File Restore**: Rewind changes across multiple files instantly
## Example Agent Interaction
```
π€ User: "Add error handling..."
π€ Agent: Creating checkpoint before modifications...
β
Checkpoint: "Before adding error handling"
π€ Agent: "I have added error handling to the code"
π€ User: "This breaks the flow, please rewind"
π€ Agent: Restoring files from checkpoint...
β
Files restored to state before error handling
```
## π Quick Start
### Installation
```bash
git clone https://github.com/khalilbalaree/Rewind-MCP.git
cd Rewind-MCP
```
then,
```bash
npm install
npm run build
```
### Claude Code Configuration
Add this server to your Claude Code MCP configuration:
#### User-Based Configuration (Global)
Edit `~/Library/Application Support/Claude/claude_code_config.json`:
```json
{
"mcpServers": {
"Rewind-MCP": {
"command": "node",
"args": ["/absolute/path/to/Rewind-MCP/dist/index.js"],
"env": {}
}
}
}
```
#### Project-Specific Configuration (Alternative)
For easier project sharing and version control, create a `.mcp.json` file in your project directory:
```bash
# In your project directory
cat > .mcp.json << 'EOF'
{
"mcpServers": {
"Rewind-MCP": {
"command": "node",
"args": ["/absolute/path/to/Rewind-MCP/dist/index.js"],
"env": {}
}
}
}
EOF
```
## Use Cases
```
π€ User: "Add error handling to my API"
π€ Agent: I'll add comprehensive error handling to your API files.
[Agent modifies src/api/routes.js]
β
Checkpoint created and pushed to stack: "Modified src/api/routes.js"
[Agent creates src/middleware/errorHandler.js]
β
Checkpoint created and pushed to stack: "Created src/middleware/errorHandler.js"
π€ Agent: I've added try-catch blocks and centralized error handling to your API routes and created a new error middleware.
π€ User: "Actually, I want to try a different approach. Can you show me what checkpoints are available?"
π€ Agent: I'll show you the available checkpoints.
π Available checkpoints:
1. "Created src/middleware/errorHandler.js" - [Most Recent]
2. "Modified src/api/routes.js"
3. "Database schema update"
4. "Initial project setup"
π€ User: "Rewind the most recent changes"
π€ Agent: I'll restore the files from the most recent checkpoints.
β
Undone: "Created src/middleware/errorHandler.js"
β
Undone: "Modified src/api/routes.js"
Restored files:
- src/api/routes.js (restored)
- src/middleware/errorHandler.js (deleted)
π€ User: "Perfect! Now implement error handling using a custom Error class instead"
π€ Agent: I'll implement error handling using a custom Error class approach.
[Agent modifies src/api/routes.js]
β
Checkpoint created and pushed to stack: "Modified src/api/routes.js"
[Agent creates src/utils/CustomError.js]
β
Checkpoint created and pushed to stack: "Created src/utils/CustomError.js"
π€ Agent: I've implemented error handling using a custom Error class that provides better error categorization and response formatting.
```
## Available Functional Calls for Claude
Just ask, and it will do the rest.
- `checkpoint(files, description)` - Create checkpoint before changes
- `undo(file)` - Restore to previous checkpoint
- `list_undos()` - Show available checkpoints
- `cleanup` - clean up all the checkpoints
- `status()` - Show current checkpoint status
## π€ Contributing
1. Fork the repository
2. Create your feature branch (`git checkout -b feature/amazing-feature`)
3. Commit your changes (`git commit -m 'Add amazing feature'`)
4. Push to the branch (`git push origin feature/amazing-feature`)
5. Open a Pull Request
## π License
MIT License - see [LICENSE](LICENSE) file for details.
## πββοΈ Support
- π [Documentation](https://github.com/khalilbalaree/Rewind-MCP/wiki)
- π [Issue Tracker](https://github.com/khalilbalaree/Rewind-MCP/issues)
- π¬ [Discussions](https://github.com/khalilbalaree/Rewind-MCP/discussions)
---
**Built with β€οΈ for the Claude Code ecosystem**