Files
openclaw/extensions/firecrawl/web-search-shared.ts
Vincent Koc beea31a6b5 feat(firecrawl): add keyless scrape support (#94551)
Merged under maintainer approval while exact-head CI was queue-bound.

Co-authored-by: Developers Digest <124798203+developersdigest@users.noreply.github.com>
Co-authored-by: Vincent Koc <vincentkoc@users.noreply.github.com>
2026-06-19 00:23:41 +08:00

67 lines
2.2 KiB
TypeScript

// Firecrawl plugin module implements web search shared behavior.
import {
createWebSearchProviderContractFields,
enablePluginInConfig,
type WebSearchProviderPlugin,
} from "openclaw/plugin-sdk/provider-web-search-contract";
export const FIRECRAWL_CREDENTIAL_PATH = "plugins.entries.firecrawl.config.webSearch.apiKey";
export const FIRECRAWL_FETCH_CREDENTIAL_PATH = "plugins.entries.firecrawl.config.webFetch.apiKey";
export function getConfiguredFirecrawlFetchCredentialFallback(config?: {
plugins?: { entries?: { firecrawl?: { config?: unknown } } };
}) {
const apiKey = (
config?.plugins?.entries?.firecrawl?.config as { webFetch?: { apiKey?: unknown } } | undefined
)?.webFetch?.apiKey;
return apiKey === undefined
? undefined
: {
path: FIRECRAWL_FETCH_CREDENTIAL_PATH,
value: apiKey,
};
}
export function buildFirecrawlWebSearchProviderBase(): Omit<WebSearchProviderPlugin, "createTool"> {
const contractFields = createWebSearchProviderContractFields({
credentialPath: FIRECRAWL_CREDENTIAL_PATH,
searchCredential: { type: "scoped", scopeId: "firecrawl" },
configuredCredential: { pluginId: "firecrawl" },
});
return {
id: "firecrawl",
label: "Firecrawl Search",
hint: "Structured results with optional result scraping",
onboardingScopes: ["text-inference"],
credentialLabel: "Firecrawl API key",
envVars: ["FIRECRAWL_API_KEY"],
placeholder: "fc-...",
signupUrl: "https://www.firecrawl.dev/",
docsUrl: "https://docs.openclaw.ai/tools/firecrawl",
autoDetectOrder: 60,
credentialPath: FIRECRAWL_CREDENTIAL_PATH,
...contractFields,
applySelectionConfig: (config) => {
const enabled = enablePluginInConfig(config, "firecrawl");
if (!enabled.enabled || enabled.config.tools?.web?.fetch?.provider) {
return enabled.config;
}
return {
...enabled.config,
tools: {
...enabled.config.tools,
web: {
...enabled.config.tools?.web,
fetch: {
...enabled.config.tools?.web?.fetch,
provider: "firecrawl",
},
},
},
};
},
getConfiguredCredentialFallback: getConfiguredFirecrawlFetchCredentialFallback,
};
}