Perplexica/src/lib/searxng.ts

66 lines
1.6 KiB
TypeScript
Raw Normal View History

2024-04-09 16:21:05 +05:30
import axios from 'axios';
2025-03-19 16:23:27 +05:30
import { getSearxngApiEndpoint } from './config';
2024-04-09 16:21:05 +05:30
interface SearxngSearchOptions {
categories?: string[];
engines?: string[];
language?: string;
pageno?: number;
}
interface SearxngSearchResult {
title: string;
url: string;
img_src?: string;
thumbnail_src?: string;
2024-04-30 14:31:32 +05:30
thumbnail?: string;
2024-04-09 16:21:05 +05:30
content?: string;
author?: string;
2024-04-30 14:31:32 +05:30
iframe_src?: string;
2024-04-09 16:21:05 +05:30
}
interface SearxngResponse {
results: SearxngSearchResult[];
suggestions: string[];
searchUrl: string;
}
2024-04-09 16:21:05 +05:30
export const searchSearxng = async (
query: string,
opts?: SearxngSearchOptions,
) => {
2024-04-20 09:32:19 +05:30
const searxngURL = getSearxngApiEndpoint();
const url = new URL(`${searxngURL}/search?format=json`);
2024-04-09 16:21:05 +05:30
url.searchParams.append('q', query);
if (opts) {
Object.keys(opts).forEach((key) => {
2025-03-19 16:23:27 +05:30
const value = opts[key as keyof SearxngSearchOptions];
if (Array.isArray(value)) {
url.searchParams.append(key, value.join(','));
2024-04-09 16:21:05 +05:30
return;
}
2025-03-19 16:23:27 +05:30
url.searchParams.append(key, value as string);
2024-04-09 16:21:05 +05:30
});
}
const res = await axios.get(url.toString());
const results: SearxngSearchResult[] = res.data.results;
const suggestions: string[] = res.data.suggestions;
// Create a URL for viewing the search results in the SearXNG web interface
const searchUrl = new URL(searxngURL);
searchUrl.pathname = '/search';
searchUrl.searchParams.append('q', query);
if (opts?.engines?.length) {
searchUrl.searchParams.append('engines', opts.engines.join(','));
}
if (opts?.language) {
searchUrl.searchParams.append('language', opts.language);
}
return { results, suggestions, searchUrl: searchUrl.toString() };
2024-04-09 16:21:05 +05:30
};