2024-06-08 23:06:56 +02:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"net/http"
|
|
|
|
"net/url"
|
2024-06-14 17:56:20 +02:00
|
|
|
"time"
|
2024-06-08 23:06:56 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const LIBREX_DOMAIN = "librex.antopie.org"
|
|
|
|
|
|
|
|
type LibreXResult struct {
|
|
|
|
Title string `json:"title"`
|
|
|
|
URL string `json:"url"`
|
|
|
|
Description string `json:"description"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type LibreXResponse []LibreXResult
|
|
|
|
|
2024-06-14 17:56:20 +02:00
|
|
|
func PerformLibreXTextSearch(query, safe, lang string, page int) ([]TextSearchResult, time.Duration, error) {
|
|
|
|
startTime := time.Now() // Start the timer
|
2024-06-14 09:23:14 +02:00
|
|
|
|
|
|
|
// LibreX/Y uses offset instead of page that starts at 0
|
|
|
|
page--
|
|
|
|
page = page * 10
|
|
|
|
|
2024-06-09 21:44:49 +02:00
|
|
|
searchURL := fmt.Sprintf("https://%s/api.php?q=%s&p=%d&t=0", LIBREX_DOMAIN, url.QueryEscape(query), page)
|
2024-06-08 23:06:56 +02:00
|
|
|
|
|
|
|
// User Agent generation
|
|
|
|
userAgent, err := GetUserAgent("librex-text-search")
|
|
|
|
if err != nil {
|
2024-06-14 17:56:20 +02:00
|
|
|
return nil, 0, err
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if debugMode {
|
|
|
|
log.Println("Generated User Agent (text):", userAgent)
|
|
|
|
}
|
|
|
|
|
|
|
|
req, err := http.NewRequest("GET", searchURL, nil)
|
|
|
|
if err != nil {
|
2024-06-14 17:56:20 +02:00
|
|
|
return nil, 0, err
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
req.Header.Set("User-Agent", userAgent)
|
|
|
|
|
|
|
|
client := &http.Client{}
|
|
|
|
resp, err := client.Do(req)
|
|
|
|
if err != nil {
|
2024-06-14 17:56:20 +02:00
|
|
|
return nil, 0, logError("error making request to LibreX", err)
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
defer resp.Body.Close()
|
|
|
|
|
|
|
|
if resp.StatusCode != http.StatusOK {
|
2024-06-14 17:56:20 +02:00
|
|
|
return nil, 0, logError("unexpected status code", fmt.Errorf("%d", resp.StatusCode))
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var librexResp LibreXResponse
|
|
|
|
if err := json.NewDecoder(resp.Body).Decode(&librexResp); err != nil {
|
2024-06-14 17:56:20 +02:00
|
|
|
return nil, 0, logError("error decoding LibreX response", err)
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var results []TextSearchResult
|
|
|
|
for _, item := range librexResp {
|
|
|
|
result := TextSearchResult{
|
|
|
|
URL: item.URL,
|
|
|
|
Header: item.Title,
|
|
|
|
Description: item.Description,
|
|
|
|
Source: "LibreX",
|
|
|
|
}
|
|
|
|
|
|
|
|
results = append(results, result)
|
|
|
|
}
|
|
|
|
|
2024-06-14 17:56:20 +02:00
|
|
|
duration := time.Since(startTime) // Calculate the duration
|
|
|
|
|
|
|
|
return results, duration, nil
|
2024-06-08 23:06:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func logError(message string, err error) error {
|
|
|
|
log.Printf("%s: %v", message, err)
|
|
|
|
return fmt.Errorf("%s: %w", message, err)
|
|
|
|
}
|