mirror of
				https://github.com/yiisoft/yii2.git
				synced 2025-11-04 06:37:55 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * @link http://www.yiiframework.com/
 | 
						|
 * @copyright Copyright (c) 2008 Yii Software LLC
 | 
						|
 * @license http://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 (!isset($this->_params)) {
 | 
						|
            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.
 | 
						|
     */
 | 
						|
    public function resolve()
 | 
						|
    {
 | 
						|
        $rawParams = $this->getParams();
 | 
						|
        if (isset($rawParams[0])) {
 | 
						|
            $route = $rawParams[0];
 | 
						|
            array_shift($rawParams);
 | 
						|
        } else {
 | 
						|
            $route = '';
 | 
						|
        }
 | 
						|
 | 
						|
        $params = [];
 | 
						|
        foreach ($rawParams as $param) {
 | 
						|
            if (preg_match('/^--(\w+)(=(.*))?$/', $param, $matches)) {
 | 
						|
                $name = $matches[1];
 | 
						|
                if ($name !== Application::OPTION_APPCONFIG) {
 | 
						|
                    $params[$name] = isset($matches[3]) ? $matches[3] : true;
 | 
						|
                }
 | 
						|
            } else {
 | 
						|
                $params[] = $param;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
        return [$route, $params];
 | 
						|
    }
 | 
						|
}
 |