From 0bd6f7645159095be3a39e01888eab116b397883 Mon Sep 17 00:00:00 2001 From: millette Date: Thu, 20 Nov 2008 16:13:47 -0500 Subject: [PATCH] sphinx search of people darcs-hash:20081120211347-099f7-d5588788dcd9a16cf72ece59da3d2bf9b8171b85.gz --- actions/peoplesearch.php | 12 +++---- classes/Profile.php | 15 +++++++++ classes/SearchEngines.php | 71 +++++++++++++++++++++++++++++++++++++++ lib/common.php | 4 +++ 4 files changed, 94 insertions(+), 8 deletions(-) create mode 100644 classes/SearchEngines.php diff --git a/actions/peoplesearch.php b/actions/peoplesearch.php index 6b03169a02..d493c76678 100644 --- a/actions/peoplesearch.php +++ b/actions/peoplesearch.php @@ -40,16 +40,12 @@ class PeoplesearchAction extends SearchAction { # lcase it for comparison $q = strtolower($q); - if(common_config('db','type')=='mysql') { - $profile->whereAdd('MATCH(nickname, fullname, location, bio, homepage) ' . - 'against (\''.addslashes($q).'\')'); - } else { - $profile->whereAdd('textsearch @@ plainto_tsquery(\''.addslashes($q).'\')'); - } + $search_engine = $profile->getSearchEngine(); - # Ask for an extra to see if there's more. + $search_engine->query($q); - $profile->limit((($page-1)*PROFILES_PER_PAGE), PROFILES_PER_PAGE + 1); + # Ask for an extra to see if there's more. + $search_engine->limit((($page-1)*PROFILES_PER_PAGE), PROFILES_PER_PAGE + 1); $cnt = $profile->find(); diff --git a/classes/Profile.php b/classes/Profile.php index 794dc1de93..9de92ec4bc 100644 --- a/classes/Profile.php +++ b/classes/Profile.php @@ -46,6 +46,21 @@ class Profile extends Memcached_DataObject /* the code above is auto generated do not remove the tag below */ ###END_AUTOCODE + function getSearchEngine() { + require_once INSTALLDIR.'/classes/SearchEngines.php'; + static $search_engine; + if (!isset($search_engine)) { + if (common_config('sphinx', 'enabled')) { + $search_engine = new SphinxSearch($this); + } elseif ('mysql' === common_config('db', 'type')) { + $search_engine = new MySQLSearch($this); + } else { + $search_engine = new PGSearch($this); + } + } + return $search_engine; + } + function getAvatar($width, $height=NULL) { if (is_null($height)) { $height = $width; diff --git a/classes/SearchEngines.php b/classes/SearchEngines.php new file mode 100644 index 0000000000..e5f4e14ea7 --- /dev/null +++ b/classes/SearchEngines.php @@ -0,0 +1,71 @@ +. + */ + +if (!defined('LACONICA')) { exit(1); } + +class SearchEngine { + protected $profile; + + function __construct($profile) { + $this->profile = $profile; + } + + function query($q) { + } + + function limit($offset, $count) { + return $this->profile->limit($offset, $count); + } +} + +class SphinxSearch extends SearchEngine { + private $sphinx; + + function __construct($profile) { + parent::__construct($profile); + $this->sphinx = new SphinxClient; + $this->sphinx->setServer(common_config('sphinx', 'server'), common_config('sphinx', 'port')); + } + + function limit($offset, $count) { + $this->sphinx->setLimits($offset, $count); + $this->profile->limit($offset, $count); + } + + function query($q) { + $result = $this->sphinx->query($q); + if (!isset($result['matches'])) return false; + $id_set = join(', ', array_keys($result['matches'])); + return $this->profile->whereAdd("id in ($id_set)"); + } +} + +class MySQLSearch extends SearchEngine { + function query($q) { + return $this->profile->whereAdd('MATCH(nickname, fullname, location, bio, homepage) ' . + 'against (\''.addslashes($q).'\')'); + } +} + +class PGSearch extends SearchEngine { + function query($q) { + $this->profile->whereAdd('textsearch @@ plainto_tsquery(\''.addslashes($q).'\')'); + } +} + diff --git a/lib/common.php b/lib/common.php index def1833753..acea1252cc 100644 --- a/lib/common.php +++ b/lib/common.php @@ -102,6 +102,10 @@ $config = 'host' => NULL, # only set if != server 'debug' => false, # print extra debug info 'public' => array()), # JIDs of users who want to receive the public stream + 'sphinx' => + array('enabled' => false, + 'server' => 'localhost', + 'port' => 3312), 'tag' => array('dropoff' => 864000.0), 'daemon' => -- 2.39.5