*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace HtmlSanitizer\Extension\Image\NodeVisitor;
use HtmlSanitizer\Model\Cursor;
use HtmlSanitizer\Extension\Image\Node\ImgNode;
use HtmlSanitizer\Node\NodeInterface;
use HtmlSanitizer\Extension\Image\Sanitizer\ImgSrcSanitizer;
use HtmlSanitizer\Visitor\AbstractNodeVisitor;
use HtmlSanitizer\Visitor\IsChildlessTagVisitorTrait;
use HtmlSanitizer\Visitor\NamedNodeVisitorInterface;
/**
* @author Titouan Galopin
*
* @final
*/
class ImgNodeVisitor extends AbstractNodeVisitor implements NamedNodeVisitorInterface
{
use IsChildlessTagVisitorTrait;
/**
* @var ImgSrcSanitizer
*/
private $sanitizer;
public function __construct(array $config = [])
{
parent::__construct($config);
$this->sanitizer = new ImgSrcSanitizer(
$this->config['allowed_schemes'],
$this->config['allowed_hosts'],
$this->config['allow_data_uri'],
$this->config['allow_relative_links'],
$this->config['force_https']
);
}
protected function getDomNodeName(): string
{
return 'img';
}
public function getDefaultAllowedAttributes(): array
{
return ['src', 'alt', 'title'];
}
public function getDefaultConfiguration(): array
{
return [
'allowed_schemes' => ['http', 'https'],
'allowed_hosts' => null,
'allow_data_uri' => false,
'allow_relative_links' => false,
'force_https' => false,
];
}
protected function createNode(\DOMNode $domNode, Cursor $cursor): NodeInterface
{
$node = new ImgNode($cursor->node);
$node->setAttribute('src', $this->sanitizer->sanitize($this->getAttribute($domNode, 'src')));
return $node;
}
}