mirror of
				https://github.com/yiisoft/yii2.git
				synced 2025-11-04 06:37:55 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			109 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			109 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * @link https://www.yiiframework.com/
 | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC
 | 
						|
 * @license https://www.yiiframework.com/license/
 | 
						|
 */
 | 
						|
 | 
						|
namespace yii\console;
 | 
						|
 | 
						|
/**
 | 
						|
 * The console Request represents the environment information for a console application.
 | 
						|
 *
 | 
						|
 * It is a wrapper for the PHP `$_SERVER` variable which holds information about the
 | 
						|
 * currently running PHP script and the command line arguments given to it.
 | 
						|
 *
 | 
						|
 * @property array $params The command line arguments. It does not include the entry script name.
 | 
						|
 *
 | 
						|
 * @author Qiang Xue <qiang.xue@gmail.com>
 | 
						|
 * @since 2.0
 | 
						|
 */
 | 
						|
class Request extends \yii\base\Request
 | 
						|
{
 | 
						|
    private $_params;
 | 
						|
 | 
						|
 | 
						|
    /**
 | 
						|
     * Returns the command line arguments.
 | 
						|
     * @return array the command line arguments. It does not include the entry script name.
 | 
						|
     */
 | 
						|
    public function getParams()
 | 
						|
    {
 | 
						|
        if ($this->_params === null) {
 | 
						|
            if (isset($_SERVER['argv'])) {
 | 
						|
                $this->_params = $_SERVER['argv'];
 | 
						|
                array_shift($this->_params);
 | 
						|
            } else {
 | 
						|
                $this->_params = [];
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return $this->_params;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Sets the command line arguments.
 | 
						|
     * @param array $params the command line arguments
 | 
						|
     */
 | 
						|
    public function setParams($params)
 | 
						|
    {
 | 
						|
        $this->_params = $params;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Resolves the current request into a route and the associated parameters.
 | 
						|
     * @return array the first element is the route, and the second is the associated parameters.
 | 
						|
     * @throws Exception when parameter is wrong and can not be resolved
 | 
						|
     */
 | 
						|
    public function resolve()
 | 
						|
    {
 | 
						|
        $rawParams = $this->getParams();
 | 
						|
        $endOfOptionsFound = false;
 | 
						|
        if (isset($rawParams[0])) {
 | 
						|
            $route = array_shift($rawParams);
 | 
						|
 | 
						|
            if ($route === '--') {
 | 
						|
                $endOfOptionsFound = true;
 | 
						|
                $route = array_shift($rawParams);
 | 
						|
            }
 | 
						|
        } else {
 | 
						|
            $route = '';
 | 
						|
        }
 | 
						|
 | 
						|
        $params = [];
 | 
						|
        $prevOption = null;
 | 
						|
        foreach ($rawParams as $param) {
 | 
						|
            if ($endOfOptionsFound) {
 | 
						|
                $params[] = $param;
 | 
						|
            } elseif ($param === '--') {
 | 
						|
                $endOfOptionsFound = true;
 | 
						|
            } elseif (preg_match('/^--([\w-]+)(?:=(.*))?$/', $param, $matches)) {
 | 
						|
                $name = $matches[1];
 | 
						|
                if (is_numeric(substr($name, 0, 1))) {
 | 
						|
                    throw new Exception('Parameter "' . $name . '" is not valid');
 | 
						|
                }
 | 
						|
 | 
						|
                if ($name !== Application::OPTION_APPCONFIG) {
 | 
						|
                    $params[$name] = isset($matches[2]) ? $matches[2] : true;
 | 
						|
                    $prevOption = &$params[$name];
 | 
						|
                }
 | 
						|
            } elseif (preg_match('/^-([\w-]+)(?:=(.*))?$/', $param, $matches)) {
 | 
						|
                $name = $matches[1];
 | 
						|
                if (is_numeric($name)) {
 | 
						|
                    $params[] = $param;
 | 
						|
                } else {
 | 
						|
                    $params['_aliases'][$name] = isset($matches[2]) ? $matches[2] : true;
 | 
						|
                    $prevOption = &$params['_aliases'][$name];
 | 
						|
                }
 | 
						|
            } elseif ($prevOption === true) {
 | 
						|
                // `--option value` syntax
 | 
						|
                $prevOption = $param;
 | 
						|
            } else {
 | 
						|
                $params[] = $param;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return [$route, $params];
 | 
						|
    }
 | 
						|
}
 |