2022-02-27 03:07:39 +01:00
|
|
|
import RE2 from 're2';
|
|
|
|
import { Note } from '@/models/entities/note.js';
|
|
|
|
import { User } from '@/models/entities/user.js';
|
2020-07-27 06:34:20 +02:00
|
|
|
|
|
|
|
type NoteLike = {
|
|
|
|
userId: Note['userId'];
|
|
|
|
text: Note['text'];
|
|
|
|
};
|
|
|
|
|
|
|
|
type UserLike = {
|
|
|
|
id: User['id'];
|
|
|
|
};
|
|
|
|
|
2022-02-10 11:47:46 +01:00
|
|
|
export async function checkWordMute(note: NoteLike, me: UserLike | null | undefined, mutedWords: Array<string | string[]>): Promise<boolean> {
|
2020-07-27 06:34:20 +02:00
|
|
|
// 自分自身
|
|
|
|
if (me && (note.userId === me.id)) return false;
|
|
|
|
|
2022-02-10 11:47:46 +01:00
|
|
|
if (mutedWords.length > 0) {
|
2020-07-27 06:34:20 +02:00
|
|
|
if (note.text == null) return false;
|
|
|
|
|
2022-02-10 11:47:46 +01:00
|
|
|
const matched = mutedWords.some(filter => {
|
|
|
|
if (Array.isArray(filter)) {
|
|
|
|
return filter.every(keyword => note.text!.includes(keyword));
|
|
|
|
} else {
|
|
|
|
// represents RegExp
|
|
|
|
const regexp = filter.match(/^\/(.+)\/(.*)$/);
|
|
|
|
|
|
|
|
// This should never happen due to input sanitisation.
|
|
|
|
if (!regexp) return false;
|
|
|
|
|
|
|
|
try {
|
2020-07-27 06:34:20 +02:00
|
|
|
return new RE2(regexp[1], regexp[2]).test(note.text!);
|
2022-02-10 11:47:46 +01:00
|
|
|
} catch (err) {
|
|
|
|
// This should never happen due to input sanitisation.
|
|
|
|
return false;
|
2020-07-27 06:34:20 +02:00
|
|
|
}
|
2022-02-10 11:47:46 +01:00
|
|
|
}
|
|
|
|
});
|
2020-07-27 06:34:20 +02:00
|
|
|
|
|
|
|
if (matched) return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|