autocomplete caching

see 7dce8da850d2b266ffc196a9e9c0aa9ee9314fe3
This commit is contained in:
Daku 2016-06-18 13:19:25 +01:00
parent 2546621c59
commit 56e5348470

View File

@ -13,21 +13,28 @@ class AutoComplete extends Extension {
if(!isset($_GET["s"])) return; if(!isset($_GET["s"])) return;
//$limit = 0; //$limit = 0;
$cache_key = "autocomplete-" . strtolower($_GET["s"]);
$limitSQL = ""; $limitSQL = "";
$SQLarr = array("search"=>$_GET["s"]."%"); $SQLarr = array("search"=>$_GET["s"]."%");
if(isset($_GET["limit"]) && $_GET["limit"] !== 0){ if(isset($_GET["limit"]) && $_GET["limit"] !== 0){
$limitSQL = "LIMIT :limit"; $limitSQL = "LIMIT :limit";
$SQLarr['limit'] = $_GET["limit"]; $SQLarr['limit'] = $_GET["limit"];
$cache_key .= "-" . $_GET["limit"];
} }
$res = $database->get_pairs(" $res = null;
SELECT tag, count $database->cache->get($cache_key);
FROM tags if(!$res) {
WHERE tag LIKE :search $res = $database->get_pairs("
AND count > 0 SELECT tag, count
ORDER BY count DESC FROM tags
$limitSQL", $SQLarr WHERE tag LIKE :search
); AND count > 0
ORDER BY count DESC
$limitSQL", $SQLarr
);
$database->cache->set($cache_key, $res, 600);
}
$page->set_mode("data"); $page->set_mode("data");
$page->set_type("application/json"); $page->set_type("application/json");