Blame view

vendor/ezyang/htmlpurifier/library/HTMLPurifier/AttrTransform/TargetBlank.php 1.07 KB
70f4f18b   Administrator   first_commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
  <?php
  
  // must be called POST validation
  
  /**
   * Adds target="blank" to all outbound links.  This transform is
   * only attached if Attr.TargetBlank is TRUE.  This works regardless
   * of whether or not Attr.AllowedFrameTargets
   */
  class HTMLPurifier_AttrTransform_TargetBlank extends HTMLPurifier_AttrTransform
  {
      /**
       * @type HTMLPurifier_URIParser
       */
      private $parser;
  
      public function __construct()
      {
          $this->parser = new HTMLPurifier_URIParser();
      }
  
      /**
       * @param array $attr
       * @param HTMLPurifier_Config $config
       * @param HTMLPurifier_Context $context
       * @return array
       */
      public function transform($attr, $config, $context)
      {
          if (!isset($attr['href'])) {
              return $attr;
          }
  
          // XXX Kind of inefficient
          $url = $this->parser->parse($attr['href']);
          $scheme = $url->getSchemeObj($config, $context);
  
          if ($scheme->browsable && !$url->isBenign($config, $context)) {
              $attr['target'] = '_blank';
          }
          return $attr;
      }
  }
  
  // vim: et sw=4 sts=4