2008-06-10 00:13:44 +00:00
|
|
|
<?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.
|
2008-12-06 02:28:20 -05:00
|
|
|
*
|
2008-06-10 00:13:44 +00:00
|
|
|
* @note
|
|
|
|
* This class only supports Flash. In the future, Quicktime support
|
|
|
|
* may be added.
|
2008-12-06 02:28:20 -05:00
|
|
|
*
|
2008-06-10 00:13:44 +00:00
|
|
|
* @warning
|
|
|
|
* This class expects an injector to add the necessary parameters tags.
|
|
|
|
*/
|
2008-12-06 02:28:20 -05:00
|
|
|
class HTMLPurifier_AttrTransform_SafeParam extends HTMLPurifier_AttrTransform
|
2008-06-10 00:13:44 +00:00
|
|
|
{
|
|
|
|
public $name = "SafeParam";
|
|
|
|
private $uri;
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2008-06-10 01:18:03 +00:00
|
|
|
public function __construct() {
|
2008-06-10 00:13:44 +00:00
|
|
|
$this->uri = new HTMLPurifier_AttrDef_URI(true); // embedded
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2008-06-10 01:18:03 +00:00
|
|
|
public function transform($attr, $config, $context) {
|
2008-06-10 00:13:44 +00:00
|
|
|
// 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 'wmode':
|
|
|
|
$attr['value'] = 'window';
|
|
|
|
break;
|
|
|
|
case 'movie':
|
|
|
|
$attr['value'] = $this->uri->validate($attr['value'], $config, $context);
|
|
|
|
break;
|
|
|
|
// add other cases to support other param name/value pairs
|
|
|
|
default:
|
|
|
|
$attr['name'] = $attr['value'] = null;
|
|
|
|
}
|
|
|
|
return $attr;
|
|
|
|
}
|
|
|
|
}
|
2008-12-06 04:24:59 -05:00
|
|
|
|
|
|
|
// vim: et sw=4 sts=4
|