user_id = $user_id; $this->own = $own; } /** * Note that the sorting for this is by order of *fave* not order of *notice*. * * @fixme add since_id, max_id support? * * @param $user_id * @param $own * @param $offset * @param $limit * @param $since_id * @param $max_id * @return */ function getNoticeIds($offset, $limit, $since_id, $max_id) { $fav = new Fave(); $qry = null; if ($this->own) { $qry = 'SELECT fave.* FROM fave '; $qry .= 'WHERE fave.user_id = ' . $this->user_id . ' '; } else { $qry = 'SELECT fave.* FROM fave '; $qry .= 'INNER JOIN notice ON fave.notice_id = notice.id '; $qry .= 'WHERE fave.user_id = ' . $this->user_id . ' '; $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 . ' '; } // NOTE: we sort by fave time, not by notice time! $qry .= 'ORDER BY modified DESC '; if (!is_null($offset)) { $qry .= "LIMIT $limit OFFSET $offset"; } $fav->query($qry); $ids = array(); while ($fav->fetch()) { $ids[] = $fav->notice_id; } $fav->free(); unset($fav); return $ids; } }