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;
 | 
						|
    }
 | 
						|
}
 | 
						|
 |