mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-08 23:11:52 +00:00
Add AttrDef_Id, as well as amend the accumulator by adding a load.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@131 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
bba0d0b77a
commit
bb0435bdd4
37
library/HTMLPurifier/AttrDef/ID.php
Normal file
37
library/HTMLPurifier/AttrDef/ID.php
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once 'HTMLPurifier/AttrDef.php';
|
||||||
|
require_once 'HTMLPurifier/IDAccumulator.php';
|
||||||
|
|
||||||
|
class HTMLPurifier_AttrDef_ID extends HTMLPurifier_AttrDef
|
||||||
|
{
|
||||||
|
|
||||||
|
function validate($id, $accumulator) {
|
||||||
|
|
||||||
|
$id = @ (string) $id; // sanity check
|
||||||
|
|
||||||
|
if ($id === '') return false;
|
||||||
|
if (isset($accumulator->ids[$id])) return false;
|
||||||
|
|
||||||
|
// we purposely avoid using regex, hopefully this is faster
|
||||||
|
|
||||||
|
if (ctype_alpha($id)) {
|
||||||
|
$result = true;
|
||||||
|
} else {
|
||||||
|
if (!ctype_alpha(@$id[0])) return false;
|
||||||
|
$trim = trim(
|
||||||
|
$id,
|
||||||
|
'A..Za..z0..9:-._'
|
||||||
|
);
|
||||||
|
$result = ($trim === '');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($result) $accumulator->add($id);
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
@ -10,6 +10,12 @@ class HTMLPurifier_IDAccumulator
|
|||||||
return $this->ids[$id] = true;
|
return $this->ids[$id] = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function load($array_of_ids) {
|
||||||
|
foreach ($array_of_ids as $id) {
|
||||||
|
$this->ids[$id] = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
33
tests/HTMLPurifier/AttrDef/IDTest.php
Normal file
33
tests/HTMLPurifier/AttrDef/IDTest.php
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
require_once 'HTMLPurifier/AttrDef/ID.php';
|
||||||
|
require_once 'HTMLPurifier/IDAccumulator.php';
|
||||||
|
|
||||||
|
class HTMLPurifier_AttrDef_IDTest extends UnitTestCase
|
||||||
|
{
|
||||||
|
|
||||||
|
function test() {
|
||||||
|
|
||||||
|
$acc = new HTMLPurifier_IDAccumulator();
|
||||||
|
|
||||||
|
$def = new HTMLPurifier_AttrDef_ID();
|
||||||
|
|
||||||
|
// valid ID names
|
||||||
|
$this->assertTrue($def->validate('alpha', $acc));
|
||||||
|
$this->assertTrue($def->validate('al_ha', $acc));
|
||||||
|
$this->assertTrue($def->validate('a0-:.', $acc));
|
||||||
|
$this->assertTrue($def->validate('a' , $acc));
|
||||||
|
|
||||||
|
// invalid ID names
|
||||||
|
$this->assertFalse($def->validate('<asa', $acc));
|
||||||
|
$this->assertFalse($def->validate('0123', $acc));
|
||||||
|
$this->assertFalse($def->validate('.asa', $acc));
|
||||||
|
|
||||||
|
// test duplicate detection
|
||||||
|
$this->assertFalse($def->validate('a' , $acc));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
@ -14,6 +14,20 @@ class HTMLPurifier_IDAccumulatorTest extends UnitTestCase
|
|||||||
$this->assertTrue( $accumulator->add('id2'));
|
$this->assertTrue( $accumulator->add('id2'));
|
||||||
$this->assertFalse($accumulator->add('id1')); // repeated id
|
$this->assertFalse($accumulator->add('id1')); // repeated id
|
||||||
|
|
||||||
|
// you can also access the properties (they're public)
|
||||||
|
$this->assertTrue( isset($accumulator->ids['id2']) );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function testLoad() {
|
||||||
|
|
||||||
|
$accumulator = new HTMLPurifier_IDAccumulator();
|
||||||
|
|
||||||
|
$accumulator->load(array('id1', 'id2', 'id3'));
|
||||||
|
|
||||||
|
$this->assertFalse($accumulator->add('id1')); // repeated id
|
||||||
|
$this->assertTrue($accumulator->add('id4'));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ $test->addTestFile('HTMLPurifier/Strategy/FixNestingTest.php');
|
|||||||
$test->addTestFile('HTMLPurifier/Strategy/CompositeTest.php');
|
$test->addTestFile('HTMLPurifier/Strategy/CompositeTest.php');
|
||||||
$test->addTestFile('HTMLPurifier/Strategy/CoreTest.php');
|
$test->addTestFile('HTMLPurifier/Strategy/CoreTest.php');
|
||||||
$test->addTestFile('HTMLPurifier/AttrDef/EnumTest.php');
|
$test->addTestFile('HTMLPurifier/AttrDef/EnumTest.php');
|
||||||
|
$test->addTestFile('HTMLPurifier/AttrDef/IDTest.php');
|
||||||
$test->addTestFile('HTMLPurifier/IDAccumulatorTest.php');
|
$test->addTestFile('HTMLPurifier/IDAccumulatorTest.php');
|
||||||
|
|
||||||
$test->run( new HtmlReporter() );
|
$test->run( new HtmlReporter() );
|
||||||
|
Loading…
Reference in New Issue
Block a user