| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |  * Smarty error handler to fix new error levels in PHP8 for backwards compatibility | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @package    Smarty | 
					
						
							|  |  |  |  * @subpackage PluginsInternal | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |  * @author     Simon Wisselink | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class Smarty_Internal_ErrorHandler | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |      * Allows {$foo} where foo is unset. | 
					
						
							|  |  |  |      * @var bool | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |     public $allowUndefinedVars = true; | 
					
						
							| 
									
										
										
										
											2018-08-31 16:45:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |      * Allows {$foo.bar} where bar is unset and {$foo.bar1.bar2} where either bar1 or bar2 is unset. | 
					
						
							|  |  |  |      * @var bool | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |     public $allowUndefinedArrayKeys = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private $previousErrorHandler = null; | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |      * Enable error handler to intercept errors | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |     public function activate() { | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |         /* | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |             Error muting is done because some people implemented custom error_handlers using | 
					
						
							|  |  |  |             https://php.net/set_error_handler and for some reason did not understand the following paragraph: | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |             It is important to remember that the standard PHP error handler is completely bypassed for the | 
					
						
							|  |  |  |             error types specified by error_types unless the callback function returns FALSE. | 
					
						
							|  |  |  |             error_reporting() settings will have no effect and your error handler will be called regardless - | 
					
						
							|  |  |  |             however you are still able to read the current value of error_reporting and act appropriately. | 
					
						
							|  |  |  |             Of particular note is that this value will be 0 if the statement that caused the error was | 
					
						
							|  |  |  |             prepended by the @ error-control operator. | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |         */ | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |         $this->previousErrorHandler = set_error_handler([$this, 'handleError']); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Disable error handler | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function deactivate() { | 
					
						
							|  |  |  |         restore_error_handler(); | 
					
						
							|  |  |  |         $this->previousErrorHandler = null; | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Error Handler to mute expected messages | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |      * @link https://php.net/set_error_handler | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-08-31 16:45:09 +02:00
										 |  |  |      * @param integer $errno Error level | 
					
						
							|  |  |  |      * @param         $errstr | 
					
						
							|  |  |  |      * @param         $errfile | 
					
						
							|  |  |  |      * @param         $errline | 
					
						
							|  |  |  |      * @param         $errcontext | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |     public function handleError($errno, $errstr, $errfile, $errline, $errcontext = []) | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  |         if ($this->allowUndefinedVars && $errstr == 'Attempt to read property "value" on null') { | 
					
						
							|  |  |  |             return; // suppresses this error
 | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($this->allowUndefinedArrayKeys && preg_match( | 
					
						
							|  |  |  |             '/^(Undefined array key|Trying to access array offset on value of type null)/', | 
					
						
							|  |  |  |             $errstr | 
					
						
							|  |  |  |         )) { | 
					
						
							|  |  |  |             return; // suppresses this error
 | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-10-13 12:15:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // pass all other errors through to the previous error handler or to the default PHP error handler
 | 
					
						
							|  |  |  |         return $this->previousErrorHandler ? | 
					
						
							|  |  |  |             call_user_func($this->previousErrorHandler, $errno, $errstr, $errfile, $errline, $errcontext) : false; | 
					
						
							| 
									
										
										
										
											2017-10-26 06:00:40 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-06-12 09:58:15 +02:00
										 |  |  | } |