You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.7 KiB
JavaScript
109 lines
3.7 KiB
JavaScript
5 years ago
|
(function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.badwords = f()}})(function(){var define,module,exports;module={exports:(exports={})};
|
||
|
var localList = require('./lang.json').words;
|
||
|
var baseList = require('badwords-list').array;
|
||
|
var Filter = (function() {
|
||
|
/**
|
||
|
* Filter constructor.
|
||
|
* @constructor
|
||
|
* @param {object} options - Filter instance options
|
||
|
* @param {boolean} options.emptyList - Instantiate filter with no blacklist
|
||
|
* @param {array} options.list - Instantiate filter with custom list
|
||
|
* @param {string} options.placeHolder - Character used to replace profane words.
|
||
|
* @param {string} options.regex - Regular expression used to sanitize words before comparing them to blacklist.
|
||
|
* @param {string} options.replaceRegex - Regular expression used to replace profane words with placeHolder.
|
||
|
*/
|
||
|
function Filter(options) {
|
||
|
options = options || {};
|
||
|
this.list = options.emptyList && [] || Array.prototype.concat.apply(localList, [baseList, options.list || []]);
|
||
|
this.exclude = options.exclude || [];
|
||
|
this.placeHolder = options.placeHolder || '*';
|
||
|
this.regex = options.regex || /[^a-zA-Z0-9|\$|\@]|\^/g;
|
||
|
this.replaceRegex = options.replaceRegex || /\w/g;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determine if a string contains profane language.
|
||
|
* @param {string} string - String to evaluate for profanity.
|
||
|
*/
|
||
|
Filter.prototype.isProfane = function isProfane(string) {
|
||
|
return string
|
||
|
.split(/\b/)
|
||
|
.map(function(w) {
|
||
|
return w.toLowerCase().replace(this.regex, '');
|
||
|
}, this)
|
||
|
.filter(this.isProfaneLike, this)
|
||
|
.shift() || false;
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Determine if a single word is profane or looks profane.
|
||
|
* @param {string} word - String to evaluate for profanity.
|
||
|
*/
|
||
|
Filter.prototype.isProfaneLike = function profaneLike(word) {
|
||
|
if (!!~this.exclude.indexOf(word)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
if (!!~this.list.indexOf(word)) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
return this.list
|
||
|
.map(function(w) {
|
||
|
return new RegExp('^' + w.replace(/(\W)/g, '\\$1') + '$', 'gi');
|
||
|
}, this)
|
||
|
.reduce(function(outcome, wordExp) {
|
||
|
return outcome || wordExp.test(word);
|
||
|
}, false);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Replace a word with placeHolder characters;
|
||
|
* @param {string} string - String to replace.
|
||
|
*/
|
||
|
Filter.prototype.replaceWord = function replaceWord(string) {
|
||
|
return string.replace(this.regex, '').replace(this.replaceRegex, this.placeHolder);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Evaluate a string for profanity and return an edited version.
|
||
|
* @param {string} string - Sentence to filter.
|
||
|
*/
|
||
|
Filter.prototype.clean = function clean(string) {
|
||
|
return string.split(/\b/).map(function(word) {
|
||
|
return this.isProfane(word) ? this.replaceWord(word) : word;
|
||
|
}.bind(this)).join('');
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Add words to blacklist filter / remove words from whitelist filter
|
||
|
* @param {(string|string[])}
|
||
|
*/
|
||
|
Filter.prototype.addWords = function addWords(words) {
|
||
|
words = (words instanceof Array) ? words : [words];
|
||
|
this.list = this.list.concat(words);
|
||
|
|
||
|
words.forEach(function(word) {
|
||
|
if(!!~this.exclude.indexOf(word)) {
|
||
|
this.exclude.splice(this.exclude.indexOf(word), 1);
|
||
|
}
|
||
|
}, this);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Add words to whitelist filter
|
||
|
* @param {...string} word - Word to add to whitelist.
|
||
|
*/
|
||
|
Filter.prototype.removeWords = function removeWords() {
|
||
|
var words = Array.prototype.slice.call(arguments);
|
||
|
this.exclude.push.apply(this.exclude, words);
|
||
|
};
|
||
|
|
||
|
return Filter;
|
||
|
})();
|
||
|
|
||
|
module.exports = Filter;
|
||
|
|
||
|
return module.exports;});
|
||
|
|