ave-cms/admin/rubs.php

670 lines
15 KiB
PHP
Raw Normal View History

2017-06-24 00:58:56 +03:00
<?php
2018-04-19 19:11:58 +03:00
/**
* AVE.cms
*
* @package AVE.cms
* @version 3.x
* @filesource
* @copyright © 2007-2014 AVE.cms, http://www.ave-cms.ru
*
* @license GPL v.2
*/
if (!defined('ACP'))
{
header('Location:index.php');
exit;
}
require(BASE_DIR . '/class/class.rubs.php');
$AVE_Rubric = new AVE_Rubric;
$AVE_Template->config_load(BASE_DIR . '/admin/lang/' . $_SESSION['admin_language'] . '/rubs.txt', 'rubs');
switch($_REQUEST['action'])
{
case '' :
if(check_permission('rubric_view'))
{
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case 'quicksave':
$AVE_Rubric->quickSave();
break;
}
}
$AVE_Rubric->rubricList();
$AVE_Template->assign('templates', get_all_templates());
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/list.tpl'));
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_VIEW'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'new':
if(check_permission('rubric_edit'))
{
$AVE_Template->assign('templates', get_all_templates());
$AVE_Rubric->rubricNew();
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE3'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'template':
2017-06-24 00:58:56 +03:00
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
2018-04-19 19:11:58 +03:00
case '':
$AVE_Rubric->rubricTemplateShow();
2017-06-24 00:58:56 +03:00
break;
2018-04-19 19:11:58 +03:00
case 'save':
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$Rtemplate = $_POST['rubric_template'];
$Htemplate = $_POST['rubric_header_template'];
$Ftemplate = $_POST['rubric_footer_template'];
$Ttemplate = $_POST['rubric_teaser_template'];
$Atemplate = $_POST['rubric_admin_teaser_template'];
$check_code = strtolower($Rtemplate.$Htemplate.$Ttemplate.$Atemplate.$Ftemplate);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = true;
if ((is_php_code($check_code)) && !check_permission('rubric_php') )
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('php_forbidden', 1);
$ok = false;
}
if (! $ok)
{
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PHP_ERR');
$header = $AVE_Template->get_config_vars('RUBRIC_ERROR');
$theme = 'error';
if (isAjax())
{
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
exit;
}
else
{
$AVE_Rubric->rubricTemplateShow(1);
}
2017-06-24 00:58:56 +03:00
}
else
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->rubricTemplateSave($Rtemplate, $Htemplate, $Ttemplate, $Atemplate, $Ftemplate);
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
}
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE2'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'delete':
if(check_permission('rubric_edit'))
{
$AVE_Rubric->rubricDelete();
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'multi':
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case 'save':
$AVE_Rubric->rubricCopy();
break;
}
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/multi.tpl'));
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_MULTIPLY'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'edit':
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case '':
switch($_REQUEST['submit'])
{
case 'saveperms':
if (check_permission('rubric_perms')){
$AVE_Rubric->rubricPermissionSave((int)$_REQUEST['Id']);
}
break;
case 'save':
$AVE_Rubric->rubricFieldSave((int)$_REQUEST['Id']);
break;
case 'linked_rubric':
$AVE_Rubric->rubricShow(1);
break;
case 'code':
if (check_permission('rubric_code')){
$AVE_Rubric->rubricCode((int)$_REQUEST['Id']);
}
break;
case 'description':
$AVE_Rubric->rubricDesc((int)$_REQUEST['Id']);
break;
}
}
$AVE_Rubric->rubricFieldShow((int)$_REQUEST['Id'], null);
break;
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE1'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'alias_add':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricAliasAdd();
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'code':
if (check_permission('rubric_code'))
{
$AVE_Rubric->rubricCodeEdit($_REQUEST['Id']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'field_template':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldTemplate();
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'field_template_save':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldTemplateSave((int)$_REQUEST['field_id'], (int)$_REQUEST['rubric_id']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'fieldssort':
if(check_permission_acp('rubric_edit'))
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->rubricFieldsSort((array)$_REQUEST['sort']);
}
exit;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'rubssort':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricsSort((array)$_REQUEST['sort']);
}
exit;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'alias_check':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricAliasCheck((int)$_REQUEST['rubric_id'],(int)$_REQUEST['field_id'], $_REQUEST['rubric_field_alias']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'newfield':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldNew((int)$_REQUEST['Id'], $_REQUEST['ajax']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'fields':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldShow((int)$_REQUEST['Id'], $_REQUEST['ajax']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'change':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldChange((int)$_REQUEST['field_id'], (int)$_REQUEST['rubric_id']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'changesave':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldChangeSave((int)$_REQUEST['field_id'], (int)$_REQUEST['rubric_id']);
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'changegroup':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldGroupChange((int)$_REQUEST['field_id'], (int)$_REQUEST['rubric_id']);
}
break;
case 'changegroupsave':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldGroupChangeSave((int)$_REQUEST['field_id'], (int)$_REQUEST['rubric_id']);
}
break;
case 'fieldsgroups':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldsGroups((int)$_REQUEST['Id']);
}
break;
case 'newfieldsgroup':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricNewGroupFields((int)$_REQUEST['Id']);
}
break;
case 'savefieldsgroup':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricEditGroupFields((int)$_REQUEST['Id']);
}
break;
case 'delfieldsgroup':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricDelGroupFields((int)$_REQUEST['Id'], (int)$_REQUEST['rubric_id']);
}
break;
case 'fieldsgroupssort':
if(check_permission_acp('rubric_edit'))
{
$AVE_Rubric->rubricFieldsGroupsSort((array)$_REQUEST['sort']);
}
exit;
case 'tmpls':
if (check_permission_acp('rubric_edit'))
{
$AVE_Rubric->tmplsList();
$AVE_Template->assign('content', $AVE_Template->fetch('rubs/tmpls.tpl'));
}
break;
case 'tmpls_edit':
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case '':
$AVE_Rubric->tmplsEdit();
break;
case 'save':
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$title = $_POST['template_title'];
$template = $_POST['rubric_template'];
$check_code = strtolower($template);
$ok = true;
if((is_php_code($check_code)) && !check_permission('rubric_php') )
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('php_forbidden', 1);
$ok = false;
}
if(! $ok)
{
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PHP_ERR');
$header = $AVE_Template->get_config_vars('RUBRIC_ERROR');
$theme = 'error';
if (isAjax())
{
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
exit;
}
else
{
$AVE_Rubric->tmplsEdit();
}
2017-06-24 00:58:56 +03:00
}
else
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->tmplsSave($template, $title);
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
}
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
else
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE2'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'tmpls_new':
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case '':
$AVE_Rubric->tmplsEdit();
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'save':
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$title = $_POST['template_title'];
$template = $_POST['rubric_template'];
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$check_code = strtolower($template);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = true;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if((is_php_code($check_code)) && !check_permission('rubric_php') )
{
$AVE_Template->assign('php_forbidden', 1);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = false;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(! $ok)
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PHP_ERR');
$header = $AVE_Template->get_config_vars('RUBRIC_ERROR');
$theme = 'error';
if (isAjax())
{
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
exit;
}
else
{
$AVE_Rubric->tmplsEdit();
}
2017-06-24 00:58:56 +03:00
}
else
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->tmplsSave($template, $title);
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
}
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE2'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'tmpls_from':
if(check_permission('rubric_edit'))
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
switch($_REQUEST['sub'])
{
case '':
$AVE_Rubric->tmplsEdit();
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'save':
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$title = $_POST['template_title'];
$template = $_POST['rubric_template'];
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$check_code = strtolower($template);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = true;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if((is_php_code($check_code)) && !check_permission('rubric_php') )
{
$AVE_Template->assign('php_forbidden', 1);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = false;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(! $ok)
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PHP_ERR');
$header = $AVE_Template->get_config_vars('RUBRIC_ERROR');
$theme = 'error';
if (isAjax())
{
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
exit;
}
else
{
$AVE_Rubric->tmplsEdit();
}
2017-06-24 00:58:56 +03:00
}
else
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->tmplsSave($template, $title);
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
}
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
else
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE2'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'tmpls_copy':
if(check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case '':
$AVE_Rubric->tmplsEdit();
break;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
case 'save':
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$title = $_POST['template_title'];
$template = $_POST['rubric_template'];
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$check_code = strtolower($template);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = true;
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if((is_php_code($check_code)) && !check_permission('rubric_php') )
{
$AVE_Template->assign('php_forbidden', 1);
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
$ok = false;
}
2017-06-24 00:58:56 +03:00
2018-04-19 19:11:58 +03:00
if(! $ok)
2017-06-24 00:58:56 +03:00
{
2018-04-19 19:11:58 +03:00
$message = $AVE_Template->get_config_vars('RUBRIC_SAVED_PHP_ERR');
$header = $AVE_Template->get_config_vars('RUBRIC_ERROR');
$theme = 'error';
if (isAjax())
{
echo json_encode(array('message' => $message, 'header' => $header, 'theme' => $theme));
exit;
}
else
{
$AVE_Rubric->tmplsEdit();
}
2017-06-24 00:58:56 +03:00
}
else
{
2018-04-19 19:11:58 +03:00
$AVE_Rubric->tmplsSave($template, $title);
2017-06-24 00:58:56 +03:00
}
2018-04-19 19:11:58 +03:00
break;
}
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE2'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
2018-03-12 23:35:55 +03:00
}
2018-04-19 19:11:58 +03:00
break;
case 'tmpls_del':
if(check_permission('rubric_edit'))
{
$AVE_Rubric->tmplsDelete();
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'rules':
if (check_permission('rubric_edit'))
{
switch($_REQUEST['sub'])
{
case '':
switch($_REQUEST['submit'])
{
case 'saveperms':
if (check_permission('rubric_perms'))
$AVE_Rubric->rubricPermissionSave((int)$_REQUEST['Id']);
break;
}
}
$AVE_Rubric->rubricRulesShow((int)$_REQUEST['Id'], null);
break;
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_CHANGE1'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftlist':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->ShowFields();
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftshowfield':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->ShowFieldsByType($_REQUEST['type']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftcreate':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->EditFieldTpl((int)$_REQUEST['id'], $_REQUEST['fld'], $_REQUEST['type']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftedit':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->EditFieldTpl((int)$_REQUEST['id'], $_REQUEST['fld'], $_REQUEST['type']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftempledit':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->EditFieldTpl('', $_REQUEST['fld'], $_REQUEST['type']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftsave':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->SaveFieldTpl((int)$_REQUEST['field_id'], $_REQUEST['field_name'], $_REQUEST['field_type'], $_REQUEST['func']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
case 'ftdelete':
if (check_permission('rubric_edit'))
{
$AVE_Rubric->DeleteFieldTpl((int)$_REQUEST['id'], $_REQUEST['fld'], $_REQUEST['type'], $_REQUEST['func']);
}
else
{
$AVE_Template->assign('erorr', $AVE_Template->get_config_vars('RUBRIK_NO_PERMISSION'));
$AVE_Template->assign('content', $AVE_Template->fetch('error.tpl'));
}
break;
}
?>