2009-06-28 01:35:26 +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
|
|
|
|
|
*
|
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
set_include_path(get_include_path().PATH_SEPARATOR.dirname(__FILE__));
|
|
|
|
|
require_once('mapper/Vote.mapper.class.php');
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Модуль для работы с голосованиями
|
|
|
|
|
*
|
|
|
|
|
*/
|
2010-05-27 17:02:43 +03:00
|
|
|
|
class ModuleVote extends Module {
|
2009-06-28 01:35:26 +03:00
|
|
|
|
protected $oMapper;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Инициализация
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
public function Init() {
|
|
|
|
|
$this->oMapper=new Mapper_Vote($this->Database_GetConnect());
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Добавляет голосование
|
|
|
|
|
*
|
|
|
|
|
* @param VoteEntity_Vote $oVote
|
|
|
|
|
* @return unknown
|
|
|
|
|
*/
|
|
|
|
|
public function AddVote(VoteEntity_Vote $oVote) {
|
|
|
|
|
if ($this->oMapper->AddVote($oVote)) {
|
|
|
|
|
$this->Cache_Delete("vote_{$oVote->getTargetType()}_{$oVote->getTargetId()}_{$oVote->getVoterId()}");
|
2009-08-08 12:33:32 +03:00
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("vote_update_{$oVote->getTargetType()}_{$oVote->getVoterId()}"));
|
2009-06-28 01:35:26 +03:00
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Получает голосование
|
|
|
|
|
*
|
|
|
|
|
* @param unknown_type $sTargetId
|
|
|
|
|
* @param unknown_type $sTargetType
|
|
|
|
|
* @param unknown_type $sUserId
|
|
|
|
|
* @return unknown
|
|
|
|
|
*/
|
|
|
|
|
public function GetVote($sTargetId,$sTargetType,$sUserId) {
|
|
|
|
|
$data=$this->GetVoteByArray($sTargetId,$sTargetType,$sUserId);
|
|
|
|
|
if (isset($data[$sTargetId])) {
|
|
|
|
|
return $data[$sTargetId];
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Получить список голосований по списку айдишников
|
|
|
|
|
*
|
|
|
|
|
* @param unknown_type $sTargetId
|
|
|
|
|
* @param unknown_type $sTargetType
|
|
|
|
|
*/
|
|
|
|
|
public function GetVoteByArray($aTargetId,$sTargetType,$sUserId) {
|
2009-08-08 12:33:32 +03:00
|
|
|
|
if (!$aTargetId) {
|
|
|
|
|
return array();
|
|
|
|
|
}
|
2009-10-10 22:13:14 +03:00
|
|
|
|
if (Config::Get('sys.cache.solid')) {
|
2009-08-08 12:33:32 +03:00
|
|
|
|
return $this->GetVoteByArraySolid($aTargetId,$sTargetType,$sUserId);
|
|
|
|
|
}
|
2009-06-28 01:35:26 +03:00
|
|
|
|
if (!is_array($aTargetId)) {
|
|
|
|
|
$aTargetId=array($aTargetId);
|
|
|
|
|
}
|
|
|
|
|
$aTargetId=array_unique($aTargetId);
|
|
|
|
|
$aVote=array();
|
|
|
|
|
$aIdNotNeedQuery=array();
|
|
|
|
|
/**
|
|
|
|
|
* Делаем мульти-запрос к кешу
|
|
|
|
|
*/
|
|
|
|
|
$aCacheKeys=func_build_cache_keys($aTargetId,"vote_{$sTargetType}_",'_'.$sUserId);
|
2009-08-08 12:33:32 +03:00
|
|
|
|
if (false !== ($data = $this->Cache_Get($aCacheKeys))) {
|
2009-06-28 01:35:26 +03:00
|
|
|
|
/**
|
|
|
|
|
* проверяем что досталось из кеша
|
|
|
|
|
*/
|
|
|
|
|
foreach ($aCacheKeys as $sValue => $sKey ) {
|
|
|
|
|
if (array_key_exists($sKey,$data)) {
|
|
|
|
|
if ($data[$sKey]) {
|
|
|
|
|
$aVote[$data[$sKey]->getTargetId()]=$data[$sKey];
|
|
|
|
|
} else {
|
|
|
|
|
$aIdNotNeedQuery[]=$sValue;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Смотрим каких топиков не было в кеше и делаем запрос в БД
|
|
|
|
|
*/
|
|
|
|
|
$aIdNeedQuery=array_diff($aTargetId,array_keys($aVote));
|
|
|
|
|
$aIdNeedQuery=array_diff($aIdNeedQuery,$aIdNotNeedQuery);
|
|
|
|
|
$aIdNeedStore=$aIdNeedQuery;
|
|
|
|
|
if ($data = $this->oMapper->GetVoteByArray($aIdNeedQuery,$sTargetType,$sUserId)) {
|
|
|
|
|
foreach ($data as $oVote) {
|
|
|
|
|
/**
|
|
|
|
|
* Добавляем к результату и сохраняем в кеш
|
|
|
|
|
*/
|
|
|
|
|
$aVote[$oVote->getTargetId()]=$oVote;
|
2009-08-08 12:33:32 +03:00
|
|
|
|
$this->Cache_Set($oVote, "vote_{$oVote->getTargetType()}_{$oVote->getTargetId()}_{$oVote->getVoterId()}", array(), 60*60*24*7);
|
2009-06-28 01:35:26 +03:00
|
|
|
|
$aIdNeedStore=array_diff($aIdNeedStore,array($oVote->getTargetId()));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Сохраняем в кеш запросы не вернувшие результата
|
|
|
|
|
*/
|
|
|
|
|
foreach ($aIdNeedStore as $sId) {
|
2009-08-08 12:33:32 +03:00
|
|
|
|
$this->Cache_Set(null, "vote_{$sTargetType}_{$sId}_{$sUserId}", array(), 60*60*24*7);
|
2009-06-28 01:35:26 +03:00
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* Сортируем результат согласно входящему массиву
|
|
|
|
|
*/
|
|
|
|
|
$aVote=func_array_sort_by_keys($aVote,$aTargetId);
|
|
|
|
|
return $aVote;
|
|
|
|
|
}
|
2009-08-08 12:33:32 +03:00
|
|
|
|
/**
|
|
|
|
|
* Получить список голосований по списку айдишников, но используя единый кеш
|
|
|
|
|
*
|
|
|
|
|
* @param unknown_type $aTargetId
|
|
|
|
|
* @param unknown_type $sTargetType
|
|
|
|
|
* @param unknown_type $sUserId
|
|
|
|
|
* @return unknown
|
|
|
|
|
*/
|
|
|
|
|
public function GetVoteByArraySolid($aTargetId,$sTargetType,$sUserId) {
|
|
|
|
|
if (!is_array($aTargetId)) {
|
|
|
|
|
$aTargetId=array($aTargetId);
|
|
|
|
|
}
|
|
|
|
|
$aTargetId=array_unique($aTargetId);
|
|
|
|
|
$aVote=array();
|
|
|
|
|
$s=join(',',$aTargetId);
|
|
|
|
|
if (false === ($data = $this->Cache_Get("vote_{$sTargetType}_{$sUserId}_id_{$s}"))) {
|
|
|
|
|
$data = $this->oMapper->GetVoteByArray($aTargetId,$sTargetType,$sUserId);
|
|
|
|
|
foreach ($data as $oVote) {
|
|
|
|
|
$aVote[$oVote->getTargetId()]=$oVote;
|
|
|
|
|
}
|
2009-11-10 20:49:53 +02:00
|
|
|
|
$this->Cache_Set(
|
|
|
|
|
$aVote, "vote_{$sTargetType}_{$sUserId}_id_{$s}",
|
|
|
|
|
array("vote_update_{$sTargetType}_{$sUserId}","vote_update_{$sTargetType}"),
|
|
|
|
|
60*60*24*1
|
|
|
|
|
);
|
2009-08-08 12:33:32 +03:00
|
|
|
|
return $aVote;
|
|
|
|
|
}
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
2009-10-25 22:01:05 +02:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Удаляет голосование из базы по списку идентификаторов таргета
|
|
|
|
|
*
|
|
|
|
|
* @param array|int $aTargetId
|
|
|
|
|
* @param string $sTargetType
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function DeleteVoteByTarget($aTargetId, $sTargetType) {
|
|
|
|
|
if (!is_array($aTargetId)) $aTargetId=array($aTargetId);
|
|
|
|
|
$aTargetId=array_unique($aTargetId);
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Чистим зависимые кеши
|
|
|
|
|
*/
|
|
|
|
|
$this->Cache_Clean(Zend_Cache::CLEANING_MODE_MATCHING_TAG,array("vote_update_{$sTargetType}"));
|
|
|
|
|
return $this->oMapper->DeleteVoteByTarget($aTargetId,$sTargetType);
|
|
|
|
|
}
|
2009-06-28 01:35:26 +03:00
|
|
|
|
}
|
|
|
|
|
?>
|