當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Kohana_Exception::text方法代碼示例

本文整理匯總了PHP中Kohana_Exception::text方法的典型用法代碼示例。如果您正苦於以下問題:PHP Kohana_Exception::text方法的具體用法?PHP Kohana_Exception::text怎麽用?PHP Kohana_Exception::text使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Kohana_Exception的用法示例。


在下文中一共展示了Kohana_Exception::text方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: _show_themed_error_page

 /**
  * Shows a themed error page.
  * @see Kohana_Exception::handle
  */
 private static function _show_themed_error_page(Exception $e)
 {
     // Create a text version of the exception
     $error = Kohana_Exception::text($e);
     // Add this exception to the log
     Kohana_Log::add('error', $error);
     // Manually save logs after exceptions
     Kohana_Log::save();
     if (!headers_sent()) {
         if ($e instanceof Kohana_Exception) {
             $e->sendHeaders();
         } else {
             header("HTTP/1.1 500 Internal Server Error");
         }
     }
     $view = new Theme_View("page.html", "other", "error");
     if ($e instanceof Kohana_404_Exception) {
         $view->page_title = t("Dang...  Page not found!");
         $view->content = new View("error_404.html");
         $user = identity::active_user();
         $view->content->is_guest = $user && $user->guest;
         if ($view->content->is_guest) {
             $view->content->login_form = new View("login_ajax.html");
             $view->content->login_form->form = auth::get_login_form("login/auth_html");
             // Avoid anti-phishing protection by passing the url as session variable.
             Session::instance()->set("continue_url", url::current(true));
         }
     } else {
         $view->page_title = t("Dang...  Something went wrong!");
         $view->content = new View("error.html");
     }
     print $view;
 }
開發者ID:andyst,項目名稱:gallery3,代碼行數:37,代碼來源:MY_Kohana_Exception.php

示例2: login

 public function login()
 {
     $form = $errors = array("user" => "", "password" => "");
     $post = new Validation($_POST);
     $post->add_rules("user", "required");
     $post->add_rules("password", "required");
     if ($valid = $post->validate()) {
         try {
             $token = G3Remote::instance()->get_access_token($post["user"], $post["password"]);
             Session::instance()->set("g3_client_access_token", $token);
             $response = G3Remote::instance()->get_resource("gallery");
             $valid = true;
             $content = $this->_get_main_view($response->resource);
         } catch (Exception $e) {
             Kohana_Log::add("error", Kohana_Exception::text($e));
             $valid = false;
         }
     }
     if (!$valid) {
         $content = new View('login.html');
         $content->form = arr::overwrite($form, $post->as_array());
         $content->errors = arr::overwrite($errors, $post->errors());
     }
     $this->auto_render = false;
     print json_encode(array("status" => $valid ? "ok" : "error", "content" => (string) $content));
 }
開發者ID:webmatter,項目名稱:gallery3-contrib,代碼行數:26,代碼來源:g3_client.php

示例3: __toString

 /**
  * Return the SQL query string.
  *
  * @return  string
  */
 public final function __toString()
 {
     try {
         // Return the SQL string
         return $this->compile(Database::instance());
     } catch (Exception $e) {
         return Kohana_Exception::text($e);
     }
 }
開發者ID:reznikds,項目名稱:Reznik,代碼行數:14,代碼來源:query.php

示例4: log

 /**
  * Logs with an arbitrary level.
  *
  * @param string  $level  a PSR LogLevel constant
  * @param string $message
  * @param array  $context
  *
  * @return null
  */
 public function log($level, $message, array $context = array())
 {
     $level = $this->convert_psr_to_kohana_level($level);
     if ($exception = $this->get_exception_from_context($context)) {
         $message .= \PHP_EOL . \Kohana_Exception::text($exception);
     } elseif ($message instanceof \Exception) {
         $context['exception'] = $message;
         $message = \Kohana_Exception::text($message);
     }
     $this->log->add($level, $message, array(), $context);
 }
開發者ID:ingenerator,項目名稱:kohana-logger,代碼行數:20,代碼來源:KohanaLogger.php

