Langsung ke konten utama

Pencarian Web

Tool web_search mencari di web menggunakan provider yang Anda konfigurasi dan mengembalikan hasil. Hasil di-cache berdasarkan kueri selama 15 menit (dapat dikonfigurasi). OpenClaw juga menyertakan x_search untuk postingan X (sebelumnya Twitter) dan web_fetch untuk pengambilan URL ringan. Pada fase ini, web_fetch tetap lokal sementara web_search dan x_search dapat menggunakan xAI Responses di balik layar.
web_search adalah tool HTTP ringan, bukan otomatisasi browser. Untuk situs yang banyak menggunakan JS atau login, gunakan Browser Web. Untuk mengambil URL tertentu, gunakan Web Fetch.

Mulai cepat

1

Pilih provider

Pilih provider dan selesaikan penyiapan yang diperlukan. Beberapa provider tidak memerlukan key, sementara yang lain menggunakan API key. Lihat halaman provider di bawah untuk detailnya.
2

Konfigurasi

openclaw configure --section web
Ini menyimpan provider dan kredensial yang diperlukan. Anda juga dapat menyetel env var (misalnya BRAVE_API_KEY) dan melewati langkah ini untuk provider berbasis API.
3

Gunakan

Agen kini dapat memanggil web_search:
await web_search({ query: "OpenClaw plugin SDK" });
Untuk postingan X, gunakan:
await x_search({ query: "dinner recipes" });

Memilih provider

Brave Search

Hasil terstruktur dengan cuplikan. Mendukung mode llm-context, filter negara/bahasa. Tersedia tier gratis.

DuckDuckGo

Fallback tanpa key. Tidak perlu API key. Integrasi tidak resmi berbasis HTML.

Exa

Pencarian neural + kata kunci dengan ekstraksi konten (highlight, teks, ringkasan).

Firecrawl

Hasil terstruktur. Paling cocok dipasangkan dengan firecrawl_search dan firecrawl_scrape untuk ekstraksi mendalam.

Gemini

Jawaban yang disintesis AI dengan sitasi melalui grounding Google Search.

Grok

Jawaban yang disintesis AI dengan sitasi melalui web grounding xAI.

Kimi

Jawaban yang disintesis AI dengan sitasi melalui pencarian web Moonshot.

MiniMax Search

Hasil terstruktur melalui API pencarian MiniMax Coding Plan.

Ollama Web Search

Pencarian tanpa key melalui host Ollama yang Anda konfigurasi. Memerlukan ollama signin.

Perplexity

Hasil terstruktur dengan kontrol ekstraksi konten dan pemfilteran domain.

SearXNG

Meta-search yang di-host sendiri. Tidak perlu API key. Mengagregasikan Google, Bing, DuckDuckGo, dan lainnya.

Tavily

Hasil terstruktur dengan kedalaman pencarian, pemfilteran topik, dan tavily_extract untuk ekstraksi URL.

Perbandingan provider

ProviderGaya hasilFilterAPI key
BraveCuplikan terstrukturNegara, bahasa, waktu, mode llm-contextBRAVE_API_KEY
DuckDuckGoCuplikan terstrukturTidak ada (tanpa key)
ExaTerstruktur + diekstrakMode neural/kata kunci, tanggal, ekstraksi kontenEXA_API_KEY
FirecrawlCuplikan terstrukturMelalui tool firecrawl_searchFIRECRAWL_API_KEY
GeminiSintesis AI + sitasiGEMINI_API_KEY
GrokSintesis AI + sitasiXAI_API_KEY
KimiSintesis AI + sitasiKIMI_API_KEY / MOONSHOT_API_KEY
MiniMax SearchCuplikan terstrukturRegion (global / cn)MINIMAX_CODE_PLAN_KEY / MINIMAX_CODING_API_KEY
Ollama Web SearchCuplikan terstrukturTidak ada secara default; ollama signin diperlukan, dapat memakai ulang bearer auth provider Ollama
PerplexityCuplikan terstrukturNegara, bahasa, waktu, domain, batas kontenPERPLEXITY_API_KEY / OPENROUTER_API_KEY
SearXNGCuplikan terstrukturKategori, bahasaTidak ada (self-hosted)
TavilyCuplikan terstrukturMelalui tool tavily_searchTAVILY_API_KEY

Auto-detection

Pencarian web Codex native

