tag -> search stuff: basic search subscription implementation in SearchSub

This commit is contained in:
Brion Vibber 2011-03-15 15:34:06 -07:00
parent 08b430a247
commit 341bef5e01

View File

@ -139,7 +139,17 @@ class SearchSubPlugin extends Plugin
*/ */
function onStartNoticeWhoGets(Notice $notice, array &$ni) function onStartNoticeWhoGets(Notice $notice, array &$ni)
{ {
foreach ($notice->getTags() as $search) { // Warning: this is potentially very slow
// with a lot of searches!
$sub = new SearchSub();
$sub->groupBy('search');
$sub->find();
while ($sub->fetch()) {
$search = $sub->search;
if ($this->matchSearch($notice, $search)) {
// Match? Find all those who subscribed to this
// search term and get our delivery on...
$searchsub = new SearchSub(); $searchsub = new SearchSub();
$searchsub->search = $search; $searchsub->search = $search;
$searchsub->find(); $searchsub->find();
@ -149,19 +159,39 @@ class SearchSubPlugin extends Plugin
$ni[$searchsub->profile_id] = NOTICE_INBOX_SOURCE_SUB; $ni[$searchsub->profile_id] = NOTICE_INBOX_SOURCE_SUB;
} }
} }
}
return true; return true;
} }
/** /**
* Does the given notice match the given fulltext search query?
* *
* @param SearchAction $action * Warning: not guaranteed to match other search engine behavior, etc.
* Currently using a basic case-insensitive substring match, which
* probably fits with the 'LIKE' search but not the default MySQL
* or Sphinx search backends.
*
* @param Notice $notice
* @param string $search
* @return boolean
*/
function matchSearch(Notice $notice, $search)
{
return (mb_stripos($notice->content, $search) !== false);
}
/**
*
* @param NoticeSearchAction $action
* @param string $q
* @param Notice $notice
* @return boolean hook result * @return boolean hook result
*/ */
function onStartTagShowContent(SearchAction $action) function onStartNoticeSearchShowResults($action, $q, $notice)
{ {
$user = common_current_user(); $user = common_current_user();
if ($user) { if ($user) {
$search = $action->trimmed('search'); $search = $q;
$searchsub = SearchSub::pkeyGet(array('search' => $search, $searchsub = SearchSub::pkeyGet(array('search' => $search,
'profile_id' => $user->id)); 'profile_id' => $user->id));
if ($searchsub) { if ($searchsub) {