Labsco
ihor-sokoliuk logo

SearXNG

β˜… 1,000

from ihor-sokoliuk

A Model Context Protocol Server for SearXNG

πŸ”₯πŸ”₯πŸ”₯πŸ”₯βœ“ VerifiedFreeAdvanced setup

πŸ” SearXNG MCP Server

Private web search for AI assistants β€” connect any SearXNG instance to Claude, Cursor, and more.

An MCP server that integrates the SearXNG API, giving AI assistants web search capabilities.

✨ Featured in the GitHub MCP Registry.

Features

  • Web Search: General queries, news, articles, with pagination.

  • Instance Failover: Configure multiple interchangeable SearXNG replicas in SEARXNG_URL; searches fail over by default and can optionally fan out in parallel.

  • Structured Search Output: Choose formatted text or raw SearXNG-shaped JSON with response_format.

  • Direct Answers & Metadata: Text results surface SearXNG answers, corrections, suggestions, and infoboxes before result lists.

  • Search Suggestions: Query autocomplete via SearXNG's /autocompleter endpoint.

  • Instance Capability Discovery: Inspect configured categories, engines, defaults, locales, and plugins from /config.

  • URL Content Reading: Advanced content extraction with pagination, section filtering, and heading extraction.

  • Intelligent Caching: URL content is cached with TTL (Time-To-Live) to improve performance and reduce redundant requests.

  • Pagination: Control which page of results to retrieve.

  • Time Filtering: Filter results by time range (day, week, month, year).

  • Language Selection: Filter results by preferred language.

  • Safe Search: Control content filtering level for search results.

  • Relevance Filtering: Filter out low-scoring search results with min_score.

Why mcp-searxng?

Brave MCP Exa MCP Firecrawl MCP mcp-searxng Web Search βœ“ βœ“ βœ“ βœ“ Read URL βœ— βœ“ βœ“ βœ“ Pagination βœ— βœ— βœ“ βœ“ Self-hosted βœ— βœ— Partial βœ“ Privacy βœ— βœ— βœ— βœ“ Free / No API key βœ— βœ— βœ— βœ“

How It Works

mcp-searxng is a standalone MCP server β€” a separate Node.js process that your AI assistant connects to for web search. It queries one SearXNG instance, or a semicolon-separated list of interchangeable SearXNG replicas, via the HTTP JSON API.

Not a SearXNG plugin: This project cannot be installed as a native SearXNG plugin. Point it at any existing SearXNG instance, or interchangeable replica list, by setting SEARXNG_URL.

Copy & paste β€” that's it
AI Assistant (e.g. Claude)
 β”‚ MCP protocol
 β–Ό
 mcp-searxng (this project β€” Node.js process)
 β”‚ HTTP JSON API (SEARXNG_URL)
 β–Ό
 SearXNG instance(s)

Tools

searxng_web_search

  • Execute web searches with pagination

  • Inputs:

  • query (string): The search query. This string is passed to external search services.

  • pageno (number, optional): Search page number, starts at 1 (default 1)

  • time_range (string, optional): Filter results by time range - one of: "day", "week", "month", "year" (default: none)

  • language (string, optional): Language code for results (e.g., "en", "fr", "de") or "all" (default: "all")

  • safesearch (string enum, optional): Safe search filter level, one of "0" (None), "1" (Moderate), or "2" (Strict). Legacy numeric values 0, 1, and 2 are still accepted for backward compatibility. (default: instance setting)

  • min_score (number, optional): Minimum relevance score from 0.0 to 1.0. Results below this score are filtered out.

  • num_results (number, optional): Maximum number of results to return, from 1 to 20. SEARXNG_MAX_RESULTS applies as an operator ceiling.

  • categories (string, optional): Comma-separated SearXNG categories (e.g. "news", "it,science"). Live /config capabilities are aggregated across reachable instances; prefer searxng_instance_info categories.common for consistent multi-instance results. Known values are trimmed and normalized case-insensitively; unknown values are forwarded trimmed so SearXNG can ignore or honor them. If /config is unavailable, values are forwarded as-is with a warning. If omitted, each instance uses its server-side default.

  • engines (string, optional): Comma-separated SearXNG engine names (e.g. "google,bing,ddg", "semantic scholar"). Live /config capabilities are aggregated across reachable instances; prefer searxng_instance_info engines.common.enabled for consistent multi-instance results. Known values are trimmed and normalized case-insensitively, including engines disabled by default; unknown values are forwarded trimmed so SearXNG can ignore or honor them. If /config is unavailable, values are forwarded as-is with a warning. If omitted, each instance uses its server-side default.

  • response_format (string, optional): Response format, either "text" for formatted agent-readable output or "json" for raw SearXNG JSON with filtered/sliced results. (default: "text")

searxng_search_suggestions

  • Get autocomplete suggestions for refining search queries

  • Inputs:

  • query (string): Partial or complete query to autocomplete.

  • language (string, optional): Language code for suggestions (e.g., "en", "fr", "de") or "all" (default: "all")

searxng_instance_info

  • Discover categories, engines, defaults, locales, and plugins exposed by all reachable configured SearXNG instances. The response reports common values present on every reachable instance and available values present on at least one reachable instance.

  • Inputs:

  • includeEngines (boolean, optional): Include enabled engine names in the response. (default: false)

  • includeDisabled (boolean, optional): Include disabled engine names when includeEngines is true. (default: false)

  • category (string, optional): Filter categories and engines to a single category name.

  • refresh (boolean, optional): Bypass the process cache and fetch fresh /config data. (default: false)

web_url_read

  • Read and convert the content from a URL to markdown with advanced content extraction options

  • Inputs:

  • url (string): The URL to fetch and process

  • startChar (number, optional): Starting character position for content extraction (default: 0)

  • maxLength (number, optional): Maximum number of characters to return

  • section (string, optional): Extract content under a specific heading (searches for heading text)

  • paragraphRange (string, optional): Return specific paragraph ranges (e.g., '1-5', '3', '10-')

  • readHeadings (boolean, optional): Return only a list of headings instead of full content

Contributing

See CONTRIBUTING.md

Star History

License

MIT β€” see LICENSE for details.