示例5: handler

 /**
  * Inline exception handler, displays the error message, source of the
  * exception, and the stack trace of the error.
  *
  * @uses    Kohana_Exception::text
  * @param   object   exception object
  * @return  boolean
  */
 public static function handler(Exception $e)
 {
     try {
         // Get the exception information
         $type = get_class($e);
         $code = $e->getCode();
         $message = $e->getMessage();
         $file = $e->getFile();
         $line = $e->getLine();
         // Create a text version of the exception
         $error = Kohana_Exception::text($e);
         if (is_object(Kohana::$log)) {
             // Add this exception to the log
             Kohana::$log->add(Log::ERROR, $error);
             // Make sure the logs are written
             Kohana::$log->write();
         }
         if (Kohana::$is_cli) {
             // Just display the text of the exception
             echo "\n{$error}\n";
             return TRUE;
         }
         if ($e instanceof ErrorException) {
             if (isset(Kohana_Exception::$php_errors[$code])) {
                 // Use the human-readable error name
                 $code = Kohana_Exception::$php_errors[$code];
             }
         }
         if (!headers_sent()) {
             Request::$current->response()->status($code);
             Request::$current->response()->headers('Content-Type', 'text/plain; charset=' . Kohana::$charset);
             Request::$current->response()->send_headers();
         }
         if (Kohana::$environment === Kohana::DEVELOPMENT) {
             echo $error;
         } else {
             echo $message;
         }
         return TRUE;
     } catch (Exception $e) {
         // Clean the output buffer if one exists
         ob_get_level() and ob_clean();
         // Make sure the proper content type is sent with a 500 status
         header('Content-Type: text/plain; charset=' . Kohana::$charset, TRUE, 500);
         // Display the exception message
         if (Kohana::$environment === Kohana::DEVELOPMENT) {
             echo Kohana_Exception::text($e), "\n";
         } else {
             echo $e->getMessage(), "\n";
         }
         // Exit with an error status
         // exit(1);
     }
 }
開發者ID:alextoshinov,項目名稱:musyme,代碼行數:62,代碼來源:Exception.php

示例6: _get

 /**
  * Get from GeoNames by geonameId
  *
  * @static
  * @param   integer  $id
  * @return  array
  */
 private static function _get($id, $lang = 'en')
 {
     $url = Kohana::$config->load('geo.base_url') . '/get?geonameId=' . (int) $id . '&lang=' . $lang . '&style=full';
     try {
         $xml = new SimpleXMLElement($url, null, true);
         Kohana::$log->add(Log::DEBUG, 'GeoNames OK: ' . $url);
         return $xml;
     } catch (Exception $e) {
         Kohana::$log->add(Log::ERROR, 'GeoNames failed: ' . $url . ' - ' . Kohana_Exception::text($e));
         return false;
     }
 }
開發者ID:anqh,項目名稱:core,代碼行數:19,代碼來源:geo.php

示例7: execute

 public function execute()
 {
     // try
     $options = isset($this->options) ? $this->options->as_array(FALSE) : array();
     $options['task'] = $this->task;
     $success = FALSE;
     try {
         // create minion task
         $minion = Minion_Task::factory($options);
         // validate options here, to handle invalid tasks
         $validation = Validation::factory($minion->get_options());
         $validation = $minion->build_validation($validation);
         if (!$validation->check()) {
             $errors = $validation->errors(TRUE);
             $error = array_shift($errors);
             // don't execute task, log validation error
             Kohana::$log->add(Log::ERROR, 'Task of id: :id and type: :type failed validation: ":msg"', array(':id' => (string) $this->_id, ':type' => (string) $this->task, ':msg' => $error));
             // no need to retry
             $this->try = $this->max_tries;
             $this->message = $error;
         } else {
             $minion->execute();
             $success = TRUE;
         }
     } catch (Exception $e) {
         $error = Kohana_Exception::text($e);
         Kohana::$log->add(Log::ERROR, 'Task :id failed on try: :try with message :msg', array(':id' => (string) $this->_id, ':msg' => $error, ':try' => $this->try));
         $this->message = $error;
     }
     if ($success) {
         // success, delete task
         $this->delete();
     } else {
         $this->status = 'failed';
         if ($this->try < $this->max_tries) {
             // requeue
             $this->status = 'queued';
             $this->update();
         } else {
             if ($this->keep_failed) {
                 $this->update();
             } else {
                 $this->delete();
             }
         }
     }
     Kohana::$log->write();
     return $success;
 }
