<?php namespace Majestic\App; /** * @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; protected $error_stream; protected function __construct() { //\Majestic\Exception\ErrorHandler::init(); $this->error_stream = \Majestic\Config::get('ErrorStream', 'php://stderr'); } /** * Refuse cloning * @codeCoverageIgnoreStart */ private function __clone() { } /** * @codeCoverageIgnoreEnd */ /** * @static * @return CliController */ public static function getInstance() { if (!isset(self::$instance)) { self::$instance = new static(); } return self::$instance; } /** * @param iCli|string $cli * @throws \ErrorException|\Majestic\Exception\GeneralException */ public function execute($cli) { try { $this->run($cli); } catch (\Exception $e) { $this->exception($e); } } protected function run($cli) { if (is_string($cli)) { if (!class_exists($cli)) { throw new \Majestic\Exception\GeneralException('Action class "' . $cli . '" not found.'); } $cli = new $cli; } if (!in_array('Majestic\App\iCli', class_implements($cli))) { throw new \ErrorException('Runner "' . get_class($cli) . '" need implement of "iCli" interface.'); } $cli->run(); if (\Majestic\Config::get('PROFILER')) { $profile = \Majestic\Util\Profiler\Profiler::getInstance()->getCli(); if (\Majestic\Config::get('LOGGING')) { \Majestic\Logger\Logger::getInstance()->log($profile); } else { echo $profile; } } } protected function exception($e) { $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); } }