Merge remote-tracking branch 'origin/dev'

This commit is contained in:
Фёдор Подлеснов 2018-01-15 16:47:43 +03:00
commit 7187963ac9
8 changed files with 66 additions and 15 deletions

View file

@ -177,7 +177,7 @@ class Controller_Component
public function setParameters(/*.View_Composite.*/$view)
{
$form = new Form_Form();
$options = new OptionFactory($this->db);
$options = new OptionFactory($this->db, $this->registry);
$settings = $this->getInfo();
$form->addFieldList($settings['parameter'], $options);
@ -262,10 +262,16 @@ class Controller_Component
$component->parameter = $params;
$component->template = $params->get('template', false);
global $componentsConfig;
$editor = $component->getEditUrl();
if ($editor) {
$componentsConfig[] = $editor;
if(class_exists("Controller_Site")){ //Если мы в CMS2
$instance = Controller_Site::getInstance();
$instance->componentsConfig[] = $editor;
}else{
global $componentsConfig;
$componentsConfig[] = $editor;
}
}
return $component;
@ -310,6 +316,10 @@ class Controller_Component
return '?' . http_build_query($arr);
}
/**
* @deprecated В CMS2 перенесено в контроллер сайта!
*/
function addRequireJsPath($name, $path, $shim = null) {
Controller_Site::addRequireJsPath($name, $path, $shim);
}

View file

@ -101,6 +101,15 @@ class Controller_Front extends Controller_Action
} else {
$controller = false;
}
return $this->loadModule($name[0], $request, $controller);
try{
return $this->loadModule($name[0], $request, $controller);
} catch (UserMessageException $ex) { //Исключение с понятным пользователю сообщением
$mode = $request->get('mode');
if($mode == 'ajax' || $mode == 'json'){
return json_encode(['result'=>'fail', 'message'=> $ex->userMessage]);
} else {
return $ex->userMessage;
}
}
}
}

View file

@ -26,7 +26,8 @@ class Filter_ActionAccess
$action = $request->getAction();
if(! $this->checkAction($action)) {
$request->set('action', 'index');
}
$request->setAction('index');
}
return $this->processor->execute($request);
}
}

View file

@ -15,7 +15,8 @@ class Filter_Login extends Filter_Filter
public $mode = 'ajax';
//AJAX-Реквесты для которых не требуется авторизация, потребовалось для сбора статистики
public $whiteRequestList = array(array('module' => "requiredcontent", "action" => "getcount"));
public $whiteRequestList = [['module' => "requiredcontent", "action" => "getcount"],
['module' => "requiredcontent", "action" => "teststructure"]];
/**
* Проверка авторизации
* @return Boolean Авторизовани пользователь или нет

View file

@ -190,9 +190,10 @@ class TDateTime extends TInput {
class OptionFactory {
public $db;
function __construct($db) {
public $registry;
function __construct($db, $registry = null) {
$this->db = $db;
$this->registry = $registry;
}
function create(TSelect $field, $input) {
@ -225,6 +226,10 @@ class OptionFactory {
$field->options = $this->optionsDB($key, $value, $query_result);
} elseif (isset($input['options.pair'])) {
$field->options = $this->optionsPair($input['options.pair']);
} elseif (isset($input['options.model'])) {
$factory = new Model_Factory($this->db, $this->registry);
$model = $factory->getModel($input['options.model']);
$field->options = $model->getAllAsOptions();
} else {
$field->options = $input['options'];
}

View file

@ -0,0 +1,17 @@
<?php
/**
* UserMessageException.php
*
*/
/**
* Исключение с понятным пользователю сообщением, которое имеет смысл ему показать.
* @see Controller_Front
*/
class UserMessageException extends Exception {
public $userMessage;
public function __construct($message) {
parent::__construct($message);
$this->userMessage = $message;
}
}

View file

@ -49,10 +49,14 @@ class View_Page extends View_View
{
//$result = phptal_component($match, $offset);
//*
global $db, $registry; // Нужно как-то передавать параметры
$component = Controller_Component::loadComponent($match, $db, $registry);
if(class_exists("Controller_Site")){ //Если мы в CMS2
$component = Controller_Site::loadComponent($match);
}else{
global $db, $registry; //
$component = Controller_Component::loadComponent($match, $db, $registry);
}
$req = new HttpRequest();
unset($req['active_page']);

View file

@ -45,10 +45,14 @@ function phptal_time ($e)
* Функция подключения компонента
*/
function phptal_component ($expression) {
global $db, $registry; // Нужно как-то передавать параметры
$begin = microtime(true);
$component = Controller_Component::loadComponent($expression, $db, $registry);
if(class_exists("Controller_Site")){ //Если мы в CMS2
$component = Controller_Site::loadComponent($expression);
}else{
global $db, $registry; // Иначе обращаемся к глобальным переменным
$component = Controller_Component::loadComponent($expression, $db, $registry);
}
$req = new HttpRequest();
$result = $component->execute($req);