Skip to main content
Glama

mcp-omnisearch

index.ts3.33 kB
import { http_json } from '../../../common/http.js'; import { BaseSearchParams, ErrorType, ProviderError, SearchProvider, SearchResult, } from '../../../common/types.js'; import { retry_with_backoff, sanitize_query, validate_api_key, } from '../../../common/utils.js'; import { config } from '../../../config/env.js'; interface ExaAnswerRequest { query: string; type?: string; livecrawl?: 'always' | 'fallback' | 'preferred'; includeDomains?: string[]; excludeDomains?: string[]; useAutoprompt?: boolean; } interface ExaAnswerResponse { answer: string; sources?: Array<{ id: string; title: string; url: string; text?: string; publishedDate?: string; author?: string; }>; requestId: string; } export class ExaAnswerProvider implements SearchProvider { name = 'exa_answer'; description = 'Get direct AI-generated answers to questions using Exa Answer API'; async search(params: BaseSearchParams): Promise<SearchResult[]> { const api_key = validate_api_key( config.ai_response.exa_answer.api_key, this.name, ); const search_request = async () => { try { const request_body: ExaAnswerRequest = { query: sanitize_query(params.query), type: 'auto', livecrawl: 'fallback', useAutoprompt: true, }; // Add domain filtering if provided if ( params.include_domains && params.include_domains.length > 0 ) { request_body.includeDomains = params.include_domains; } if ( params.exclude_domains && params.exclude_domains.length > 0 ) { request_body.excludeDomains = params.exclude_domains; } const data = await http_json<ExaAnswerResponse>( this.name, `${config.ai_response.exa_answer.base_url}/answer`, { method: 'POST', headers: { 'x-api-key': api_key, Authorization: `Bearer ${api_key}`, 'Content-Type': 'application/json', }, body: JSON.stringify(request_body), }, ); // Create a result with the AI answer and sources const results: SearchResult[] = [ { title: 'AI Answer', url: '', // No specific URL for AI-generated answers snippet: data.answer, score: 1.0, source_provider: this.name, metadata: { requestId: data.requestId, type: 'ai_answer', sources_count: data.sources?.length || 0, }, }, ]; // Add sources as additional results if they exist if (data.sources && data.sources.length > 0) { const source_results = data.sources.map( (source, index) => ({ title: source.title, url: source.url, snippet: source.text || 'Source reference', score: 0.9 - index * 0.1, source_provider: this.name, metadata: { id: source.id, author: source.author, publishedDate: source.publishedDate, type: 'source', requestId: data.requestId, }, }), ); results.push(...source_results); } return results; } catch (error) { if (error instanceof ProviderError) { throw error; } throw new ProviderError( ErrorType.API_ERROR, `Failed to fetch: ${ error instanceof Error ? error.message : 'Unknown error' }`, this.name, ); } }; return retry_with_backoff(search_request); } }

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/spences10/mcp-omnisearch'

If you have feedback or need assistance with the MCP directory API, please join our Discord server