3 class HTMLPurifier_URIFilter_Munge
extends HTMLPurifier_URIFilter
5 public $name = 'Munge';
7 private $target, $parser, $doEmbed, $secretKey;
9 protected $replace = array();
11 public function prepare($config) {
12 $this->target
= $config->get('URI.' . $this->name
);
13 $this->parser
= new HTMLPurifier_URIParser();
14 $this->doEmbed
= $config->get('URI.MungeResources');
15 $this->secretKey
= $config->get('URI.MungeSecretKey');
18 public function filter(&$uri, $config, $context) {
19 if ($context->get('EmbeddedURI', true) && !$this->doEmbed
) return true;
21 $scheme_obj = $uri->getSchemeObj($config, $context);
22 if (!$scheme_obj) return true; // ignore unknown schemes, maybe another postfilter did it
23 if (is_null($uri->host
) ||
empty($scheme_obj->browsable
)) {
26 // don't redirect if target host is our host
27 if ($uri->host
=== $config->getDefinition('URI')->host
) {
31 $this->makeReplace($uri, $config, $context);
32 $this->replace
= array_map('rawurlencode', $this->replace
);
34 $new_uri = strtr($this->target
, $this->replace
);
35 $new_uri = $this->parser
->parse($new_uri);
36 // don't redirect if the target host is the same as the
38 if ($uri->host
=== $new_uri->host
) return true;
39 $uri = $new_uri; // overwrite
43 protected function makeReplace($uri, $config, $context) {
44 $string = $uri->toString();
46 $this->replace
['%s'] = $string;
47 $this->replace
['%r'] = $context->get('EmbeddedURI', true);
48 $token = $context->get('CurrentToken', true);
49 $this->replace
['%n'] = $token ?
$token->name
: null;
50 $this->replace
['%m'] = $context->get('CurrentAttr', true);
51 $this->replace
['%p'] = $context->get('CurrentCSSProperty', true);
52 // not always available
53 if ($this->secretKey
) $this->replace
['%t'] = sha1($this->secretKey
. ':' . $string);