38 lines
1022 B
PHP
38 lines
1022 B
PHP
|
<?php
|
||
|
|
||
|
// must be called POST validation
|
||
|
|
||
|
/**
|
||
|
* Adds rel="noopener" to any links which target a different window
|
||
|
* than the current one. This is used to prevent malicious websites
|
||
|
* from silently replacing the original window, which could be used
|
||
|
* to do phishing.
|
||
|
* This transform is controlled by %HTML.TargetNoopener.
|
||
|
*/
|
||
|
class HTMLPurifier_AttrTransform_TargetNoopener extends HTMLPurifier_AttrTransform
|
||
|
{
|
||
|
/**
|
||
|
* @param array $attr
|
||
|
* @param HTMLPurifier_Config $config
|
||
|
* @param HTMLPurifier_Context $context
|
||
|
* @return array
|
||
|
*/
|
||
|
public function transform($attr, $config, $context)
|
||
|
{
|
||
|
if (isset($attr['rel'])) {
|
||
|
$rels = explode(' ', $attr['rel']);
|
||
|
} else {
|
||
|
$rels = array();
|
||
|
}
|
||
|
if (isset($attr['target']) && !in_array('noopener', $rels)) {
|
||
|
$rels[] = 'noopener';
|
||
|
}
|
||
|
if (!empty($rels) || isset($attr['rel'])) {
|
||
|
$attr['rel'] = implode(' ', $rels);
|
||
|
}
|
||
|
|
||
|
return $attr;
|
||
|
}
|
||
|
}
|
||
|
|