
- NOTICE: config.default.php has changed, re-create your config.php!! - [fix] No longer caches empty results - [fix] No longer make a request if the search query is empty - [fix] Movie highlight/box office cache now works - [fix] Language selector for Qwant, Wikipedia and Duckduckgo - [fix] Season and Episode filter for tv show searches - [fix] Safe search filter now actually works - [fix] Magnet Search category exclusion filter now actually works - [fix] Image size filter works more reliably - [fix] Handling of doublequotes in search queries - [fix] Search sources now show result amounts accurately - [fix] Old cache files are now actually deleted when expired - [fix] Search tabs not properly centered on smaller screens - [new] Box Office page with latest/new downloads from a few supported torrent websites - [new] News page with the latest news from major outlets - [new] Popup with movie info and download links for YTS Movie Highlights - [new] CSS colorschemes configurable in config.php - [new] Easily share magnet links with other Goosle users - [new] Search results from Quant API - [new] Search results from Brave - [new] Image results from Qwant Image API - [new] News results from Hackernews - [new] News results from Yahoo! News - [new] News results from Brave News - [new] News results from Qwant News API - [new] Magnet results from Sukebei.nyaa.si - [new] Special search for IP Lookups via ipify (Search for "ip" or "myip") - [new] Safe search switch for Yahoo! Images - [new] Image size switch for Qwant Images - [new] Merge missing magnet meta data from duplicate results if it doesn't already exist in the matched previous result - [new] Detect meta data for Magnet Search results such as sound and video quality. - [tweak] Cache ttl is now in hours (was minutes) - [tweak] Optimizations in CSS, HTML separators and more - [tweak] Moved icons into CSS so they can be colored using colorschemes - [tweak] Better handling of image results - [tweak] Better handling of empty/incomplete results for all engines - [tweak] Better handling of empty/missing meta data for all magnet engines - [tweak] Better category detection for Limetorrent magnets - [tweak] Raised Magnet search limit to 200 (was 50) - [tweak] Raised Wikipedia search limit to 20 (was 10) - [tweak] Hide magnet results with 0 seeders by default - [tweak] Uniform array formatting for all engines - [tweak] Consistent use of single-quotes and double-qoutes - [tweak] File size string conversion and formatting for all image and magnet engines - [tweak] Update checks are now done weekly(ish) via the Cron job - [tweak] Updated .htaccess caching rules - [removed] CSS for 320px viewport
95 lines
2.9 KiB
PHP
95 lines
2.9 KiB
PHP
<?php
|
|
/* ------------------------------------------------------------------------------------
|
|
* Goosle - The fast, privacy oriented search tool that just works.
|
|
*
|
|
* COPYRIGHT NOTICE
|
|
* Copyright 2023-2024 Arnan de Gans. All Rights Reserved.
|
|
*
|
|
* COPYRIGHT NOTICES AND ALL THE COMMENTS SHOULD REMAIN INTACT.
|
|
* By using this code you agree to indemnify Arnan de Gans from any
|
|
* liability that might arise from its use.
|
|
------------------------------------------------------------------------------------ */
|
|
class DefinitionRequest extends EngineRequest {
|
|
public function get_request_url() {
|
|
$query = str_replace('%22', '\"', $this->query);
|
|
$query_terms = explode(' ', $query);
|
|
|
|
// [0] = (define|d|mean|meaning)
|
|
// [1] = WORD
|
|
|
|
// Is there no query left? Bail!
|
|
if(empty($query)) return false;
|
|
|
|
$url = 'https://api.dictionaryapi.dev/api/v2/entries/en/'.$query_terms[1];
|
|
|
|
unset($query, $query_terms);
|
|
|
|
return $url;
|
|
}
|
|
|
|
public function get_request_headers() {
|
|
return array(
|
|
'Accept' => 'application/json, */*;q=0.8',
|
|
'Accept-Language' => null,
|
|
'Accept-Encoding' => null,
|
|
'Sec-Fetch-Dest' => null,
|
|
'Sec-Fetch-Mode' => null,
|
|
'Sec-Fetch-Site' => null
|
|
);
|
|
}
|
|
|
|
public function parse_results($response) {
|
|
$engine_result = array();
|
|
$json_response = json_decode($response, true);
|
|
|
|
// No response
|
|
if(empty($json_response)) return $engine_result;
|
|
|
|
// No results
|
|
if(array_key_exists('title', $json_response)) return $engine_result;
|
|
|
|
// Grab first result if there are multiple
|
|
$result = $json_response[0];
|
|
|
|
// Find a phonetic spelling
|
|
if(isset($result['phonetic'])) {
|
|
$phonetic = $result['phonetic'];
|
|
} else if(isset($result['phonetics'])) {
|
|
$phonetic = array_column($result['phonetics'], 'text');
|
|
$phonetic = (count($phonetic) > 0) ? $phonetic[0] : $result['word'];
|
|
} else {
|
|
$phonetic = $result['word'];
|
|
}
|
|
|
|
// List definitions
|
|
$formatted_response = "";
|
|
foreach($result['meanings'] as $meaning) {
|
|
$formatted_response .= "<p>".sanitize($meaning['partOfSpeech'])."</p>";
|
|
$definitions = array_slice($meaning['definitions'], 0, 3);
|
|
|
|
$formatted_response .= "<ol class=\"word-definitions\">";
|
|
foreach($definitions as $definition) {
|
|
$formatted_response .= "<li>";
|
|
$formatted_response .= " ".sanitize($definition['definition']);
|
|
$formatted_response .= (array_key_exists("example", $definition)) ? " <br /><small><strong>Example:</strong> ".sanitize($definition['example'])."</small>" : "";
|
|
$formatted_response .= "</li>";
|
|
|
|
unset($definition);
|
|
}
|
|
$formatted_response .= "</ol>";
|
|
|
|
unset($meaning);
|
|
}
|
|
|
|
$engine_result = array(
|
|
'title' => "Definition for: ".sanitize($result['word'])." <span>[".sanitize($phonetic)."]</span>",
|
|
'text' => $formatted_response,
|
|
'source' => sanitize($result['sourceUrls'][0])
|
|
);
|
|
|
|
unset($response, $json_response, $result, $phonetic, $definitions, $formatted_response);
|
|
|
|
return $engine_result;
|
|
}
|
|
}
|
|
?>
|