npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

mcp-image-optimizer

v1.0.4

Published

MCP server for image optimization with URL support

Downloads

57

Readme

MCP Image Optimizer

A Model Context Protocol server for image optimization. Process images from URLs or local files with advanced transformations powered by Sharp.

Features

  • 🖼️ Process images from URLs or local files
  • 🔄 Resize, rotate, flip, blur, sharpen, and more
  • 📦 Batch process multiple images
  • 🎨 Convert between JPEG, PNG, WebP, AVIF, TIFF
  • ✂️ Auto-crop borders and whitespace
  • 🎯 Smart crop with attention detection
  • 🌫️ Generate low-quality placeholders (LQIP)
  • 💧 Add watermarks (image or text) with full control
  • 🌟 Generate favicons in all required sizes and formats

Installation

Run this command to add the MCP server:

claude mcp add image-optimizer -- npx -y mcp-image-optimizer

See Claude Code MCP docs for more info.

Add to your Claude Desktop config file:

  • macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
  • Windows: %APPDATA%\Claude\claude_desktop_config.json
  • Linux: ~/.config/Claude/claude_desktop_config.json
{
  "mcpServers": {
    "image-optimizer": {
      "command": "npx",
      "args": ["mcp-image-optimizer"]
    }
  }
}

Add the following configuration to your OpenAI Codex MCP server settings:

[mcp_servers.image-optimizer]
args = ["-y", "mcp-image-optimizer"]
command = "npx"

See OpenAI Codex for more information.

Add to your VS Code settings for MCP extensions like Cline or Continue:

{
  "image-optimizer": {
    "command": "npx",
    "args": ["mcp-image-optimizer"]
  }
}

Navigate to Settings → Cursor Settings → MCP → Add new global MCP server

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "image-optimizer": {
      "command": "npx",
      "args": ["mcp-image-optimizer"]
    }
  }
}

Install globally for faster startup:

npm install -g mcp-image-optimizer

Then use this simpler config in any client:

{
  "command": "mcp-image-optimizer"
}

Usage Examples

Ask your AI assistant:

  • "Optimize ~/Desktop/photo.jpg to 800px width"
  • "Convert https://images.pexels.com/photos/32206277/pexels-photo-32206277.jpeg to WebP"
  • "Batch optimize all images in ~/Downloads/"
  • "Create a 200x200 thumbnail with smart crop"
  • "Generate a placeholder for lazy loading"
  • "Add my company logo as watermark to product images"
  • "Add 'Copyright 2025' text watermark"
  • "Generate all favicon sizes from my logo"

Available Tools

Resize, convert, and transform images.

Example:

"Optimize image.jpg to 800px width with 85% quality"

Parameters:

  • input - Image path or URL
  • output - Output file path
  • width - Target width in pixels
  • height - Target height in pixels
  • quality - Quality 1-100 for lossy formats
  • format - Output format (jpeg, png, webp, avif, tiff)
  • fit - Resize fit mode (cover, contain, fill, inside, outside)
  • Plus rotate, flip, grayscale, blur, sharpen, normalize

Process multiple images at once.

Example:

"Optimize all images in ~/Pictures/ to 1200px width"

Parameters:

  • inputs - Array of image paths or URLs
  • outputDir - Output directory
  • width, height, quality, format - Same as single image
  • prefix - Add to filename start
  • suffix - Add to filename end

Extract image metadata.

Example:

"Get info about image.jpg"

Returns:

  • Dimensions, format, color space
  • File size, DPI
  • EXIF data presence

Remove borders and whitespace automatically.

Example:

"Auto-crop screenshot.png to remove white borders"

Parameters:

  • input - Image path or URL
  • output - Output file path
  • threshold - Color similarity threshold 0-100
  • backgroundColor - Background to detect

Intelligent cropping to specific dimensions.

Example:

"Smart crop portrait.jpg to 500x500 square"

Parameters:

  • input - Image path or URL
  • output - Output file path
  • width, height - Target dimensions
  • strategy - "attention" or "entropy"

Generate low-quality image placeholders for lazy loading.

Example:

"Create a blurred placeholder for hero-image.jpg"

Parameters:

  • input - Image path or URL
  • width - Placeholder width (default: 20)
  • height - Placeholder height (auto if not set)
  • quality - JPEG quality 1-100 (default: 40)
  • blur - Blur amount 0.3-1000 (default: 5)
  • format - "base64", "datauri", or "file"

Add image or text watermarks with positioning and styling.

Example:

"Add logo.png as watermark to photo.jpg in bottom-right corner"
"Add 'Copyright 2025' text watermark with 50% opacity"
"Add 'CONFIDENTIAL' diagonally across the document"

Parameters:

  • input - Image path or URL
  • output - Output file path
  • watermark - Path/URL to watermark image, base64 data, or text
  • position - Corner, center, diagonal, or tile pattern
  • opacity - Transparency 0-1
  • scale - Size relative to base image
  • margin - Distance from edges
  • blend - Blend mode for effects
  • Text options: text, fontSize, fontColor, fontFamily

Generate all favicon sizes and formats for modern web apps.

Example:

"Generate favicons from logo.png and save to ./public"
"Create all icon sizes for my PWA"

Parameters:

  • input - Source image (recommend 512x512 or larger)
  • outputDir - Directory to save all favicon files
  • sizes - Custom sizes array (default: all standard sizes)
  • platforms - Target platforms: web, apple, android, microsoft, all
  • generateManifest - Create manifest.json snippet for PWAs

Generated files:

  • PNG favicons in all sizes (16x16 to 512x512)
  • apple-touch-icon.png (180x180)
  • android-chrome-192x192.png, android-chrome-512x512.png
  • mstile-150x150.png (Microsoft tile)
  • favicon-html.txt (ready-to-use HTML tags)
  • manifest-icons.json (PWA configuration)

Path Support

  • URLs: https://example.com/image.jpg
  • Absolute paths: /Users/name/Desktop/image.jpg
  • Home directory: ~/Desktop/image.jpg
  • ⚠️ Relative paths: Works with cwd config setting

To use relative paths, add a working directory:

{
  "command": "npx",
  "args": ["mcp-image-optimizer"],
  "cwd": "/Users/yourname/Desktop"
}

Requirements

  • Node.js 22+ (npx handles this automatically)
  • Compatible MCP client

Troubleshooting

"Command not found"

  • Make sure Node.js is installed: node --version
  • Try the global install method

"File not found"

  • Use absolute paths: /Users/name/Desktop/image.jpg
  • Check file permissions

"MCP tools not available"

  • Restart your MCP client after configuration
  • Check config file is valid JSON

License

MIT

Links