forked from GNUsocial/gnu-social
6b134ae4c7
Twitter removed 'since' support some time ago, and we've already removed it from the public timeline, so it shouldn't be missed.
125 lines
3.4 KiB
PHP
125 lines
3.4 KiB
PHP
<?php
|
|
/**
|
|
* Table Definition for fave
|
|
*/
|
|
require_once INSTALLDIR.'/classes/Memcached_DataObject.php';
|
|
|
|
class Fave extends Memcached_DataObject
|
|
{
|
|
###START_AUTOCODE
|
|
/* the code below is auto generated do not remove the above tag */
|
|
|
|
public $__table = 'fave'; // table name
|
|
public $notice_id; // int(4) primary_key not_null
|
|
public $user_id; // int(4) primary_key not_null
|
|
public $modified; // timestamp() not_null default_CURRENT_TIMESTAMP
|
|
|
|
/* Static get */
|
|
function staticGet($k,$v=null)
|
|
{ return Memcached_DataObject::staticGet('Fave',$k,$v); }
|
|
|
|
/* the code above is auto generated do not remove the tag below */
|
|
###END_AUTOCODE
|
|
|
|
static function addNew($profile, $notice) {
|
|
|
|
$fave = null;
|
|
|
|
if (Event::handle('StartFavorNotice', array($profile, $notice, &$fave))) {
|
|
|
|
$fave = new Fave();
|
|
|
|
$fave->user_id = $profile->id;
|
|
$fave->notice_id = $notice->id;
|
|
|
|
if (!$fave->insert()) {
|
|
common_log_db_error($fave, 'INSERT', __FILE__);
|
|
return false;
|
|
}
|
|
|
|
Event::handle('EndFavorNotice', array($profile, $notice));
|
|
}
|
|
|
|
return $fave;
|
|
}
|
|
|
|
function delete()
|
|
{
|
|
$profile = Profile::staticGet('id', $this->user_id);
|
|
$notice = Notice::staticGet('id', $this->notice_id);
|
|
|
|
$result = null;
|
|
|
|
if (Event::handle('StartDisfavorNotice', array($profile, $notice, &$result))) {
|
|
|
|
$result = parent::delete();
|
|
|
|
if ($result) {
|
|
Event::handle('EndDisfavorNotice', array($profile, $notice));
|
|
}
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
function pkeyGet($kv)
|
|
{
|
|
return Memcached_DataObject::pkeyGet('Fave', $kv);
|
|
}
|
|
|
|
function stream($user_id, $offset=0, $limit=NOTICES_PER_PAGE, $own=false)
|
|
{
|
|
$ids = Notice::stream(array('Fave', '_streamDirect'),
|
|
array($user_id, $own),
|
|
($own) ? 'fave:ids_by_user_own:'.$user_id :
|
|
'fave:ids_by_user:'.$user_id,
|
|
$offset, $limit);
|
|
return $ids;
|
|
}
|
|
|
|
function _streamDirect($user_id, $own, $offset, $limit, $since_id, $max_id)
|
|
{
|
|
$fav = new Fave();
|
|
$qry = null;
|
|
|
|
if ($own) {
|
|
$qry = 'SELECT fave.* FROM fave ';
|
|
$qry .= 'WHERE fave.user_id = ' . $user_id . ' ';
|
|
} else {
|
|
$qry = 'SELECT fave.* FROM fave ';
|
|
$qry .= 'INNER JOIN notice ON fave.notice_id = notice.id ';
|
|
$qry .= 'WHERE fave.user_id = ' . $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;
|
|
}
|
|
}
|