mirror of
https://github.com/ezyang/htmlpurifier.git
synced 2025-01-03 13:21:51 +00:00
Update advanced API with more details on selection interface.
git-svn-id: http://htmlpurifier.org/svnroot/htmlpurifier/trunk@908 48356398-32a2-884e-a903-53898d9a118a
This commit is contained in:
parent
97a4ec7598
commit
14d98413fd
@ -29,7 +29,7 @@ filtersets: therefore, users must be able to define their own sets of
|
|||||||
<li>Filtersets: Rich / Plain / Full ...</li>
|
<li>Filtersets: Rich / Plain / Full ...</li>
|
||||||
<li>Mode: Lenient / Correctional</li>
|
<li>Mode: Lenient / Correctional</li>
|
||||||
<li>Collections (?): Safe / Unsafe</li>
|
<li>Collections (?): Safe / Unsafe</li>
|
||||||
<li>Modules / Tags / Attributes</li>
|
<li>Tags / Attributes / Modules</li>
|
||||||
</ul></dd>
|
</ul></dd>
|
||||||
<dt>Customize</dt>
|
<dt>Customize</dt>
|
||||||
<dd><ul>
|
<dd><ul>
|
||||||
@ -61,6 +61,11 @@ the DTD identifier.</p>
|
|||||||
|
|
||||||
<pre>$config->set('HTML', 'Doctype', 'XHTML 1.0 Transitional');</pre>
|
<pre>$config->set('HTML', 'Doctype', 'XHTML 1.0 Transitional');</pre>
|
||||||
|
|
||||||
|
<p>Due to legacy, the default option is XHTML 1.0 Transitional, however, we
|
||||||
|
really shouldn't be guessing what the user's doctype is. Fortunantely,
|
||||||
|
people who can't be bothered to set this won't be bothered when their
|
||||||
|
pages stop validating.</p>
|
||||||
|
|
||||||
<h3>Selecting a Filterset</h3>
|
<h3>Selecting a Filterset</h3>
|
||||||
|
|
||||||
<p>However, selecting this doctype doesn't mean much, because if we
|
<p>However, selecting this doctype doesn't mean much, because if we
|
||||||
@ -131,7 +136,14 @@ Currently, we have two modes, which may be used together:</p>
|
|||||||
|
|
||||||
<p>Further investigation in this field is necessary.</p>
|
<p>Further investigation in this field is necessary.</p>
|
||||||
|
|
||||||
<h3>Selecting Modules / Tags / Attributes</h3>
|
<p>With regards to the various levels of operation conjectured in the
|
||||||
|
Correctional mode, this is prompted by the fact that a user may want to
|
||||||
|
correct certain problems but not others, for example, fix the <code>center</code>
|
||||||
|
tag but not the <code>u</code> tag, both of which are deprecated.
|
||||||
|
Having an integer <q>level</q> will not work very well for such fine
|
||||||
|
grained tweaking, but an array of specific settings might.</p>
|
||||||
|
|
||||||
|
<h3>Selecting Tags / Attributes / Modules</h3>
|
||||||
|
|
||||||
<p>If this cookie cutter approach doesn't appeal to a user, they may
|
<p>If this cookie cutter approach doesn't appeal to a user, they may
|
||||||
decide to roll their own filterset by selecting modules, tags and
|
decide to roll their own filterset by selecting modules, tags and
|
||||||
@ -143,35 +155,42 @@ as a filterset author would use, except that it would go under an
|
|||||||
relevant module/tag/attribute selection configuration directives were
|
relevant module/tag/attribute selection configuration directives were
|
||||||
non-null.</p>
|
non-null.</p>
|
||||||
|
|
||||||
<p>On the highest level, a user will usually be most interested in
|
<p>In practice, this is the most commonly demanded feature. Most users are
|
||||||
directly specifying which elements and attributes are desired. For
|
perfectly happy defining a filterset that looks like:</p>
|
||||||
example:</p>
|
|
||||||
|
|
||||||
<pre>$config->set('HTML', 'AllowedElements', 'a,b,em,p,blockquote,code,i');</pre>
|
<pre>$config->setAllowedHTML('a[href,title],em,p,blockquote');</pre>
|
||||||
|
|
||||||
<p>Attribute declarations could be merged into this declaration as such:</p>
|
<p>We currently support a separated interface, which also must be preserved:</p>
|
||||||
|
|
||||||
<pre>$config->set('HTML', 'Allowed', 'a[href,title],b,em,p[class],blockquote[cite],code,i');</pre>
|
<pre>$config->set('HTML', 'AllowedTags', 'a,em,p,blockquote');
|
||||||
|
$config->set('HTML', 'AllowedAttributes', 'a.href,a.title');</pre>
|
||||||
|
|
||||||
<p>...or be kept separate:</p>
|
<p class="technical">The directive %HTML.Allowed is a convenience function
|
||||||
|
that may be fully expressed with the legacy interface, and thus is
|
||||||
|
given its own setter.</p>
|
||||||
|
|
||||||
<pre>$config->set('HTML', 'AllowedAttributes', 'a.href,a.title,p.class,blockquote.cite');</pre>
|
<p>A user may also choose to allow modules:</p>
|
||||||
|
|
||||||
<p class="technical">Considering that, internally speaking, as mandated by
|
<pre>$config->set('HTML', 'AllowedModules', 'Hypertext,Text,Lists'); // or
|
||||||
the XHTML 1.1 Modularization specification, we have organized our
|
$config->setAllowedHTML('Hypertext,Text,Lists');</pre>
|
||||||
elements around modules, considerable gymnastics will be needed to
|
|
||||||
get this sort of functionality working.</p>
|
|
||||||
|
|
||||||
<p>A user may also specify a module to load a class of elements and attributes
|
<p>But it is not expected that this feature will be widely used.</p>
|
||||||
into their filterest:</p>
|
|
||||||
|
|
||||||
<pre>$config->set('HTML', 'Allowed', 'Hypertext,Core');</pre>
|
|
||||||
|
|
||||||
<p class="fixme">The granularity of these modules is too coarse for
|
<p class="fixme">The granularity of these modules is too coarse for
|
||||||
the average user (for example, the core module loads everything from
|
the average user (for example, the core module loads everything from
|
||||||
the essential <code>p</code> tag to the not-so-safe <code>h1</code>
|
the essential <code>p</code> tag to the not-so-safe <code>h1</code>
|
||||||
tag). How do we make this still a viable solution?</p>
|
tag). How do we make this still a viable solution?</p>
|
||||||
|
|
||||||
|
<p class="technical">Modules are distinguished from regular tags by the
|
||||||
|
case of their first letter. While XML distinguishes between lower and uppercase
|
||||||
|
letters, in practice, most well-known XML languages use only lower-case
|
||||||
|
tag names for sake of consistency.</p>
|
||||||
|
|
||||||
|
<p class="technical">Considering that, internally speaking, as mandated by
|
||||||
|
the XHTML 1.1 Modularization specification, we have organized our
|
||||||
|
elements around modules, considerable gymnastics will be needed to
|
||||||
|
get this sort of functionality working.</p>
|
||||||
|
|
||||||
<h3>Unified selector</h3>
|
<h3>Unified selector</h3>
|
||||||
|
|
||||||
<p>Because selecting each and every one of these configuration options
|
<p>Because selecting each and every one of these configuration options
|
||||||
|
Loading…
Reference in New Issue
Block a user