dev-tahir/get-best-image
If you are the rightful owner of get-best-image and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
An intelligent MCP server that searches for images, labels them, combines them into a composite image, and uses Google's Gemini 2.0 Flash AI to select the best match for your query.
MCP Image Server
An intelligent MCP (Model Context Protocol) server that searches for images, labels them, combines them into a composite image, and uses Google's Gemini 2.0 Flash AI to select the best match for your query.
Features
- š Image Search: Searches multiple sources (Unsplash, Pexels, with fallback to Lorem Picsum)
- š·ļø Smart Labeling: Labels each image (1-20) with black borders for easy identification
- š¼ļø Image Composition: Combines all images into a single grid view
- š¤ AI Selection: Uses Google's Gemini 2.0 Flash to intelligently select the best matching image
- š¦ Base64 Output: Returns images as base64 for easy integration
Installation
-
Clone or download this repository
-
Install dependencies:
npm install
-
Copy the environment template:
copy .env.example .env
-
Edit
.env
and add your API keys:GOOGLE_AI_API_KEY=your_google_ai_api_key_here UNSPLASH_ACCESS_KEY=your_unsplash_access_key_here PEXELS_API_KEY=your_pexels_api_key_here
Getting API Keys
Google AI API Key (Required for AI selection)
- Go to Google AI Studio
- Create a new API key
- Add it to your
.env
file asGOOGLE_AI_API_KEY
Unsplash API Key (Optional but recommended)
- Go to Unsplash Developers
- Create a new application
- Get your Access Key
- Add it to your
.env
file asUNSPLASH_ACCESS_KEY
Pexels API Key (Optional but recommended)
- Go to Pexels API
- Create a free account and get your API key
- Add it to your
.env
file asPEXELS_API_KEY
Usage
Development Mode
npm run dev
Build and Run
npm run build
npm start
Using with Claude Desktop
Add this server to your Claude Desktop configuration:
{
"mcpServers": {
"mcp-image-server": {
"command": "node",
"args": ["C:/path/to/your/project/build/index.js"]
}
}
}
Available Tools
search_and_select_best_image
Searches for images matching your query and returns the AI-selected best match.
Parameters:
query
(string, required): The search query for imagesmaxImages
(number, optional): Maximum number of images to search (1-20, default: 20)
Example usage in Claude:
"Search for the best image of a sunset over mountains"
How It Works
- Search: Queries multiple image APIs (Unsplash, Pexels) for relevant images
- Download: Downloads up to 20 images and resizes them to thumbnails
- Label: Adds numbered labels (1-20) with black borders to each image
- Compose: Combines all labeled images into a single grid
- AI Analysis: Sends the composite to Google's Gemini 2.0 Flash with your original query
- Select: AI analyzes each numbered image and selects the best match
- Return: Downloads and returns the selected image as base64
Error Handling
- If no API keys are provided, the server uses placeholder images from Lorem Picsum
- If Google AI API is not available, it uses a fallback selection algorithm
- Failed image downloads are replaced with placeholder images
- All errors are logged to stderr for debugging
Project Structure
src/
āāā index.ts # Main MCP server entry point
āāā services/
āāā ImageSearchService.ts # Handles image search from various APIs
āāā ImageProcessingService.ts # Processes and combines images
āāā AISelectionService.ts # Uses Google AI for selection
Development
npm run dev
- Run in development mode with auto-restartnpm run build
- Build TypeScript to JavaScriptnpm run clean
- Clean build directory
License
MIT License
Contributing
Feel free to submit issues and enhancement requests!