1
0
Fork 0
mirror of https://github.com/Oreolek/ifhub.club.git synced 2024-07-08 01:14:24 +03:00
ifhub.club/application/classes/modules/userfeed/mapper/Userfeed.mapper.class.php

112 lines
4.2 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?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
*
---------------------------------------------------------
*/
/**
* Маппер для работы с БД
*
* @package modules.userfeed
* @since 1.0
*/
class ModuleUserfeed_MapperUserfeed extends Mapper {
/**
* Подписать пользователя
*
* @param int $iUserId ID подписываемого пользователя
* @param int $iSubscribeType Тип подписки (см. константы класса)
* @param int $iTargetId ID цели подписки
* @return bool
*/
public function subscribeUser($iUserId, $iSubscribeType, $iTargetId) {
$sql = 'SELECT * FROM ' . Config::Get('db.table.userfeed_subscribe') . ' WHERE
user_id = ?d AND subscribe_type = ?d AND target_id = ?d';
if (!$this->oDb->select($sql, $iUserId, $iSubscribeType, $iTargetId)) {
$sql = 'INSERT INTO ' . Config::Get('db.table.userfeed_subscribe') . ' SET
user_id = ?d, subscribe_type = ?d, target_id = ?d';
$this->oDb->query($sql, $iUserId, $iSubscribeType, $iTargetId);
return true;
}
return false;
}
/**
* Отписать пользователя
*
* @param int $iUserId ID подписываемого пользователя
* @param int $iSubscribeType Тип подписки (см. константы класса)
* @param int $iTargetId ID цели подписки
* @return bool
*/
public function unsubscribeUser($iUserId, $iSubscribeType, $iTargetId) {
$sql = 'DELETE FROM ' . Config::Get('db.table.userfeed_subscribe') . ' WHERE
user_id = ?d AND subscribe_type = ?d AND target_id = ?d';
$res=$this->oDb->query($sql, $iUserId, $iSubscribeType, $iTargetId);
return $this->IsSuccessful($res);
}
/**
* Получить список подписок пользователя
*
* @param int $iUserId ID пользователя, для которого загружаются подписки
* @return array
*/
public function getUserSubscribes($iUserId) {
$sql = 'SELECT subscribe_type, target_id FROM ' . Config::Get('db.table.userfeed_subscribe') . ' WHERE user_id = ?d';
$aSubscribes = $this->oDb->select($sql, $iUserId);
$aResult = array('blogs' => array(), 'users' => array());
if (!count($aSubscribes)) return $aResult;
foreach ($aSubscribes as $aSubscribe) {
if($aSubscribe['subscribe_type'] == ModuleUserfeed::SUBSCRIBE_TYPE_BLOG) {
$aResult['blogs'][] = $aSubscribe['target_id'];
} elseif ($aSubscribe['subscribe_type'] == ModuleUserfeed::SUBSCRIBE_TYPE_USER) {
$aResult['users'][] = $aSubscribe['target_id'];
}
}
return $aResult;
}
/**
* Получить ленту топиков по подписке
*
* @param array $aUserSubscribes Список подписок пользователя
* @param int $iCount Число получаемых записей (если null, из конфига)
* @param int $iFromId Получить записи, начиная с указанной
* @return array
*/
public function readFeed($aUserSubscribes, $iCount, $iFromId) {
$sql = "
SELECT
t.topic_id
FROM
".Config::Get('db.table.topic')." as t,
".Config::Get('db.table.blog')." as b
WHERE
t.topic_publish = 1
AND t.blog_id=b.blog_id
AND b.blog_type!='close'
{ AND t.topic_id < ?d }
AND ( 1=0 { OR t.blog_id IN (?a) } { OR t.user_id IN (?a) } )
ORDER BY t.topic_id DESC
{ LIMIT 0, ?d }";
$aTopics=$aTopics=$this->oDb->selectCol($sql,
$iFromId ? $iFromId : DBSIMPLE_SKIP,
count($aUserSubscribes['blogs']) ? $aUserSubscribes['blogs'] : DBSIMPLE_SKIP,
count($aUserSubscribes['users']) ? $aUserSubscribes['users'] : DBSIMPLE_SKIP,
$iCount ? $iCount : DBSIMPLE_SKIP
);
return $aTopics;
}
}