22fead1b46
commit fb1dfa9e98ded23fb5bdebae6465424a8cb8acd6 Author: Evan Prodromou <evan@status.net> Date: Thu Oct 20 10:40:07 2011 -0400 Use popular notice stream for favorited page commit e1d409ff738e39061ad35589d546ce9bed456975 Author: Evan Prodromou <evan@status.net> Date: Thu Oct 20 10:32:23 2011 -0400 Use a caching stream for popular notice section Instead of a big cached query, we now use a caching notice stream for the popular notice section. It uses a single-table query at the bottom, then scopes the notices and filters for silenced users. This should be much nicer to our database servers. Also clears the popular cache when someone favors or disfavors something. A nice optimization would be to save the last weights and re-calculate them at invalidation time, adding the new notice (or not) depending on its own score. That will have to wait for another day, though. commit e9b7ab4c26c95e755adaff53c3957dcfca31c16b Author: Evan Prodromou <evan@status.net> Date: Thu Oct 20 10:31:14 2011 -0400 Let CachingNoticeStream users skip the ';last' optimization
110 lines
3.2 KiB
PHP
110 lines
3.2 KiB
PHP
<?php
|
|
/**
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
* Copyright (C) 2011, StatusNet, Inc.
|
|
*
|
|
* Stream of notices sorted by popularity
|
|
*
|
|
* PHP version 5
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @category Popular
|
|
* @package StatusNet
|
|
* @author Evan Prodromou <evan@status.net>
|
|
* @copyright 2011 StatusNet, Inc.
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
* @link http://status.net/
|
|
*/
|
|
|
|
if (!defined('STATUSNET')) {
|
|
// This check helps protect against security problems;
|
|
// your code file can't be executed directly from the web.
|
|
exit(1);
|
|
}
|
|
|
|
/**
|
|
* Stream of notices sorted by popularity
|
|
*
|
|
* @category Popular
|
|
* @package StatusNet
|
|
* @author Evan Prodromou <evan@status.net>
|
|
* @copyright 2011 StatusNet, Inc.
|
|
* @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
|
|
* @link http://status.net/
|
|
*/
|
|
|
|
class PopularNoticeStream extends ScopingNoticeStream
|
|
{
|
|
function __construct($profile=null)
|
|
{
|
|
parent::__construct(new HideSilencedStream(new CachingNoticeStream(new RawPopularNoticeStream(),
|
|
'popular',
|
|
false)),
|
|
$profile);
|
|
}
|
|
}
|
|
|
|
class HideSilencedStream extends FilteringNoticeStream
|
|
{
|
|
/**
|
|
* Only return notices where the profile is in scope
|
|
*
|
|
* @param Notice $notice The notice to check
|
|
*
|
|
* @return boolean whether to include the notice
|
|
*/
|
|
|
|
function filter($notice)
|
|
{
|
|
$author = $notice->getProfile();
|
|
return !$author->isSilenced();
|
|
}
|
|
}
|
|
|
|
class RawPopularNoticeStream extends NoticeStream
|
|
{
|
|
function getNoticeIds($offset, $limit, $since_id, $max_id)
|
|
{
|
|
$weightexpr = common_sql_weight('modified', common_config('popular', 'dropoff'));
|
|
$cutoff = sprintf("modified > '%s'",
|
|
common_sql_date(time() - common_config('popular', 'cutoff')));
|
|
|
|
$fave = new Fave();
|
|
$fave->selectAdd();
|
|
$fave->selectAdd('notice_id');
|
|
$fave->selectAdd("$weightexpr as weight");
|
|
$fave->whereAdd($cutoff);
|
|
$fave->orderBy('weight DESC');
|
|
$fave->groupBy('notice_id');
|
|
|
|
if (!is_null($offset)) {
|
|
$fave->limit($offset, $limit);
|
|
}
|
|
|
|
// FIXME: $since_id, $max_id are ignored
|
|
|
|
$ids = array();
|
|
|
|
if ($fave->find()) {
|
|
while ($fave->fetch()) {
|
|
$ids[] = $fave->notice_id;
|
|
}
|
|
}
|
|
|
|
return $ids;
|
|
}
|
|
}
|
|
|