113 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
		
		
			
		
	
	
			113 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			PHP
		
	
	
| 
								 | 
							
								<?php
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								class HTMLPurifier_URIDefinition extends HTMLPurifier_Definition
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public $type = 'URI';
							 | 
						||
| 
								 | 
							
								    protected $filters = array();
							 | 
						||
| 
								 | 
							
								    protected $postFilters = array();
							 | 
						||
| 
								 | 
							
								    protected $registeredFilters = array();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * HTMLPurifier_URI object of the base specified at %URI.Base
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public $base;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * String host to consider "home" base, derived off of $base
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public $host;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Name of default scheme based on %URI.DefaultScheme and %URI.Base
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public $defaultScheme;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function __construct()
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_DisableExternal());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_DisableExternalResources());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_DisableResources());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_HostBlacklist());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_SafeIframe());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_MakeAbsolute());
							 | 
						||
| 
								 | 
							
								        $this->registerFilter(new HTMLPurifier_URIFilter_Munge());
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function registerFilter($filter)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $this->registeredFilters[$filter->name] = $filter;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function addFilter($filter, $config)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $r = $filter->prepare($config);
							 | 
						||
| 
								 | 
							
								        if ($r === false) return; // null is ok, for backwards compat
							 | 
						||
| 
								 | 
							
								        if ($filter->post) {
							 | 
						||
| 
								 | 
							
								            $this->postFilters[$filter->name] = $filter;
							 | 
						||
| 
								 | 
							
								        } else {
							 | 
						||
| 
								 | 
							
								            $this->filters[$filter->name] = $filter;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    protected function doSetup($config)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $this->setupMemberVariables($config);
							 | 
						||
| 
								 | 
							
								        $this->setupFilters($config);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    protected function setupFilters($config)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        foreach ($this->registeredFilters as $name => $filter) {
							 | 
						||
| 
								 | 
							
								            if ($filter->always_load) {
							 | 
						||
| 
								 | 
							
								                $this->addFilter($filter, $config);
							 | 
						||
| 
								 | 
							
								            } else {
							 | 
						||
| 
								 | 
							
								                $conf = $config->get('URI.' . $name);
							 | 
						||
| 
								 | 
							
								                if ($conf !== false && $conf !== null) {
							 | 
						||
| 
								 | 
							
								                    $this->addFilter($filter, $config);
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        unset($this->registeredFilters);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    protected function setupMemberVariables($config)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $this->host = $config->get('URI.Host');
							 | 
						||
| 
								 | 
							
								        $base_uri = $config->get('URI.Base');
							 | 
						||
| 
								 | 
							
								        if (!is_null($base_uri)) {
							 | 
						||
| 
								 | 
							
								            $parser = new HTMLPurifier_URIParser();
							 | 
						||
| 
								 | 
							
								            $this->base = $parser->parse($base_uri);
							 | 
						||
| 
								 | 
							
								            $this->defaultScheme = $this->base->scheme;
							 | 
						||
| 
								 | 
							
								            if (is_null($this->host)) $this->host = $this->base->host;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        if (is_null($this->defaultScheme)) $this->defaultScheme = $config->get('URI.DefaultScheme');
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function getDefaultScheme($config, $context)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return HTMLPurifier_URISchemeRegistry::instance()->getScheme($this->defaultScheme, $config, $context);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function filter(&$uri, $config, $context)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        foreach ($this->filters as $name => $f) {
							 | 
						||
| 
								 | 
							
								            $result = $f->filter($uri, $config, $context);
							 | 
						||
| 
								 | 
							
								            if (!$result) return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        return true;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function postFilter(&$uri, $config, $context)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        foreach ($this->postFilters as $name => $f) {
							 | 
						||
| 
								 | 
							
								            $result = $f->filter($uri, $config, $context);
							 | 
						||
| 
								 | 
							
								            if (!$result) return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        return true;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// vim: et sw=4 sts=4
							 |