$s) { if (strlen($s) > 2) $astr[$k] = sprintf("%u", crc32($s)); else unset($astr[$k]); } return $astr; } // str = long text function ftsearch_split(&$str, $simple) { global $ftsearch_ignores; // interpunktion $str = mb_ereg_replace('\\?', ' ', $str); $str = mb_ereg_replace('\\)', ' ', $str); $str = mb_ereg_replace('\\(', ' ', $str); $str = mb_ereg_replace('\\.', ' ', $str); $str = mb_ereg_replace('´', ' ', $str); $str = mb_ereg_replace('`', ' ', $str); $str = mb_ereg_replace('\'', ' ', $str); $str = mb_ereg_replace('/', ' ', $str); $str = mb_ereg_replace(':', ' ', $str); $str = mb_ereg_replace(',', ' ', $str); $str = mb_ereg_replace("\r\n", ' ', $str); $str = mb_ereg_replace("\n", ' ', $str); $str = mb_ereg_replace("\r", ' ', $str); $ostr = ''; while ($ostr != $str) { $ostr = $str; $str = mb_ereg_replace(' ', ' ', $str); } $astr = mb_split(' ', $str); $str = ''; ftsearch_load_ignores(); for ($i = count($astr) - 1; $i >= 0; $i--) { // ignore? if (array_search(mb_strtolower($astr[$i]), $ftsearch_ignores) !== false) unset($astr[$i]); else { if ($simple) $astr[$i] = ftsearch_text2simple($astr[$i]); if ($astr[$i] == '') unset($astr[$i]); } } return $astr; } function ftsearch_load_ignores() { global $ftsearch_ignores; global $ftsearch_ignores_loaded; if ($ftsearch_ignores_loaded != true) { $ftsearch_ignores = array(); $rs = sql('SELECT `word` FROM `search_ignore`'); while ($r = sql_fetch_assoc($rs)) $ftsearch_ignores[] = $r['word']; sql_free_result($rs); $ftsearch_ignores_loaded = true; } } // str = single word function ftsearch_text2simple($str) { global $ftsearch_simplerules; $str = ftsearch_text2sort($str); // regeln anwenden foreach ($ftsearch_simplerules AS $rule) { $str = mb_ereg_replace($rule[0], $rule[1], $str); } // doppelte chars ersetzen for ($c = ord('a'); $c <= ord('z'); $c++) { $old_str = ''; while ($old_str != $str) { $old_str = $str; $str = mb_ereg_replace(chr($c) . chr($c), chr($c), $str); } $old_str = ''; } return $str; } // str = single word function ftsearch_text2sort($str) { $str = mb_strtolower($str); // deutsches $str = mb_ereg_replace('ä', 'ae', $str); $str = mb_ereg_replace('ö', 'oe', $str); $str = mb_ereg_replace('ü', 'ue', $str); $str = mb_ereg_replace('Ä', 'ae', $str); $str = mb_ereg_replace('Ö', 'oe', $str); $str = mb_ereg_replace('Ü', 'ue', $str); $str = mb_ereg_replace('ß', 'ss', $str); // akzente usw. $str = mb_ereg_replace('à', 'a', $str); $str = mb_ereg_replace('á', 'a', $str); $str = mb_ereg_replace('â', 'a', $str); $str = mb_ereg_replace('è', 'e', $str); $str = mb_ereg_replace('é', 'e', $str); $str = mb_ereg_replace('ë', 'e', $str); $str = mb_ereg_replace('É', 'e', $str); $str = mb_ereg_replace('ô', 'o', $str); $str = mb_ereg_replace('ó', 'o', $str); $str = mb_ereg_replace('ò', 'o', $str); $str = mb_ereg_replace('ê', 'e', $str); $str = mb_ereg_replace('ě', 'e', $str); $str = mb_ereg_replace('û', 'u', $str); $str = mb_ereg_replace('ç', 'c', $str); $str = mb_ereg_replace('c', 'c', $str); $str = mb_ereg_replace('ć', 'c', $str); $str = mb_ereg_replace('î', 'i', $str); $str = mb_ereg_replace('ï', 'i', $str); $str = mb_ereg_replace('ì', 'i', $str); $str = mb_ereg_replace('í', 'i', $str); $str = mb_ereg_replace('ł', 'l', $str); $str = mb_ereg_replace('š', 's', $str); $str = mb_ereg_replace('Š', 's', $str); $str = mb_ereg_replace('u', 'u', $str); $str = mb_ereg_replace('ý', 'y', $str); $str = mb_ereg_replace('ž', 'z', $str); $str = mb_ereg_replace('Ž', 'Z', $str); $str = mb_ereg_replace('Æ', 'ae', $str); $str = mb_ereg_replace('æ', 'ae', $str); $str = mb_ereg_replace('œ', 'oe', $str); // sonstiges $str = mb_ereg_replace('[^A-Za-z ]', '', $str); return $str; } function ftsearch_refresh() { ftsearch_refresh_all_caches(); ftsearch_refresh_all_cache_desc(); ftsearch_refresh_all_pictures(); ftsearch_refresh_all_cache_logs(); } function ftsearch_refresh_all_caches() { $rs = sql('SELECT `caches`.`cache_id` FROM `caches` LEFT JOIN `search_index_times` ON `caches`.`cache_id`=`search_index_times`.`object_id` AND 2=`search_index_times`.`object_type` WHERE `caches`.`status`!=5 AND ISNULL(`search_index_times`.`object_id`) UNION DISTINCT SELECT `caches`.`cache_id` FROM `caches` INNER JOIN `search_index_times` ON `search_index_times`.`object_type`=2 AND `caches`.`cache_id`=`search_index_times`.`object_id` WHERE `caches`.`last_modified`>`search_index_times`.`last_refresh` AND `caches`.`status`!=5'); while ($r = sql_fetch_assoc($rs)) ftsearch_refresh_cache($r['cache_id']); sql_free_result($rs); } function ftsearch_refresh_cache($cache_id) { $rs = sql("SELECT `name`, `last_modified` FROM `caches` WHERE `cache_id`='&1'", $cache_id); if ($r = sql_fetch_assoc($rs)) { ftsearch_set_entries(2, $cache_id, $cache_id, $r['name'], $r['last_modified']); } sql_free_result($rs); } function ftsearch_refresh_all_cache_desc() { $rs = sql('SELECT `cache_desc`.`id` FROM `cache_desc` INNER JOIN `caches` ON `caches`.`cache_id`=`cache_desc`.`cache_id` LEFT JOIN `search_index_times` ON `cache_desc`.`id`=`search_index_times`.`object_id` AND 3=`search_index_times`.`object_type` WHERE `caches`.`status`!=5 AND ISNULL(`search_index_times`.`object_id`) UNION DISTINCT SELECT `cache_desc`.`id` FROM `cache_desc` INNER JOIN `caches` ON `caches`.`cache_id`=`cache_desc`.`cache_id` INNER JOIN `search_index_times` ON `search_index_times`.`object_type`=3 AND `cache_desc`.`id`=`search_index_times`.`object_id` WHERE `cache_desc`.`last_modified`>`search_index_times`.`last_refresh` AND `caches`.`status`!=5'); while ($r = sql_fetch_assoc($rs)) ftsearch_refresh_cache_desc($r['id']); sql_free_result($rs); } function ftsearch_refresh_cache_desc($id) { $rs = sql("SELECT `cache_id`, `desc`, `last_modified` FROM `cache_desc` WHERE `id`='&1'", $id); if ($r = sql_fetch_assoc($rs)) { $r['desc'] = ftsearch_strip_html($r['desc']); ftsearch_set_entries(3, $id, $r['cache_id'], $r['desc'], $r['last_modified']); } sql_free_result($rs); } function ftsearch_refresh_all_pictures() { $rs = sql('SELECT `pictures`.`id` FROM `pictures` LEFT JOIN `search_index_times` ON `pictures`.`id`=`search_index_times`.`object_id` AND 6=`search_index_times`.`object_type` WHERE ISNULL(`search_index_times`.`object_id`) UNION DISTINCT SELECT `pictures`.`id` FROM `pictures` INNER JOIN `search_index_times` ON `search_index_times`.`object_type`=6 AND `pictures`.`id`=`search_index_times`.`object_id` WHERE `pictures`.`last_modified`>`search_index_times`.`last_refresh`'); while ($r = sql_fetch_assoc($rs)) ftsearch_refresh_picture($r['id']); sql_free_result($rs); } function ftsearch_refresh_picture($id) { $rs = sql("SELECT `caches`.`cache_id`, `pictures`.`title`, `pictures`.`last_modified` FROM `pictures` INNER JOIN `caches` ON `pictures`.`object_type`=2 AND `caches`.`cache_id`=`pictures`.`object_id` WHERE `pictures`.`id`='&1' UNION DISTINCT SELECT `cache_logs`.`cache_id` , `pictures`.`title`, `pictures`.`last_modified` FROM `pictures` INNER JOIN `cache_logs` ON `pictures`.`object_type`=1 AND `cache_logs`.`id`=`pictures`.`object_id` WHERE `pictures`.`id`='&1' LIMIT 1", $id); if ($r = sql_fetch_assoc($rs)) { ftsearch_set_entries(6, $id, $r['cache_id'], $r['title'], $r['last_modified']); } sql_free_result($rs); } function ftsearch_refresh_all_cache_logs() { $rs = sql('SELECT `cache_logs`.`id` FROM `cache_logs` LEFT JOIN `search_index_times` ON `cache_logs`.`id`=`search_index_times`.`object_id` AND 1=`search_index_times`.`object_type` WHERE ISNULL(`search_index_times`.`object_id`) UNION DISTINCT SELECT `cache_logs`.`id` FROM `cache_logs` INNER JOIN `search_index_times` ON `search_index_times`.`object_type`=1 AND `cache_logs`.`id`=`search_index_times`.`object_id` WHERE `cache_logs`.`last_modified`>`search_index_times`.`last_refresh`'); while ($r = sql_fetch_assoc($rs)) ftsearch_refresh_cache_logs($r['id']); sql_free_result($rs); } function ftsearch_refresh_cache_logs($id) { $rs = sql("SELECT `cache_id`, `text`, `last_modified` FROM `cache_logs` WHERE `id`='&1'", $id); if ($r = sql_fetch_assoc($rs)) { $r['text'] = ftsearch_strip_html($r['text']); ftsearch_set_entries(1, $id, $r['cache_id'], $r['text'], $r['last_modified']); } sql_free_result($rs); } function ftsearch_delete_entries($object_type, $object_id, $cache_id) { sql("DELETE FROM `search_index` WHERE `object_type`='&1' AND `cache_id`='&2'", $object_type, $cache_id); sql("DELETE FROM `search_index_times` WHERE `object_type`='&1' AND `object_id`='&2'", $object_type, $object_id); } function ftsearch_set_entries($object_type, $object_id, $cache_id, &$text, $last_modified) { ftsearch_delete_entries($object_type, $object_id, $cache_id); $ahash = ftsearch_hash($text); foreach ($ahash AS $k => $h) { sql("INSERT INTO `search_index` (`object_type`, `cache_id`, `hash`, `count`) VALUES ('&1', '&2', '&3', '&4') ON DUPLICATE KEY UPDATE `count`=`count`+1", $object_type, $cache_id, $h, 1); } sql("INSERT INTO `search_index_times` (`object_id`, `object_type`, `last_refresh`) VALUES ('&1', '&2', '&3') ON DUPLICATE KEY UPDATE `last_refresh`='&3'", $object_id, $object_type, $last_modified); } function ftsearch_strip_html($text) { $text = str_replace("\n", ' ', $text); $text = str_replace("\r", ' ', $text); $text = str_replace('
', ' ', $text); $text = str_replace('
', ' ', $text); $text = str_replace('
', ' ', $text); $text = strip_tags($text); $text = html_entity_decode($text, ENT_COMPAT, 'UTF-8'); return $text; } ?>