Perplexity Search API

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

호환성을 위해 레거시 Perplexity Sonar/OpenRouter 설정도 지원합니다. OPENROUTER_API_KEY를 사용하거나, tools.web.search.perplexity.apiKeysk-or-... 키를 넣거나, tools.web.search.perplexity.baseUrl / model을 설정하면 채팅 완성 경로로 전환되어 구조화된 Search API 결과 대신 인용이 포함된 AI 합성 답변을 반환합니다.

Perplexity API 키 발급

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

OpenRouter 호환성

이미 OpenRouter를 통해 Perplexity Sonar를 사용하고 있다면, provider: "perplexity"를 유지한 채 Gateway 환경에 OPENROUTER_API_KEY를 설정하거나, tools.web.search.perplexity.apiKeysk-or-... 키를 저장하세요.

선택적 레거시 설정:

  • tools.web.search.perplexity.baseUrl
  • tools.web.search.perplexity.model

설정 예시

네이티브 Perplexity Search API

{
  tools: {
    web: {
      search: {
        provider: "perplexity",
        perplexity: {
          apiKey: "pplx-...",
        },
      },
    },
  },
}

OpenRouter / Sonar 호환 모드

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

키 설정 위치

설정 파일: openclaw configure --section web을 실행합니다. ~/.openclaw/openclaw.jsontools.web.search.perplexity.apiKey에 키가 저장됩니다. 이 필드는 SecretRef 객체도 지원합니다.

환경 변수: Gateway 프로세스 환경에 PERPLEXITY_API_KEY 또는 OPENROUTER_API_KEY를 설정합니다. Gateway 설치 시에는 ~/.openclaw/.env(또는 서비스 환경)에 넣으세요. 환경 변수를 참고하세요.

provider: "perplexity"가 설정되어 있는데 Perplexity 키 SecretRef가 해석되지 않고 환경 변수 폴백도 없으면 시작/리로드 시 즉시 실패합니다.

도구 파라미터

네이티브 Perplexity Search API 경로에 적용되는 파라미터입니다.

파라미터설명
query검색 쿼리 (필수)
count반환할 결과 수 (1-10, 기본값: 5)
country2자리 ISO 국가 코드 (예: “US”, “DE”)
languageISO 639-1 언어 코드 (예: “en”, “de”, “fr”)
freshness기간 필터: day (24시간), week, month, year
date_after해당 날짜 이후 게시된 결과만 (YYYY-MM-DD)
date_before해당 날짜 이전 게시된 결과만 (YYYY-MM-DD)
domain_filter도메인 허용/차단 목록 배열 (최대 20개)
max_tokens전체 콘텐츠 예산 (기본값: 25000, 최대: 1000000)
max_tokens_per_page페이지당 토큰 제한 (기본값: 2048)

레거시 Sonar/OpenRouter 호환 경로에서는 queryfreshness만 지원됩니다. Search API 전용 필터인 country, language, date_after, date_before, domain_filter, max_tokens, max_tokens_per_page는 명시적 오류를 반환합니다.

예시:

// 국가 및 언어별 검색
await web_search({
  query: "renewable energy",
  country: "DE",
  language: "de",
});

// 최근 결과 (지난 1주일)
await web_search({
  query: "AI news",
  freshness: "week",
});

// 날짜 범위 검색
await web_search({
  query: "AI developments",
  date_after: "2024-01-01",
  date_before: "2024-06-30",
});

// 도메인 필터링 (허용 목록)
await web_search({
  query: "climate research",
  domain_filter: ["nature.com", "science.org", ".edu"],
});

// 도메인 필터링 (차단 목록 - 접두사 -)
await web_search({
  query: "product reviews",
  domain_filter: ["-reddit.com", "-pinterest.com"],
});

// 더 많은 콘텐츠 추출
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 또는 명시적 baseUrl / model 설정은 Perplexity를 Sonar 채팅 완성 모드로 전환합니다(호환용).
  • 결과는 기본적으로 15분간 캐시됩니다(cacheTtlMinutes로 조정 가능).

전체 web_search 설정은 Web tools를 참고하세요. 자세한 내용은 Perplexity Search API 문서를 참고하세요.