2013-08-01 08:52:51 +00:00
|
|
|
<?php
|
|
|
|
class No_Iframes extends Plugin {
|
|
|
|
private $host;
|
|
|
|
|
|
|
|
function about() {
|
|
|
|
return array(1.0,
|
2014-11-25 15:40:19 +00:00
|
|
|
"Remove embedded iframes (unless whitelisted)",
|
2013-08-01 08:52:51 +00:00
|
|
|
"fox");
|
|
|
|
}
|
|
|
|
|
|
|
|
function init($host) {
|
|
|
|
$this->host = $host;
|
|
|
|
|
|
|
|
$host->add_hook($host::HOOK_SANITIZE, $this);
|
|
|
|
}
|
|
|
|
|
2017-04-26 17:57:36 +00:00
|
|
|
/**
|
|
|
|
* @SuppressWarnings(PHPMD.UnusedFormalParameter)
|
|
|
|
*/
|
2013-08-01 08:52:51 +00:00
|
|
|
function hook_sanitize($doc, $site_url, $allowed_elements, $disallowed_attributes) {
|
|
|
|
|
2014-11-25 15:40:19 +00:00
|
|
|
$xpath = new DOMXpath($doc);
|
|
|
|
$entries = $xpath->query('//iframe');
|
|
|
|
|
|
|
|
foreach ($entries as $entry) {
|
2020-09-22 06:04:33 +00:00
|
|
|
if (!Sanitizer::iframe_whitelisted($entry))
|
2014-11-25 15:40:19 +00:00
|
|
|
$entry->parentNode->removeChild($entry);
|
|
|
|
}
|
2013-08-01 08:52:51 +00:00
|
|
|
|
|
|
|
return array($doc, $allowed_elements, $disallowed_attributes);
|
|
|
|
}
|
|
|
|
|
|
|
|
function api_version() {
|
|
|
|
return 2;
|
|
|
|
}
|
|
|
|
|
2020-09-22 06:04:33 +00:00
|
|
|
}
|