2016-08-18 21:53:59 -04:00
|
|
|
<?php
|
|
|
|
|
2016-08-24 21:17:58 -04:00
|
|
|
namespace Miniflux\Model\ItemFeed;
|
2016-08-18 21:53:59 -04:00
|
|
|
|
2016-12-26 09:44:53 -05:00
|
|
|
use Miniflux\Model\Feed;
|
|
|
|
use Miniflux\Model\Item;
|
2016-08-18 21:53:59 -04:00
|
|
|
use PicoDb\Database;
|
|
|
|
|
2016-12-26 09:44:53 -05:00
|
|
|
function count_items_by_status($user_id, $feed_id)
|
|
|
|
{
|
|
|
|
$counts = Database::getInstance('db')
|
|
|
|
->table(Item\TABLE)
|
|
|
|
->columns('status', 'count(*) as item_count')
|
|
|
|
->in('status', array(Item\STATUS_READ, Item\STATUS_UNREAD))
|
|
|
|
->eq('user_id', $user_id)
|
|
|
|
->eq('feed_id', $feed_id)
|
|
|
|
->groupBy('status')
|
|
|
|
->findAll();
|
|
|
|
|
|
|
|
$result = array(
|
|
|
|
'items_unread' => 0,
|
|
|
|
'items_total' => 0,
|
|
|
|
);
|
|
|
|
|
|
|
|
foreach ($counts as &$count) {
|
|
|
|
if ($count['status'] === Item\STATUS_UNREAD) {
|
|
|
|
$result['items_unread'] = (int) $count['item_count'];
|
|
|
|
}
|
|
|
|
|
|
|
|
$result['items_total'] += $count['item_count'];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
function count_items($user_id, $feed_id)
|
2016-08-18 21:53:59 -04:00
|
|
|
{
|
|
|
|
return Database::getInstance('db')
|
2016-12-26 09:44:53 -05:00
|
|
|
->table(Item\TABLE)
|
2016-08-18 21:53:59 -04:00
|
|
|
->eq('feed_id', $feed_id)
|
2016-12-26 09:44:53 -05:00
|
|
|
->eq('user_id', $user_id)
|
|
|
|
->in('status', array(Item\STATUS_READ, Item\STATUS_UNREAD))
|
2016-08-18 21:53:59 -04:00
|
|
|
->count();
|
|
|
|
}
|
|
|
|
|
2016-12-26 09:44:53 -05:00
|
|
|
function get_all_items($user_id, $feed_id, $offset = null, $limit = null, $order_column = 'updated', $order_direction = 'desc')
|
2016-08-18 21:53:59 -04:00
|
|
|
{
|
|
|
|
return Database::getInstance('db')
|
|
|
|
->table('items')
|
|
|
|
->columns(
|
|
|
|
'items.id',
|
|
|
|
'items.title',
|
|
|
|
'items.updated',
|
|
|
|
'items.url',
|
2016-12-26 09:44:53 -05:00
|
|
|
'items.enclosure_url',
|
2016-08-18 21:53:59 -04:00
|
|
|
'items.enclosure_type',
|
|
|
|
'items.feed_id',
|
|
|
|
'items.status',
|
|
|
|
'items.content',
|
|
|
|
'items.bookmark',
|
|
|
|
'items.language',
|
2016-12-26 09:44:53 -05:00
|
|
|
'items.rtl',
|
2016-08-18 21:53:59 -04:00
|
|
|
'items.author',
|
|
|
|
'feeds.site_url',
|
2016-12-26 09:44:53 -05:00
|
|
|
'feeds.title AS feed_title'
|
2016-08-18 21:53:59 -04:00
|
|
|
)
|
2016-12-26 09:44:53 -05:00
|
|
|
->join(Feed\TABLE, 'id', 'feed_id')
|
|
|
|
->in('status', array(Item\STATUS_UNREAD, Item\STATUS_READ))
|
|
|
|
->eq('items.feed_id', $feed_id)
|
|
|
|
->eq('items.user_id', $user_id)
|
2016-08-18 21:53:59 -04:00
|
|
|
->orderBy($order_column, $order_direction)
|
|
|
|
->offset($offset)
|
|
|
|
->limit($limit)
|
|
|
|
->findAll();
|
|
|
|
}
|
|
|
|
|
2016-12-26 09:44:53 -05:00
|
|
|
function change_items_status($user_id, $feed_id, $current_status, $new_status, $before = null)
|
2016-08-18 21:53:59 -04:00
|
|
|
{
|
2016-12-26 09:44:53 -05:00
|
|
|
$query = Database::getInstance('db')
|
|
|
|
->table(Item\TABLE)
|
|
|
|
->eq('status', $current_status)
|
2016-08-18 21:53:59 -04:00
|
|
|
->eq('feed_id', $feed_id)
|
2016-12-26 09:44:53 -05:00
|
|
|
->eq('user_id', $user_id);
|
|
|
|
|
|
|
|
if ($before !== null) {
|
|
|
|
$query->lte('updated', $before);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $query->update(array('status' => $new_status));
|
2016-08-18 21:53:59 -04:00
|
|
|
}
|