2017-06-24 00:58:56 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AVE.cms
|
|
|
|
*
|
|
|
|
* @package AVE.cms
|
|
|
|
* @version 3.x
|
|
|
|
* @filesource
|
|
|
|
* @copyright © 2007-2017 AVE.cms, http://www.ave-cms.ru
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
class Sysblocks
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
2019-08-21 19:04:33 +03:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| aliasValidate
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Проверка алиаса на валидность и уникальность
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function aliasValidate ($alias = '', $id = 0)
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
|
|
|
global $AVE_DB;
|
|
|
|
|
|
|
|
//-- Соответствие требованиям
|
|
|
|
if (empty ($alias) || preg_match('/^[A-Za-z0-9-_]{1,20}$/i', $alias) !== 1 || is_numeric($alias))
|
|
|
|
return 'syn';
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sql = "
|
|
|
|
SELECT
|
|
|
|
1
|
2017-06-24 00:58:56 +03:00
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
WHERE
|
|
|
|
sysblock_alias = '" . $alias . "'
|
2019-08-21 19:04:33 +03:00
|
|
|
AND
|
2017-06-24 00:58:56 +03:00
|
|
|
id != '" . $id . "'
|
2019-08-21 19:04:33 +03:00
|
|
|
";
|
|
|
|
|
|
|
|
//-- Уникальность
|
|
|
|
return !(bool)$AVE_DB->Query($sql)->GetCell();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| startPage
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Гланая страница
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function startPage()
|
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
|
|
|
//-- Группы
|
|
|
|
$groups = [];
|
|
|
|
|
|
|
|
$sql = "
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks_groups
|
|
|
|
ORDER BY
|
|
|
|
position ASC
|
|
|
|
";
|
|
|
|
|
|
|
|
$query = $AVE_DB->Query($sql);
|
|
|
|
|
|
|
|
while ($row = $query->FetchAssocArray())
|
|
|
|
{
|
|
|
|
$row['count'] = 0;
|
|
|
|
$groups[$row['id']] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
//-- Блоки
|
|
|
|
$sysblocks = [];
|
|
|
|
|
|
|
|
$sql = "
|
|
|
|
SELECT
|
|
|
|
a.*,
|
|
|
|
a.sysblock_group_id
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks AS a
|
|
|
|
LEFT JOIN
|
|
|
|
" . PREFIX . "_sysblocks_groups AS b
|
|
|
|
ON a.sysblock_group_id = b.id
|
|
|
|
ORDER BY
|
|
|
|
b.position ASC, a.id ASC
|
|
|
|
";
|
|
|
|
|
|
|
|
$query = $AVE_DB->Query($sql);
|
|
|
|
|
|
|
|
while ($row = $query->FetchAssocArray())
|
|
|
|
{
|
|
|
|
$row['author'] = get_username_by_id($row['sysblock_author_id']);
|
|
|
|
$sysblocks[$row['sysblock_group_id']][] = $row;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($sysblocks AS $_k => $_v)
|
|
|
|
{
|
|
|
|
if ($_k == 0)
|
|
|
|
{
|
|
|
|
$groups[$_k]['position'] = 0;
|
|
|
|
$groups[$_k]['title'] = 'Без группы';
|
|
|
|
$groups[$_k]['description'] = 'Описание отсутсвует';
|
|
|
|
}
|
|
|
|
|
|
|
|
$groups[$_k]['count'] = count($sysblocks[$_k]);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Debug::_echo($sysblocks, true);
|
|
|
|
//Debug::_echo($groups, true);
|
|
|
|
$AVE_Template->assign('groups', $groups);
|
|
|
|
$AVE_Template->assign('sysblocks', $sysblocks);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/start.tpl'));
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| listBlocks
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Список системных блоков
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function listBlocks()
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sysblocks = [];
|
2017-06-24 00:58:56 +03:00
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sql = "
|
2017-06-24 00:58:56 +03:00
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
ORDER BY
|
|
|
|
id
|
2019-08-21 19:04:33 +03:00
|
|
|
";
|
|
|
|
|
|
|
|
$query = $AVE_DB->Query($sql);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
// Формируем массив из полученных данных
|
2019-08-21 19:04:33 +03:00
|
|
|
while ($row = $query->FetchRow())
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
|
|
|
$row->sysblock_author_id = get_username_by_id($row->sysblock_author_id);
|
|
|
|
array_push($sys_blocks, $row);
|
|
|
|
}
|
|
|
|
|
|
|
|
$AVE_Template->assign('sid', 0);
|
2019-08-21 19:04:33 +03:00
|
|
|
$AVE_Template->assign('sysblocks', $sysblocks);
|
2017-06-24 00:58:56 +03:00
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/list.tpl'));
|
|
|
|
}
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| listGroups
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Список групп системных блоков
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function listGroups()
|
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
|
|
|
$groups = [];
|
|
|
|
|
|
|
|
$sql = "
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks_groups
|
|
|
|
ORDER BY
|
|
|
|
id
|
|
|
|
";
|
|
|
|
|
|
|
|
$query = $AVE_DB->Query($sql);
|
|
|
|
|
|
|
|
// Формируем массив из полученных данных
|
|
|
|
while ($row = $query->FetchAssocArray())
|
|
|
|
array_push($groups, $row);
|
|
|
|
|
|
|
|
$AVE_Template->assign('sid', 0);
|
|
|
|
$AVE_Template->assign('groups', $groups);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/groups.tpl'));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| newBlock
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Создание системного блока
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function newBlock ()
|
|
|
|
{
|
|
|
|
global $AVE_Template;
|
|
|
|
|
|
|
|
$row['sysblock_name'] = '';
|
|
|
|
$row['sysblock_alias'] = '';
|
|
|
|
$row['sysblock_text'] = '';
|
|
|
|
$row['sysblock_visual'] = (isset($_REQUEST['sysblock_visual']) && $_REQUEST['sysblock_visual'] != 0) ? $_REQUEST['sysblock_visual'] : '';
|
|
|
|
|
|
|
|
$AVE_Template->assign('sid', 0);
|
|
|
|
|
|
|
|
if ((isset($_REQUEST['sysblock_visual']) && $_REQUEST['sysblock_visual'] == 1) || $row['sysblock_visual'] == 1)
|
|
|
|
{
|
|
|
|
$oCKeditor = new CKeditor();
|
|
|
|
$oCKeditor->returnOutput = true;
|
|
|
|
$oCKeditor->config['customConfig'] = 'sysblock.js';
|
|
|
|
$oCKeditor->config['toolbar'] = 'Big';
|
|
|
|
$oCKeditor->config['height'] = 400;
|
|
|
|
$config = array();
|
|
|
|
$row['sysblock_text'] = $oCKeditor->editor('sysblock_text', $row['sysblock_text'], $config);
|
|
|
|
|
|
|
|
$AVE_Template->assign($row);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/form_visual.tpl'));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$AVE_Template->assign($row);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/form.tpl'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| editBlock
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Редактирование системного блока
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function editBlock ()
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sysblock_id = (int)$_REQUEST['id'];
|
|
|
|
|
|
|
|
$row = $AVE_DB->Query("
|
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
WHERE
|
|
|
|
id = '" . $sysblock_id . "'
|
|
|
|
")->FetchAssocArray();
|
|
|
|
|
|
|
|
$AVE_Template->assign('sid', $sysblock_id);
|
|
|
|
|
|
|
|
if ((isset($_REQUEST['sysblock_visual']) && $_REQUEST['sysblock_visual'] == 1) || $row['sysblock_visual'] == 1)
|
|
|
|
{
|
|
|
|
$oCKeditor = new CKeditor();
|
|
|
|
$oCKeditor->returnOutput = true;
|
|
|
|
$oCKeditor->config['customConfig'] = 'sysblock.js';
|
|
|
|
$oCKeditor->config['toolbar'] = 'Big';
|
|
|
|
$oCKeditor->config['height'] = 400;
|
|
|
|
$config = array();
|
|
|
|
$row['sysblock_text'] = $oCKeditor->editor('sysblock_text', $row['sysblock_text'], $config);
|
|
|
|
|
|
|
|
$AVE_Template->assign($row);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/form_visual.tpl'));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$AVE_Template->assign($row);
|
|
|
|
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/form.tpl'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| editBlock
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Сохранение системного блока
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function saveBlock()
|
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
|
|
|
$sysblock_id = $_REQUEST['id']
|
|
|
|
? (int)$_REQUEST['id']
|
|
|
|
: null;
|
|
|
|
|
2017-06-24 00:58:56 +03:00
|
|
|
if (is_numeric($sysblock_id))
|
|
|
|
{
|
|
|
|
|
|
|
|
$_REQUEST['sysblock_external'] = (isset($_REQUEST['sysblock_external'])) ? $_REQUEST['sysblock_external'] : 0;
|
|
|
|
$_REQUEST['sysblock_ajax'] = (isset($_REQUEST['sysblock_ajax'])) ? $_REQUEST['sysblock_ajax'] : 0;
|
2019-08-21 19:04:33 +03:00
|
|
|
$_REQUEST['sysblock_eval'] = (isset($_REQUEST['sysblock_eval'])) ? $_REQUEST['sysblock_eval'] : 0;
|
2017-06-24 00:58:56 +03:00
|
|
|
$_REQUEST['sysblock_visual'] = (isset($_REQUEST['sysblock_visual'])) ? $_REQUEST['sysblock_visual'] : 0;
|
2019-08-19 09:34:29 +03:00
|
|
|
$_REQUEST['sysblock_alias'] = isset($_REQUEST['sysblock_alias']) ? $_REQUEST['sysblock_alias'] : '';
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
$sql = $AVE_DB->Query("
|
|
|
|
UPDATE
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
SET
|
|
|
|
sysblock_name = '" . $_REQUEST['sysblock_name'] . "',
|
|
|
|
sysblock_description = '" . addslashes($_REQUEST['sysblock_description']) . "',
|
|
|
|
sysblock_alias = '" . $_REQUEST['sysblock_alias'] . "',
|
|
|
|
sysblock_text = '" . $_REQUEST['sysblock_text'] . "',
|
2019-08-19 09:34:29 +03:00
|
|
|
sysblock_eval = '" . (int)$_REQUEST['sysblock_eval'] . "',
|
2017-06-24 00:58:56 +03:00
|
|
|
sysblock_external = '" . (int)$_REQUEST['sysblock_external'] . "',
|
|
|
|
sysblock_ajax = '" . (int)$_REQUEST['sysblock_ajax'] . "',
|
|
|
|
sysblock_visual = '" . (int)$_REQUEST['sysblock_visual'] . "'
|
|
|
|
WHERE
|
|
|
|
id = '" . $sysblock_id . "'
|
|
|
|
");
|
|
|
|
|
|
|
|
if ($sql->_result === false)
|
|
|
|
{
|
|
|
|
$message = $AVE_Template->get_config_vars('SYSBLOCK_SAVED_ERR');
|
|
|
|
$header = $AVE_Template->get_config_vars('SYSBLOCK_ERROR');
|
|
|
|
$theme = 'error';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$message = $AVE_Template->get_config_vars('SYSBLOCK_SAVED');
|
|
|
|
$header = $AVE_Template->get_config_vars('SYSBLOCK_SUCCESS');
|
|
|
|
$theme = 'accept';
|
|
|
|
|
|
|
|
//-- Стираем кеш сисблока
|
2019-08-21 19:04:33 +03:00
|
|
|
self::clearCache($sysblock_id, $_REQUEST['sysblock_alias']);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
//-- Сохраняем системное сообщение в журнал
|
|
|
|
reportLog($AVE_Template->get_config_vars('SYSBLOCK_SQLUPDATE') . " (" . stripslashes($_REQUEST['sysblock_name']) . ") (id: $sysblock_id)");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isAjax())
|
|
|
|
{
|
|
|
|
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$AVE_Template->assign('message', $message);
|
|
|
|
header('Location:index.php?do=sysblocks&cp=' . SESSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
else
|
2019-08-21 19:04:33 +03:00
|
|
|
{
|
|
|
|
$AVE_DB->Query("
|
2017-06-24 00:58:56 +03:00
|
|
|
INSERT INTO
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
SET
|
|
|
|
sysblock_name = '" . $_REQUEST['sysblock_name'] . "',
|
|
|
|
sysblock_description = '" . addslashes($_REQUEST['sysblock_description']) . "',
|
|
|
|
sysblock_alias = '" . $_REQUEST['sysblock_alias'] . "',
|
|
|
|
sysblock_text = '" . $_REQUEST['sysblock_text'] . "',
|
|
|
|
sysblock_author_id = '" . (int)$_SESSION['user_id'] . "',
|
2019-08-19 09:34:29 +03:00
|
|
|
sysblock_eval = '" . (int)$_REQUEST['sysblock_eval'] . "',
|
2017-06-24 00:58:56 +03:00
|
|
|
sysblock_external = '" . (int)$_REQUEST['sysblock_external'] . "',
|
|
|
|
sysblock_ajax = '" . (int)$_REQUEST['sysblock_ajax'] . "',
|
|
|
|
sysblock_visual = '" . (int)$_REQUEST['sysblock_visual'] . "',
|
|
|
|
sysblock_created = '" . time() . "'
|
|
|
|
");
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sysblock_id = $AVE_DB->InsertId();
|
2017-06-24 00:58:56 +03:00
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
//-- Сохраняем системное сообщение в журнал
|
|
|
|
reportLog($AVE_Template->get_config_vars('SYSBLOCK_SQLNEW') . " (" . stripslashes($_REQUEST['sysblock_name']) . ") (id: $sysblock_id)");
|
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
if (! isset($_REQUEST['next_edit']))
|
|
|
|
header('Location:index.php?do=sysblocks&cp=' . SESSION);
|
|
|
|
else
|
|
|
|
header('Location:index.php?do=sysblocks&action=edit&&id=' . $sysblock_id . '&cp=' . SESSION);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| delBlock
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Удаление системного блока
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function delBlock ()
|
2017-06-24 00:58:56 +03:00
|
|
|
{
|
|
|
|
global $AVE_DB, $AVE_Template;
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
$sysblock_id = $_REQUEST['id'];
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
if (is_numeric($sysblock_id))
|
|
|
|
{
|
2019-08-21 19:04:33 +03:00
|
|
|
$sysblock = $AVE_DB->Query("
|
2017-06-24 00:58:56 +03:00
|
|
|
SELECT
|
|
|
|
*
|
|
|
|
FROM
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
WHERE
|
|
|
|
id = '" . $sysblock_id . "'
|
|
|
|
")->FetchRow();
|
|
|
|
|
|
|
|
$AVE_DB->Query("
|
|
|
|
DELETE FROM
|
|
|
|
" . PREFIX . "_sysblocks
|
|
|
|
WHERE
|
|
|
|
id = '" . $sysblock_id . "'
|
|
|
|
");
|
|
|
|
|
|
|
|
//-- Стираем кеш сисблока
|
2019-08-21 19:04:33 +03:00
|
|
|
self::clearCache($sysblock_id, $sysblock->sysblock_alias);
|
2017-06-24 00:58:56 +03:00
|
|
|
|
|
|
|
//-- Сохраняем системное сообщение в журнал
|
2019-08-21 19:04:33 +03:00
|
|
|
reportLog($AVE_Template->get_config_vars('SYSBLOCK_SQLDEL') . " (" . stripslashes($sysblock->sysblock_name) . ") (id: $sysblock_id)");
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
header('Location:index.php?do=sysblocks&cp=' . SESSION);
|
|
|
|
}
|
2018-04-19 19:11:58 +03:00
|
|
|
|
|
|
|
|
2019-08-21 19:04:33 +03:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
| editBlock
|
|
|
|
|--------------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Очистка кеша системного блока
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
public static function clearCache ($id, $alias = null)
|
2018-04-19 19:11:58 +03:00
|
|
|
{
|
2018-05-19 09:15:15 +03:00
|
|
|
$from_id = BASE_DIR . '/tmp/cache/sql/sysblocks/' . $id;
|
|
|
|
rrmdir($from_id);
|
2018-04-19 19:11:58 +03:00
|
|
|
|
2018-05-19 09:15:15 +03:00
|
|
|
if ($alias)
|
|
|
|
{
|
|
|
|
$from_alias = BASE_DIR . '/tmp/cache/sql/sysblocks/' . $alias;
|
|
|
|
rrmdir($from_alias);
|
|
|
|
}
|
2018-04-19 19:11:58 +03:00
|
|
|
}
|
2017-06-24 00:58:56 +03:00
|
|
|
}
|
|
|
|
?>
|