| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @copyright NetMonsters <team@netmonsters.ru> | 
					
						
							|  |  |  |  * @link http://netmonsters.ru | 
					
						
							|  |  |  |  * @package Majestic | 
					
						
							|  |  |  |  * @subpackage App | 
					
						
							|  |  |  |  * @since 27.06.12 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * @desc CliController (run cli_class, end profiler) | 
					
						
							|  |  |  |  * @author Aleksandr Demidov | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class CliController | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @var CliController | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     protected static $instance; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-11 17:23:14 +04:00
										 |  |  |     protected $error_stream; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |     protected function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         ErrorHandler::init(); | 
					
						
							| 
									
										
										
										
											2012-10-08 19:29:53 +04:00
										 |  |  |         $this->error_stream = Config::get('ErrorStream', 'php://stderr'); | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-11-21 15:09:13 +04:00
										 |  |  |      * Refuse cloning | 
					
						
							| 
									
										
										
										
											2012-11-21 21:02:13 +04:00
										 |  |  |      * @codeCoverageIgnoreStart | 
					
						
							| 
									
										
										
										
											2012-11-21 15:09:13 +04:00
										 |  |  |      */ | 
					
						
							|  |  |  |     private function __clone() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-11-21 21:02:13 +04:00
										 |  |  |      * @codeCoverageIgnoreEnd | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |      * @static | 
					
						
							|  |  |  |      * @return CliController | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public static function getInstance() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (!isset(self::$instance)) { | 
					
						
							|  |  |  |             self::$instance = new self(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return self::$instance; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2013-09-09 14:02:15 +04:00
										 |  |  |      * @param iCli|string $cli | 
					
						
							|  |  |  |      * @throws ErrorException|GeneralException | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2013-06-26 13:32:17 +04:00
										 |  |  |     public function execute($cli) | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |     { | 
					
						
							|  |  |  |         try { | 
					
						
							| 
									
										
										
										
											2013-06-26 13:32:17 +04:00
										 |  |  |             if (is_string($cli)) { | 
					
						
							|  |  |  |                 if (!class_exists($cli)) { | 
					
						
							|  |  |  |                     throw new GeneralException('Action class "' . $cli . '" not found.'); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 $cli = new $cli; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             if (!in_array('iCli', class_implements($cli))) { | 
					
						
							|  |  |  |                 throw new ErrorException('Runner "' . get_class($cli) . '" need implement of "iCli" interface.'); | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2013-06-26 13:32:17 +04:00
										 |  |  |             $cli->run(); | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |             if (Config::get('PROFILER')) { | 
					
						
							| 
									
										
										
										
											2012-10-05 19:39:23 +04:00
										 |  |  |                 $profile = Profiler::getInstance()->getCli(); | 
					
						
							|  |  |  |                 if (Config::get('LOGGING')) { | 
					
						
							|  |  |  |                     Logger::getInstance()->log($profile); | 
					
						
							|  |  |  |                 } else { | 
					
						
							|  |  |  |                     echo $profile; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2012-11-21 15:09:13 +04:00
										 |  |  |         } | 
					
						
							|  |  |  |         catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2012-10-05 19:39:23 +04:00
										 |  |  |             $code = $e->getCode(); | 
					
						
							|  |  |  |             if ($e instanceof ErrorException) { | 
					
						
							|  |  |  |                 $code = $e->getSeverity(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             file_put_contents($this->error_stream, PHP_EOL . 'Error ' . '#' . $code . ': ' . $e->getMessage() . PHP_EOL, FILE_APPEND); | 
					
						
							|  |  |  |             file_put_contents($this->error_stream, PHP_EOL . 'Stack trace: ' . PHP_EOL . $e->getTraceAsString() . PHP_EOL, FILE_APPEND); | 
					
						
							| 
									
										
										
										
											2012-07-10 19:37:03 +04:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |