class ReplyNoticeStream extends ScopingNoticeStream
{
- function __construct($userId)
+ function __construct($userId, $profile=-1)
{
+ if (is_int($profile) && $profile == -1) {
+ $profile = Profile::current();
+ }
parent::__construct(new CachingNoticeStream(new RawReplyNoticeStream($userId),
- 'reply:stream:' . $userId));
+ 'reply:stream:' . $userId),
+ $profile);
}
}
function __construct($userId)
{
+ parent::__construct();
$this->userId = $userId;
}
- function getNoticeIds($offset=0, $limit=NOTICES_PER_PAGE, $since_id=0, $max_id=0)
+ function getNoticeIds($offset, $limit, $since_id, $max_id)
{
$reply = new Reply();
- $reply->profile_id = $this->userId;
- Notice::addWhereSinceId($reply, $since_id, 'notice_id', 'modified');
- Notice::addWhereMaxId($reply, $max_id, 'notice_id', 'modified');
+ $reply->selectAdd();
+ $reply->selectAdd('notice_id');
- $reply->orderBy('modified DESC, notice_id DESC');
+ $reply->whereAdd(sprintf('reply.profile_id = %u', $this->userId));
+
+ Notice::addWhereSinceId($reply, $since_id, 'notice_id', 'reply.modified');
+ Notice::addWhereMaxId($reply, $max_id, 'notice_id', 'reply.modified');
+
+ if (!empty($this->selectVerbs)) {
+ $reply->joinAdd(array('notice_id', 'notice:id'));
+ $reply->whereAddIn('notice.verb', $this->selectVerbs, 'string');
+ }
+
+ $reply->orderBy('reply.modified DESC, reply.notice_id DESC');
if (!is_null($offset)) {
$reply->limit($offset, $limit);
return $ids;
}
-}
\ No newline at end of file
+}