blob: 49c2217c9b54099f9e5d0a8ec9a195bc1b745201 [file] [log] [blame]
Andrey Andreevc5536aa2012-11-01 17:33:58 +02001<?php
Derek Allard2067d1a2008-11-13 22:59:24 +00002/**
3 * CodeIgniter
4 *
Phil Sturgeon07c1ac82012-03-09 17:03:37 +00005 * An open source application development framework for PHP 5.2.4 or newer
Derek Allard2067d1a2008-11-13 22:59:24 +00006 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05007 * NOTICE OF LICENSE
Andrey Andreev7ac33d72012-01-07 19:39:39 +02008 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -05009 * Licensed under the Open Software License version 3.0
Andrey Andreev7ac33d72012-01-07 19:39:39 +020010 *
Derek Jonesf4a4bd82011-10-20 12:18:42 -050011 * This source file is subject to the Open Software License (OSL 3.0) that is
12 * bundled with this package in the files license.txt / license.rst. It is
13 * also available through the world wide web at this URL:
14 * http://opensource.org/licenses/OSL-3.0
15 * If you did not receive a copy of the license and are unable to obtain it
16 * through the world wide web, please send an email to
17 * licensing@ellislab.com so we can send you a copy immediately.
18 *
Derek Allard2067d1a2008-11-13 22:59:24 +000019 * @package CodeIgniter
Derek Jonesf4a4bd82011-10-20 12:18:42 -050020 * @author EllisLab Dev Team
darwinel871754a2014-02-11 17:34:57 +010021 * @copyright Copyright (c) 2008 - 2014, EllisLab, Inc. (http://ellislab.com/)
Derek Jonesf4a4bd82011-10-20 12:18:42 -050022 * @license http://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0)
Derek Allard2067d1a2008-11-13 22:59:24 +000023 * @link http://codeigniter.com
24 * @since Version 1.0
25 * @filesource
26 */
Andrey Andreevc5536aa2012-11-01 17:33:58 +020027defined('BASEPATH') OR exit('No direct script access allowed');
Derek Allard2067d1a2008-11-13 22:59:24 +000028
Derek Allard2067d1a2008-11-13 22:59:24 +000029/**
30 * Exceptions Class
31 *
32 * @package CodeIgniter
33 * @subpackage Libraries
34 * @category Exceptions
Derek Jonesf4a4bd82011-10-20 12:18:42 -050035 * @author EllisLab Dev Team
Derek Allard2067d1a2008-11-13 22:59:24 +000036 * @link http://codeigniter.com/user_guide/libraries/exceptions.html
37 */
38class CI_Exceptions {
Andrey Andreev7ac33d72012-01-07 19:39:39 +020039
David Behler209b2cf2011-08-14 23:00:43 +020040 /**
41 * Nesting level of the output buffering mechanism
David Behler209b2cf2011-08-14 23:00:43 +020042 *
Timothy Warren48a7fbb2012-04-23 11:58:16 -040043 * @var int
David Behler209b2cf2011-08-14 23:00:43 +020044 */
Andrey Andreev7ac33d72012-01-07 19:39:39 +020045 public $ob_level;
Derek Allard2067d1a2008-11-13 22:59:24 +000046
David Behler209b2cf2011-08-14 23:00:43 +020047 /**
vlakoffd5ce5082014-04-25 10:13:04 +020048 * List of available error levels
David Behler209b2cf2011-08-14 23:00:43 +020049 *
Timothy Warren48a7fbb2012-04-23 11:58:16 -040050 * @var array
David Behler209b2cf2011-08-14 23:00:43 +020051 */
Andrey Andreev7ac33d72012-01-07 19:39:39 +020052 public $levels = array(
Timothy Warren40403d22012-04-19 16:38:50 -040053 E_ERROR => 'Error',
54 E_WARNING => 'Warning',
55 E_PARSE => 'Parsing Error',
56 E_NOTICE => 'Notice',
57 E_CORE_ERROR => 'Core Error',
58 E_CORE_WARNING => 'Core Warning',
59 E_COMPILE_ERROR => 'Compile Error',
60 E_COMPILE_WARNING => 'Compile Warning',
61 E_USER_ERROR => 'User Error',
62 E_USER_WARNING => 'User Warning',
63 E_USER_NOTICE => 'User Notice',
64 E_STRICT => 'Runtime Notice'
65 );
Derek Allard2067d1a2008-11-13 22:59:24 +000066
Timothy Warrenad475052012-04-19 13:21:06 -040067 /**
Andrey Andreev3e9d2b82012-10-27 14:28:51 +030068 * Class constructor
Andrey Andreev92ebfb62012-05-17 12:49:24 +030069 *
70 * @return void
Timothy Warrenad475052012-04-19 13:21:06 -040071 */
Greg Akera9263282010-11-10 15:26:43 -060072 public function __construct()
Derek Allard2067d1a2008-11-13 22:59:24 +000073 {
74 $this->ob_level = ob_get_level();
Andrey Andreev7ac33d72012-01-07 19:39:39 +020075 // Note: Do not log messages from this constructor.
Derek Allard2067d1a2008-11-13 22:59:24 +000076 }
Barry Mienydd671972010-10-04 16:33:58 +020077
Derek Allard2067d1a2008-11-13 22:59:24 +000078 // --------------------------------------------------------------------
79
80 /**
81 * Exception Logger
82 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +030083 * Logs PHP generated error messages
Derek Allard2067d1a2008-11-13 22:59:24 +000084 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +030085 * @param int $severity Log level
86 * @param string $message Error message
87 * @param string $filepath File path
88 * @param int $line Line number
Andrey Andreev7ac33d72012-01-07 19:39:39 +020089 * @return void
Derek Allard2067d1a2008-11-13 22:59:24 +000090 */
Andrey Andreev7ac33d72012-01-07 19:39:39 +020091 public function log_exception($severity, $message, $filepath, $line)
Barry Mienydd671972010-10-04 16:33:58 +020092 {
Andrey Andreev92ebfb62012-05-17 12:49:24 +030093 $severity = isset($this->levels[$severity]) ? $this->levels[$severity] : $severity;
Andrey Andreev29947ee2013-11-12 18:36:46 +020094 log_message('error', 'Severity: '.$severity.' --> '.$message.' '.$filepath.' '.$line);
Derek Allard2067d1a2008-11-13 22:59:24 +000095 }
96
97 // --------------------------------------------------------------------
98
99 /**
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300100 * 404 Error Handler
Derek Allard2067d1a2008-11-13 22:59:24 +0000101 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300102 * @uses CI_Exceptions::show_error()
103 *
104 * @param string $page Page URI
105 * @param bool $log_error Whether to log the error
106 * @return void
Derek Allard2067d1a2008-11-13 22:59:24 +0000107 */
Andrey Andreev7ac33d72012-01-07 19:39:39 +0200108 public function show_404($page = '', $log_error = TRUE)
Barry Mienydd671972010-10-04 16:33:58 +0200109 {
Andrey Andreev29947ee2013-11-12 18:36:46 +0200110 if (is_cli())
111 {
112 $heading = 'Not Found';
113 $message = 'The controller/method pair you requested was not found.';
114 }
115 else
116 {
117 $heading = '404 Page Not Found';
118 $message = 'The page you requested was not found.';
119 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000120
Derek Allard2ddc9492010-08-05 10:08:33 -0400121 // By default we log this, but allow a dev to skip it
122 if ($log_error)
123 {
Andrey Andreev29947ee2013-11-12 18:36:46 +0200124 log_message('error', $heading.': '.$page);
Derek Allard2ddc9492010-08-05 10:08:33 -0400125 }
126
Derek Jonesf6b442b2009-07-11 18:23:30 +0000127 echo $this->show_error($heading, $message, 'error_404', 404);
Andrey Andreev7cf682a2014-03-13 14:55:45 +0200128 exit(4); // EXIT_UNKNOWN_FILE
Derek Allard2067d1a2008-11-13 22:59:24 +0000129 }
Barry Mienydd671972010-10-04 16:33:58 +0200130
Derek Allard2067d1a2008-11-13 22:59:24 +0000131 // --------------------------------------------------------------------
132
133 /**
134 * General Error Page
135 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300136 * Takes an error message as input (either as a string or an array)
137 * and displays it using the specified template.
Derek Allard2067d1a2008-11-13 22:59:24 +0000138 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300139 * @param string $heading Page heading
140 * @param string|string[] $message Error message
141 * @param string $template Template name
Andrey Andreev5232ba02012-10-27 15:25:05 +0300142 * @param int $status_code (default: 500)
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300143 *
144 * @return string Error page output
Derek Allard2067d1a2008-11-13 22:59:24 +0000145 */
Andrey Andreev7ac33d72012-01-07 19:39:39 +0200146 public function show_error($heading, $message, $template = 'error_general', $status_code = 500)
Derek Allard2067d1a2008-11-13 22:59:24 +0000147 {
Andrey Andreevd444d442014-10-06 00:00:08 +0300148 $templates_path = config_item('error_views_path');
149 if (empty($templates_path))
150 {
151 $templates_path = VIEWPATH.'errors'.DIRECTORY_SEPARATOR;
152 }
vlakoff08ea83b2014-04-14 14:34:06 +0200153
Andrey Andreev29947ee2013-11-12 18:36:46 +0200154 if (is_cli())
155 {
156 $message = "\t".(is_array($message) ? implode("\n\t", $message) : $message);
157 $template = 'cli'.DIRECTORY_SEPARATOR.$template;
158 }
159 else
160 {
161 set_status_header($status_code);
162 $message = '<p>'.(is_array($message) ? implode('</p><p>', $message) : $message).'</p>';
163 $template = 'html'.DIRECTORY_SEPARATOR.$template;
164 }
Derek Allard2067d1a2008-11-13 22:59:24 +0000165
166 if (ob_get_level() > $this->ob_level + 1)
167 {
Barry Mienydd671972010-10-04 16:33:58 +0200168 ob_end_flush();
Derek Allard2067d1a2008-11-13 22:59:24 +0000169 }
170 ob_start();
vlakoff08ea83b2014-04-14 14:34:06 +0200171 include($templates_path.$template.'.php');
Derek Allard2067d1a2008-11-13 22:59:24 +0000172 $buffer = ob_get_contents();
173 ob_end_clean();
174 return $buffer;
175 }
176
177 // --------------------------------------------------------------------
178
179 /**
180 * Native PHP error handler
181 *
Andrey Andreev3e9d2b82012-10-27 14:28:51 +0300182 * @param int $severity Error level
183 * @param string $message Error message
184 * @param string $filepath File path
185 * @param int $line Line number
186 * @return string Error page output
Derek Allard2067d1a2008-11-13 22:59:24 +0000187 */
Andrey Andreevc6a68e02012-03-26 14:30:10 +0300188 public function show_php_error($severity, $message, $filepath, $line)
Barry Mienydd671972010-10-04 16:33:58 +0200189 {
Andrey Andreevd444d442014-10-06 00:00:08 +0300190 $templates_path = config_item('error_views_path');
191 if (empty($templates_path))
192 {
193 $templates_path = VIEWPATH.'errors'.DIRECTORY_SEPARATOR;
194 }
vlakoff08ea83b2014-04-14 14:34:06 +0200195
Andrey Andreev92ebfb62012-05-17 12:49:24 +0300196 $severity = isset($this->levels[$severity]) ? $this->levels[$severity] : $severity;
Barry Mienydd671972010-10-04 16:33:58 +0200197
Andrey Andreev29947ee2013-11-12 18:36:46 +0200198 // For safety reasons we don't show the full file path in non-CLI requests
199 if ( ! is_cli())
Derek Allard2067d1a2008-11-13 22:59:24 +0000200 {
Andrey Andreev29947ee2013-11-12 18:36:46 +0200201 $filepath = str_replace('\\', '/', $filepath);
202 if (FALSE !== strpos($filepath, '/'))
203 {
204 $x = explode('/', $filepath);
205 $filepath = $x[count($x)-2].'/'.end($x);
206 }
207
208 $template = 'html'.DIRECTORY_SEPARATOR.'error_php';
209 }
210 else
211 {
212 $template = 'cli'.DIRECTORY_SEPARATOR.'error_php';
Derek Allard2067d1a2008-11-13 22:59:24 +0000213 }
Barry Mienydd671972010-10-04 16:33:58 +0200214
Derek Allard2067d1a2008-11-13 22:59:24 +0000215 if (ob_get_level() > $this->ob_level + 1)
216 {
Barry Mienydd671972010-10-04 16:33:58 +0200217 ob_end_flush();
Derek Allard2067d1a2008-11-13 22:59:24 +0000218 }
219 ob_start();
vlakoff08ea83b2014-04-14 14:34:06 +0200220 include($templates_path.$template.'.php');
Derek Allard2067d1a2008-11-13 22:59:24 +0000221 $buffer = ob_get_contents();
222 ob_end_clean();
223 echo $buffer;
224 }
225
Derek Allard2067d1a2008-11-13 22:59:24 +0000226}
Derek Allard2067d1a2008-11-13 22:59:24 +0000227
228/* End of file Exceptions.php */
Andrey Andreevc6a68e02012-03-26 14:30:10 +0300229/* Location: ./system/core/Exceptions.php */