openstackweb/news/code/infrastructure/repositories/SapphireNewsRepository.php
2014-10-31 16:59:18 -03:00

182 lines
6.1 KiB
PHP

<?php
/**
* Copyright 2014 Openstack Foundation
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
**/
/**
* Class SapphireNewsRepository
*/
final class SapphireNewsRepository extends SapphireRepository {
public function __construct(){
parent::__construct(new News());
}
/**
* @return INews[]
*/
public function getFeaturedNews()
{
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('Featured','1'));
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
$query->addOrder(QueryOrder::asc('Rank'));
list($list,$count) = $this->getAll($query,0,1000);
return $list;
}
/**
* @return INews[]
*/
public function getRecentNews()
{
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('Featured','0'));
$query->addAddCondition(QueryCriteria::equal('Slider','0'));
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
$query->addOrder(QueryOrder::desc('Date'));
$query->addOrder(QueryOrder::asc('Rank'));
list($list,$count) = $this->getAll($query,0,1000);
return $list;
}
/**
* @return INews[]
*/
public function getStandByNews()
{
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('Featured','0'));
$query->addAddCondition(QueryCriteria::equal('Slider','0'));
$query->addAddCondition(QueryCriteria::equal('Approved','0'));
$query->addOrder(QueryOrder::desc('Date'));
$query->addOrder(QueryOrder::asc('Rank'));
list($list,$count) = $this->getAll($query,0,1000);
return $list;
}
/**
* @return INews[]
*/
public function getSlideNews()
{
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('Slider','1'));
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
$query->addOrder(QueryOrder::asc('Rank'));
list($list,$count) = $this->getAll($query,0,1000);
return $list;
}
/**
* @return INews[]
*/
public function getNewsByID($articleID)
{
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('ID',$articleID));
return $this->getBy($query);
}
/**
* @return INews[]
*/
public function getExpiredNews()
{
$today = date("Y-m-d");
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::lower('DateExpire',$today));
list($expired_articles,$count) = $this->getAll($query);
return $expired_articles;
}
public function getNewsToActivate()
{
$today = date("Y-m-d");
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::lower('DateEmbargo',$today));
$query->addAddCondition(QueryCriteria::equal('Approved',1));
list($activate_articles,$count) = $this->getAll($query);
return $activate_articles;
}
public function getArticlesBySection($section) {
$approved = $slider = $featured = 0;
if ($section == 'recent') {
$approved = 1;
} elseif ($section == 'slider') {
$slider = 1;
$approved = 1;
} elseif ($section == 'featured') {
$featured = 1;
$approved = 1;
}
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::equal('Slider',$slider));
$query->addAddCondition(QueryCriteria::equal('Approved',$approved));
$query->addAddCondition(QueryCriteria::equal('Featured',$featured));
$query->addOrder(QueryOrder::asc('Rank'));
list($articles,$count) = $this->getAll($query);
return $articles;
}
public function getArticlesToSort($article_id,$new_rank,$old_rank,$is_new,$is_remove,$type) {
$slider = $featured = $approved = 0;
if ($type == 'slider') {
$slider = 1;
$approved = 1;
} elseif ($type == 'featured') {
$featured = 1;
$approved = 1;
} elseif ($type == 'recent') {
$approved = 1;
}
$query = new QueryObject(new News);
$query->addAddCondition(QueryCriteria::notEqual('ID',$article_id));
$query->addAddCondition(QueryCriteria::equal('Slider',$slider));
$query->addAddCondition(QueryCriteria::equal('Featured',$featured));
$query->addAddCondition(QueryCriteria::equal('Approved',$approved));
if ($is_new) {
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$new_rank));
$rank_delta = 1;
} elseif ($is_remove) {
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$old_rank));
$rank_delta = -1;
} else {
if ($old_rank < $new_rank) {
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$old_rank));
$query->addAddCondition(QueryCriteria::lowerOrEqual('Rank',$new_rank));
$rank_delta = -1;
} else {
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$new_rank));
$query->addAddCondition(QueryCriteria::lowerOrEqual('Rank',$old_rank));
$rank_delta = 1;
}
}
list($other_articles,$count) = $this->getAll($query);
$return_array = array($other_articles,$rank_delta);
return $return_array;
}
public function deleteArticle($article_id) {
DataObject::delete_by_id('News',$article_id);
}
}