開發者ID:wouterrr,項目名稱:mangotask,代碼行數:49,代碼來源:Task.php

示例8: _handler

 public static function _handler(Exception $e)
 {
     if (method_exists($e, 'get_response')) {
         return $e->get_response();
     }
     /**
      * Things are going *really* badly for us, We now have no choice
      * but to bail. Hard.
      */
     // Clean the output buffer if one exists
     ob_get_level() and ob_clean();
     // Set the Status code to 500, and Content-Type to text/plain.
     header('Content-Type: text/plain; charset=' . Kohana::$charset, TRUE, 500);
     echo Kohana_Exception::text($e);
 }
開發者ID:gianebao,項目名稱:kohana-rest,代碼行數:15,代碼來源:Exception.php

示例9: log

 /**
  * Logs an exception.
  *
  * @uses    Kohana_Exception::text
  * @param   Exception  $e
  * @param   int        $level
  * @return  void
  */
 public static function log(Exception $e, $level = Log::EMERGENCY)
 {
     if (is_object(Kohana::$log)) {
         // Create a text version of the exception
         $error = Kohana_Exception::text($e);
         // add url to error
         $error .= "\n on " . URL::current();
         if (isset($_SERVER['HTTP_REFERER'])) {
             $error .= "\n from " . $_SERVER['HTTP_REFERER'];
         }
         // Add this exception to the log
         Kohana::$log->add($level, $error, NULL, array('exception' => $e));
         // Make sure the logs are written
         Kohana::$log->write();
     }
 }
開發者ID:yubinchen18,項目名稱:A-basic-website-project-for-a-company-using-the-MVC-pattern-in-Kohana-framework,代碼行數:24,代碼來源:Exception.php

示例10: loop

 public function loop(array $config)
 {
     if ($this->_auto_terminate && memory_get_usage() > $this->_auto_terminate) {
         Kohana::$log->add(Log::WARNING, "Queue autoterminating. Memory usage (:usage bytes) higher than limit (:limit bytes).", array(":usage" => memory_get_usage(), ":limit" => $this->_auto_terminate));
         return FALSE;
     } else {
         if (count($this->_pids) < $this->_max_tasks) {
             try {
                 // find next task
                 $task = Mango::factory('task')->get_next();
             } catch (MongoException $e) {
                 Kohana::$log->add(Log::ERROR, Kohana_Exception::text($e));
                 Kohana::$log->add(Log::ERROR, 'Error loading next task. Exiting');
                 return FALSE;
             }
             if ($task->loaded()) {
                 // Write log to prevent memory issues
                 Kohana::$log->write();
                 // close all database connections before forking
                 foreach (MangoDB::$instances as $instance) {
                     $instance->disconnect();
                 }
                 $pid = pcntl_fork();
                 if ($pid == -1) {
                     // error forking
                     Kohana::$log->add(Log::ERROR, 'Queue. Could not spawn child task process.');
                     Kohana::$log->write();
                     exit;
                 } else {
                     if ($pid) {
                         // parent process
                         $this->_pids[$pid] = time();
                     } else {
                         // child process
                         $task->execute();
                         exit(0);
                     }
                 }
             }
         }
     }
     return TRUE;
 }
開發者ID:wouterrr,項目名稱:mangotask,代碼行數:43,代碼來源:Worker.php

示例11: kandler

 /**
  * Inline exception handler.
  *
  * @param   Exception  exception object
  * @return  string
  * @uses    Arr::get
  * @uses    Kohana::find_file
  * @uses    Kohana_Exception::handler
  * @uses    Kohana_Exception::text
  */
 function kandler(Exception $e)
 {
     try {
         // Get error code
         $code = $e->getCode();
         // Retrieve Kandler's config
         $config = Kohana::$config->load('kandler');
         // Use views defined by user or use default
         $view = Arr::get($config->errors, $code, $code);
         // Create path to error view
         $path = $config->path . DIRECTORY_SEPARATOR . $view;
         if (Kohana::find_file('views', $path)) {
             // Set an exception view
             Kohana_Exception::$error_view = $path;
         }
         // Handle an exception using Kohana's handler
         Kohana_Exception::handler($e);
     } catch (Exception $e) {
         return Kohana_Exception::text($e);
     }
 }
