/unified-diff-mcp

Primary LanguageTypeScriptOtherNOASSERTION

Unified Diff MCP Server

smithery badge

Beautiful diff visualization for Claude Desktop. Transform code diffs into stunning visual comparisons with GitHub Gist integration and local file output.

Unified Diff Visualization Screenshot

โœจ Features

  • ๐ŸŽจ Beautiful HTML diff visualization using diff2html
  • ๐ŸŒ GitHub Gist integration for instant sharing
  • ๐Ÿ“ Local file output (PNG/HTML)
  • ๐Ÿ”„ Auto-delete functionality for temporary diffs
  • ๐Ÿ–ฅ๏ธ Cross-platform support (Windows, macOS, Linux)
  • โšก High-performance with Bun runtime
  • ๐Ÿ›ก๏ธ Enhanced Security with multi-level protection for shared diffs
  • ๐Ÿ”’ Multi-level security (Low/Medium/High) for different use cases

๐Ÿš€ Quick Start

Installing via Smithery

bunx @smithery/cli install @gorosun/unified-diff-mcp --client claude --config '{
  "defaultAutoOpen": true,
  "defaultOutputMode": "html",
  "githubUsername": "your_actual_github_username",
  "githubToken": "ghp_your_actual_token_here"
}'

Manual Installation

  1. Install Claude Desktop and Bun
  2. Clone and build:
    git clone https://github.com/gorosun/unified-diff-mcp.git
    cd unified-diff-mcp
    bun install
  3. Configure Claude Desktop - see Configuration below

๐Ÿ› ๏ธ Tools Overview

Tool Purpose Output Best For
visualize_diff_html_content Browser display & sharing GitHub Gist + HTML preview URL Quick sharing, instant viewing
visualize_diff_output_file Local file storage PNG/HTML files Local storage, presentations

๐Ÿ“– Usage Examples

๐ŸŽฏ Optimal Prompts by Purpose

Purpose Recommended Prompt Tool Used Output
Quick Preview Please visualize and preview the following diff:
ไปฅไธ‹ใฎdiffใ‚’ๅฏ่ฆ–ๅŒ–ใ—ใฆใƒ—ใƒฌใƒ“ใƒฅใƒผใ—ใฆใใ ใ•ใ„
visualize_diff_html_content GitHub Gist + HTML preview URL
Local Storage Please visualize and save the following diff to a file:
ไปฅไธ‹ใฎdiffใ‚’ๅฏ่ฆ–ๅŒ–ใ—ใฆใƒ•ใ‚กใ‚คใƒซใซไฟๅญ˜ใ—ใฆใใ ใ•ใ„
visualize_diff_output_file Local HTML/PNG file
Share with Others Please visualize the following diff and create a shareable link:
ไปฅไธ‹ใฎdiffใ‚’ๅฏ่ฆ–ๅŒ–ใ—ใฆๅ…ฑๆœ‰ใƒชใƒณใ‚ฏใ‚’ไฝœๆˆใ—ใฆใใ ใ•ใ„
visualize_diff_html_content GitHub Gist with shareable URL
Image Export Please visualize and save the following diff as a PNG image:
ไปฅไธ‹ใฎdiffใ‚’ๅฏ่ฆ–ๅŒ–ใ—ใฆPNG็”ปๅƒใงไฟๅญ˜ใ—ใฆใใ ใ•ใ„
visualize_diff_output_file Local PNG image
Code Review Please visualize the following diff in side-by-side format:
ไปฅไธ‹ใฎdiffใ‚’side-by-sideๅฝขๅผใงๅฏ่ฆ–ๅŒ–ใ—ใฆใใ ใ•ใ„
Either tool Side-by-side comparison
Documentation Please visualize and save the following diff as an HTML file:
ไปฅไธ‹ใฎdiffใ‚’ๅฏ่ฆ–ๅŒ–ใ—ใฆHTMLใƒ•ใ‚กใ‚คใƒซใงไฟๅญ˜ใ—ใฆใใ ใ•ใ„
visualize_diff_output_file Local HTML file
๐Ÿ”’ Secure Sharing Please visualize this diff with high security:
ไปฅไธ‹ใฎdiffใ‚’้ซ˜ใ‚ปใ‚ญใƒฅใƒชใƒ†ใ‚ฃใงๅฏ่ฆ–ๅŒ–ใ—ใฆใใ ใ•ใ„
visualize_diff_html_content Secret Gist with auto-delete

Share diff instantly (GitHub Gist)

