You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @copyright Copyright (c) 2008 Yii Software LLC
|
|
|
|
* @link http://www.yiiframework.com/
|
|
|
|
* @license http://www.yiiframework.com/license/
|
|
|
|
*/
|
|
|
|
namespace yii\helpers\base;
|
|
|
|
|
|
|
|
if (!class_exists('HTMLPurifier_Bootstrap', false)) {
|
|
|
|
require_once(\Yii::getAlias('@yii/vendor/ezyang/htmlpurifier/library/HTMLPurifier.auto.php'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Purifier provides an ability to clean up HTML from any harmful code.
|
|
|
|
*
|
|
|
|
* Basic usage is the following:
|
|
|
|
*
|
|
|
|
* ```php
|
|
|
|
* $my_html = Purifier::process($my_text);
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* If you want to configure it:
|
|
|
|
*
|
|
|
|
* ```php
|
|
|
|
* $my_html = Purifier::process($my_text, array(
|
|
|
|
* 'Attr.EnableID' => true,
|
|
|
|
* ));
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* For more details please refer to HTMLPurifier documentation](http://htmlpurifier.org/).
|
|
|
|
*
|
|
|
|
* @author Alexander Makarov <sam@rmcreative.ru>
|
|
|
|
* @since 2.0
|
|
|
|
*/
|
|
|
|
class Purifier
|
|
|
|
{
|
|
|
|
public static function process($content, $config = null)
|
|
|
|
{
|
|
|
|
$purifier=\HTMLPurifier::instance($config);
|
|
|
|
$purifier->config->set('Cache.SerializerPath', \Yii::$app->getRuntimePath());
|
|
|
|
return $purifier->purify($content);
|
|
|
|
}
|
|
|
|
}
|