mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-03 05:11:52 +00:00
[1.3.2]
! HTMLPurifier object now accepts configuration arrays, no need to manually instantiate a configuration object ! Context object now accessible to outside . HTMLPurifier_Config::create() added, takes mixed variable and converts into a HTMLPurifier_Config object. git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@611 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
41a25cb6b8
commit
360f984f63
5
NEWS
5
NEWS
@ -14,7 +14,12 @@ NEWS ( CHANGELOG and HISTORY ) HTMLPurifier
|
|||||||
|
|
||||||
1.3.2, unknown release date, may be dropped
|
1.3.2, unknown release date, may be dropped
|
||||||
(security/bugfix/minor feature release)
|
(security/bugfix/minor feature release)
|
||||||
|
! HTMLPurifier object now accepts configuration arrays, no need to manually
|
||||||
|
instantiate a configuration object
|
||||||
|
! Context object now accessible to outside
|
||||||
- printDefinition.php: added labels, added better clarification
|
- printDefinition.php: added labels, added better clarification
|
||||||
|
. HTMLPurifier_Config::create() added, takes mixed variable and converts into
|
||||||
|
a HTMLPurifier_Config object.
|
||||||
|
|
||||||
1.3.1, released 2006-12-06
|
1.3.1, released 2006-12-06
|
||||||
! Added HTMLPurifier.func.php stub for a convenient function to call the library
|
! Added HTMLPurifier.func.php stub for a convenient function to call the library
|
||||||
|
@ -68,15 +68,23 @@ class HTMLPurifier
|
|||||||
|
|
||||||
var $lexer, $strategy, $generator;
|
var $lexer, $strategy, $generator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Final HTMLPurifier_Context of last run purification. Might be an array.
|
||||||
|
* @public
|
||||||
|
*/
|
||||||
|
var $context;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes the purifier.
|
* Initializes the purifier.
|
||||||
* @param $config Optional HTMLPurifier_Config object for all instances of
|
* @param $config Optional HTMLPurifier_Config object for all instances of
|
||||||
* the purifier, if omitted, a default configuration is
|
* the purifier, if omitted, a default configuration is
|
||||||
* supplied (which can be overridden on a per-use basis).
|
* supplied (which can be overridden on a per-use basis).
|
||||||
|
* The parameter can also be any type that
|
||||||
|
* HTMLPurifier_Config::create() supports.
|
||||||
*/
|
*/
|
||||||
function HTMLPurifier($config = null) {
|
function HTMLPurifier($config = null) {
|
||||||
|
|
||||||
$this->config = $config ? $config : HTMLPurifier_Config::createDefault();
|
$this->config = HTMLPurifier_Config::create($config);
|
||||||
|
|
||||||
$this->lexer = HTMLPurifier_Lexer::create();
|
$this->lexer = HTMLPurifier_Lexer::create();
|
||||||
$this->strategy = new HTMLPurifier_Strategy_Core();
|
$this->strategy = new HTMLPurifier_Strategy_Core();
|
||||||
@ -91,22 +99,35 @@ class HTMLPurifier
|
|||||||
* @param $html String of HTML to purify
|
* @param $html String of HTML to purify
|
||||||
* @param $config HTMLPurifier_Config object for this operation, if omitted,
|
* @param $config HTMLPurifier_Config object for this operation, if omitted,
|
||||||
* defaults to the config object specified during this
|
* defaults to the config object specified during this
|
||||||
* object's construction.
|
* object's construction. The parameter can also be any type
|
||||||
|
* that HTMLPurifier_Config::create() supports.
|
||||||
* @return Purified HTML
|
* @return Purified HTML
|
||||||
*/
|
*/
|
||||||
function purify($html, $config = null) {
|
function purify($html, $config = null) {
|
||||||
$config = $config ? $config : $this->config;
|
|
||||||
|
$config = $config ? HTMLPurifier_Config::create($config) : $this->config;
|
||||||
|
|
||||||
|
|
||||||
$context =& new HTMLPurifier_Context();
|
$context =& new HTMLPurifier_Context();
|
||||||
$html = $this->encoder->convertToUTF8($html, $config, $context);
|
$html = $this->encoder->convertToUTF8($html, $config, $context);
|
||||||
|
|
||||||
|
// purified HTML
|
||||||
$html =
|
$html =
|
||||||
$this->generator->generateFromTokens(
|
$this->generator->generateFromTokens(
|
||||||
|
// list of tokens
|
||||||
$this->strategy->execute(
|
$this->strategy->execute(
|
||||||
$this->lexer->tokenizeHTML($html, $config, $context),
|
// list of un-purified tokens
|
||||||
|
$this->lexer->tokenizeHTML(
|
||||||
|
// un-purified HTML
|
||||||
|
$html, $config, $context
|
||||||
|
),
|
||||||
$config, $context
|
$config, $context
|
||||||
),
|
),
|
||||||
$config, $context
|
$config, $context
|
||||||
);
|
);
|
||||||
|
|
||||||
$html = $this->encoder->convertFromUTF8($html, $config, $context);
|
$html = $this->encoder->convertFromUTF8($html, $config, $context);
|
||||||
|
$this->context =& $context;
|
||||||
return $html;
|
return $html;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,6 +44,20 @@ class HTMLPurifier_Config
|
|||||||
$this->def = $definition; // keep a copy around for checking
|
$this->def = $definition; // keep a copy around for checking
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convenience constructor that creates a config object based on a mixed var
|
||||||
|
* @param mixed $config Variable that defines the state of the config
|
||||||
|
* object. Can be: a HTMLPurifier_Config() object or
|
||||||
|
* an array of directives based on loadArray().
|
||||||
|
* @return Configured HTMLPurifier_Config object
|
||||||
|
*/
|
||||||
|
function create($config) {
|
||||||
|
if (is_a($config, 'HTMLPurifier_Config')) return $config;
|
||||||
|
$ret = HTMLPurifier_Config::createDefault();
|
||||||
|
if (is_array($config)) $ret->loadArray($config);
|
||||||
|
return $ret;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Convenience constructor that creates a default configuration object.
|
* Convenience constructor that creates a default configuration object.
|
||||||
* @return Default HTMLPurifier_Config object.
|
* @return Default HTMLPurifier_Config object.
|
||||||
|
@ -180,6 +180,25 @@ class HTMLPurifier_ConfigTest extends UnitTestCase
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function test_create() {
|
||||||
|
|
||||||
|
HTMLPurifier_ConfigSchema::defineNamespace('Cake', 'Properties of it.');
|
||||||
|
HTMLPurifier_ConfigSchema::define('Cake', 'Sprinkles', 666, 'int', 'Number of.');
|
||||||
|
HTMLPurifier_ConfigSchema::define('Cake', 'Flavor', 'vanilla', 'string', 'Flavor of the batter.');
|
||||||
|
|
||||||
|
$config = HTMLPurifier_Config::createDefault();
|
||||||
|
$config->set('Cake', 'Sprinkles', 42);
|
||||||
|
|
||||||
|
// test flat pass-through
|
||||||
|
$created_config = HTMLPurifier_Config::create($config);
|
||||||
|
$this->assertEqual($config, $created_config);
|
||||||
|
|
||||||
|
// test loadArray
|
||||||
|
$created_config = HTMLPurifier_Config::create(array('Cake.Sprinkles' => 42));
|
||||||
|
$this->assertEqual($config, $created_config);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
@ -25,7 +25,7 @@ class HTMLPurifier_Test extends UnitTestCase
|
|||||||
function testStrict() {
|
function testStrict() {
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$config = HTMLPurifier_Config::createDefault();
|
||||||
$config->set('HTML', 'Strict', true);
|
$config->set('HTML', 'Strict', true);
|
||||||
$this->purifier = new HTMLPurifier($config);
|
$this->purifier = new HTMLPurifier( $config ); // verbose syntax
|
||||||
|
|
||||||
$this->assertPurification(
|
$this->assertPurification(
|
||||||
'<u>Illegal underline</u>',
|
'<u>Illegal underline</u>',
|
||||||
@ -40,10 +40,11 @@ class HTMLPurifier_Test extends UnitTestCase
|
|||||||
}
|
}
|
||||||
|
|
||||||
function testDifferentAllowedElements() {
|
function testDifferentAllowedElements() {
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
|
||||||
$config->set('HTML', 'AllowedElements', array('b', 'i', 'p', 'a'));
|
$this->purifier = new HTMLPurifier(array(
|
||||||
$config->set('HTML', 'AllowedAttributes', array('a.href', '*.id'));
|
'HTML.AllowedElements' => array('b', 'i', 'p', 'a'),
|
||||||
$this->purifier = new HTMLPurifier($config);
|
'HTML.AllowedAttributes' => array('a.href', '*.id')
|
||||||
|
));
|
||||||
|
|
||||||
$this->assertPurification(
|
$this->assertPurification(
|
||||||
'<p>Par.</p><p>Para<a href="http://google.com/">gr</a>aph</p>Text<b>Bol<i>d</i></b>'
|
'<p>Par.</p><p>Para<a href="http://google.com/">gr</a>aph</p>Text<b>Bol<i>d</i></b>'
|
||||||
@ -58,9 +59,7 @@ class HTMLPurifier_Test extends UnitTestCase
|
|||||||
|
|
||||||
function testDisableURI() {
|
function testDisableURI() {
|
||||||
|
|
||||||
$config = HTMLPurifier_Config::createDefault();
|
$this->purifier = new HTMLPurifier( array('Attr.DisableURI' => true) );
|
||||||
$config->set('Attr', 'DisableURI', true);
|
|
||||||
$this->purifier = new HTMLPurifier($config);
|
|
||||||
|
|
||||||
$this->assertPurification(
|
$this->assertPurification(
|
||||||
'<img src="foobar"/>',
|
'<img src="foobar"/>',
|
||||||
|
Loading…
Reference in New Issue
Block a user