visualize_diff_html_content:
- Creates temporary GitHub Gist
- Auto-deletes after 30 minutes
- Instant browser-ready URLs
- Perfect for code reviews

Save diff locally

visualize_diff_output_file:
- Saves PNG or HTML to local disk
- Auto-opens in browser (optional)
- Perfect for documentation

๐ŸŽ›๏ธ Configuration

Environment Variables

Variable Description Default
GITHUB_TOKEN GitHub Personal Access Token (for Gist integration) Required for visualize_diff_html_content
DEFAULT_AUTO_OPEN Auto-open generated files false
DEFAULT_OUTPUT_MODE Default output format (html or image) html

GitHub Token Setup

  1. Go to GitHub Settings > Personal Access Tokens
  2. Generate new token with gist scope
  3. Add to your environment:
    export GITHUB_TOKEN="your_token_here"

Claude Desktop Configuration

macOS:

code ~/Library/Application\ Support/Claude/claude_desktop_config.json

Windows:

code %APPDATA%\Claude\claude_desktop_config.json

Configuration template:

{
  "mcpServers": {
    "unified-diff-mcp": {
      "command": "bun",
      "args": ["run", "/path/to/unified-diff-mcp/src/index.ts"],
      "env": {
        "GITHUB_TOKEN": "your_github_token_here",
        "DEFAULT_AUTO_OPEN": "true",
        "DEFAULT_OUTPUT_MODE": "html"
      }
    }
  }
}

๐Ÿ“‹ Parameters Reference

Common Parameters

Parameter Type Default Description
diff string (required) Unified diff text
format string side-by-side Display format (line-by-line or side-by-side)
showFileList boolean true Show file list summary
highlight boolean true Enable syntax highlighting
oldPath string file.txt Original file path
newPath string file.txt Modified file path
autoOpen boolean false Auto-open in browser

GitHub Gist Specific

Parameter Type Default Description
expiryMinutes number 30 Auto-delete time (1-1440 minutes)
public boolean false Public vs secret gist

Local File Specific

Parameter Type Default Description
outputType string html Output format (html or image)

๐ŸŒ Platform Support

Platform Auto-Open Commands
Windows โœ… start (primary), explorer (fallback)
macOS โœ… open (primary), AppleScript (fallback)
Linux โœ… xdg-open

๐Ÿ”ง Development

Development mode (with hot reload):

{
  "command": "bun",
  "args": ["--watch", "/path/to/unified-diff-mcp/src/index.ts"]
}

Production mode:

{
  "command": "bun",
  "args": ["run", "/path/to/unified-diff-mcp/src/index.ts"]
}

๐Ÿ“š Advanced Usage

๐Ÿ”’ Enhanced Security Levels

When GitHub Token isn't available or for secure sharing, you can choose from multiple security levels:

Security Level Configuration Features Use Cases
๐ŸŸข Low Secret Gist + 60min auto-delete URL-only access Code examples, learning
๐ŸŸก Medium Secret Gist + Password + 30min auto-delete URL + Access code required Team reviews
๐Ÿ”ด High Secret Gist + Password + 15min auto-delete URL + Access code + Short duration Sensitive code

Usage Example

Please visualize this diff with high security:
--- a/config.js
+++ b/config.js
@@ -1,3 +1,4 @@
 const config = {
-  apiKey: 'old-key'
+  apiKey: 'new-secure-key',
+  timeout: 5000
 };

Response Example:

๐Ÿ”’ **Secure Diff Visualization**

๐Ÿ”ด **Security Level**: High Security - Secret Gist + Password (15min auto-delete)
๐Ÿ“‹ **Preview Link**: https://htmlpreview.github.io/?...
๐Ÿ”‘ **Access Code**: `a7x9k2`
โฐ **Auto-delete**: 15 minutes

๐Ÿ”„ Fallback Functionality

When GitHub Token is unavailable, the system falls back to local files:

  • HTML saved as temporary file
  • Automatic browser opening
  • Security-based file management

For detailed setup and integration guides:

๐Ÿค Supported Clients

  • Claude Desktop (Primary)
  • Claude Code (CLI)
  • VS Code + MCP Extension
  • Cline and other MCP clients

๐Ÿ“„ License

MIT License - see LICENSE file for details.

Dependencies

Library License Purpose
diff2html MIT HTML diff generation
playwright-core Apache 2.0 Browser automation
@modelcontextprotocol/sdk MIT MCP integration

Made with โค๏ธ for the Claude Desktop community