234 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			234 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // +----------------------------------------------------------------------
 | |
| // | ThinkPHP [ WE CAN DO IT JUST THINK ]
 | |
| // +----------------------------------------------------------------------
 | |
| // | Copyright (c) 2006~2015 http://thinkphp.cn All rights reserved.
 | |
| // +----------------------------------------------------------------------
 | |
| // | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
 | |
| // +----------------------------------------------------------------------
 | |
| // | Author: yunwuxin <448901948@qq.com>
 | |
| // +----------------------------------------------------------------------
 | |
| 
 | |
| namespace think\process;
 | |
| 
 | |
| use think\Process;
 | |
| 
 | |
| class Builder
 | |
| {
 | |
|     private $arguments;
 | |
|     private $cwd;
 | |
|     private $env = null;
 | |
|     private $input;
 | |
|     private $timeout        = 60;
 | |
|     private $options        = [];
 | |
|     private $inheritEnv     = true;
 | |
|     private $prefix         = [];
 | |
|     private $outputDisabled = false;
 | |
| 
 | |
|     /**
 | |
|      * 构造方法
 | |
|      * @param string[] $arguments 参数
 | |
|      */
 | |
|     public function __construct(array $arguments = [])
 | |
|     {
 | |
|         $this->arguments = $arguments;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 创建一个实例
 | |
|      * @param string[] $arguments 参数
 | |
|      * @return self
 | |
|      */
 | |
|     public static function create(array $arguments = [])
 | |
|     {
 | |
|         return new static($arguments);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 添加一个参数
 | |
|      * @param string $argument 参数
 | |
|      * @return self
 | |
|      */
 | |
|     public function add($argument)
 | |
|     {
 | |
|         $this->arguments[] = $argument;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 添加一个前缀
 | |
|      * @param string|array $prefix
 | |
|      * @return self
 | |
|      */
 | |
|     public function setPrefix($prefix)
 | |
|     {
 | |
|         $this->prefix = is_array($prefix) ? $prefix : [$prefix];
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置参数
 | |
|      * @param string[] $arguments
 | |
|      * @return  self
 | |
|      */
 | |
|     public function setArguments(array $arguments)
 | |
|     {
 | |
|         $this->arguments = $arguments;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置工作目录
 | |
|      * @param null|string $cwd
 | |
|      * @return  self
 | |
|      */
 | |
|     public function setWorkingDirectory($cwd)
 | |
|     {
 | |
|         $this->cwd = $cwd;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 是否初始化环境变量
 | |
|      * @param bool $inheritEnv
 | |
|      * @return self
 | |
|      */
 | |
|     public function inheritEnvironmentVariables($inheritEnv = true)
 | |
|     {
 | |
|         $this->inheritEnv = $inheritEnv;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置环境变量
 | |
|      * @param string      $name
 | |
|      * @param null|string $value
 | |
|      * @return self
 | |
|      */
 | |
|     public function setEnv($name, $value)
 | |
|     {
 | |
|         $this->env[$name] = $value;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      *  添加环境变量
 | |
|      * @param array $variables
 | |
|      * @return self
 | |
|      */
 | |
|     public function addEnvironmentVariables(array $variables)
 | |
|     {
 | |
|         $this->env = array_replace($this->env, $variables);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置输入
 | |
|      * @param mixed $input
 | |
|      * @return self
 | |
|      */
 | |
|     public function setInput($input)
 | |
|     {
 | |
|         $this->input = Utils::validateInput(sprintf('%s::%s', __CLASS__, __FUNCTION__), $input);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置超时时间
 | |
|      * @param float|null $timeout
 | |
|      * @return self
 | |
|      */
 | |
|     public function setTimeout($timeout)
 | |
|     {
 | |
|         if (null === $timeout) {
 | |
|             $this->timeout = null;
 | |
| 
 | |
|             return $this;
 | |
|         }
 | |
| 
 | |
|         $timeout = (float) $timeout;
 | |
| 
 | |
|         if ($timeout < 0) {
 | |
|             throw new \InvalidArgumentException('The timeout value must be a valid positive integer or float number.');
 | |
|         }
 | |
| 
 | |
|         $this->timeout = $timeout;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 设置proc_open选项
 | |
|      * @param string $name
 | |
|      * @param string $value
 | |
|      * @return self
 | |
|      */
 | |
|     public function setOption($name, $value)
 | |
|     {
 | |
|         $this->options[$name] = $value;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 禁止输出
 | |
|      * @return self
 | |
|      */
 | |
|     public function disableOutput()
 | |
|     {
 | |
|         $this->outputDisabled = true;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 开启输出
 | |
|      * @return self
 | |
|      */
 | |
|     public function enableOutput()
 | |
|     {
 | |
|         $this->outputDisabled = false;
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * 创建一个Process实例
 | |
|      * @return Process
 | |
|      */
 | |
|     public function getProcess()
 | |
|     {
 | |
|         if (0 === count($this->prefix) && 0 === count($this->arguments)) {
 | |
|             throw new \LogicException('You must add() command arguments before calling getProcess().');
 | |
|         }
 | |
| 
 | |
|         $options = $this->options;
 | |
| 
 | |
|         $arguments = array_merge($this->prefix, $this->arguments);
 | |
|         $script    = implode(' ', array_map([__NAMESPACE__ . '\\Utils', 'escapeArgument'], $arguments));
 | |
| 
 | |
|         if ($this->inheritEnv) {
 | |
|             // include $_ENV for BC purposes
 | |
|             $env = array_replace($_ENV, $_SERVER, $this->env);
 | |
|         } else {
 | |
|             $env = $this->env;
 | |
|         }
 | |
| 
 | |
|         $process = new Process($script, $this->cwd, $env, $this->input, $this->timeout, $options);
 | |
| 
 | |
|         if ($this->outputDisabled) {
 | |
|             $process->disableOutput();
 | |
|         }
 | |
| 
 | |
|         return $process;
 | |
|     }
 | |
| }
 |