Skip to main content
Glama
shgsousa

ddg_mcp_server

by shgsousa

DuckDuckGo MCP Server

A web-based search interface using DuckDuckGo's search API, built with Python and Gradio.

Docker Setup

Prerequisites

  • Docker installed on your system

  • Git (optional, for cloning the repository)

Building the Docker Image

  1. Clone the repository (if you haven't already):

git clone <repository-url>
cd ddg_mcp_server
  1. Build the Docker image:

docker build -t ddg-mcp-server .

Running the Container

Run the container with port 7860 mapped to your host:

docker run -p 7860:7860 ddg-mcp-server

The application will be available at:

Troubleshooting

If you cannot connect to the application:

  1. Verify the container is running:

docker ps
  1. Check the container logs:

docker logs $(docker ps -q)
  1. Try stopping any existing containers and starting fresh:

docker stop $(docker ps -q)
docker run -p 7860:7860 ddg-mcp-server

Features

  • Web-based search interface using DuckDuckGo

  • Real-time search results with full content

  • Markdown-formatted output

  • Configurable number of results

  • AI-powered content summarization (see SUMMARIZATION.md for details)

Development

The application is built with:

  • Python 3.10

  • Gradio for the web interface

  • DuckDuckGo Search API

  • BeautifulSoup4 for web scraping

  • Markdownify for content conversion

API Configuration for Summarization

This application supports content summarization using OpenAI's API or any compatible API service. To enable this feature:

  1. Copy the .env.example file to .env:

cp .env.example .env
  1. Edit the .env file and set your API credentials:

OPENAI_API_URL=https://api.openai.com/v1
ACCESS_TOKEN=your_api_key_here

Notes:

  • OPENAI_API_URL defaults to the official OpenAI API server if not specified

  • ACCESS_TOKEN is required for the summarization feature to work

  • You can use any OpenAI-compatible API by changing the OPENAI_API_URL

Running with Docker and API Credentials

To run the Docker container with your API credentials:

docker run -p 7860:7860 \
  -e OPENAI_API_URL="https://api.openai.com/v1" \
  -e ACCESS_TOKEN="your_api_key_here" \
  ddg-mcp-server

Testing the API Connection

After configuring your API credentials, you can test if the connection works correctly:

python main.py --test-api

This will validate your API credentials without starting the full server.

Model Configuration

The AI model used for summarization can be configured in the config.py file:

# Default model to use for summarization
DEFAULT_MODEL = "gpt-4.1-turbo"

For detailed instructions on model configuration, see SUMMARIZATION.md.

A
license - permissive license
-
quality - not tested
C
maintenance

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/shgsousa/ddg_mcp_server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server