1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- <?php
- if (!defined('GNUSOCIAL')) { exit(1); }
- class RawEventsNoticeStream extends NoticeStream
- {
- function getNoticeIds($offset, $limit, $since_id, $max_id)
- {
- $notice = new Notice();
- $qry = null;
- $qry = 'SELECT notice.* FROM notice ';
- $qry .= 'INNER JOIN happening ON happening.uri = notice.uri ';
- $qry .= 'AND notice.is_local != ' . Notice::GATEWAY . ' ';
- if ($since_id != 0) {
- $qry .= 'AND notice.id > ' . $since_id . ' ';
- }
- if ($max_id != 0) {
- $qry .= 'AND notice.id <= ' . $max_id . ' ';
- }
-
- $qry .= 'ORDER BY happening.created DESC ';
- if (!is_null($offset)) {
- $qry .= "LIMIT $limit OFFSET $offset";
- }
- $notice->query($qry);
- $ids = array();
- while ($notice->fetch()) {
- $ids[] = $notice->id;
- }
- $notice->free();
- unset($notice);
- return $ids;
- }
- }
- class EventsNoticeStream extends ScopingNoticeStream
- {
-
- protected $rsvp = ['Y', 'N', '?'];
- protected $target = null;
- function __construct(Profile $target, Profile $scoped=null, array $rsvp=array())
- {
- $stream = new RawEventsNoticeStream();
- if ($target->sameAs($scoped)) {
- $key = 'happening:ids_for_user_own:'.$target->getID();
- } else {
- $key = 'happening:ids_for_user:'.$target->getID();
- }
-
-
-
- $this->rsvp = array_intersect($this->rsvp, $rsvp);
- $this->target = $target;
- parent::__construct(new CachingNoticeStream($stream, $key), $scoped);
- }
- protected function filter(Notice $notice)
- {
- if (!parent::filter($notice)) {
-
- return false;
- }
- if (empty($this->rsvp)) {
-
-
- return true;
- }
- $rsvp = new RSVP();
- $rsvp->profile_id = $this->target->getID();
- $rsvp->event_uri = $notice->getUri();
- $rsvp->whereAddIn('response', $this->rsvp, $rsvp->columnType('response'));
-
- return $rsvp->N > 0;
- }
- }
|