You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							77 lines
						
					
					
						
							1.8 KiB
						
					
					
				
			
		
		
	
	
							77 lines
						
					
					
						
							1.8 KiB
						
					
					
				| <?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]; | |
| 				$params[$name] = isset($matches[3]) ? $matches[3] : true; | |
| 			} else { | |
| 				$params[] = $param; | |
| 			} | |
| 		} | |
|  | |
| 		return [$route, $params]; | |
| 	} | |
| }
 | |
| 
 |