ave-cms/class/class.sysblocks.php

675 lines
17 KiB
PHP
Raw Normal View History

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();
}
2019-08-22 12:14:11 +03:00
/*
|--------------------------------------------------------------------------------------
| getGroups
|--------------------------------------------------------------------------------------
|
| Получаем список групп
|
*/
public static function getGroups ()
{
global $AVE_DB;
$sql = "
SELECT
*
FROM
" . PREFIX . "_sysblocks_groups
";
$query = $AVE_DB->Query($sql);
$groups = [];
while ($row = $query->FetchRow())
array_push($groups, $row);
return $groups;
}
2019-08-21 19:04:33 +03:00
/*
|--------------------------------------------------------------------------------------
| startPage
|--------------------------------------------------------------------------------------
|
| Гланая страница
|
*/
2020-02-26 21:59:06 +03:00
public static function startPage ()
2019-08-21 19:04:33 +03:00
{
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]['count'] = count($sysblocks[$_k]);
}
$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
|--------------------------------------------------------------------------------------
|
| Список системных блоков
|
*/
2020-02-26 21:59:06 +03:00
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
|--------------------------------------------------------------------------------------
|
| Список групп системных блоков
|
*/
2020-02-26 21:59:06 +03:00
public static function listGroups ()
2019-08-21 19:04:33 +03:00
{
global $AVE_DB, $AVE_Template;
$groups = [];
$sql = "
SELECT
*
FROM
" . PREFIX . "_sysblocks_groups
ORDER BY
2020-02-26 21:59:06 +03:00
position
2019-08-21 19:04:33 +03:00
";
$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'));
}
2020-02-26 21:59:06 +03:00
/*
|--------------------------------------------------------------------------------------
| groupsSort
|--------------------------------------------------------------------------------------
|
| Сортировка групп
|
*/
public static function groupsSort ()
{
global $AVE_DB, $AVE_Template;
foreach ($_REQUEST['sort'] AS $position => $group_id)
{
$position++;
$sql = "
UPDATE
" . PREFIX . "_sysblocks_groups
SET
position = '" . (int)$position . "'
WHERE
id = '" . (int)$group_id . "'
";
$AVE_DB->Query($sql);
}
if (isAjax())
{
$message = $AVE_Template->get_config_vars('RUBRIK_SORTED');
$header = $AVE_Template->get_config_vars('RUBRIK_FILDS_SUCCESS');
$theme = 'accept';
echo json_encode(['message' => $message, 'header' => $header, 'theme' => $theme]);
exit;
}
}
/*
|--------------------------------------------------------------------------------------
| newGroup
|--------------------------------------------------------------------------------------
|
| Новая группа
|
*/
public static function newGroup ()
{
global $AVE_DB;
$sql = "
SELECT
MAX(position)
FROM
" . PREFIX . "_sysblocks_groups
";
$position = $AVE_DB->Query($sql)->GetCell();
$position++;
$sql = "
INSERT
" . PREFIX . "_sysblocks_groups
SET
position = '" . $position . "',
title = '" . $_REQUEST['title'] . "',
description = '" . $_REQUEST['description'] . "'
";
$AVE_DB->Query($sql);
header('Location:index.php?do=sysblocks&action=groups&cp=' . SESSION);
exit;
}
/*
|--------------------------------------------------------------------------------------
| delGroup
|--------------------------------------------------------------------------------------
|
| Удалить группу
|
*/
public static function delGroup ()
{
global $AVE_DB;
$id = (int)$_REQUEST['id'];
$sql = "
DELETE FROM
" . PREFIX . "_sysblocks_groups
WHERE
id = '" . $id . "'
";
$AVE_DB->Query($sql);
header('Location:index.php?do=sysblocks&action=groups&cp=' . SESSION);
exit;
}
2019-08-21 19:04:33 +03:00
/*
|--------------------------------------------------------------------------------------
| newBlock
|--------------------------------------------------------------------------------------
|
| Создание системного блока
|
*/
public static function newBlock ()
{
global $AVE_Template;
$row['sysblock_name'] = '';
$row['sysblock_alias'] = '';
$row['sysblock_text'] = '';
2019-08-22 12:14:11 +03:00
$row['sysblock_eval'] = '1';
2019-08-21 19:04:33 +03:00
$row['sysblock_visual'] = (isset($_REQUEST['sysblock_visual']) && $_REQUEST['sysblock_visual'] != 0) ? $_REQUEST['sysblock_visual'] : '';
$AVE_Template->assign('sid', 0);
2019-08-22 12:14:11 +03:00
$AVE_Template->assign('groups', self::getGroups());
2019-08-21 19:04:33 +03:00
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;
2020-02-26 21:59:06 +03:00
$config = [];
2019-08-21 19:04:33 +03:00
$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
2019-08-22 12:14:11 +03:00
{
$AVE_Template->assign($row);
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/form.tpl'));
}
2019-08-21 19:04:33 +03:00
}
/*
|--------------------------------------------------------------------------------------
| 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'];
2020-02-26 21:59:06 +03:00
$sql = "
2019-08-21 19:04:33 +03:00
SELECT
*
FROM
" . PREFIX . "_sysblocks
WHERE
id = '" . $sysblock_id . "'
2020-02-26 21:59:06 +03:00
";
$row = $AVE_DB->Query($sql)->FetchAssocArray();
2019-08-21 19:04:33 +03:00
$AVE_Template->assign('sid', $sysblock_id);
2019-08-22 12:14:11 +03:00
$AVE_Template->assign('groups', self::getGroups());
2019-08-21 19:04:33 +03:00
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;
2020-02-26 21:59:06 +03:00
$config = [];
2019-08-21 19:04:33 +03:00
$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
|--------------------------------------------------------------------------------------
|
| Сохранение системного блока
|
*/
2020-02-26 21:59:06 +03:00
public static function saveBlock ()
2019-08-21 19:04:33 +03:00
{
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
2020-02-26 21:59:06 +03:00
$sql = "
2017-06-24 00:58:56 +03:00
UPDATE
" . PREFIX . "_sysblocks
SET
2019-08-22 12:14:11 +03:00
sysblock_group_id = '" . (int)$_REQUEST['sysblock_group_id'] . "',
2017-06-24 00:58:56 +03:00
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 . "'
2020-02-26 21:59:06 +03:00
";
2017-06-24 00:58:56 +03:00
2020-02-26 21:59:06 +03:00
$query = $AVE_DB->Query($sql);
if ($query->_result === false)
2017-06-24 00:58:56 +03:00
{
$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())
{
2020-02-26 21:59:06 +03:00
echo json_encode(['message' => $message, 'header' => $header, 'theme' => $theme]);
2017-06-24 00:58:56 +03:00
}
else
{
$AVE_Template->assign('message', $message);
header('Location:index.php?do=sysblocks&cp=' . SESSION);
}
exit;
}
else
2019-08-21 19:04:33 +03:00
{
2020-02-26 21:59:06 +03:00
$sql = "
INSERT INTO
" . PREFIX . "_sysblocks
SET
sysblock_group_id = '" . (int)$_REQUEST['sysblock_group_id'] . "',
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'] . "',
sysblock_eval = '" . (int)$_REQUEST['sysblock_eval'] . "',
sysblock_external = '" . (int)$_REQUEST['sysblock_external'] . "',
sysblock_ajax = '" . (int)$_REQUEST['sysblock_ajax'] . "',
sysblock_visual = '" . (int)$_REQUEST['sysblock_visual'] . "',
sysblock_created = '" . time() . "'
";
$AVE_DB->Query($sql);
2017-06-24 00:58:56 +03:00
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
}
2019-08-22 12:14:11 +03:00
/*
|--------------------------------------------------------------------------------------
| multiBlock
|--------------------------------------------------------------------------------------
|
| Копирование системного блока
|
*/
public static function multiBlock ()
{
global $AVE_DB, $AVE_Template;
$_REQUEST['sub'] = (!isset($_REQUEST['sub']))
? ''
: $_REQUEST['sub'];
$errors = [];
switch ($_REQUEST['sub'])
{
case 'save':
$ok = true;
2020-02-26 21:59:06 +03:00
$sql = "
2019-08-22 12:14:11 +03:00
SELECT
sysblock_name
FROM
" . PREFIX . "_sysblocks
WHERE
sysblock_name = '" . $_REQUEST['sysblock_name'] . "'
2020-02-26 21:59:06 +03:00
";
$row = $AVE_DB->Query($sql)->FetchRow();
2019-08-22 12:14:11 +03:00
if (@$row->sysblock_name != '')
{
array_push($errors, $AVE_Template->get_config_vars('SYSBLOCK_EXIST'));
$AVE_Template->assign('errors', $errors);
$ok = false;
}
if ($_REQUEST['sysblock_name'] == '')
{
array_push($errors, $AVE_Template->get_config_vars('SYSBLOCK_COPY_TIP'));
$AVE_Template->assign('errors', $errors);
$ok = false;
}
if ($ok)
{
2020-02-26 21:59:06 +03:00
$sql = "
SELECT
sysblock_text
FROM
" . PREFIX . "_sysblocks
WHERE
id = '" . (int)$_REQUEST['id'] . "'
";
$row = $AVE_DB->Query($sql)->FetchRow();
$sql = "
INSERT INTO
" . PREFIX . "_sysblocks
2019-08-22 12:14:11 +03:00
SET
Id = '',
sysblock_name = '" . $_REQUEST['sysblock_name'] . "',
sysblock_text = '" . addslashes($row->sysblock_text) . "',
sysblock_author_id = '" . $_SESSION['user_id'] . "',
sysblock_created = '" . time() . "'
2020-02-26 21:59:06 +03:00
";
$AVE_DB->Query($sql);
2019-08-22 12:14:11 +03:00
2020-02-26 21:59:06 +03:00
reportLog($_SESSION['user_name'] . ' - ' . $AVE_Template->get_config_vars('SYSBLOCK_COPY_LOG') .' (' . (int)$_REQUEST['id'] . ')', 2, 2);
2019-08-22 12:14:11 +03:00
header('Location:index.php?do=sysblocks'.'&cp=' . SESSION);
}
$AVE_Template->assign('content', $AVE_Template->fetch('sysblocks/multi.tpl'));
break;
}
}
2017-06-24 00:58:56 +03:00
}
?>