Tools
Perplexity 검색
OpenClaw은 Perplexity Search API를 web_search 제공자로 지원합니다.
이 API는 title, url, snippet 필드가 포함된 구조화된 결과를 반환합니다.
호환성을 위해 OpenClaw은 기존 Perplexity Sonar/OpenRouter 설정도 지원합니다.
OPENROUTER_API_KEY, plugins.entries.perplexity.config.webSearch.apiKey의 sk-or-... 키를 사용하거나 plugins.entries.perplexity.config.webSearch.baseUrl / model을 설정하면, 제공자는 chat completions 경로로 전환되어 구조화된 Search API 결과 대신 인용이 포함된 AI 합성 답변을 반환합니다.
Perplexity API 키 받기
- perplexity.ai/settings/api에서 Perplexity 계정을 만드세요.
- 대시보드에서 API 키를 생성하세요.
- 키를 config에 저장하거나 Gateway 환경에서
PERPLEXITY_API_KEY를 설정하세요.
OpenRouter 호환성
이미 Perplexity Sonar에 OpenRouter를 사용하고 있었다면 provider: "perplexity"를 유지하고 Gateway 환경에서 OPENROUTER_API_KEY를 설정하거나, plugins.entries.perplexity.config.webSearch.apiKey에 sk-or-... 키를 저장하세요.
선택적 호환성 제어 항목:
plugins.entries.perplexity.config.webSearch.baseUrlplugins.entries.perplexity.config.webSearch.model
Config 예시
네이티브 Perplexity Search API
{
plugins: {
entries: {
perplexity: {
config: {
webSearch: {
apiKey: "pplx-...",
},
},
},
},
},
tools: {
web: {
search: {
provider: "perplexity",
},
},
},
}
OpenRouter / Sonar 호환성
{
plugins: {
entries: {
perplexity: {
config: {
webSearch: {
apiKey: "<openrouter-api-key>",
baseUrl: "https://openrouter.ai/api/v1",
model: "perplexity/sonar-pro",
},
},
},
},
},
tools: {
web: {
search: {
provider: "perplexity",
},
},
},
}
키를 설정하는 위치
Config 사용: openclaw configure --section web을 실행하세요. 이 명령은 키를
plugins.entries.perplexity.config.webSearch.apiKey 아래의
~/.openclaw/openclaw.json에 저장합니다.
해당 필드는 SecretRef 객체도 허용합니다.
환경 사용: Gateway 프로세스 환경에서 PERPLEXITY_API_KEY 또는 OPENROUTER_API_KEY를 설정하세요. gateway 설치의 경우
~/.openclaw/.env(또는 서비스 환경)에 넣으세요. 환경 변수를 참고하세요.
provider: "perplexity"가 구성되어 있고 Perplexity 키 SecretRef가 환경 폴백 없이 해석되지 않으면 시작/다시 로드가 빠르게 실패합니다.
도구 매개변수
이 매개변수는 네이티브 Perplexity Search API 경로에 적용됩니다.
querystringrequired검색 쿼리.
countnumber반환할 결과 수(1-10).
countrystring2글자 ISO 국가 코드(예: US, DE).
languagestringISO 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_tokensnumber전체 콘텐츠 예산(최대 1000000).
max_tokens_per_pagenumber페이지당 토큰 제한.
기존 Sonar/OpenRouter 호환성 경로의 경우:
query,count,freshness가 허용됩니다.- 여기서
count는 호환성 전용입니다. 응답은 N개 결과 목록이 아니라 여전히 인용이 포함된 하나의 합성 답변입니다. country,language,date_after,date_before,domain_filter,max_tokens,max_tokens_per_page같은 Search API 전용 필터는 명시적 오류를 반환합니다.
예시:
// Country and language-specific search
await web_search({
query: "renewable energy",
country: "DE",
language: "de",
});
// Recent results (past week)
await web_search({
query: "AI news",
freshness: "week",
});
// Date range search
await 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 extraction
await 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로 구성 가능).