2009-09-09 20:39:26 +03:00
|
|
|
|
<?php
|
2014-10-08 08:20:29 +03:00
|
|
|
|
/*
|
|
|
|
|
* LiveStreet CMS
|
|
|
|
|
* Copyright © 2013 OOO "ЛС-СОФТ"
|
|
|
|
|
*
|
|
|
|
|
* ------------------------------------------------------
|
|
|
|
|
*
|
|
|
|
|
* Official site: www.livestreetcms.com
|
|
|
|
|
* Contact e-mail: office@livestreetcms.com
|
|
|
|
|
*
|
|
|
|
|
* GNU General Public License, version 2:
|
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
|
*
|
|
|
|
|
* ------------------------------------------------------
|
|
|
|
|
*
|
|
|
|
|
* @link http://www.livestreetcms.com
|
|
|
|
|
* @copyright 2013 OOO "ЛС-СОФТ"
|
|
|
|
|
* @author Maxim Mzhelskiy <rus.engine@gmail.com>
|
|
|
|
|
*
|
|
|
|
|
*/
|
2009-09-09 20:39:26 +03:00
|
|
|
|
|
2012-06-24 13:47:34 +03:00
|
|
|
|
/**
|
|
|
|
|
* Маппер для работы с БД
|
|
|
|
|
*
|
2014-10-08 08:20:29 +03:00
|
|
|
|
* @package application.modules.notify
|
2012-06-24 13:47:34 +03:00
|
|
|
|
* @since 1.0
|
|
|
|
|
*/
|
2014-10-08 11:49:34 +03:00
|
|
|
|
class ModuleNotify_MapperNotify extends Mapper
|
|
|
|
|
{
|
|
|
|
|
/**
|
|
|
|
|
* Добавляет задание
|
|
|
|
|
*
|
|
|
|
|
* @param ModuleNotify_EntityTask $oNotifyTask Объект задания
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function AddTask(ModuleNotify_EntityTask $oNotifyTask)
|
|
|
|
|
{
|
|
|
|
|
$sql = "
|
|
|
|
|
INSERT INTO " . Config::Get('db.table.notify_task') . "
|
2009-09-09 20:39:26 +03:00
|
|
|
|
( user_login, user_mail, notify_subject, notify_text, date_created, notify_task_status )
|
|
|
|
|
VALUES
|
|
|
|
|
( ?, ?, ?, ?, ?, ?d )
|
|
|
|
|
";
|
2012-06-24 13:47:34 +03:00
|
|
|
|
|
2014-10-08 11:49:34 +03:00
|
|
|
|
if ($this->oDb->query(
|
|
|
|
|
$sql,
|
|
|
|
|
$oNotifyTask->getUserLogin(),
|
|
|
|
|
$oNotifyTask->getUserMail(),
|
|
|
|
|
$oNotifyTask->getNotifySubject(),
|
|
|
|
|
$oNotifyTask->getNotifyText(),
|
|
|
|
|
$oNotifyTask->getDateCreated(),
|
|
|
|
|
$oNotifyTask->getTaskStatus()
|
|
|
|
|
) === 0
|
|
|
|
|
) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2012-06-24 13:47:34 +03:00
|
|
|
|
|
2014-10-08 11:49:34 +03:00
|
|
|
|
/**
|
|
|
|
|
* Добавляет задания списком
|
|
|
|
|
*
|
|
|
|
|
* @param array $aTasks Список объектов заданий
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function AddTaskArray($aTasks)
|
|
|
|
|
{
|
|
|
|
|
if (!is_array($aTasks) && count($aTasks) == 0) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$aValues = array();
|
|
|
|
|
foreach ($aTasks as $oTask) {
|
|
|
|
|
$aValues[] = "(" . implode(',',
|
|
|
|
|
array(
|
|
|
|
|
$this->oDb->escape($oTask->getUserLogin()),
|
|
|
|
|
$this->oDb->escape($oTask->getUserMail()),
|
|
|
|
|
$this->oDb->escape($oTask->getNotifySubject()),
|
|
|
|
|
$this->oDb->escape($oTask->getNotifyText()),
|
|
|
|
|
$this->oDb->escape($oTask->getDateCreated()),
|
|
|
|
|
$this->oDb->escape($oTask->getTaskStatus())
|
|
|
|
|
)
|
|
|
|
|
) . ")";
|
|
|
|
|
}
|
|
|
|
|
$sql = "
|
|
|
|
|
INSERT INTO " . Config::Get('db.table.notify_task') . "
|
2009-09-09 20:39:26 +03:00
|
|
|
|
( user_login, user_mail, notify_subject, notify_text, date_created, notify_task_status )
|
|
|
|
|
VALUES
|
2014-10-08 11:49:34 +03:00
|
|
|
|
" . implode(', ', $aValues);
|
|
|
|
|
|
|
|
|
|
return $this->oDb->query($sql);
|
|
|
|
|
}
|
2009-09-09 20:39:26 +03:00
|
|
|
|
|
2014-10-08 11:49:34 +03:00
|
|
|
|
/**
|
|
|
|
|
* Удаляет задание
|
|
|
|
|
*
|
|
|
|
|
* @param ModuleNotify_EntityTask $oNotifyTask Объект задания
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function DeleteTask(ModuleNotify_EntityTask $oNotifyTask)
|
|
|
|
|
{
|
|
|
|
|
$sql = "
|
|
|
|
|
DELETE FROM " . Config::Get('db.table.notify_task') . "
|
2009-09-09 20:39:26 +03:00
|
|
|
|
WHERE
|
|
|
|
|
notify_task_id = ?d
|
2012-06-24 13:47:34 +03:00
|
|
|
|
";
|
2014-10-08 11:49:34 +03:00
|
|
|
|
$res = $this->oDb->query($sql, $oNotifyTask->getTaskId());
|
|
|
|
|
return $this->IsSuccessful($res);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Удаляет отложенные Notify-задания по списку идентификаторов
|
|
|
|
|
*
|
|
|
|
|
* @param array $aTaskId Список ID заданий на отправку
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
public function DeleteTaskByArrayId($aTaskId)
|
|
|
|
|
{
|
|
|
|
|
$sql = "
|
|
|
|
|
DELETE FROM " . Config::Get('db.table.notify_task') . "
|
2009-09-09 20:39:26 +03:00
|
|
|
|
WHERE
|
|
|
|
|
notify_task_id IN(?a)
|
2012-06-24 13:47:34 +03:00
|
|
|
|
";
|
2014-10-08 11:49:34 +03:00
|
|
|
|
$res = $this->oDb->query($sql, $aTaskId);
|
|
|
|
|
return $this->IsSuccessful($res);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Получает массив заданий на публикацию из базы с указанным количественным ограничением (выборка FIFO)
|
|
|
|
|
*
|
|
|
|
|
* @param int $iLimit Количество
|
|
|
|
|
* @return array
|
|
|
|
|
*/
|
|
|
|
|
public function GetTasks($iLimit)
|
|
|
|
|
{
|
|
|
|
|
$sql = "SELECT *
|
|
|
|
|
FROM " . Config::Get('db.table.notify_task') . "
|
2009-09-10 21:51:58 +03:00
|
|
|
|
ORDER BY date_created ASC
|
|
|
|
|
LIMIT ?d";
|
2014-10-08 11:49:34 +03:00
|
|
|
|
$aTasks = array();
|
|
|
|
|
if ($aRows = $this->oDb->select($sql, $iLimit)) {
|
|
|
|
|
foreach ($aRows as $aTask) {
|
|
|
|
|
$aTasks[] = Engine::GetEntity('Notify_Task', $aTask);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return $aTasks;
|
|
|
|
|
}
|
2014-05-28 08:37:30 +03:00
|
|
|
|
}
|