Perplexity Search API

OpenClaw 支持将 Perplexity Search API 用作 web_search 提供商。 它返回结构化结果,包含 titleurlsnippet 字段。

为了兼容旧配置,OpenClaw 也支持 Perplexity Sonar/OpenRouter 的传统用法。 如果你使用 OPENROUTER_API_KEY、在 tools.web.search.perplexity.apiKey 中填入 sk-or-... 开头的密钥,或设置了 tools.web.search.perplexity.baseUrl / model,提供商会切换到 chat-completions 路径,返回带引用的 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.apiKey 中填入 sk-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_KEYOPENROUTER_API_KEY。对于 Gateway 安装,放在 ~/.openclaw/.env 中(或你的服务环境中)。详见环境变量

如果配置了 provider: "perplexity" 但 Perplexity 密钥的 SecretRef 无法解析且没有环境变量兜底,启动/重载会立即报错。

工具参数

以下参数适用于原生 Perplexity Search API 路径。

参数说明
query搜索关键词(必填)
count返回结果数量(1-10,默认 5)
country两位 ISO 国家代码(如 “US”、“DE”)
languageISO 639-1 语言代码(如 “en”、“de”、“fr”)
freshness时间过滤:day(24 小时)、weekmonthyear
date_after仅返回此日期之后发布的结果(YYYY-MM-DD)
date_before仅返回此日期之前发布的结果(YYYY-MM-DD)
domain_filter域名白名单/黑名单数组(最多 20 个)
max_tokens内容总 token 预算(默认 25000,上限 1000000)
max_tokens_per_page每页 token 上限(默认 2048)

对于旧版 Sonar/OpenRouter 兼容路径,仅支持 queryfreshness。Search API 专有的过滤参数如 countrylanguagedate_afterdate_beforedomain_filtermax_tokensmax_tokens_per_page 会返回明确的错误。

示例:

// 按国家和语言搜索
await web_search({
  query: "renewable energy",
  country: "DE",
  language: "de",
});

// 最近结果(过去一周)
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 返回结构化网页搜索结果(titleurlsnippet
  • 使用 OpenRouter 或显式设置 baseUrl / model 会让 Perplexity 切回 Sonar chat completions 模式,以保持兼容
  • 结果默认缓存 15 分钟(可通过 cacheTtlMinutes 调整)

完整的 web_search 配置详见 Web 工具。 更多细节参阅 Perplexity Search API 文档