mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-23 13:51:54 +00:00
86ca784da3
Signed-off-by: Edward Z. Yang <edwardzyang@thewritingpot.com>
51 lines
1.5 KiB
PHP
51 lines
1.5 KiB
PHP
<?php
|
|
|
|
/**
|
|
* A "safe" object module. In theory, objects permitted by this module will
|
|
* be safe, and untrusted users can be allowed to embed arbitrary flash objects
|
|
* (maybe other types too, but only Flash is supported as of right now).
|
|
* Highly experimental.
|
|
*/
|
|
class HTMLPurifier_HTMLModule_SafeObject extends HTMLPurifier_HTMLModule
|
|
{
|
|
|
|
public $name = 'SafeObject';
|
|
|
|
public function setup($config) {
|
|
|
|
// These definitions are not intrinsically safe: the attribute transforms
|
|
// are a vital part of ensuring safety.
|
|
|
|
$max = $config->get('HTML.MaxImgLength');
|
|
$object = $this->addElement(
|
|
'object',
|
|
'Inline',
|
|
'Optional: param | Flow | #PCDATA',
|
|
'Common',
|
|
array(
|
|
// While technically not required by the spec, we're forcing
|
|
// it to this value.
|
|
'type' => 'Enum#application/x-shockwave-flash',
|
|
'width' => 'Pixels#' . $max,
|
|
'height' => 'Pixels#' . $max,
|
|
'data' => 'URI#embedded'
|
|
)
|
|
);
|
|
$object->attr_transform_post[] = new HTMLPurifier_AttrTransform_SafeObject();
|
|
|
|
$param = $this->addElement('param', false, 'Empty', false,
|
|
array(
|
|
'id' => 'ID',
|
|
'name*' => 'Text',
|
|
'value' => 'Text'
|
|
)
|
|
);
|
|
$param->attr_transform_post[] = new HTMLPurifier_AttrTransform_SafeParam();
|
|
$this->info_injector[] = 'SafeObject';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// vim: et sw=4 sts=4
|