]> git.mxchange.org Git - quix0rs-gnu-social.git/blob - lib/inboxnoticestream.php
Removed plugin Google-Analytics as this is free/libre and decentralized
[quix0rs-gnu-social.git] / lib / inboxnoticestream.php
1 <?php
2 /**
3  * StatusNet - the distributed open-source microblogging tool
4  * Copyright (C) 2011, StatusNet, Inc.
5  *
6  * Stream of notices for a profile's "all" feed
7  *
8  * PHP version 5
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU Affero General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Affero General Public License for more details.
19  *
20  * You should have received a copy of the GNU Affero General Public License
21  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
22  *
23  * @category  NoticeStream
24  * @package   StatusNet
25  * @author    Evan Prodromou <evan@status.net>
26  * @author    Mikael Nordfeldth <mmn@hethane.se>
27  * @copyright 2011 StatusNet, Inc.
28  * @copyright 2014 Free Software Foundation, Inc.
29  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
30  * @link      http://status.net/
31  */
32
33 if (!defined('GNUSOCIAL') && !defined('STATUSNET')) { exit(1); }
34
35 /**
36  * Stream of notices for a profile's "all" feed
37  *
38  * @category  General
39  * @package   StatusNet
40  * @author    Evan Prodromou <evan@status.net>
41  * @author    Mikael Nordfeldth <mmn@hethane.se>
42  * @copyright 2011 StatusNet, Inc.
43  * @copyright 2014 Free Software Foundation, Inc.
44  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
45  * @link      http://status.net/
46  */
47 class InboxNoticeStream extends ScopingNoticeStream
48 {
49     /**
50      * Constructor
51      *
52      * @param Profile $target Profile to get a stream for
53      * @param Profile $scoped Currently scoped profile (if null, it is fetched)
54      */
55     function __construct(Profile $target, Profile $scoped=null)
56     {
57         if ($scoped === null) {
58             $scoped = Profile::current();
59         }
60         // FIXME: we don't use CachingNoticeStream - but maybe we should?
61         parent::__construct(new CachingNoticeStream(new RawInboxNoticeStream($target), 'profileall'), $scoped);
62     }
63 }
64
65 /**
66  * Raw stream of notices for the target's inbox
67  *
68  * @category  General
69  * @package   StatusNet
70  * @author    Evan Prodromou <evan@status.net>
71  * @copyright 2011 StatusNet, Inc.
72  * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
73  * @link      http://status.net/
74  */
75 class RawInboxNoticeStream extends NoticeStream
76 {
77     protected $target  = null;
78     protected $inbox = null;
79
80     /**
81      * Constructor
82      *
83      * @param Profile $target Profile to get a stream for
84      */
85     function __construct(Profile $target)
86     {
87         $this->target  = $target;
88         $this->unselectVerbs = array(ActivityVerb::DELETE);
89     }
90
91     /**
92      * Get IDs in a range
93      *
94      * @param int $offset   Offset from start
95      * @param int $limit    Limit of number to get
96      * @param int $since_id Since this notice
97      * @param int $max_id   Before this notice
98      *
99      * @return Array IDs found
100      */
101     function getNoticeIds($offset, $limit, $since_id, $max_id)
102     {
103         $notice = new Notice();
104         $notice->selectAdd();
105         $notice->selectAdd('id');
106         $notice->whereAdd(sprintf('notice.created > "%s"', $notice->escape($this->target->created)));
107         // Reply:: is a table of mentions
108         // Subscription:: is a table of subscriptions (every user is subscribed to themselves)
109         $notice->whereAdd(
110                 sprintf('notice.id IN (SELECT notice_id FROM reply WHERE profile_id=%1$d) ' .
111                         'OR notice.profile_id IN (SELECT subscribed FROM subscription WHERE subscriber=%1$d) ' .
112                         'OR notice.id IN (SELECT notice_id FROM group_inbox WHERE group_id IN (SELECT group_id FROM group_member WHERE profile_id=%1$d))' .
113                         'OR notice.id IN (SELECT notice_id FROM attention WHERE profile_id=%1$d)',
114                     $this->target->id)
115             );
116         if (!empty($since_id)) {
117             $notice->whereAdd(sprintf('notice.id > %d', $since_id));
118         }
119         if (!empty($max_id)) {
120             $notice->whereAdd(sprintf('notice.id <= %d', $max_id));
121         }
122         if (!empty($this->selectVerbs)) {
123             $notice->whereAddIn('verb', $this->selectVerbs, $notice->columnType('verb'));
124         }
125         if (!empty($this->unselectVerbs)) {
126             $notice->whereAddIn('!verb', $this->unselectVerbs, $notice->columnType('verb'));
127         }
128         $notice->limit($offset, $limit);
129         // notice.id will give us even really old posts, which were
130         // recently imported. For example if a remote instance had
131         // problems and just managed to post here. Another solution
132         // would be to have a 'notice.imported' field and order by it.
133         $notice->orderBy('notice.id DESC');
134
135         if (!$notice->find()) {
136             return array();
137         }
138
139         $ids = $notice->fetchAll('id');
140
141         return $ids;
142     }
143 }