2009-08-22 00:01:09 +03:00
|
|
|
|
<?php
|
|
|
|
|
/*-------------------------------------------------------
|
|
|
|
|
*
|
|
|
|
|
* LiveStreet Engine Social Networking
|
|
|
|
|
* Copyright © 2008 Mzhelskiy Maxim
|
|
|
|
|
*
|
|
|
|
|
*--------------------------------------------------------
|
|
|
|
|
*
|
|
|
|
|
* Official site: www.livestreet.ru
|
|
|
|
|
* Contact e-mail: rus.engine@gmail.com
|
|
|
|
|
*
|
|
|
|
|
* GNU General Public License, version 2:
|
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
|
*
|
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/**
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* Модуль для работы с избранным
|
2009-08-22 00:01:09 +03:00
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @package modules.favourite
|
|
|
|
|
* @since 1.0
|
2009-08-22 00:01:09 +03:00
|
|
|
|
*/
|
2012-06-24 10:20:49 +03:00
|
|
|
|
class ModuleFavourite extends Module {
|
|
|
|
|
/**
|
|
|
|
|
* Объект маппера
|
|
|
|
|
*
|
|
|
|
|
* @var ModuleFavourite_MapperFavourite
|
|
|
|
|
*/
|
|
|
|
|
protected $oMapper;
|
|
|
|
|
|
2009-08-22 00:01:09 +03:00
|
|
|
|
/**
|
|
|
|
|
* Инициализация
|
|
|
|
|
*
|
|
|
|
|
*/
|
2012-06-24 10:20:49 +03:00
|
|
|
|
public function Init() {
|
2010-05-27 23:40:30 +03:00
|
|
|
|
$this->oMapper=Engine::GetMapper(__CLASS__);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Получает информацию о том, найден ли таргет в избранном или нет
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sTargetId ID владельца
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $sUserId ID пользователя
|
2010-05-27 18:16:20 +03:00
|
|
|
|
* @return ModuleFavourite_EntityFavourite|null
|
2009-08-22 00:01:09 +03:00
|
|
|
|
*/
|
|
|
|
|
public function GetFavourite($sTargetId,$sTargetType,$sUserId) {
|
2012-07-08 11:50:36 +03:00
|
|
|
|
if (!is_numeric($sTargetId) or !is_string($sTargetType)) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$data=$this->GetFavouritesByArray($sTargetId,$sTargetType,$sUserId);
|
|
|
|
|
return (isset($data[$sTargetId]))
|
|
|
|
|
? $data[$sTargetId]
|
|
|
|
|
: null;
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Получить список избранного по списку айдишников
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array $aTargetId Список ID владельцев
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $sUserId ID пользователя
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function GetFavouritesByArray($aTargetId,$sTargetType,$sUserId) {
|
|
|
|
|
if (!$aTargetId) {
|
|
|
|
|
return array();
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-10-10 22:13:14 +03:00
|
|
|
|
if (Config::Get('sys.cache.solid')) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
return $this->GetFavouritesByArraySolid($aTargetId,$sTargetType,$sUserId);
|
|
|
|
|
}
|
|
|
|
|
if (!is_array($aTargetId)) {
|
|
|
|
|
$aTargetId=array($aTargetId);
|
|
|
|
|
}
|
|
|
|
|
$aTargetId=array_unique($aTargetId);
|
|
|
|
|
$aFavourite=array();
|
|
|
|
|
$aIdNotNeedQuery=array();
|
|
|
|
|
/**
|
|
|
|
|
* Делаем мульти-запрос к кешу
|
|
|
|
|
*/
|
|
|
|
|
$aCacheKeys=func_build_cache_keys($aTargetId,"favourite_{$sTargetType}_",'_'.$sUserId);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (false !== ($data = $this->Cache_Get($aCacheKeys))) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
/**
|
|
|
|
|
* проверяем что досталось из кеша
|
|
|
|
|
*/
|
|
|
|
|
foreach ($aCacheKeys as $sValue => $sKey ) {
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (array_key_exists($sKey,$data)) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
if ($data[$sKey]) {
|
|
|
|
|
$aFavourite[$data[$sKey]->getTargetId()]=$data[$sKey];
|
|
|
|
|
} else {
|
|
|
|
|
$aIdNotNeedQuery[]=$sValue;
|
|
|
|
|
}
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
2009-08-22 00:45:31 +03:00
|
|
|
|
* Смотрим чего не было в кеше и делаем запрос в БД
|
2012-06-24 10:20:49 +03:00
|
|
|
|
*/
|
|
|
|
|
$aIdNeedQuery=array_diff($aTargetId,array_keys($aFavourite));
|
|
|
|
|
$aIdNeedQuery=array_diff($aIdNeedQuery,$aIdNotNeedQuery);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$aIdNeedStore=$aIdNeedQuery;
|
2009-12-18 14:27:41 +02:00
|
|
|
|
if ($data = $this->oMapper->GetFavouritesByArray($aIdNeedQuery,$sTargetType,$sUserId)) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
foreach ($data as $oFavourite) {
|
|
|
|
|
/**
|
|
|
|
|
* Добавляем к результату и сохраняем в кеш
|
|
|
|
|
*/
|
|
|
|
|
$aFavourite[$oFavourite->getTargetId()]=$oFavourite;
|
2009-08-22 00:45:31 +03:00
|
|
|
|
$this->Cache_Set($oFavourite, "favourite_{$oFavourite->getTargetType()}_{$oFavourite->getTargetId()}_{$sUserId}", array(), 60*60*24*7);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$aIdNeedStore=array_diff($aIdNeedStore,array($oFavourite->getTargetId()));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Сохраняем в кеш запросы не вернувшие результата
|
|
|
|
|
*/
|
|
|
|
|
foreach ($aIdNeedStore as $sId) {
|
|
|
|
|
$this->Cache_Set(null, "favourite_{$sTargetType}_{$sId}_{$sUserId}", array(), 60*60*24*7);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
/**
|
|
|
|
|
* Сортируем результат согласно входящему массиву
|
|
|
|
|
*/
|
|
|
|
|
$aFavourite=func_array_sort_by_keys($aFavourite,$aTargetId);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
return $aFavourite;
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
|
|
|
|
/**
|
2009-08-22 00:45:31 +03:00
|
|
|
|
* Получить список избранного по списку айдишников, но используя единый кеш
|
2009-08-22 00:01:09 +03:00
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array $aTargetId Список ID владельцев
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $sUserId ID пользователя
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function GetFavouritesByArraySolid($aTargetId,$sTargetType,$sUserId) {
|
|
|
|
|
if (!is_array($aTargetId)) {
|
|
|
|
|
$aTargetId=array($aTargetId);
|
|
|
|
|
}
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$aTargetId=array_unique($aTargetId);
|
|
|
|
|
$aFavourites=array();
|
|
|
|
|
$s=join(',',$aTargetId);
|
|
|
|
|
if (false === ($data = $this->Cache_Get("favourite_{$sTargetType}_{$sUserId}_id_{$s}"))) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$data = $this->oMapper->GetFavouritesByArray($aTargetId,$sTargetType,$sUserId);
|
|
|
|
|
foreach ($data as $oFavourite) {
|
|
|
|
|
$aFavourites[$oFavourite->getTargetId()]=$oFavourite;
|
|
|
|
|
}
|
2009-08-22 00:45:31 +03:00
|
|
|
|
$this->Cache_Set($aFavourites, "favourite_{$sTargetType}_{$sUserId}_id_{$s}", array("favourite_{$sTargetType}_change_user_{$sUserId}"), 60*60*24*1);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
return $aFavourites;
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
/**
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* Получает список таргетов из избранного
|
2009-08-22 00:01:09 +03:00
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sUserId ID пользователя
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $iCurrPage Номер страницы
|
|
|
|
|
* @param int $iPerPage Количество элементов на страницу
|
|
|
|
|
* @param array $aExcludeTarget Список ID владельцев для исклчения
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
2012-06-24 10:20:49 +03:00
|
|
|
|
public function GetFavouritesByUserId($sUserId,$sTargetType,$iCurrPage,$iPerPage,$aExcludeTarget=array()) {
|
2009-09-18 23:36:07 +03:00
|
|
|
|
$s=serialize($aExcludeTarget);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (false === ($data = $this->Cache_Get("{$sTargetType}_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_{$s}"))) {
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$data = array(
|
2009-10-15 02:34:03 +03:00
|
|
|
|
'collection' => $this->oMapper->GetFavouritesByUserId($sUserId,$sTargetType,$iCount,$iCurrPage,$iPerPage,$aExcludeTarget),
|
2009-08-22 00:01:09 +03:00
|
|
|
|
'count' => $iCount
|
|
|
|
|
);
|
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"{$sTargetType}_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_{$s}",
|
2009-08-22 00:01:09 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_{$sTargetType}_change",
|
|
|
|
|
"favourite_{$sTargetType}_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-08-22 00:01:09 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-18 23:36:07 +03:00
|
|
|
|
return $data;
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает число таргетов определенного типа в избранном по ID пользователя
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sUserId ID пользователя
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param array $aExcludeTarget Список ID владельцев для исклчения
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
2009-09-18 23:36:07 +03:00
|
|
|
|
public function GetCountFavouritesByUserId($sUserId,$sTargetType,$aExcludeTarget=array()) {
|
2009-09-19 03:43:00 +03:00
|
|
|
|
$s=serialize($aExcludeTarget);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (false === ($data = $this->Cache_Get("{$sTargetType}_count_favourite_user_{$sUserId}_{$s}"))) {
|
2009-09-18 23:36:07 +03:00
|
|
|
|
$data = $this->oMapper->GetCountFavouritesByUserId($sUserId,$sTargetType,$aExcludeTarget);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"{$sTargetType}_count_favourite_user_{$sUserId}_{$s}",
|
2009-08-22 00:01:09 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_{$sTargetType}_change",
|
|
|
|
|
"favourite_{$sTargetType}_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-08-22 00:01:09 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
|
|
|
|
}
|
2009-09-18 23:36:07 +03:00
|
|
|
|
return $data;
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
/**
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* Получает список комментариев к записям открытых блогов
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* из избранного указанного пользователя
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sUserId ID пользователя
|
|
|
|
|
* @param int $iCurrPage Номер страницы
|
|
|
|
|
* @param int $iPerPage Количество элементов на страницу
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
2012-06-24 10:20:49 +03:00
|
|
|
|
public function GetFavouriteOpenCommentsByUserId($sUserId,$iCurrPage,$iPerPage) {
|
|
|
|
|
if (false === ($data = $this->Cache_Get("comment_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_open"))) {
|
2009-09-19 13:53:33 +03:00
|
|
|
|
$data = array(
|
|
|
|
|
'collection' => $this->oMapper->GetFavouriteOpenCommentsByUserId($sUserId,$iCount,$iCurrPage,$iPerPage),
|
|
|
|
|
'count' => $iCount
|
|
|
|
|
);
|
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"comment_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_open",
|
2009-09-19 13:53:33 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_comment_change",
|
|
|
|
|
"favourite_comment_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-09-19 13:53:33 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
return $data;
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
/**
|
|
|
|
|
* Возвращает число комментариев к открытым блогам в избранном по ID пользователя
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sUserId ID пользователя
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function GetCountFavouriteOpenCommentsByUserId($sUserId) {
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (false === ($data = $this->Cache_Get("comment_count_favourite_user_{$sUserId}_open"))) {
|
2009-09-19 13:53:33 +03:00
|
|
|
|
$data = $this->oMapper->GetCountFavouriteOpenCommentsByUserId($sUserId);
|
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"comment_count_favourite_user_{$sUserId}_open",
|
2009-09-19 13:53:33 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_comment_change",
|
|
|
|
|
"favourite_comment_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-09-19 13:53:33 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return $data;
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
/**
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* Получает список топиков из открытых блогов
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* из избранного указанного пользователя
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $sUserId ID пользователя
|
|
|
|
|
* @param int $iCurrPage Номер страницы
|
|
|
|
|
* @param int $iPerPage Количество элементов на страницу
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
2012-06-24 10:20:49 +03:00
|
|
|
|
public function GetFavouriteOpenTopicsByUserId($sUserId,$iCurrPage,$iPerPage) {
|
|
|
|
|
if (false === ($data = $this->Cache_Get("topic_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_open"))) {
|
2009-09-19 13:53:33 +03:00
|
|
|
|
$data = array(
|
|
|
|
|
'collection' => $this->oMapper->GetFavouriteOpenTopicsByUserId($sUserId,$iCount,$iCurrPage,$iPerPage),
|
|
|
|
|
'count' => $iCount
|
|
|
|
|
);
|
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"topic_favourite_user_{$sUserId}_{$iCurrPage}_{$iPerPage}_open",
|
2009-09-19 13:53:33 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_topic_change",
|
|
|
|
|
"favourite_topic_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-09-19 13:53:33 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
return $data;
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-09-19 13:53:33 +03:00
|
|
|
|
/**
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* Возвращает число топиков в открытых блогах из избранного по ID пользователя
|
2009-09-19 13:53:33 +03:00
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param string $sUserId ID пользователя
|
2009-09-19 13:53:33 +03:00
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function GetCountFavouriteOpenTopicsByUserId($sUserId) {
|
2012-06-24 10:20:49 +03:00
|
|
|
|
if (false === ($data = $this->Cache_Get("topic_count_favourite_user_{$sUserId}_open"))) {
|
2009-09-19 13:53:33 +03:00
|
|
|
|
$data = $this->oMapper->GetCountFavouriteOpenTopicsByUserId($sUserId);
|
|
|
|
|
$this->Cache_Set(
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$data,
|
|
|
|
|
"topic_count_favourite_user_{$sUserId}_open",
|
2009-09-19 13:53:33 +03:00
|
|
|
|
array(
|
|
|
|
|
"favourite_topic_change",
|
|
|
|
|
"favourite_topic_change_user_{$sUserId}"
|
2012-06-24 10:20:49 +03:00
|
|
|
|
),
|
2009-09-19 13:53:33 +03:00
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return $data;
|
2012-06-24 10:20:49 +03:00
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
/**
|
|
|
|
|
* Добавляет таргет в избранное
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param ModuleFavourite_EntityFavourite $oFavourite Объект избранного
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2010-05-27 18:16:20 +03:00
|
|
|
|
public function AddFavourite(ModuleFavourite_EntityFavourite $oFavourite) {
|
2012-03-27 13:45:52 +03:00
|
|
|
|
if (!$oFavourite->getTags()) {
|
|
|
|
|
$oFavourite->setTags('');
|
|
|
|
|
}
|
|
|
|
|
$this->SetFavouriteTags($oFavourite);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
//чистим зависимые кеши
|
2012-06-24 10:20:49 +03:00
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("favourite_{$oFavourite->getTargetType()}_change_user_{$oFavourite->getUserId()}"));
|
|
|
|
|
$this->Cache_Delete("favourite_{$oFavourite->getTargetType()}_{$oFavourite->getTargetId()}_{$oFavourite->getUserId()}");
|
2009-08-22 00:01:09 +03:00
|
|
|
|
return $this->oMapper->AddFavourite($oFavourite);
|
|
|
|
|
}
|
2012-03-27 13:45:52 +03:00
|
|
|
|
/**
|
|
|
|
|
* Обновляет запись об избранном
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param ModuleFavourite_EntityFavourite $oFavourite Объект избранного
|
|
|
|
|
* @return bool
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*/
|
|
|
|
|
public function UpdateFavourite(ModuleFavourite_EntityFavourite $oFavourite) {
|
|
|
|
|
if (!$oFavourite->getTags()) {
|
|
|
|
|
$oFavourite->setTags('');
|
|
|
|
|
}
|
|
|
|
|
$this->SetFavouriteTags($oFavourite);
|
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("favourite_{$oFavourite->getTargetType()}_change_user_{$oFavourite->getUserId()}"));
|
|
|
|
|
$this->Cache_Delete("favourite_{$oFavourite->getTargetType()}_{$oFavourite->getTargetId()}_{$oFavourite->getUserId()}");
|
|
|
|
|
return $this->oMapper->UpdateFavourite($oFavourite);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Устанавливает список тегов для избранного
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param ModuleFavourite_EntityFavourite $oFavourite Объект избранного
|
|
|
|
|
* @param bool $bAddNew Добавлять новые теги или нет
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*/
|
|
|
|
|
public function SetFavouriteTags($oFavourite,$bAddNew=true) {
|
|
|
|
|
/**
|
|
|
|
|
* Удаляем все теги
|
|
|
|
|
*/
|
|
|
|
|
$this->oMapper->DeleteTags($oFavourite);
|
|
|
|
|
/**
|
|
|
|
|
* Добавляем новые
|
|
|
|
|
*/
|
|
|
|
|
if ($bAddNew and $oFavourite->getTags()) {
|
|
|
|
|
/**
|
|
|
|
|
* Добавляем теги объекта избранного, если есть
|
|
|
|
|
*/
|
|
|
|
|
if ($aTags=$this->GetTagsTarget($oFavourite->getTargetType(),$oFavourite->getTargetId())) {
|
|
|
|
|
foreach($aTags as $sTag) {
|
|
|
|
|
$oTag=Engine::GetEntity('ModuleFavourite_EntityTag',$oFavourite->_getData());
|
|
|
|
|
$oTag->setText(htmlspecialchars($sTag));
|
|
|
|
|
$oTag->setIsUser(0);
|
|
|
|
|
$this->oMapper->AddTag($oTag);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Добавляем пользовательские теги
|
|
|
|
|
*/
|
|
|
|
|
foreach($oFavourite->getTagsArray() as $sTag) {
|
|
|
|
|
$oTag=Engine::GetEntity('ModuleFavourite_EntityTag',$oFavourite->_getData());
|
|
|
|
|
$oTag->setText($sTag); // htmlspecialchars уже используется при установке тегов
|
|
|
|
|
$oTag->setIsUser(1);
|
|
|
|
|
$this->oMapper->AddTag($oTag);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
/**
|
|
|
|
|
* Удаляет таргет из избранного
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param ModuleFavourite_EntityFavourite $oFavourite Объект избранного
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2010-05-27 18:16:20 +03:00
|
|
|
|
public function DeleteFavourite(ModuleFavourite_EntityFavourite $oFavourite) {
|
2012-03-27 13:45:52 +03:00
|
|
|
|
$this->SetFavouriteTags($oFavourite,false);
|
2009-08-22 00:01:09 +03:00
|
|
|
|
//чистим зависимые кеши
|
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("favourite_{$oFavourite->getTargetType()}_change_user_{$oFavourite->getUserId()}"));
|
|
|
|
|
$this->Cache_Delete("favourite_{$oFavourite->getTargetType()}_{$oFavourite->getTargetId()}_{$oFavourite->getUserId()}");
|
|
|
|
|
return $this->oMapper->DeleteFavourite($oFavourite);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Меняет параметры публикации у таргета
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array|int $aTargetId Список ID владельцев
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $iPublish Флаг публикации
|
2009-08-22 00:01:09 +03:00
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
2009-11-20 02:59:01 +02:00
|
|
|
|
public function SetFavouriteTargetPublish($aTargetId,$sTargetType,$iPublish) {
|
|
|
|
|
if(!is_array($aTargetId)) $aTargetId = array($aTargetId);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
|
2009-08-22 00:01:09 +03:00
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("favourite_{$sTargetType}_change"));
|
2009-11-20 02:59:01 +02:00
|
|
|
|
return $this->oMapper->SetFavouriteTargetPublish($aTargetId,$sTargetType,$iPublish);
|
2009-10-25 22:01:05 +02:00
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Удаляет избранное по списку идентификаторов таргетов
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array|int $aTargetId Список ID владельцев
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
2009-10-25 22:01:05 +02:00
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function DeleteFavouriteByTargetId($aTargetId, $sTargetType) {
|
|
|
|
|
if(!is_array($aTargetId)) $aTargetId = array($aTargetId);
|
|
|
|
|
/**
|
|
|
|
|
* Чистим зависимые кеши
|
|
|
|
|
*/
|
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("favourite_{$sTargetType}_change"));
|
2012-03-27 13:45:52 +03:00
|
|
|
|
$this->DeleteTagByTarget($aTargetId,$sTargetType);
|
2012-06-24 10:20:49 +03:00
|
|
|
|
return $this->oMapper->DeleteFavouriteByTargetId($aTargetId,$sTargetType);
|
2009-10-25 22:01:05 +02:00
|
|
|
|
}
|
2012-04-16 05:19:05 +03:00
|
|
|
|
/**
|
|
|
|
|
* Удаление тегов по таргету
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array $aTargetId Список ID владельцев
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @return bool
|
2012-04-16 05:19:05 +03:00
|
|
|
|
*/
|
|
|
|
|
public function DeleteTagByTarget($aTargetId,$sTargetType) {
|
|
|
|
|
return $this->oMapper->DeleteTagByTarget($aTargetId,$sTargetType);
|
|
|
|
|
}
|
2012-03-27 13:45:52 +03:00
|
|
|
|
/**
|
|
|
|
|
* Возвращает список тегов для объекта избранного
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param int $iTargetId ID владельца
|
|
|
|
|
* @return bool|array
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*/
|
|
|
|
|
public function GetTagsTarget($sTargetType,$iTargetId) {
|
|
|
|
|
$sMethod = 'GetTagsTarget'.func_camelize($sTargetType);
|
|
|
|
|
if (method_exists($this,$sMethod)) {
|
|
|
|
|
return $this->$sMethod($iTargetId);
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает наиболее часто используемые теги
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $iUserId ID пользователя
|
|
|
|
|
* @param string $sTargetType Тип владельца
|
|
|
|
|
* @param bool $bIsUser Возвращает все теги ли только пользовательские
|
|
|
|
|
* @param int $iLimit Количество элементов
|
|
|
|
|
* @return array
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*/
|
|
|
|
|
public function GetGroupTags($iUserId,$sTargetType,$bIsUser,$iLimit) {
|
|
|
|
|
return $this->oMapper->GetGroupTags($iUserId,$sTargetType,$bIsUser,$iLimit);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает список тегов по фильтру
|
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param array $aFilter Фильтр
|
|
|
|
|
* @param array $aOrder Сортировка
|
|
|
|
|
* @param int $iCurrPage Номер страницы
|
|
|
|
|
* @param int $iPerPage Количество элементов на страницу
|
2012-03-27 13:45:52 +03:00
|
|
|
|
* @return array('collection'=>array,'count'=>int)
|
|
|
|
|
*/
|
|
|
|
|
public function GetTags($aFilter,$aOrder,$iCurrPage,$iPerPage) {
|
|
|
|
|
return array('collection'=>$this->oMapper->GetTags($aFilter,$aOrder,$iCount,$iCurrPage,$iPerPage),'count'=>$iCount);
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Возвращает список тегов для топика, название метода формируется автоматически из GetTagsTarget()
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @see GetTagsTarget
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*
|
2012-06-24 10:20:49 +03:00
|
|
|
|
* @param int $iTargetId ID владельца
|
|
|
|
|
* @return bool|array
|
2012-03-27 13:45:52 +03:00
|
|
|
|
*/
|
|
|
|
|
public function GetTagsTargetTopic($iTargetId) {
|
|
|
|
|
if ($oTopic=$this->Topic_GetTopicById($iTargetId)) {
|
|
|
|
|
return $oTopic->getTagsArray();
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2009-08-22 00:01:09 +03:00
|
|
|
|
}
|
|
|
|
|
?>
|