mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-13 04:37:36 +01:00
fix(string utils): do not escape possible regular expressions
This commit is contained in:
12
test/api/unit/libs/stringUtils.test.js
Normal file
12
test/api/unit/libs/stringUtils.test.js
Normal file
@@ -0,0 +1,12 @@
|
||||
import { getMatchesByWordArray } from '../../../../website/server/libs/stringUtils';
|
||||
import bannedWords from '../../../../website/server/libs/bannedWords';
|
||||
|
||||
describe('stringUtils', () => {
|
||||
describe('getMatchesByWordArray', () => {
|
||||
it('check all banned words are matched', async () => {
|
||||
const message = bannedWords.join(',');
|
||||
const matches = getMatchesByWordArray(message, bannedWords);
|
||||
expect(matches.length).to.equal(bannedWords.length);
|
||||
});
|
||||
});
|
||||
});
|
||||
@@ -14,8 +14,6 @@ import {
|
||||
TAVERN_ID,
|
||||
} from '../../../../../website/server/models/group';
|
||||
import { CHAT_FLAG_FROM_SHADOW_MUTE, MAX_MESSAGE_LENGTH } from '../../../../../website/common/script/constants';
|
||||
import { getMatchesByWordArray } from '../../../../../website/server/libs/stringUtils';
|
||||
import bannedWords from '../../../../../website/server/libs/bannedWords';
|
||||
import guildsAllowingBannedWords from '../../../../../website/server/libs/guildsAllowingBannedWords';
|
||||
import * as email from '../../../../../website/server/libs/email';
|
||||
|
||||
@@ -292,12 +290,6 @@ describe('POST /chat', () => {
|
||||
.that.includes(testBannedWords.join(', '));
|
||||
});
|
||||
|
||||
it('check all banned words are matched', async () => {
|
||||
const message = bannedWords.join(',').replace(/\\/g, '');
|
||||
const matches = getMatchesByWordArray(message, bannedWords);
|
||||
expect(matches.length).to.equal(bannedWords.length);
|
||||
});
|
||||
|
||||
it('does not error when bad word is suffix of a word', async () => {
|
||||
const wordAsSuffix = `prefix${testBannedWordMessage}`;
|
||||
const message = await user.post('/groups/habitrpg/chat', { message: wordAsSuffix });
|
||||
|
||||
@@ -1,15 +1,12 @@
|
||||
import escapeRegExp from 'lodash/escapeRegExp';
|
||||
|
||||
export function removePunctuationFromString (str) {
|
||||
return str.replace(/[.,/#!@$%^&;:{}=\-_`~()]/g, ' ');
|
||||
}
|
||||
|
||||
// NOTE: the wordsToMatch aren't escaped in order to support regular expressions,
|
||||
// so this method should not be used if wordsToMatch contains unsanitized user input
|
||||
export function getMatchesByWordArray (str, wordsToMatch) {
|
||||
const matchedWords = [];
|
||||
const wordRegexs = wordsToMatch.map(word => {
|
||||
const escapedWord = escapeRegExp(word);
|
||||
return new RegExp(`\\b([^a-z]+)?${escapedWord}([^a-z]+)?\\b`, 'i');
|
||||
});
|
||||
const wordRegexs = wordsToMatch.map(word => new RegExp(`\\b([^a-z]+)?${word}([^a-z]+)?\\b`, 'i'));
|
||||
for (let i = 0; i < wordRegexs.length; i += 1) {
|
||||
const regEx = wordRegexs[i];
|
||||
const match = str.match(regEx);
|
||||
|
||||
@@ -1,12 +1,8 @@
|
||||
import escapeRegExp from 'lodash/escapeRegExp';
|
||||
import bannedSlurs from '../bannedSlurs';
|
||||
import { getMatchesByWordArray } from '../stringUtils';
|
||||
import forbiddenUsernames from '../forbiddenUsernames';
|
||||
|
||||
const bannedSlurRegexs = bannedSlurs.map(word => {
|
||||
const escapedWord = escapeRegExp(word);
|
||||
return new RegExp(`.*${escapedWord}.*`, 'i');
|
||||
});
|
||||
const bannedSlurRegexs = bannedSlurs.map(word => new RegExp(`.*${word}.*`, 'i'));
|
||||
|
||||
export function nameContainsSlur (username) {
|
||||
for (let i = 0; i < bannedSlurRegexs.length; i += 1) {
|
||||
|
||||
Reference in New Issue
Block a user