mirror of
https://github.com/yiisoft/yii2.git
synced 2025-08-26 06:15:19 +08:00

* php-cs-fixer: PSR2 rule. * php-cs-fixer: PSR2 rule - fix views. * Travis setup refactoring. * Add php-cs-fixer to travis cs tests. * Fix tests on hhvm-3.12 * improve travis config * composer update * revert composer update * improve travis config * Fix CS. * Extract config to separate classes. * Extract config to separate classes. * Add file header. * Force short array syntax. * binary_operator_spaces fixer * Fix broken tests * cast_spaces fixer * concat_space fixer * dir_constant fixer * ereg_to_preg fixer * function_typehint_space fixer * hash_to_slash_comment fixer * is_null fixer * linebreak_after_opening_tag fixer * lowercase_cast fixer * magic_constant_casing fixer * modernize_types_casting fixer * native_function_casing fixer * new_with_braces fixer * no_alias_functions fixer * no_blank_lines_after_class_opening fixer * no_blank_lines_after_phpdoc fixer * no_empty_comment fixer * no_empty_phpdoc fixer * no_empty_statement fixer * no_extra_consecutive_blank_lines fixer * no_leading_import_slash fixer * no_leading_namespace_whitespace fixer * no_mixed_echo_print fixer * no_multiline_whitespace_around_double_arrow fixer * no_multiline_whitespace_before_semicolons fixer * no_php4_constructor fixer * no_short_bool_cast fixer * no_singleline_whitespace_before_semicolons fixer * no_spaces_around_offset fixer * no_trailing_comma_in_list_call fixer * no_trailing_comma_in_singleline_array fixer * no_unneeded_control_parentheses fixer * no_unused_imports fixer * no_useless_return fixer * no_whitespace_before_comma_in_array fixer * no_whitespace_in_blank_line fixer * not_operator_with_successor_space fixer * object_operator_without_whitespace fixer * ordered_imports fixer * php_unit_construct fixer * php_unit_dedicate_assert fixer * php_unit_fqcn_annotation fixer * phpdoc_indent fixer * phpdoc_no_access fixer * phpdoc_no_empty_return fixer * phpdoc_no_package fixer * phpdoc_no_useless_inheritdoc fixer * Fix broken tests * phpdoc_return_self_reference fixer * phpdoc_single_line_var_spacing fixer * phpdoc_single_line_var_spacing fixer * phpdoc_to_comment fixer * phpdoc_trim fixer * phpdoc_var_without_name fixer * psr4 fixer * self_accessor fixer * short_scalar_cast fixer * single_blank_line_before_namespace fixer * single_quote fixer * standardize_not_equals fixer * ternary_operator_spaces fixer * trailing_comma_in_multiline_array fixer * trim_array_spaces fixer * protected_to_private fixer * unary_operator_spaces fixer * whitespace_after_comma_in_array fixer * `parent::setRules()` -> `$this->setRules()` * blank_line_after_opening_tag fixer * Update finder config. * Revert changes for YiiRequirementChecker. * Fix array formatting. * Add missing import. * Fix CS for new code merged from master. * Fix some indentation issues.
132 lines
4.7 KiB
PHP
132 lines
4.7 KiB
PHP
<?php
|
|
/**
|
|
* @link http://www.yiiframework.com/
|
|
* @copyright Copyright (c) 2008 Yii Software LLC
|
|
* @license http://www.yiiframework.com/license/
|
|
*/
|
|
|
|
namespace yii\web;
|
|
|
|
use Yii;
|
|
use yii\base\Action;
|
|
use yii\base\ViewNotFoundException;
|
|
|
|
/**
|
|
* ViewAction represents an action that displays a view according to a user-specified parameter.
|
|
*
|
|
* By default, the view being displayed is specified via the `view` GET parameter.
|
|
* The name of the GET parameter can be customized via [[viewParam]].
|
|
*
|
|
* Users specify a view in the format of `path/to/view`, which translates to the view name
|
|
* `ViewPrefix/path/to/view` where `ViewPrefix` is given by [[viewPrefix]]. The view will then
|
|
* be rendered by the [[\yii\base\Controller::render()|render()]] method of the currently active controller.
|
|
*
|
|
* Note that the user-specified view name must start with a word character and can only contain
|
|
* word characters, forward slashes, dots and dashes.
|
|
*
|
|
* @author Alexander Makarov <sam@rmcreative.ru>
|
|
* @author Qiang Xue <qiang.xue@gmail.com>
|
|
* @since 2.0
|
|
*/
|
|
class ViewAction extends Action
|
|
{
|
|
/**
|
|
* @var string the name of the GET parameter that contains the requested view name.
|
|
*/
|
|
public $viewParam = 'view';
|
|
/**
|
|
* @var string the name of the default view when [[\yii\web\ViewAction::$viewParam]] GET parameter is not provided
|
|
* by user. Defaults to 'index'. This should be in the format of 'path/to/view', similar to that given in the
|
|
* GET parameter.
|
|
* @see \yii\web\ViewAction::$viewPrefix
|
|
*/
|
|
public $defaultView = 'index';
|
|
/**
|
|
* @var string a string to be prefixed to the user-specified view name to form a complete view name.
|
|
* For example, if a user requests for `tutorial/chap1`, the corresponding view name will
|
|
* be `pages/tutorial/chap1`, assuming the prefix is `pages`.
|
|
* The actual view file is determined by [[\yii\base\View::findViewFile()]].
|
|
* @see \yii\base\View::findViewFile()
|
|
*/
|
|
public $viewPrefix = 'pages';
|
|
/**
|
|
* @var mixed the name of the layout to be applied to the requested view.
|
|
* This will be assigned to [[\yii\base\Controller::$layout]] before the view is rendered.
|
|
* Defaults to null, meaning the controller's layout will be used.
|
|
* If false, no layout will be applied.
|
|
*/
|
|
public $layout;
|
|
|
|
|
|
/**
|
|
* Runs the action.
|
|
* This method displays the view requested by the user.
|
|
* @throws NotFoundHttpException if the view file cannot be found
|
|
*/
|
|
public function run()
|
|
{
|
|
$viewName = $this->resolveViewName();
|
|
$this->controller->actionParams[$this->viewParam] = Yii::$app->request->get($this->viewParam);
|
|
|
|
$controllerLayout = null;
|
|
if ($this->layout !== null) {
|
|
$controllerLayout = $this->controller->layout;
|
|
$this->controller->layout = $this->layout;
|
|
}
|
|
|
|
try {
|
|
$output = $this->render($viewName);
|
|
|
|
if ($controllerLayout) {
|
|
$this->controller->layout = $controllerLayout;
|
|
}
|
|
} catch (ViewNotFoundException $e) {
|
|
if ($controllerLayout) {
|
|
$this->controller->layout = $controllerLayout;
|
|
}
|
|
|
|
if (YII_DEBUG) {
|
|
throw new NotFoundHttpException($e->getMessage());
|
|
} else {
|
|
throw new NotFoundHttpException(
|
|
Yii::t('yii', 'The requested view "{name}" was not found.', ['name' => $viewName])
|
|
);
|
|
}
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
|
|
/**
|
|
* Renders a view
|
|
*
|
|
* @param string $viewName view name
|
|
* @return string result of the rendering
|
|
*/
|
|
protected function render($viewName)
|
|
{
|
|
return $this->controller->render($viewName);
|
|
}
|
|
|
|
/**
|
|
* Resolves the view name currently being requested.
|
|
*
|
|
* @return string the resolved view name
|
|
* @throws NotFoundHttpException if the specified view name is invalid
|
|
*/
|
|
protected function resolveViewName()
|
|
{
|
|
$viewName = Yii::$app->request->get($this->viewParam, $this->defaultView);
|
|
|
|
if (!is_string($viewName) || !preg_match('~^\w(?:(?!\/\.{0,2}\/)[\w\/\-\.])*$~', $viewName)) {
|
|
if (YII_DEBUG) {
|
|
throw new NotFoundHttpException("The requested view \"$viewName\" must start with a word character, must not contain /../ or /./, can contain only word characters, forward slashes, dots and dashes.");
|
|
} else {
|
|
throw new NotFoundHttpException(Yii::t('yii', 'The requested view "{name}" was not found.', ['name' => $viewName]));
|
|
}
|
|
}
|
|
|
|
return empty($this->viewPrefix) ? $viewName : $this->viewPrefix . '/' . $viewName;
|
|
}
|
|
}
|