2023-07-27 07:31:52 +02:00
|
|
|
/*
|
2024-02-13 16:59:27 +01:00
|
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
2023-07-27 07:31:52 +02:00
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-02-10 11:47:46 +01:00
|
|
|
export function checkWordMute(note: Record<string, any>, me: Record<string, any> | null | undefined, mutedWords: Array<string | string[]>): 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) {
|
2022-06-23 13:26:47 +02:00
|
|
|
const text = ((note.cw ?? '') + '\n' + (note.text ?? '')).trim();
|
|
|
|
|
2022-06-24 12:44:22 +02:00
|
|
|
if (text === '') return false;
|
2020-07-27 06:34:20 +02:00
|
|
|
|
2022-02-10 11:47:46 +01:00
|
|
|
const matched = mutedWords.some(filter => {
|
|
|
|
if (Array.isArray(filter)) {
|
2022-02-11 15:26:51 +01:00
|
|
|
// Clean up
|
|
|
|
const filteredFilter = filter.filter(keyword => keyword !== '');
|
|
|
|
if (filteredFilter.length === 0) return false;
|
|
|
|
|
2022-06-23 13:26:47 +02:00
|
|
|
return filteredFilter.every(keyword => text.includes(keyword));
|
2022-02-10 11:47:46 +01:00
|
|
|
} else {
|
|
|
|
// represents RegExp
|
|
|
|
const regexp = filter.match(/^\/(.+)\/(.*)$/);
|
|
|
|
|
|
|
|
// This should never happen due to input sanitisation.
|
|
|
|
if (!regexp) return false;
|
|
|
|
|
|
|
|
try {
|
2022-06-23 13:26:47 +02:00
|
|
|
return new RegExp(regexp[1], regexp[2]).test(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;
|
|
|
|
}
|