mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2024-11-30 08:26:20 +00:00
96d4a3ecf7
Due to historical reasons, the code is in subfolder "1". With SVN removal, we place the code back and remove the annoying "1" folder.
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
|