home / skills / openclaw / skills / searxng-local-search

searxng-local-search skill

/skills/noblepayne/searxng-local-search

This skill searches the web via a self-hosted SearXNG instance to fetch current information, verify facts, and gather diverse resources.

npx playbooks add skill openclaw/skills --skill searxng-local-search

Review the files below or copy the command above to add this skill to your agents.

Files (3)
SKILL.md
3.6 KB
---
name: searxng-web-search
description: Search the web using SearXNG. Use when you need current information, research topics, find documentation, verify facts, or look up anything beyond your knowledge. Returns ranked results with titles, URLs, and content snippets.
metadata:
  openclaw:
    requires:
      bins: ["bb"]
      env: ["SEARXNG_URL"]
    emoji: "🔍"
    nix:
      plugin: "babashka"
---

# SearXNG Web Search

Search the web using a self-hosted SearXNG instance. This skill provides access to web search results through the SearXNG JSON API, with built-in rate limiting, error handling, and result formatting.

## When to Use

Use this skill when you need to:
- Find current information or recent news
- Research topics beyond your knowledge cutoff
- Look up documentation or technical references
- Verify facts or check current status
- Find URLs or resources on specific topics
- Search for code examples or solutions

## Configuration

Set the `SEARXNG_URL` environment variable to your SearXNG instance:

```bash
export SEARXNG_URL="http://localhost:8888"
```

Or use the default (http://localhost:8888) if not set.

## Usage

Execute the search script with your query:

```bash
bb scripts/search.clj "your search query"
```

### Advanced Options

Pass additional parameters as JSON:

```bash
bb scripts/search.clj "your query" '{"category": "news", "time_range": "day", "num_results": 10}'
```

Available options:
- `category` - Filter by category: general, news, images, videos, it, science
- `time_range` - Time filter: day, week, month, year
- `language` - Language code (default: en)
- `num_results` - Number of results to return (default: 5)

## Output Format

The script returns formatted search results as text:

```
Search Results for "your query"
Found 42 total results

1. Result Title [Score: 1.85]
   URL: https://example.com/page
   Description snippet from the page...
   Engines: google, bing

2. Another Result [Score: 1.62]
   ...
```

## Error Handling

The script handles common errors gracefully:
- Network timeouts (30s timeout)
- SearXNG unavailable (clear error message)
- Invalid queries (error details)
- Rate limiting (429 responses)
- Empty results (informative message)

## Rate Limiting

The script implements basic rate limiting:
- Minimum 1 second between requests
- Uses filesystem-based state (`.searxng-last-request`)
- Prevents accidental spam

## Examples

### Basic Search
```bash
bb scripts/search.clj "NixOS configuration"
```

### News Search
```bash
bb scripts/search.clj "AI developments" '{"category": "news", "time_range": "week"}'
```

### Technical Search
```bash
bb scripts/search.clj "babashka http client" '{"category": "it", "num_results": 3}'
```

### Recent Results Only
```bash
bb scripts/search.clj "product launch" '{"time_range": "day"}'
```

## Troubleshooting

**"SEARXNG_URL not set"**
- Set the environment variable: `export SEARXNG_URL="http://localhost:8888"`

**Connection timeout**
- Check that SearXNG is running: `curl $SEARXNG_URL/search?q=test&format=json`
- Verify firewall settings
- Check service status: `systemctl status searx`

**Empty results**
- Try a broader query
- Remove filters and try again
- Check SearXNG logs: `journalctl -u searx -n 50`

**Rate limit errors**
- Wait a few seconds between searches
- The script enforces minimum 1s delay automatically

## Implementation Notes

The search script (`scripts/search.clj`) uses:
- `babashka.http-client` for HTTP requests
- Clojure's `cheshire.core` for JSON parsing
- Filesystem-based rate limiting
- 30-second timeout with proper error messages
- Result scoring and sorting for best results first

For detailed API documentation, see `references/api-guide.md`.

Overview

This skill lets you search the web through a self-hosted SearXNG instance and returns ranked results with titles, URLs, and content snippets. It provides built-in rate limiting, timeout handling, and formatted output so searches are reliable and easy to read. Use it to fetch current information, verify facts, or locate documentation and resources beyond the model's knowledge cutoff.

How this skill works

The skill queries a SearXNG JSON API endpoint (configurable via SEARXNG_URL) and parses the JSON response into scored, sorted results. It enforces a minimum 1-second delay between requests using a filesystem state file to avoid accidental spam and handles network timeouts, 429 rate-limit responses, and empty or invalid responses with clear error messages. Results are returned as a concise list with title, URL, snippet, score, and source engines.

When to use it

  • Find recent news, announcements, or time-sensitive information.
  • Research topics or look up documentation and technical references beyond the knowledge cutoff.
  • Verify facts, check live status, or confirm URLs and sources.
  • Search for code examples, tutorials, or problem-solving resources.
  • Gather links and summaries quickly for reporting or research tasks.

Best practices

  • Set SEARXNG_URL to your SearXNG instance (default http://localhost:8888).
  • Use category, time_range, language, and num_results parameters to narrow results and reduce noise.
  • Avoid rapid automated loops; rely on the built-in 1s minimum delay and respect remote rate limits.
  • Start with broader queries if results are empty, then add filters (category/time_range) to refine.
  • Inspect snippets and source engines to evaluate result relevance before following links.

Example use cases

  • Quickly gather recent articles about an emerging technology using time_range=day or week.
  • Locate API documentation or configuration examples for a tool by filtering to the it category.
  • Verify a claim or event by searching multiple engines aggregated by SearXNG and reviewing snippets and URLs.
  • Find code examples or stack overflow threads by requesting multiple results and scanning snippets.
  • Compile a list of relevant resources and links for a report or research summary with formatted output.

FAQ

How do I point the skill to my SearXNG instance?

Set the SEARXNG_URL environment variable to your instance URL (for example export SEARXNG_URL="http://localhost:8888").

What happens if SearXNG is down or times out?

The skill returns a clear error message, uses a 30s request timeout, and suggests checking the service status and connectivity.