39 lines
		
	
	
		
			910 B
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			39 lines
		
	
	
		
			910 B
		
	
	
	
		
			PHP
		
	
	
|  | <?php | ||
|  | 
 | ||
|  | /** | ||
|  |  * This variable parser uses PHP's internal code engine. Because it does | ||
|  |  * this, it can represent all inputs; however, it is dangerous and cannot | ||
|  |  * be used by users. | ||
|  |  */ | ||
|  | class HTMLPurifier_VarParser_Native extends HTMLPurifier_VarParser | ||
|  | { | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @param mixed $var | ||
|  |      * @param int $type | ||
|  |      * @param bool $allow_null | ||
|  |      * @return null|string | ||
|  |      */ | ||
|  |     protected function parseImplementation($var, $type, $allow_null) | ||
|  |     { | ||
|  |         return $this->evalExpression($var); | ||
|  |     } | ||
|  | 
 | ||
|  |     /** | ||
|  |      * @param string $expr | ||
|  |      * @return mixed | ||
|  |      * @throws HTMLPurifier_VarParserException | ||
|  |      */ | ||
|  |     protected function evalExpression($expr) | ||
|  |     { | ||
|  |         $var = null; | ||
|  |         $result = eval("\$var = $expr;"); | ||
|  |         if ($result === false) { | ||
|  |             throw new HTMLPurifier_VarParserException("Fatal error in evaluated code"); | ||
|  |         } | ||
|  |         return $var; | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | // vim: et sw=4 sts=4
 |