Amazon Product Search
An AI-powered server for Amazon product search and recommendations.
Amazon Product Search MCP Server
The site is live here ! : https://shopassist-sharavana.streamlit.app/
An MCP (Model Context Protocol) server that provides AI-powered Amazon product search and recommendations using FastMCP.
Features
- 🔍 Smart product search with Amazon API
- 🤖 AI-powered product recommendations using Hugging Face
- 💰 Price range filtering
- 📋 Feature-based matching
- 🎯 Tailored recommendations for Small/Medium Enterprises
Installation
- Clone this repository and navigate to the project directory
- Install dependencies:
# Using uv (recommended) uv sync # Or using pip pip install -r requirements.txt
Server Setup
Running the MCP Server
# Activate your virtual environment
source .venv/bin/activate # On Windows: .venv\Scripts\activate
# Run the server
python main.py
The server exposes one main tool:
getdata: Search Amazon products with AI recommendations
Client Options
We provide multiple client implementations to interact with your MCP server:
1. Python Interactive Client (client.py)
A full-featured Python client with examples and interactive mode.
python client.py
Features:
- Pre-built examples (laptops, smartphones)
- Interactive search mode
- Real-time communication with MCP server
2. Command Line Interface (cli_client.py)
Quick command-line searches for automation and scripting.
# Basic search
python cli_client.py "laptop"
# With features and price range
python cli_client.py "laptop" --features "8GB RAM, SSD storage" --min-price 30000 --max-price 80000
# Smartphone search
python cli_client.py "smartphone" --features "good camera, 5G" --min-price 15000 --max-price 50000
Arguments:
product: Product to search for (required)--features,-f: Specific features to look for--min-price,-min: Minimum price in rupees--max-price,-max: Maximum price in rupees
3. Web Interface (web_client.py)
A beautiful web interface with REST API backend.
# Install additional dependencies
pip install fastapi uvicorn
# Run the web server
python web_client.py
Then open http://localhost:8000 in your browser for a user-friendly interface.
API Endpoints:
GET /: Web interfacePOST /search: REST API for product searchGET /health: Health check
4. MCP CLI Integration
You can also use the MCP CLI to interact with your server:
# Install MCP CLI if not already installed
pip install mcp
# Connect to your server
mcp connect stdio -- python main.py
Usage Examples
Example 1: Laptop Search
{
"product": "laptop",
"specific_features": "8GB RAM, SSD storage, good for programming",
"min_price": 30000,
"max_price": 80000
}
Example 2: Smartphone Search
{
"product": "smartphone",
"specific_features": "good camera, long battery life, 5G support",
"min_price": 15000,
"max_price": 50000
}
Example 3: Budget Headphones
{
"product": "wireless headphones",
"specific_features": "noise cancellation, comfortable",
"min_price": 1000,
"max_price": 5000
}
Configuration
API Keys Required
Make sure you have:
- Hugging Face API Token: Update
HF_API_TOKENinserver/buy.py - RapidAPI Key: Update the
x-rapidapi-keyinserver/buy.py
Customization
You can customize the AI recommendation prompt in the decision_agent function in server/buy.py.
Integration with Claude Desktop
To use this MCP server with Claude Desktop, add this configuration to your claude_desktop_config.json:
{
"mcpServers": {
"amazon-search": {
"command": "python",
"args": ["path/to/your/main.py"],
"env": {}
}
}
}
Troubleshooting
Common Issues
- Import errors: Make sure you're in the correct virtual environment
- API failures: Check your API keys and internet connection
- Connection issues: Ensure the MCP server is running before starting clients
Error Messages
- "No result": Usually indicates API issues or no products found
- "Connection refused": MCP server is not running
- "Tool not found": Server initialization issue
Development
Adding New Features
- Add new tools in
server/buy.pyusing the@mcp.tool()decorator - Update client code to use new tools
- Test with the interactive client first
Testing
# Test the server directly
python -c "from server.buy import mcp; print('Server loads successfully')"
# Test with the interactive client
python client.py
Architecture
┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
│ MCP Client │◄──►│ MCP Server │◄──►│ External APIs │
│ (Your Choice) │ │ (FastMCP) │ │ (Amazon/HF AI) │
└─────────────────┘ └─────────────────┘ └─────────────────┘
│ │ │
▼ ▼ ▼
┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐
│ • client.py │ │ • Tool: getdata │ │ • Amazon Search │
│ • cli_client │ │ • AI Agent │ │ • HuggingFace │
│ • web_client │ │ • FastMCP │ │ • Recommendations│
│ • Claude │ │ │ │ │
└─────────────────┘ └─────────────────┘ └─────────────────┘
License
This project is open source. Please ensure you comply with the terms of service of the APIs used (Amazon, RapidAPI, Hugging Face).
เซิร์ฟเวอร์ที่เกี่ยวข้อง
Meilisearch
Interact & query with Meilisearch (Full-text & semantic search API)
Paper Search MCP
Search and download academic papers from sources like arXiv, PubMed, and Google Scholar.
HexDocs MCP
Semantic search for Hex package documentation. Requires local Elixir and Mix installation.
Perigon MCP Server
Official MCP server for the Perigon API, providing access to real-time news and media data.
Library Docs MCP Server
Search and fetch documentation for popular libraries like Langchain, Llama-Index, and OpenAI using the Serper API.
SerpApi MCP Server
Retrieve parsed search engine results using the SerpApi.
OSRS MCP Server
Search the Old School RuneScape (OSRS) Wiki and access game data definitions.
Mevzuat MCP
Provides programmatic access to the Turkish Ministry of Justice Legislation Information System (mevzuat.gov.tr) for searching and retrieving legal texts.
Haloscan MCP Server
An MCP server for interacting with the Haloscan SEO API.
招投标大数据服务
Provides comprehensive bidding and tender information query services, including statistics, searches, and planned project queries.