From 4c68599d468f0057c34407ea96aabf4792263a80 Mon Sep 17 00:00:00 2001 From: Ha Thanh Tuan Date: Wed, 26 Aug 2015 14:40:04 +0700 Subject: [PATCH] Allowed add more dictionary to CensorWords --- src/CensorWords.php | 68 ++++++++++++++++++++++++++++++-------------- tests/CensorTest.php | 14 +++++++++ 2 files changed, 61 insertions(+), 21 deletions(-) diff --git a/src/CensorWords.php b/src/CensorWords.php index 819aa99..08551c9 100644 --- a/src/CensorWords.php +++ b/src/CensorWords.php @@ -4,6 +4,8 @@ class CensorWords { + public $badwords; + /* * When the dictionary is loaded, a ton of regular expression strings are generated * These regular expressions are used to perform the profanity checks. @@ -11,7 +13,8 @@ class CensorWords */ private $censorChecks = null; - public function __construct() { + public function __construct() { + $this->badwords = array(); $this->replacer = '*'; $this->setDictionary('en-us'); } @@ -26,34 +29,57 @@ public function __construct() { * string */ public function setDictionary($dictionary) { - + + $this->badwords = $this->readBadWords($dictionary); + } + + /** + * Add more the dictionar(y|ies) to current bad words list + * This can accept a string to a language file path, + * or an array of strings to multiple paths + * + * @param string/array + * string + */ + public function addDictionary($dictionary) { + + $this->badwords = array_merge($this->badwords, $this->readBadWords($dictionary)); + } + + /** + * Read bad words list from dictionar(y|ies) and return it + * + * @param string/array + * array + */ + private function readBadWords($dictionary) { $badwords = array(); - $this->dictionary = $dictionary; - - if (is_array($this->dictionary)) { - for ($x=0; $x < count($this->dictionary); $x++) { - if (file_exists(__DIR__ . DIRECTORY_SEPARATOR .'dict/'.$this->dictionary[$x].'.php')) { - include(__DIR__ . DIRECTORY_SEPARATOR .'dict/'.$this->dictionary[$x].'.php'); + $baseDictPath = __DIR__ . DIRECTORY_SEPARATOR .'dict/'; + + if (is_array($dictionary)) { + for ($x=0; $x < count($dictionary); $x++) { + if (file_exists($baseDictPath.$dictionary[$x].'.php')) { + include($baseDictPath.$dictionary[$x].'.php'); } else { - // if the file isn't in the dict directory, + // if the file isn't in the dict directory, // it's probably a custom user library - include($this->dictionary[$x]); + include($dictionary[$x]); } - - } - - // just a single string, not an array - } elseif (is_string($this->dictionary)) { - if (file_exists(__DIR__ . DIRECTORY_SEPARATOR .'dict/'.$this->dictionary.'.php')) { - include(__DIR__ . DIRECTORY_SEPARATOR .'dict/'.$this->dictionary.'.php'); + + } + + // just a single string, not an array + } elseif (is_string($dictionary)) { + if (file_exists($baseDictPath.$dictionary.'.php')) { + include($baseDictPath.$dictionary.'.php'); } else { - include($this->dictionary); + include($dictionary); } - } - $this->badwords = $badwords; + } + + return $badwords; } - /** * Sets the replacement character to use * diff --git a/tests/CensorTest.php b/tests/CensorTest.php index add3b2e..ae2c514 100644 --- a/tests/CensorTest.php +++ b/tests/CensorTest.php @@ -13,6 +13,20 @@ public function testSetDictionary() $censor->setDictionary('fr'); $this->assertNotEmpty($censor->badwords); } + + public function testAddDictionary() + { + $censor = new CensorWords(); + $censor->addDictionary('fr'); + + $this->assertNotEmpty($censor->badwords); + + $string1 = $censor->censorString('fuck'); + $this->assertEquals('****', $string1['clean']); + + $string2 = $censor->censorString('nique'); + $this->assertEquals('*****', $string2['clean']); + } /** * @expectedException PHPUnit_Framework_Error