80 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
/**
 | 
						|
 * Validates name/value pairs in param tags to be used in safe objects. This
 | 
						|
 * will only allow name values it recognizes, and pre-fill certain attributes
 | 
						|
 * with required values.
 | 
						|
 *
 | 
						|
 * @note
 | 
						|
 *      This class only supports Flash. In the future, Quicktime support
 | 
						|
 *      may be added.
 | 
						|
 *
 | 
						|
 * @warning
 | 
						|
 *      This class expects an injector to add the necessary parameters tags.
 | 
						|
 */
 | 
						|
class HTMLPurifier_AttrTransform_SafeParam extends HTMLPurifier_AttrTransform
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * @type string
 | 
						|
     */
 | 
						|
    public $name = "SafeParam";
 | 
						|
 | 
						|
    /**
 | 
						|
     * @type HTMLPurifier_AttrDef_URI
 | 
						|
     */
 | 
						|
    private $uri;
 | 
						|
 | 
						|
    public function __construct()
 | 
						|
    {
 | 
						|
        $this->uri = new HTMLPurifier_AttrDef_URI(true); // embedded
 | 
						|
        $this->wmode = new HTMLPurifier_AttrDef_Enum(array('window', 'opaque', 'transparent'));
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param array $attr
 | 
						|
     * @param HTMLPurifier_Config $config
 | 
						|
     * @param HTMLPurifier_Context $context
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    public function transform($attr, $config, $context)
 | 
						|
    {
 | 
						|
        // If we add support for other objects, we'll need to alter the
 | 
						|
        // transforms.
 | 
						|
        switch ($attr['name']) {
 | 
						|
            // application/x-shockwave-flash
 | 
						|
            // Keep this synchronized with Injector/SafeObject.php
 | 
						|
            case 'allowScriptAccess':
 | 
						|
                $attr['value'] = 'never';
 | 
						|
                break;
 | 
						|
            case 'allowNetworking':
 | 
						|
                $attr['value'] = 'internal';
 | 
						|
                break;
 | 
						|
            case 'allowFullScreen':
 | 
						|
                if ($config->get('HTML.FlashAllowFullScreen')) {
 | 
						|
                    $attr['value'] = ($attr['value'] == 'true') ? 'true' : 'false';
 | 
						|
                } else {
 | 
						|
                    $attr['value'] = 'false';
 | 
						|
                }
 | 
						|
                break;
 | 
						|
            case 'wmode':
 | 
						|
                $attr['value'] = $this->wmode->validate($attr['value'], $config, $context);
 | 
						|
                break;
 | 
						|
            case 'movie':
 | 
						|
            case 'src':
 | 
						|
                $attr['name'] = "movie";
 | 
						|
                $attr['value'] = $this->uri->validate($attr['value'], $config, $context);
 | 
						|
                break;
 | 
						|
            case 'flashvars':
 | 
						|
                // we're going to allow arbitrary inputs to the SWF, on
 | 
						|
                // the reasoning that it could only hack the SWF, not us.
 | 
						|
                break;
 | 
						|
            // add other cases to support other param name/value pairs
 | 
						|
            default:
 | 
						|
                $attr['name'] = $attr['value'] = null;
 | 
						|
        }
 | 
						|
        return $attr;
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
// vim: et sw=4 sts=4
 |