This is a CakePHP wrapper for the HTML Purifier lib. http://htmlpurifier.org/
HTML Purifier is a standards-compliant HTML filter library written in PHP. HTML Purifier will not only remove all malicious code (better known as XSS) with a thoroughly audited, secure yet permissive whitelist, it will also make sure your documents are standards compliant, something only achievable with a comprehensive knowledge of W3C's specifications.
The plugin includes a Helper and Behavior to clean your markup wherever you like, in the view or in Model::beforeSave.
Clone the code into your apps plugin folder
git clone git@github.com:burzum/cakephp-html-purifier.git app/Plugin/HtmlPurifier
or add it as submodule
git submodule add git@github.com:burzum/cakephp-html-purifier.git app/Plugin/HtmlPurifier
In APP/bootstrap.php add
CakePlugin::load('HtmlPurifier', array('bootstrap' => true));
...and get this error message
Fatal error: Cannot override final method HTMLPurifier_VarParser::parse()
you can fix this by adding
Configure::write(''HtmlPurifier.standalone', true);
to your bootstrap.php before you load this plugin.
This line will use a compacted one file version of Html Purifier. This is an official and know issue and workaround, see http://htmlpurifier.org/phorum/read.php?3,4099,6680.
Important: Before you start declaring a configuration you should lookup how HTML Purifier can be configured. http://htmlpurifier.org/docs
In app/Config/boostrap.php you can either set the purifier config as an array or pass a native config object.
The array style would look like this:
Purifier::config('ConfigName', array(
'HTML.AllowedElements' => 'a, em, blockquote, p, strong, pre, code, span,ul,ol,li,img',
'HTML.AllowedAttributes' => 'a.href, a.title, img.src, img.alt'
)
);
The plugin will construct a HTML Purifier config from that and instantiate the purifier.
A pure HTML Purifier config might look like this one:
$config = HTMLPurifier_Config::createDefault();
$config->set('HTML.AllowedElements', 'a, em, blockquote, p, strong, pre, code, span,ul,ol,li,img');
$config->set('HTML.AllowedAttributes', 'a.href, a.title, img.src, img.alt');
$config->set('HTML.AllowedAttributes', "*.style");
$config->set('CSS.AllowedProperties', 'text-decoration');
$config->set('HTML.TidyLevel', 'heavy');
$config->set('HTML.Doctype', 'XHTML 1.0 Transitional');
Simply assign it to a config:
Purifier::config('ConfigName', $config);
Now that you have a configured instance of HTML Purifier ready you can use it directly and get you an instance of the purifier
Purifier::config('ConfigName');
or clean some dirty HTML directly by calling
Purifier::clean($markup, 'ConfigName');
For some automatization you can also use the Behavior or Helper.
It is recommended to change the path of the purifier libs cache to your APP/tmp folder. For example:
Purifier::config('ConfigName', array(
'Cache.SerializerPath' => APP . 'tmp' . DS . 'purifier',
)
);
See this page as well http://htmlpurifier.org/live/configdoc/plain.html#Cache.
Set a config you want to use and the fields you want to sanitize.
public $actsAs = array(
'HtmlPurifier.HtmlPurifier' => array(
'config' => 'ConfigName',
'fields' => array(
'body', 'excerpt'
)
)
);
In your controller load the helper and set a default config if you want.
public $helpers = array(
'HtmlPurifier.HtmlPurifier' => array(
'config' => 'ConfigName'
)
);
In the views you can then use the helper like this:
$this->HtmlPurifier->clean($markup, 'ConfigName');
For support and feature request, please visit the HtmlPurifier issue page
https://github.com/burzum/HtmlPurifier/issues
To contribute to this plugin please follow a few basic rules.
- Pull requests must be send to the
develop
branch. - Contributions must follow the CakePHP coding standard.
- Unit tests are required.
Copyright 2012 - 2014, Florian Krämer
Licensed under The MIT License Redistributions of files must retain the above copyright notice.