mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-09 07:21:54 +00:00
[1.7.0] More HTMLModuleManager work:
- Move Doctype to its own file - Remove vestigial autoDoctype and order - Setup will automatically load modules for you - Allow overriding trust level for parent element - Random documentation update git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@1056 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
048242004e
commit
53c19552d2
33
library/HTMLPurifier/Doctype.php
Normal file
33
library/HTMLPurifier/Doctype.php
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a document type, contains information on which modules
|
||||||
|
* need to be loaded.
|
||||||
|
*/
|
||||||
|
class HTMLPurifier_Doctype
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Full name of doctype
|
||||||
|
*/
|
||||||
|
var $name;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of aliases to doctype name
|
||||||
|
*/
|
||||||
|
var $aliases = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of standard modules (string identifiers or literal objects)
|
||||||
|
* that this doctype uses
|
||||||
|
*/
|
||||||
|
var $modules = array();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Associative array of mode names to lists of modules; these are
|
||||||
|
* the modules added into the standard list if a particular mode
|
||||||
|
* is enabled, such as lenient or correctional.
|
||||||
|
*/
|
||||||
|
var $modulesForModes = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
@ -231,7 +231,7 @@ class HTMLPurifier_HTMLDefinition
|
|||||||
$support = "(for information on implementing this, see the ".
|
$support = "(for information on implementing this, see the ".
|
||||||
"support forums) ";
|
"support forums) ";
|
||||||
|
|
||||||
// setup allowed elements, SubtractiveWhitelist module
|
// setup allowed elements, SubtractiveWhitelist module(?)
|
||||||
$allowed_elements = $this->config->get('HTML', 'AllowedElements');
|
$allowed_elements = $this->config->get('HTML', 'AllowedElements');
|
||||||
if (is_array($allowed_elements)) {
|
if (is_array($allowed_elements)) {
|
||||||
foreach ($this->info as $name => $d) {
|
foreach ($this->info as $name => $d) {
|
||||||
|
@ -24,11 +24,6 @@ class HTMLPurifier_HTMLModule
|
|||||||
*/
|
*/
|
||||||
var $name;
|
var $name;
|
||||||
|
|
||||||
/**
|
|
||||||
* Dynamically set integer that specifies when the module was loaded in.
|
|
||||||
*/
|
|
||||||
var $order;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Informally, a list of elements this module changes. Not used in
|
* Informally, a list of elements this module changes. Not used in
|
||||||
* any significant way.
|
* any significant way.
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
require_once 'HTMLPurifier/HTMLModule.php';
|
require_once 'HTMLPurifier/HTMLModule.php';
|
||||||
require_once 'HTMLPurifier/ElementDef.php';
|
require_once 'HTMLPurifier/ElementDef.php';
|
||||||
|
require_once 'HTMLPurifier/Doctype.php';
|
||||||
|
|
||||||
require_once 'HTMLPurifier/ContentSets.php';
|
require_once 'HTMLPurifier/ContentSets.php';
|
||||||
require_once 'HTMLPurifier/AttrTypes.php';
|
require_once 'HTMLPurifier/AttrTypes.php';
|
||||||
@ -39,32 +40,6 @@ HTMLPurifier_ConfigSchema::define(
|
|||||||
'like %Core.XHTML or %HTML.Strict.'
|
'like %Core.XHTML or %HTML.Strict.'
|
||||||
);
|
);
|
||||||
|
|
||||||
class HTMLPurifier_Doctype
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Full name of doctype
|
|
||||||
*/
|
|
||||||
var $name;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* List of aliases to doctype name
|
|
||||||
*/
|
|
||||||
var $aliases = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* List of standard modules (string identifiers or literal objects)
|
|
||||||
* that this doctype uses
|
|
||||||
*/
|
|
||||||
var $modules = array();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Associative array of mode names to lists of modules; these are
|
|
||||||
* the modules added into the standard list if a particular mode
|
|
||||||
* is enabled, such as lenient or correctional.
|
|
||||||
*/
|
|
||||||
var $modulesForModes = array();
|
|
||||||
}
|
|
||||||
|
|
||||||
class HTMLPurifier_HTMLModuleManager
|
class HTMLPurifier_HTMLModuleManager
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -101,16 +76,8 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
*/
|
*/
|
||||||
var $validModules = array();
|
var $validModules = array();
|
||||||
|
|
||||||
var $counter = 0; /**< Designates next available integer order for modules. */
|
|
||||||
var $initialized = false; /**< Says whether initialize() was called */
|
var $initialized = false; /**< Says whether initialize() was called */
|
||||||
|
|
||||||
/**
|
|
||||||
* Specifies what doctype to siphon new modules from addModule() to,
|
|
||||||
* or false to disable the functionality. Must be used in conjunction
|
|
||||||
* with $autoCollection.
|
|
||||||
*/
|
|
||||||
var $autoDoctype = false;
|
|
||||||
|
|
||||||
/** Associative array of element name to defining modules (always array) */
|
/** Associative array of element name to defining modules (always array) */
|
||||||
var $elementLookup = array();
|
var $elementLookup = array();
|
||||||
|
|
||||||
@ -140,22 +107,6 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
function initialize() {
|
function initialize() {
|
||||||
$this->initialized = true;
|
$this->initialized = true;
|
||||||
|
|
||||||
// load default modules to the recognized modules list (not active)
|
|
||||||
$modules = array(
|
|
||||||
// define
|
|
||||||
'CommonAttributes',
|
|
||||||
'Text', 'Hypertext', 'List', 'Presentation',
|
|
||||||
'Edit', 'Bdo', 'Tables', 'Image', 'StyleAttribute',
|
|
||||||
'Target', 'Scripting',
|
|
||||||
// define-redefine
|
|
||||||
'Legacy',
|
|
||||||
// redefine
|
|
||||||
'TransformToStrict', 'TransformToXHTML11'
|
|
||||||
);
|
|
||||||
foreach ($modules as $module) {
|
|
||||||
$this->addModule($module);
|
|
||||||
}
|
|
||||||
|
|
||||||
// these doctype definitions should be placed somewhere else
|
// these doctype definitions should be placed somewhere else
|
||||||
|
|
||||||
$common = array(
|
$common = array(
|
||||||
@ -185,12 +136,12 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
$d->modules = array_merge($common);
|
$d->modules = array_merge($common);
|
||||||
$d->modulesForMode['lenient'] = array('TransformToStrict', 'TransformToXHTML11');
|
$d->modulesForMode['lenient'] = array('TransformToStrict', 'TransformToXHTML11');
|
||||||
|
|
||||||
$this->autoDoctype = '*';
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @temporary
|
* @temporary
|
||||||
|
* @note Real version should retrieve a fully formed instance of
|
||||||
|
* the doctype and register its aliases
|
||||||
*/
|
*/
|
||||||
function &addDoctype($name) {
|
function &addDoctype($name) {
|
||||||
$this->doctypes[$name] = new HTMLPurifier_Doctype();
|
$this->doctypes[$name] = new HTMLPurifier_Doctype();
|
||||||
@ -215,6 +166,9 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
* - Throw fatal error
|
* - Throw fatal error
|
||||||
* If your object name collides with an internal class, specify
|
* If your object name collides with an internal class, specify
|
||||||
* your module manually.
|
* your module manually.
|
||||||
|
* @warning If your module has the same name as an already loaded
|
||||||
|
* module, your module will overload the old one WITHOUT
|
||||||
|
* warning.
|
||||||
*/
|
*/
|
||||||
function addModule($module) {
|
function addModule($module) {
|
||||||
if (is_string($module)) {
|
if (is_string($module)) {
|
||||||
@ -237,15 +191,12 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
}
|
}
|
||||||
$module = new $module();
|
$module = new $module();
|
||||||
}
|
}
|
||||||
$module->order = $this->counter++; // assign then increment
|
|
||||||
$this->modules[$module->name] = $module;
|
$this->modules[$module->name] = $module;
|
||||||
if ($this->autoDoctype !== false && $this->autoCollection !== false) {
|
|
||||||
$this->collections[$this->autoCollection][$this->autoDoctype][] = $module->name;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Safely tests for class existence without invoking __autoload in PHP5
|
* Safely tests for class existence without invoking __autoload in PHP5
|
||||||
|
* or greater.
|
||||||
* @param $name String class name to test
|
* @param $name String class name to test
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
@ -269,6 +220,11 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
$this->prefixes[] = (string) $prefix;
|
$this->prefixes[] = (string) $prefix;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs processing on modules, after being called you may
|
||||||
|
* use getElement() and getElements()
|
||||||
|
* @param $config Instance of HTMLPurifier_Config
|
||||||
|
*/
|
||||||
function setup($config) {
|
function setup($config) {
|
||||||
|
|
||||||
// retrieve the doctype
|
// retrieve the doctype
|
||||||
@ -287,8 +243,16 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
}
|
}
|
||||||
|
|
||||||
foreach ($modules as $module) {
|
foreach ($modules as $module) {
|
||||||
|
if (is_object($module)) {
|
||||||
|
$this->validModules[$module->name] = $module;
|
||||||
|
continue;
|
||||||
|
} else {
|
||||||
|
if (!isset($this->modules[$module])) {
|
||||||
|
$this->addModule($module);
|
||||||
|
}
|
||||||
$this->validModules[$module] = $this->modules[$module];
|
$this->validModules[$module] = $this->modules[$module];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// setup lookup table based on all valid modules
|
// setup lookup table based on all valid modules
|
||||||
foreach ($this->validModules as $module) {
|
foreach ($this->validModules as $module) {
|
||||||
@ -324,11 +288,6 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
if ($doctype !== null) {
|
if ($doctype !== null) {
|
||||||
return $doctype;
|
return $doctype;
|
||||||
}
|
}
|
||||||
if (!$this->initialized) {
|
|
||||||
// don't do HTML-oriented backwards compatibility stuff
|
|
||||||
// use either the auto-doctype, or the catch-all doctype
|
|
||||||
return $this->autoDoctype ? $this->autoDoctype : '*';
|
|
||||||
}
|
|
||||||
// this is backwards-compatibility stuff
|
// this is backwards-compatibility stuff
|
||||||
if ($config->get('Core', 'XHTML')) {
|
if ($config->get('Core', 'XHTML')) {
|
||||||
$doctype = 'XHTML 1.0';
|
$doctype = 'XHTML 1.0';
|
||||||
@ -373,10 +332,13 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
* Retrieves a single merged element definition
|
* Retrieves a single merged element definition
|
||||||
* @param $name Name of element
|
* @param $name Name of element
|
||||||
* @param $config Instance of HTMLPurifier_Config, may not be necessary.
|
* @param $config Instance of HTMLPurifier_Config, may not be necessary.
|
||||||
|
* @param $trusted Boolean trusted overriding parameter: set to true
|
||||||
|
* if you want the full version of an element
|
||||||
*/
|
*/
|
||||||
function getElement($name, $config) {
|
function getElement($name, $config, $trusted = null) {
|
||||||
|
|
||||||
$def = false;
|
$def = false;
|
||||||
|
if ($trusted === null) $trusted = $this->trusted;
|
||||||
|
|
||||||
$modules = $this->validModules;
|
$modules = $this->validModules;
|
||||||
|
|
||||||
@ -390,7 +352,7 @@ class HTMLPurifier_HTMLModuleManager
|
|||||||
$new_def = $module->info[$name];
|
$new_def = $module->info[$name];
|
||||||
|
|
||||||
// refuse to create/merge in a definition that is deemed unsafe
|
// refuse to create/merge in a definition that is deemed unsafe
|
||||||
if (!$this->trusted && ($new_def->safe === false)) {
|
if (!$trusted && ($new_def->safe === false)) {
|
||||||
$def = false;
|
$def = false;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user