Tools
بحث Perplexity
يدعم OpenClaw واجهة Perplexity Search API كموفّر web_search.
وتُرجع نتائج منظمة تحتوي على حقول title وurl وsnippet.
لأغراض التوافق، يدعم OpenClaw أيضًا إعدادات Perplexity Sonar/OpenRouter القديمة.
إذا كنت تستخدم OPENROUTER_API_KEY، أو مفتاحًا بصيغة sk-or-... في plugins.entries.perplexity.config.webSearch.apiKey، أو تضبط plugins.entries.perplexity.config.webSearch.baseUrl / model، فسيتحوّل الموفّر إلى مسار إكمالات المحادثة ويُرجع إجابات مصاغة بالذكاء الاصطناعي مع استشهادات بدلًا من نتائج Search API المنظمة.
تثبيت Plugin
ثبّت Plugin الرسمي، ثم أعد تشغيل Gateway:
openclaw plugins install @openclaw/perplexity-pluginopenclaw gateway restartالحصول على مفتاح Perplexity API
- أنشئ حساب Perplexity على perplexity.ai/settings/api
- أنشئ مفتاح API في لوحة التحكم
- خزّن المفتاح في الإعدادات أو اضبط
PERPLEXITY_API_KEYفي بيئة Gateway.
التوافق مع OpenRouter
إذا كنت تستخدم OpenRouter بالفعل مع Perplexity Sonar، فأبقِ provider: "perplexity" واضبط OPENROUTER_API_KEY في بيئة Gateway، أو خزّن مفتاحًا بصيغة sk-or-... في plugins.entries.perplexity.config.webSearch.apiKey.
عناصر تحكم اختيارية للتوافق:
plugins.entries.perplexity.config.webSearch.baseUrlplugins.entries.perplexity.config.webSearch.model
أمثلة الإعدادات
واجهة 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", }, }, },}مكان ضبط المفتاح
عبر الإعدادات: شغّل openclaw configure --section web. سيخزّن المفتاح في
~/.openclaw/openclaw.json ضمن plugins.entries.perplexity.config.webSearch.apiKey.
يقبل هذا الحقل أيضًا كائنات SecretRef.
عبر البيئة: اضبط PERPLEXITY_API_KEY أو OPENROUTER_API_KEY
في بيئة عملية Gateway. بالنسبة إلى تثبيت Gateway، ضعه في
~/.openclaw/.env (أو بيئة خدمتك). راجع متغيرات البيئة.
إذا كان provider: "perplexity" مضبوطًا وكان SecretRef الخاص بمفتاح Perplexity غير محلول ولا يوجد بديل من البيئة، فسيفشل بدء التشغيل/إعادة التحميل بسرعة.
معاملات الأداة
تنطبق هذه المعاملات على مسار Perplexity Search API الأصلي.
querystringrequiredاستعلام البحث.
countnumberdefault: 5عدد النتائج المراد إرجاعها (1-10).
countrystringرمز بلد 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- المرشحات الخاصة بـ Search API فقط مثل
countryوlanguageوdate_afterوdate_beforeوdomain_filterوmax_tokensوmax_tokens_per_pageتُرجع أخطاء صريحة
أمثلة:
// 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 لأغراض التوافق - يُرجع توافق Sonar/OpenRouter إجابة واحدة مصاغة مع استشهادات، وليس صفوف نتائج منظمة
- تُخزّن النتائج مؤقتًا لمدة 15 دقيقة افتراضيًا (قابل للضبط عبر
cacheTtlMinutes)