Model yang mendukung Codex secara opsional dapat menggunakan tool web_search Responses native milik provider alih-alih fungsi web_search terkelola milik OpenClaw.
  • Konfigurasikan di bawah tools.web.search.openaiCodex
  • Ini hanya aktif untuk model yang mendukung Codex (openai-codex/* atau provider yang menggunakan api: "openai-codex-responses")
  • web_search terkelola tetap berlaku untuk model non-Codex
  • mode: "cached" adalah pengaturan default dan yang direkomendasikan
  • tools.web.search.enabled: false menonaktifkan pencarian terkelola dan native
{
  tools: {
    web: {
      search: {
        enabled: true,
        openaiCodex: {
          enabled: true,
          mode: "cached",
          allowedDomains: ["example.com"],
          contextSize: "high",
          userLocation: {
            country: "US",
            city: "New York",
            timezone: "America/New_York",
          },
        },
      },
    },
  },
}
Jika pencarian Codex native diaktifkan tetapi model saat ini tidak mendukung Codex, OpenClaw tetap mempertahankan perilaku web_search terkelola normal.

Menyiapkan pencarian web

Daftar provider di dokumen dan alur penyiapan diurutkan secara alfabetis. Auto-detection mempertahankan urutan prioritas terpisah. Jika tidak ada provider yang disetel, OpenClaw memeriksa provider dalam urutan ini dan menggunakan yang pertama yang siap: Provider berbasis API terlebih dahulu:
  1. BraveBRAVE_API_KEY atau plugins.entries.brave.config.webSearch.apiKey (urutan 10)
  2. MiniMax SearchMINIMAX_CODE_PLAN_KEY / MINIMAX_CODING_API_KEY atau plugins.entries.minimax.config.webSearch.apiKey (urutan 15)
  3. GeminiGEMINI_API_KEY atau plugins.entries.google.config.webSearch.apiKey (urutan 20)
  4. GrokXAI_API_KEY atau plugins.entries.xai.config.webSearch.apiKey (urutan 30)
  5. KimiKIMI_API_KEY / MOONSHOT_API_KEY atau plugins.entries.moonshot.config.webSearch.apiKey (urutan 40)
  6. PerplexityPERPLEXITY_API_KEY / OPENROUTER_API_KEY atau plugins.entries.perplexity.config.webSearch.apiKey (urutan 50)
  7. FirecrawlFIRECRAWL_API_KEY atau plugins.entries.firecrawl.config.webSearch.apiKey (urutan 60)
  8. ExaEXA_API_KEY atau plugins.entries.exa.config.webSearch.apiKey (urutan 65)
  9. TavilyTAVILY_API_KEY atau plugins.entries.tavily.config.webSearch.apiKey (urutan 70)
Fallback tanpa key setelah itu:
  1. DuckDuckGo — fallback HTML tanpa key tanpa akun atau API key (urutan 100)
  2. Ollama Web Search — fallback tanpa key melalui host Ollama yang Anda konfigurasi; mengharuskan Ollama dapat dijangkau dan sudah login dengan ollama signin serta dapat memakai ulang bearer auth provider Ollama jika host memerlukannya (urutan 110)
  3. SearXNGSEARXNG_BASE_URL atau plugins.entries.searxng.config.webSearch.baseUrl (urutan 200)
Jika tidak ada provider yang terdeteksi, sistem akan fallback ke Brave (Anda akan mendapatkan error key hilang yang meminta Anda untuk mengonfigurasinya).
Semua field key provider mendukung objek SecretRef. Dalam mode auto-detect, OpenClaw hanya me-resolve key provider yang dipilih — SecretRef yang tidak dipilih tetap tidak aktif.

Konfigurasi

{
  tools: {
    web: {
      search: {
        enabled: true, // default: true
        provider: "brave", // or omit for auto-detection
        maxResults: 5,
        timeoutSeconds: 30,
        cacheTtlMinutes: 15,
      },
    },
  },
}
Konfigurasi khusus provider (API key, base URL, mode) berada di bawah plugins.entries.<plugin>.config.webSearch.*. Lihat halaman provider untuk contohnya. Pemilihan provider fallback web_fetch terpisah:
  • pilih dengan tools.web.fetch.provider
  • atau hilangkan field tersebut dan biarkan OpenClaw melakukan auto-detect provider web-fetch pertama yang siap dari kredensial yang tersedia
  • saat ini provider web-fetch bawaan adalah Firecrawl, dikonfigurasi di bawah plugins.entries.firecrawl.config.webFetch.*
Saat Anda memilih Kimi selama openclaw onboard atau openclaw configure --section web, OpenClaw juga dapat menanyakan:
  • region API Moonshot (https://api.moonshot.ai/v1 atau https://api.moonshot.cn/v1)
  • model web-search Kimi default (default ke kimi-k2.5)
Untuk x_search, konfigurasikan plugins.entries.xai.config.xSearch.*. Tool ini menggunakan fallback XAI_API_KEY yang sama seperti pencarian web Grok. Konfigurasi lama tools.web.x_search.* dimigrasikan otomatis oleh openclaw doctor --fix. Saat Anda memilih Grok selama openclaw onboard atau openclaw configure --section web, OpenClaw juga dapat menawarkan penyiapan x_search opsional dengan key yang sama. Ini adalah langkah lanjutan terpisah di dalam jalur Grok, bukan pilihan provider web-search tingkat atas yang terpisah. Jika Anda memilih provider lain, OpenClaw tidak menampilkan prompt x_search.

Menyimpan API key

Jalankan openclaw configure --section web atau setel key secara langsung:
{
  plugins: {
    entries: {
      brave: {
        config: {
          webSearch: {
            apiKey: "YOUR_KEY", // pragma: allowlist secret
          },
        },
      },
    },
  },
}

Parameter tool

ParameterDeskripsi
queryKueri pencarian (wajib)
countHasil yang dikembalikan (1-10, default: 5)
countryKode negara ISO 2 huruf (mis. “US”, “DE”)
languageKode bahasa ISO 639-1 (mis. “en”, “de”)
search_langKode bahasa pencarian (khusus Brave)
freshnessFilter waktu: day, week, month, atau year
date_afterHasil setelah tanggal ini (YYYY-MM-DD)
date_beforeHasil sebelum tanggal ini (YYYY-MM-DD)
ui_langKode bahasa UI (khusus Brave)
domain_filterArray allowlist/denylist domain (khusus Perplexity)
max_tokensAnggaran total konten, default 25000 (khusus Perplexity)
max_tokens_per_pageBatas token per halaman, default 2048 (khusus Perplexity)
Tidak semua parameter berfungsi dengan semua provider. Mode llm-context Brave menolak ui_lang, freshness, date_after, dan date_before. Gemini, Grok, dan Kimi mengembalikan satu jawaban tersintesis dengan sitasi. Mereka menerima count untuk kompatibilitas tool bersama, tetapi itu tidak mengubah bentuk jawaban yang di-grounding. Perplexity berperilaku sama ketika Anda menggunakan jalur kompatibilitas Sonar/OpenRouter (plugins.entries.perplexity.config.webSearch.baseUrl / model atau OPENROUTER_API_KEY). SearXNG menerima http:// hanya untuk host private-network atau loopback yang tepercaya; endpoint SearXNG publik harus menggunakan https://. Firecrawl dan Tavily hanya mendukung query dan count melalui web_search — gunakan tool khusus mereka untuk opsi lanjutan.
x_search mengkueri postingan X (sebelumnya Twitter) menggunakan xAI dan mengembalikan jawaban yang disintesis AI dengan sitasi. Tool ini menerima kueri bahasa alami dan filter terstruktur opsional. OpenClaw hanya mengaktifkan tool x_search xAI bawaan pada permintaan yang melayani panggilan tool ini.
xAI mendokumentasikan x_search sebagai mendukung pencarian kata kunci, pencarian semantik, pencarian pengguna, dan pengambilan thread. Untuk statistik per postingan seperti repost, balasan, bookmark, atau view, lebih baik gunakan pencarian terarah untuk URL postingan yang tepat atau status ID. Pencarian kata kunci yang luas mungkin menemukan postingan yang benar tetapi mengembalikan metadata per postingan yang kurang lengkap. Pola yang baik adalah: cari postingannya terlebih dahulu, lalu jalankan kueri x_search kedua yang difokuskan pada postingan tepat tersebut.
{
  plugins: {
    entries: {
      xai: {
        config: {
          xSearch: {
            enabled: true,
            model: "grok-4-1-fast-non-reasoning",
            inlineCitations: false,
            maxTurns: 2,
            timeoutSeconds: 30,
            cacheTtlMinutes: 15,
          },
          webSearch: {
            apiKey: "xai-...", // optional if XAI_API_KEY is set
          },
        },
      },
    },
  },
}
ParameterDeskripsi
queryKueri pencarian (wajib)
allowed_x_handlesBatasi hasil ke handle X tertentu
excluded_x_handlesKecualikan handle X tertentu
from_dateHanya sertakan postingan pada atau setelah tanggal ini (YYYY-MM-DD)
to_dateHanya sertakan postingan pada atau sebelum tanggal ini (YYYY-MM-DD)
enable_image_understandingBiarkan xAI memeriksa gambar yang dilampirkan pada postingan yang cocok
enable_video_understandingBiarkan xAI memeriksa video yang dilampirkan pada postingan yang cocok
await x_search({
  query: "dinner recipes",
  allowed_x_handles: ["nytfood"],
  from_date: "2026-03-01",
});
// Per-post stats: use the exact status URL or status ID when possible
await x_search({
  query: "https://x.com/huntharo/status/1905678901234567890",
});

Contoh

// Basic search
await web_search({ query: "OpenClaw plugin SDK" });

// German-specific search
await web_search({ query: "TV online schauen", country: "DE", language: "de" });

// Recent results (past week)
await web_search({ query: "AI developments", freshness: "week" });

// Date range
await web_search({
  query: "climate research",
  date_after: "2024-01-01",
  date_before: "2024-06-30",
});

// Domain filtering (Perplexity only)
await web_search({
  query: "product reviews",
  domain_filter: ["-reddit.com", "-pinterest.com"],
});

Profil tool

Jika Anda menggunakan profil tool atau allowlist, tambahkan web_search, x_search, atau group:web:
{
  tools: {
    allow: ["web_search", "x_search"],
    // or: allow: ["group:web"]  (includes web_search, x_search, and web_fetch)
  },
}

Terkait

  • Web Fetch — ambil URL dan ekstrak konten yang mudah dibaca
  • Browser Web — otomatisasi browser penuh untuk situs yang banyak menggunakan JS
  • Grok Search — Grok sebagai provider web_search
  • Ollama Web Search — pencarian web tanpa key melalui host Ollama Anda