. * * @category Stream * @package StatusNet * @author Evan Prodromou * @copyright 2011 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ if (!defined('GNUSOCIAL')) { exit(1); } /** * Stream of notices that are repeats of mine * * @category Stream * @package StatusNet * @author Evan Prodromou * @copyright 2011 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ class RepeatsOfMeNoticeStream extends ScopingNoticeStream { function __construct(Profile $target, Profile $scoped=null) { parent::__construct(new CachingNoticeStream(new RawRepeatsOfMeNoticeStream($target), 'user:repeats_of_me:'.$target->getID()), $scoped); } } /** * Raw stream of notices that are repeats of mine * * @category Stream * @package StatusNet * @author Evan Prodromou * @copyright 2011 StatusNet, Inc. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0 * @link http://status.net/ */ class RawRepeatsOfMeNoticeStream extends NoticeStream { protected $target; function __construct(Profile $target) { $this->target = $target; } function getNoticeIds($offset, $limit, $since_id, $max_id) { $qry = 'SELECT DISTINCT original.id AS id ' . 'FROM notice original JOIN notice rept ON original.id = rept.repeat_of ' . 'WHERE original.profile_id = ' . $this->target->getID() . ' '; $since = Notice::whereSinceId($since_id, 'original.id', 'original.created'); if ($since) { $qry .= "AND ($since) "; } $max = Notice::whereMaxId($max_id, 'original.id', 'original.created'); if ($max) { $qry .= "AND ($max) "; } $qry .= 'ORDER BY original.created, original.id DESC '; if (!is_null($offset)) { $qry .= "LIMIT $limit OFFSET $offset"; } $ids = array(); $notice = new Notice(); $notice->query($qry); while ($notice->fetch()) { $ids[] = $notice->id; } $notice->free(); $notice = NULL; return $ids; } }