X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=lib%2Fprofilenoticestream.php;h=1fa795d32090a55866c49f9221757ab7c089fdcb;hb=035aae2745e25d44ab9fe1b7bdffbcaa505ba970;hp=7ea653f8c8c2a1bcc31bfabc6ad033c5f643c2d0;hpb=d69f912b00ff66e6b315599ce52d6992ac43d19a;p=quix0rs-gnu-social.git diff --git a/lib/profilenoticestream.php b/lib/profilenoticestream.php index 7ea653f8c8..1fa795d320 100644 --- a/lib/profilenoticestream.php +++ b/lib/profilenoticestream.php @@ -47,10 +47,60 @@ if (!defined('STATUSNET')) { class ProfileNoticeStream extends ScopingNoticeStream { - function __construct($profile) + var $streamProfile; + var $userProfile; + + function __construct($profile, $userProfile = -1) { + if (is_int($userProfile) && $userProfile == -1) { + $userProfile = Profile::current(); + } + $this->streamProfile = $profile; + $this->userProfile = $userProfile; parent::__construct(new CachingNoticeStream(new RawProfileNoticeStream($profile), - 'profile:notice_ids:' . $profile->id)); + 'profile:notice_ids:' . $profile->id), + $userProfile); + } + + function getNoticeIds($offset, $limit, $since_id=null, $max_id=null) + { + if ($this->impossibleStream()) { + return array(); + } else { + return parent::getNoticeIds($offset, $limit, $since_id, $max_id); + } + } + + function getNotices($offset, $limit, $since_id=null, $max_id=null) + { + if ($this->impossibleStream()) { + return new ArrayWrapper(array()); + } else { + return parent::getNotices($offset, $limit, $since_id, $max_id); + } + } + + function impossibleStream() + { + $user = User::getKV('id', $this->streamProfile->id); + + // If it's a private stream, and no user or not a subscriber + + if (!empty($user) && $user->private_stream && + (empty($this->userProfile) || !$this->userProfile->isSubscribed($this->streamProfile))) { + return true; + } + + // If it's a spammy stream, and no user or not a moderator + + if (common_config('notice', 'hidespam')) { + if ($this->streamProfile->hasRole(Profile_role::SILENCED) && + (empty($this->userProfile) || (($this->userProfile->id !== $this->streamProfile->id) && !$this->userProfile->hasRight(Right::REVIEWSPAM)))) { + return true; + } + } + + return false; } } @@ -71,6 +121,7 @@ class RawProfileNoticeStream extends NoticeStream function __construct($profile) { + parent::__construct(); $this->profile = $profile; }