Дело, было как обычно вечером :) И лежало на мне уже давно задание — добавить «похожие темы» к проекту, но ввиду приоритетов откладывалось оно на потом постоянно. Полазил по LS, нашел уже готовый бесплатный модуль:
livestreet.ru/blog/2053.html
Но незадача :( нужен fulltext для InnoDB… уже хотел похерить задание и отложить опять до лучших времен, но что-то дернуло меня все-таки покопаться чуток. А именно, вспомнил я про уже готовый fulltext поиск реализованный на sphinx'e в дефолтной сборке LS. Там как раз есть тайтл + текст, так что впринципе больше и не надо :)
В общем, пришлось чуток модифицировать имеющийся модуль + добавить ф-цию в Sphinx.class.php
К действиям:
1) берем имеющийся модуль
2) удаляем папку и ее содержимое
/classes/modules/similartopics/mapper
3) заменяем полностью содержимое файла(
/classes/modules/similartopics/SimilarTopics.class.php) на:
<?php
##### [hack] similar_topics_sphinx #####
class LsSimilarTopics extends Module {
public function Init() {
}
public function GetSimilarTopics($oTopic){
$sTitleTags=$oTopic->getTags();
$aTopics=array();
$data=$this->Sphinx_FindSimilarTopics($sTitleTags,SIMILARTOPICS_COUNT+1);
if(is_array($data['matches']) && sizeof($data['matches'])>0){
foreach($data['matches'] as $k=>$v) if($k!=$oTopic->getId()) $aTopics[]=$this->Topic_GetTopicById($k);
return $aTopics;
}else return false;
}
}
##### [hack] similar_topics_sphinx #####
?>
4) добавляем в класс(
classes/modules/sphinx/Sphinx.class.php):
##### [hack] SimilarTopics #####
public function FindSimilarTopics($sTerms,$iLimit){
$cacheKey=SEARCH_ENTITY_PREFIX."similartopics_{$sTerms}_{$iLimit}";
if(false===($data=$this->Cache_Get($cacheKey))){
$this->oSphinx->SetMatchMode(SPH_MATCH_ANY);
$this->oSphinx->SetLimits(0,$iLimit);
if(!is_array($data=$this->oSphinx->Query($sTerms,SEARCH_ENTITY_PREFIX.'topicsIndex'))) return FALSE;
# no results = no cache
if($data['total']>0) $this->Cache_Set($data,$cacheKey,array(),60*15);
}
return $data;
}
##### [hack] SimilarTopics #####
лично я оставил поиск по тэгам, хотя — можете добавить и по тайтлу, как было первоначально в плагине
5) все, радуемся жизни :)
п.с. должен быть настроен уже sphinx и работать поиск через sphinx
п.п.с. делаем на свой страх и риск, так что не забываем о том что надо бэкапить файлы ;)