開發者ID:hbarroso,項目名稱:Goworkat,代碼行數:31,代碼來源:init.php

示例12: handler

 public static function handler(Exception $e)
 {
     /*
      * In development, use the in-built Kohana
      * exception handler to display and log the
      * exception/error.
      */
     if (Kohana::$environment >= Kohana::DEVELOPMENT) {
         Kohana_Exception::handler($e);
     } else {
         try {
             $exception_text = Kohana_Exception::text($e);
             // Log the error
             Kohana::$log->add(Log::ERROR, $exception_text);
             // Email the error
             if (class_exists('Email')) {
                 $email_subject = Kohana::$config->load('error.website.name') . ' Error';
                 $email_message = $exception_text;
                 $email_from = Kohana::$config->load('error.email.from');
                 foreach ('error.email.to' as $email_to) {
                     Email::send($email_to, $email_from, $email_subject, $email_mesage);
                 }
             } else {
                 Kohana::$log->add(Log::NOTICE, 'Email module not installed, errors can not be sent.');
             }
             // Show an error page
             $action = $e instanceof HTTP_Exception ? $e->getCode() : 500;
             $post = array('message' => $e->getMessage(), 'requested_url' => Request::$current ? Request::$current->uri() : 'Unknown');
             echo Request::factory(Route::get('error-handler')->uri(array('action' => $action)))->method(Request::POST)->post($post)->execute()->send_headers()->body();
         } catch (Exception $e) {
             // Clean the output buffer if one exists
             ob_get_level() and ob_clean();
             // Display the exception text
             echo Kohana_Exception::text($e);
             // Exit with an error status
             exit(1);
         }
     }
 }
開發者ID:rowanparker,項目名稱:kohana-3-error-handling,代碼行數:39,代碼來源:handler.php

示例13: response

 public static function response($e)
 {
     try {
         $class = get_class($e);
         $code = $e->getCode();
         $message = $e->getMessage();
         $file = $e->getFile();
         $line = $e->getLine();
         $trace = $e->getTrace();
         if ($e instanceof ErrorException) {
             if (isset(Kohana_Exception::$php_errors[$code])) {
                 $code = Kohana_Exception::$php_errors[$code];
             }
         }
         $response = View::factory(Kohana_Exception::$error_view, get_defined_vars());
         return $response;
     } catch (Exception $e) {
         ob_get_level() and ob_clean();
         header('Content-Type: text/plain; charset=utf-8', TRUE, 500);
         echo Kohana_Exception::text($e);
         exit(1);
     }
 }
開發者ID:noikiy,項目名稱:kohana,代碼行數:23,代碼來源:Exception.php

示例14: action_index

 public function action_index()
 {
     $post = $this->request->current()->post();
     $group = Arr::get($post, 'group');
     $album_id = (int) Arr::get($post, 'album');
     $items = Arr::get($post, 'items');
     $operation = Arr::get($post, 'operation');
     $album_orm = ORM::factory('photo_Album')->where('group', '=', $group)->and_where('id', '=', $album_id)->find();
     if (!$album_orm->loaded() or !$this->acl->is_allowed($this->user, $album_orm, 'edit')) {
         throw new HTTP_Exception_404();
     }
     if (empty($items) or !is_array($items) or empty($operation)) {
         throw new HTTP_Exception_404();
     }
     try {
         $this->_group_operation_move($operation, $items, $album_orm);
     } catch (Exception $e) {
         $code = $e->getCode();
         $this->response->status(ctype_digit($code) ? $code : 500)->body(Kohana_Exception::text($e));
         return;
     }
     $this->response->body('OK');
 }
開發者ID:greor,項目名稱:kohana-photo,代碼行數:23,代碼來源:group.php

示例15: __toString

 public function __toString()
 {
     try {
         // Return the SQL string
         return $this->compile();
     } catch (Exception $e) {
         return Kohana_Exception::text($e);
     }
 }
開發者ID:openbuildings,項目名稱:jam,代碼行數:9,代碼來源:Update.php


注:本文中的Kohana_Exception::text方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。