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
							 |