Tools

Perplexity 검색

OpenClaw는 web_search 공급자로 Perplexity Search API를 지원합니다. title, url, snippet 필드가 포함된 구조화된 결과를 반환합니다.

호환성을 위해 OpenClaw는 레거시 Perplexity Sonar/OpenRouter 설정도 지원합니다. OPENROUTER_API_KEY, plugins.entries.perplexity.config.webSearch.apiKeysk-or-... 키를 사용하거나 plugins.entries.perplexity.config.webSearch.baseUrl / model을 설정하면, 공급자는 chat-completions 경로로 전환되어 구조화된 Search API 결과 대신 인용이 포함된 AI 합성 답변을 반환합니다.

Plugin 설치

공식 Plugin을 설치한 다음 Gateway를 다시 시작합니다.

bash
openclaw plugins install @openclaw/perplexity-pluginopenclaw gateway restart

Perplexity API 키 받기

  1. perplexity.ai/settings/api에서 Perplexity 계정을 만듭니다
  2. 대시보드에서 API 키를 생성합니다
  3. 키를 설정에 저장하거나 Gateway 환경에 PERPLEXITY_API_KEY를 설정합니다.

OpenRouter 호환성

이미 Perplexity Sonar용으로 OpenRouter를 사용하고 있었다면 provider: "perplexity"를 유지하고 Gateway 환경에 OPENROUTER_API_KEY를 설정하거나, plugins.entries.perplexity.config.webSearch.apiKeysk-or-... 키를 저장합니다.

선택적 호환성 제어 항목:

  • plugins.entries.perplexity.config.webSearch.baseUrl
  • plugins.entries.perplexity.config.webSearch.model

설정 예시

네이티브 Perplexity Search API

json5
{  plugins: {    entries: {      perplexity: {        config: {          webSearch: {            apiKey: "pplx-...",          },        },      },    },  },  tools: {    web: {      search: {        provider: "perplexity",      },    },  },}

OpenRouter / Sonar 호환성

json5
{  plugins: {    entries: {      perplexity: {        config: {          webSearch: {            apiKey: "<openrouter-api-key>",            baseUrl: "https://openrouter.ai/api/v1",            model: "perplexity/sonar-pro",          },        },      },    },  },  tools: {    web: {      search: {        provider: "perplexity",      },    },  },}

키를 설정할 위치

설정을 통해: openclaw configure --section web를 실행합니다. 이 명령은 키를 ~/.openclaw/openclaw.jsonplugins.entries.perplexity.config.webSearch.apiKey 아래에 저장합니다. 해당 필드는 SecretRef 객체도 허용합니다.

환경을 통해: Gateway 프로세스 환경에 PERPLEXITY_API_KEY 또는 OPENROUTER_API_KEY를 설정합니다. Gateway 설치의 경우 ~/.openclaw/.env(또는 서비스 환경)에 넣습니다. Env vars를 참조하세요.

provider: "perplexity"가 설정되어 있고 Perplexity 키 SecretRef가 환경 폴백 없이 확인되지 않으면, 시작/다시 로드가 빠르게 실패합니다.

도구 매개변수

이 매개변수는 네이티브 Perplexity Search API 경로에 적용됩니다.

querystringrequired

검색 쿼리입니다.

countnumberdefault: 5

반환할 결과 수입니다(1-10).

countrystring

2글자 ISO 국가 코드입니다(예: US, DE).

languagestring

ISO 639-1 언어 코드입니다(예: en, de, fr).

freshness'day' | 'week' | 'month' | 'year'

시간 필터입니다. day는 24시간입니다.

date_afterstring

이 날짜 이후에 게시된 결과만 포함합니다(YYYY-MM-DD).

date_beforestring

이 날짜 이전에 게시된 결과만 포함합니다(YYYY-MM-DD).

domain_filterstring[]

도메인 허용 목록/거부 목록 배열입니다(최대 20개).

max_tokensnumberdefault: 25000

전체 콘텐츠 예산입니다(최대 1000000).

max_tokens_per_pagenumberdefault: 2048

페이지당 토큰 제한입니다.

레거시 Sonar/OpenRouter 호환성 경로의 경우:

  • query, count, freshness가 허용됩니다
  • 여기서 count는 호환성 전용입니다. 응답은 여전히 N개 결과 목록이 아니라 인용이 포함된 하나의 합성 답변입니다
  • country, language, date_after, date_before, domain_filter, max_tokens, max_tokens_per_page와 같은 Search API 전용 필터는 명시적 오류를 반환합니다

예시:

javascript
// Country and language-specific searchawait web_search({  query: "renewable energy",  country: "DE",  language: "de",}); // Recent results (past week)await web_search({  query: "AI news",  freshness: "week",}); // Date range searchawait web_search({  query: "AI developments",  date_after: "2024-01-01",  date_before: "2024-06-30",}); // Domain filtering (allowlist)await web_search({  query: "climate research",  domain_filter: ["nature.com", "science.org", ".edu"],}); // Domain filtering (denylist - prefix with -)await web_search({  query: "product reviews",  domain_filter: ["-reddit.com", "-pinterest.com"],}); // More content extractionawait web_search({  query: "detailed AI research",  max_tokens: 50000,  max_tokens_per_page: 4096,});

도메인 필터 규칙

  • 필터당 최대 20개 도메인
  • 같은 요청에서 허용 목록과 거부 목록을 혼합할 수 없습니다
  • 거부 목록 항목에는 - 접두사를 사용합니다(예: ["-reddit.com"])

참고

  • Perplexity Search API는 구조화된 웹 검색 결과(title, url, snippet)를 반환합니다
  • OpenRouter 또는 명시적인 plugins.entries.perplexity.config.webSearch.baseUrl / model은 호환성을 위해 Perplexity를 다시 Sonar chat completions로 전환합니다
  • Sonar/OpenRouter 호환성은 구조화된 결과 행이 아니라 인용이 포함된 하나의 합성 답변을 반환합니다
  • 결과는 기본적으로 15분 동안 캐시됩니다(cacheTtlMinutes로 설정 가능)

관련 항목

Was this useful?
On this page

On this page