2013-03-21 16:16:16 +04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ownCloud - News
|
|
|
|
*
|
|
|
|
* @author Alessandro Cosentino
|
|
|
|
* @author Bernhard Posselt
|
|
|
|
* @copyright 2012 Alessandro Cosentino cosenal@gmail.com
|
|
|
|
* @copyright 2012 Bernhard Posselt nukeawhale@gmail.com
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\News\Controller;
|
|
|
|
|
|
|
|
use \OCA\AppFramework\Controller\Controller;
|
|
|
|
use \OCA\AppFramework\Core\API;
|
|
|
|
use \OCA\AppFramework\Http\Request;
|
|
|
|
|
|
|
|
use \OCA\News\Bl\ItemBl;
|
|
|
|
|
|
|
|
|
|
|
|
class ItemController extends Controller {
|
|
|
|
|
|
|
|
private $itemBl;
|
|
|
|
|
|
|
|
public function __construct(API $api, Request $request, ItemBl $itemBl){
|
|
|
|
parent::__construct($api, $request);
|
2013-03-21 20:00:19 +04:00
|
|
|
$this->itemBl = $itemBl;
|
2013-03-21 16:16:16 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function items(){
|
2013-03-23 04:23:47 +04:00
|
|
|
$userId = $this->api->getUserId();
|
2013-03-23 15:27:36 +04:00
|
|
|
$showAll = $this->api->getUserValue($userId, 'showAll') === 'true';
|
|
|
|
|
2013-03-23 04:23:47 +04:00
|
|
|
$limit = $this->params('limit');
|
2013-03-25 13:43:05 +04:00
|
|
|
$type = (int) $this->params('type');
|
|
|
|
$id = (int) $this->params('id');
|
|
|
|
|
2013-03-27 21:21:30 +04:00
|
|
|
$this->api->setUserValue('lastViewedFeedId', $id);
|
|
|
|
$this->api->setUserValue('lastViewedFeedType', $type);
|
2013-03-23 04:23:47 +04:00
|
|
|
|
|
|
|
if($limit !== null){
|
2013-03-25 13:43:05 +04:00
|
|
|
$offset = (int) $this->params('offset', 0);
|
|
|
|
$items = $this->itemBl->findAll($id, $type, (int) $limit, $offset,
|
2013-03-23 15:27:36 +04:00
|
|
|
$showAll, $userId);
|
2013-03-23 04:23:47 +04:00
|
|
|
} else {
|
2013-03-25 13:43:05 +04:00
|
|
|
$updatedSince = (int) $this->params('updatedSince');
|
2013-03-23 15:27:36 +04:00
|
|
|
$items = $this->itemBl->findAllNew($id, $type, $updatedSince,
|
|
|
|
$showAll, $userId);
|
2013-03-23 04:23:47 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
$params = array(
|
|
|
|
'items' => $items
|
|
|
|
);
|
|
|
|
|
|
|
|
return $this->renderJSON($params);
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function starred(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$userId = $this->api->getUserId();
|
|
|
|
$starredCount = $this->itemBl->starredCount($userId);
|
|
|
|
|
|
|
|
$params = array(
|
2013-03-26 21:04:02 +04:00
|
|
|
'starred' => (int) $starredCount
|
2013-03-23 01:29:58 +04:00
|
|
|
);
|
|
|
|
|
|
|
|
return $this->renderJSON($params);
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-23 01:29:58 +04:00
|
|
|
private function setStarred($isStarred){
|
|
|
|
$userId = $this->api->getUserId();
|
2013-03-27 16:47:53 +04:00
|
|
|
$feedId = (int) $this->params('feedId');
|
|
|
|
$guidHash = $this->params('guidHash');
|
2013-03-23 01:29:58 +04:00
|
|
|
|
2013-03-27 16:47:53 +04:00
|
|
|
$this->itemBl->star($feedId, $guidHash, $isStarred, $userId);
|
2013-03-23 01:29:58 +04:00
|
|
|
}
|
|
|
|
|
2013-03-27 20:19:50 +04:00
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function star(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$this->setStarred(true);
|
2013-03-26 00:54:26 +04:00
|
|
|
|
|
|
|
return $this->renderJSON();
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function unstar(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$this->setStarred(false);
|
2013-03-26 00:54:26 +04:00
|
|
|
|
|
|
|
return $this->renderJSON();
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-23 01:29:58 +04:00
|
|
|
private function setRead($isRead){
|
|
|
|
$userId = $this->api->getUserId();
|
2013-03-25 13:43:05 +04:00
|
|
|
$itemId = (int) $this->params('itemId');
|
2013-03-23 01:29:58 +04:00
|
|
|
|
|
|
|
$this->itemBl->read($itemId, $isRead, $userId);
|
|
|
|
}
|
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function read(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$this->setRead(true);
|
2013-03-26 00:54:26 +04:00
|
|
|
|
|
|
|
return $this->renderJSON();
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-03-21 20:53:30 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
2013-03-21 20:00:19 +04:00
|
|
|
public function unread(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$this->setRead(false);
|
2013-03-26 00:54:26 +04:00
|
|
|
|
|
|
|
return $this->renderJSON();
|
2013-03-21 20:00:19 +04:00
|
|
|
}
|
|
|
|
|
2013-03-21 16:16:16 +04:00
|
|
|
|
2013-03-21 23:38:09 +04:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function readFeed(){
|
2013-03-23 01:29:58 +04:00
|
|
|
$userId = $this->api->getUserId();
|
2013-03-25 13:43:05 +04:00
|
|
|
$feedId = (int) $this->params('feedId');
|
2013-03-27 15:26:04 +04:00
|
|
|
$highestItemId = (int) $this->params('highestItemId');
|
2013-03-23 01:29:58 +04:00
|
|
|
|
2013-03-27 15:26:04 +04:00
|
|
|
$this->itemBl->readFeed($feedId, $highestItemId, $userId);
|
2013-04-12 13:54:49 +04:00
|
|
|
return $this->renderJSON();
|
2013-03-21 23:38:09 +04:00
|
|
|
}
|
2013-03-23 01:29:58 +04:00
|
|
|
|
|
|
|
|
2013-03-21 16:16:16 +04:00
|
|
|
}
|