Example #1
0
 /**
  * Método para manejar las excepciones ocurridas en la aplicación
  * @param exception Excepción producida (\Exception  o \Error)
  * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]delaf.cl)
  * @version 2016-01-07
  */
 public static function handler($exception)
 {
     ob_clean();
     // Generar arreglo
     $data = array('exception' => get_class($exception), 'message' => $exception->getMessage(), 'trace' => $exception->getTraceAsString(), 'code' => $exception->getCode(), 'severity' => isset($exception->severity) ? $exception->severity : LOG_ERR);
     // renderizar dependiendo de si es una web o es una shell
     if (isset($_SERVER['REQUEST_URI'])) {
         $controller = new Controller_Error(new Network_Request(), new Network_Response());
         $controller->error_reporting = Configure::read('debug');
         $controller->display($data);
         $controller->shutdownProcess();
         $controller->response->status($data['code']);
         $controller->response->send();
     } else {
         $stdout = new Shell_Output('php://stdout');
         $stdout->write("\n" . '<error>' . $data['exception'] . ':</error>', 2);
         $stdout->write("\t" . '<error>' . str_replace("\n", "\n\t", $data['message']) . '</error>', 2);
         $stdout->write("\t" . '<error>' . str_replace("\n", "\n\t", $data['trace']) . '</error>', 2);
     }
 }
Example #2
0
 /**
  * Método para mostrar estadísticas finales de la ejecución del comando
  * @param stream Se permite elegir a través de que stream se enviarán las estadísticas
  * @author Esteban De La Fuente Rubio, DeLaF (esteban[at]delaf.cl)
  * @version 2015-02-03
  */
 public function showStats($stream = 'php://stderr')
 {
     $out = new Shell_Output($stream);
     // tiempo que tomó la ejecución del comando
     $time = microtime(true) - TIME_START;
     if ($time < 60) {
         $out->write('Proceso ejecutado en ' . num($time, 1) . ' segundos.' . "\n");
     } else {
         if ($time < 3600) {
             $out->write('Proceso ejecutado en ' . num($time / 60, 1) . ' minutos.' . "\n");
         } else {
             $out->write('Proceso ejecutado en ' . num($time / 3600, 1) . ' horas.' . "\n");
         }
     }
 }