mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2024-12-23 17:01:51 +00:00
e2103ce0f2
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@725 48356398-32a2-884e-a903-53898d9a118a
125 lines
4.2 KiB
PHP
125 lines
4.2 KiB
PHP
<?php
|
|
|
|
require_once 'HTMLPurifier/AttrTypes.php';
|
|
require_once 'HTMLPurifier/AttrDef/Lang.php';
|
|
|
|
/**
|
|
* Defines common attribute collections that modules reference
|
|
*/
|
|
|
|
class HTMLPurifier_AttrCollections
|
|
{
|
|
|
|
/**
|
|
* Associative array of attribute collections, indexed by name
|
|
* @note Technically, the composition of these is more complicated,
|
|
* but we bypass it using our own excludes property
|
|
*/
|
|
var $info = array(
|
|
'Core' => array(
|
|
0 => array('Style'),
|
|
// 'xml:space' => false,
|
|
'class' => 'NMTOKENS',
|
|
'id' => 'ID',
|
|
'title' => 'CDATA',
|
|
),
|
|
'Lang' => array(
|
|
'xml:lang' => false, // see constructor
|
|
),
|
|
'I18N' => array(
|
|
0 => array('Lang'), // proprietary, for xml:lang/lang
|
|
),
|
|
'Common' => array(
|
|
0 => array('Core', 'I18N')
|
|
)
|
|
);
|
|
|
|
/**
|
|
* Sets up direct objects not registered to HTMLPurifier_AttrTypes
|
|
*/
|
|
function HTMLPurifier_AttrCollections() {
|
|
// setup direct objects
|
|
$this->info['Lang']['xml:lang'] = new HTMLPurifier_AttrDef_Lang();
|
|
}
|
|
|
|
/**
|
|
* Performs all expansions on internal data for use by other inclusions
|
|
* It also collects all attribute collection extensions from
|
|
* modules
|
|
* @param $attr_types HTMLPurifier_AttrTypes instance
|
|
* @param $modules Hash array of HTMLPurifier_HTMLModule members
|
|
*/
|
|
function setup($attr_types, $modules) {
|
|
$info =& $this->info;
|
|
// load extensions from the modules
|
|
foreach ($modules as $module) {
|
|
foreach ($module->attr_collections as $coll_i => $coll) {
|
|
foreach ($coll as $attr_i => $attr) {
|
|
if ($attr_i === 0 && isset($info[$coll_i][$attr_i])) {
|
|
// merge in includes
|
|
$info[$coll_i][$attr_i] = array_merge(
|
|
$info[$coll_i][$attr_i], $attr);
|
|
continue;
|
|
}
|
|
$info[$coll_i][$attr_i] = $attr;
|
|
}
|
|
}
|
|
}
|
|
// perform internal expansions and inclusions
|
|
foreach ($info as $name => $attr) {
|
|
// merge attribute collections that include others
|
|
$this->performInclusions($info[$name]);
|
|
// replace string identifiers with actual attribute objects
|
|
$this->expandIdentifiers($info[$name], $attr_types);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Takes a reference to an attribute associative array and performs
|
|
* all inclusions specified by the zero index.
|
|
* @param &$attr Reference to attribute array
|
|
*/
|
|
function performInclusions(&$attr) {
|
|
if (!isset($attr[0])) return;
|
|
$merge = $attr[0];
|
|
// loop through all the inclusions
|
|
for ($i = 0; isset($merge[$i]); $i++) {
|
|
// foreach attribute of the inclusion, copy it over
|
|
foreach ($this->info[$merge[$i]] as $key => $value) {
|
|
if (isset($attr[$key])) continue; // also catches more inclusions
|
|
$attr[$key] = $value;
|
|
}
|
|
if (isset($info[$merge[$i]][0])) {
|
|
// recursion
|
|
$merge = array_merge($merge, isset($info[$merge[$i]][0]));
|
|
}
|
|
}
|
|
unset($attr[0]);
|
|
}
|
|
|
|
/**
|
|
* Expands all string identifiers in an attribute array by replacing
|
|
* them with the appropriate values inside HTMLPurifier_AttrTypes
|
|
* @param &$attr Reference to attribute array
|
|
* @param $attr_types HTMLPurifier_AttrTypes instance
|
|
*/
|
|
function expandIdentifiers(&$attr, $attr_types) {
|
|
foreach ($attr as $def_i => $def) {
|
|
if ($def_i === 0) continue;
|
|
if (!is_string($def)) continue;
|
|
if ($def === false) {
|
|
unset($attr[$def_i]);
|
|
continue;
|
|
}
|
|
if (isset($attr_types->info[$def])) {
|
|
$attr[$def_i] = $attr_types->info[$def];
|
|
} else {
|
|
trigger_error('Attempted to reference undefined attribute type', E_USER_ERROR);
|
|
unset($attr[$def_i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
?>
|