2006-07-30 16:35:05 +00:00
|
|
|
<?php
|
|
|
|
|
2006-08-20 21:47:15 +00:00
|
|
|
/**
|
|
|
|
* Validates the HTML attribute ID.
|
|
|
|
* @warning Even though this is the id processor, it
|
|
|
|
* will ignore the directive Attr:IDBlacklist, since it will only
|
|
|
|
* go according to the ID accumulator. Since the accumulator is
|
|
|
|
* automatically generated, it will have already absorbed the
|
|
|
|
* blacklist. If you're hacking around, make sure you use load()!
|
|
|
|
*/
|
2006-07-30 16:35:05 +00:00
|
|
|
|
2007-02-14 20:38:51 +00:00
|
|
|
class HTMLPurifier_AttrDef_HTML_ID extends HTMLPurifier_AttrDef
|
2006-07-30 16:35:05 +00:00
|
|
|
{
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2012-01-14 03:08:02 -05:00
|
|
|
// selector is NOT a valid thing to use for IDREFs, because IDREFs
|
|
|
|
// *must* target IDs that exist, whereas selector #ids do not.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines whether or not we're validating an ID in a CSS
|
|
|
|
* selector context.
|
2013-07-16 13:56:14 +02:00
|
|
|
* @type bool
|
2012-01-14 03:08:02 -05:00
|
|
|
*/
|
|
|
|
protected $selector;
|
|
|
|
|
2013-07-16 13:56:14 +02:00
|
|
|
/**
|
|
|
|
* @param bool $selector
|
|
|
|
*/
|
|
|
|
public function __construct($selector = false)
|
|
|
|
{
|
2012-01-14 03:08:02 -05:00
|
|
|
$this->selector = $selector;
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2013-07-16 13:56:14 +02:00
|
|
|
/**
|
|
|
|
* @param string $id
|
|
|
|
* @param HTMLPurifier_Config $config
|
|
|
|
* @param HTMLPurifier_Context $context
|
|
|
|
* @return bool|string
|
|
|
|
*/
|
|
|
|
public function validate($id, $config, $context)
|
|
|
|
{
|
|
|
|
if (!$this->selector && !$config->get('Attr.EnableID')) {
|
|
|
|
return false;
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2006-08-05 00:30:31 +00:00
|
|
|
$id = trim($id); // trim it first
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2013-07-16 13:56:14 +02:00
|
|
|
if ($id === '') {
|
|
|
|
return false;
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2009-02-19 19:17:49 -05:00
|
|
|
$prefix = $config->get('Attr.IDPrefix');
|
2006-11-17 01:05:41 +00:00
|
|
|
if ($prefix !== '') {
|
2009-02-19 19:17:49 -05:00
|
|
|
$prefix .= $config->get('Attr.IDPrefixLocal');
|
2006-11-17 01:05:41 +00:00
|
|
|
// prevent re-appending the prefix
|
2013-07-16 13:56:14 +02:00
|
|
|
if (strpos($id, $prefix) !== 0) {
|
|
|
|
$id = $prefix . $id;
|
|
|
|
}
|
2009-02-19 19:17:49 -05:00
|
|
|
} elseif ($config->get('Attr.IDPrefixLocal') !== '') {
|
2013-07-16 13:56:14 +02:00
|
|
|
trigger_error(
|
|
|
|
'%Attr.IDPrefixLocal cannot be used unless ' .
|
|
|
|
'%Attr.IDPrefix is set',
|
|
|
|
E_USER_WARNING
|
|
|
|
);
|
2006-11-17 01:05:41 +00:00
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2012-01-14 03:08:02 -05:00
|
|
|
if (!$this->selector) {
|
2007-02-02 22:03:09 +00:00
|
|
|
$id_accumulator =& $context->get('IDAccumulator');
|
2013-07-16 13:56:14 +02:00
|
|
|
if (isset($id_accumulator->ids[$id])) {
|
|
|
|
return false;
|
|
|
|
}
|
2012-01-14 03:08:02 -05:00
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2006-07-30 16:35:05 +00:00
|
|
|
// we purposely avoid using regex, hopefully this is faster
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2016-07-16 05:52:45 -07:00
|
|
|
if ($config->get('Attr.ID.HTML5') === true) {
|
|
|
|
if (preg_match('/[\t\n\x0b\x0c ]/', $id)) {
|
2013-07-16 13:56:14 +02:00
|
|
|
return false;
|
|
|
|
}
|
2016-07-16 05:52:45 -07:00
|
|
|
} else {
|
|
|
|
if (ctype_alpha($id)) {
|
|
|
|
// OK
|
|
|
|
} else {
|
|
|
|
if (!ctype_alpha(@$id[0])) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
// primitive style of regexps, I suppose
|
|
|
|
$trim = trim(
|
|
|
|
$id,
|
|
|
|
'A..Za..z0..9:-._'
|
|
|
|
);
|
|
|
|
if ($trim !== '') {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
2006-07-30 16:35:05 +00:00
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2009-02-19 19:17:49 -05:00
|
|
|
$regexp = $config->get('Attr.IDBlacklistRegexp');
|
2007-03-31 03:25:10 +00:00
|
|
|
if ($regexp && preg_match($regexp, $id)) {
|
|
|
|
return false;
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2016-07-16 05:52:45 -07:00
|
|
|
if (!$this->selector) {
|
2013-07-16 13:56:14 +02:00
|
|
|
$id_accumulator->add($id);
|
|
|
|
}
|
2008-12-06 02:28:20 -05:00
|
|
|
|
2006-08-04 00:11:54 +00:00
|
|
|
// if no change was made to the ID, return the result
|
|
|
|
// else, return the new id if stripping whitespace made it
|
|
|
|
// valid, or return false.
|
2016-07-16 05:52:45 -07:00
|
|
|
return $id;
|
2006-07-30 16:35:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-12-06 04:24:59 -05:00
|
|
|
// vim: et sw=4 sts=4
|