2023-01-20 02:11:27 +00:00
|
|
|
export type Muted = {
|
|
|
|
muted: boolean;
|
|
|
|
matched: string[];
|
|
|
|
};
|
|
|
|
|
|
|
|
const NotMuted = { muted: false, matched: [] };
|
|
|
|
|
|
|
|
function escapeRegExp(x: string) {
|
|
|
|
return x.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string
|
|
|
|
}
|
|
|
|
|
|
|
|
export function getWordMute(
|
2023-01-13 04:40:33 +00:00
|
|
|
note: Record<string, any>,
|
|
|
|
me: Record<string, any> | null | undefined,
|
|
|
|
mutedWords: Array<string | string[]>,
|
2023-01-20 02:11:27 +00:00
|
|
|
): Muted {
|
2020-07-27 04:34:20 +00:00
|
|
|
// 自分自身
|
2023-01-20 02:11:27 +00:00
|
|
|
if (me && note.userId === me.id) {
|
|
|
|
return NotMuted;
|
|
|
|
}
|
2020-07-27 04:34:20 +00:00
|
|
|
|
2022-02-10 10:47:46 +00:00
|
|
|
if (mutedWords.length > 0) {
|
2023-01-13 04:40:33 +00:00
|
|
|
const text = ((note.cw ?? "") + "\n" + (note.text ?? "")).trim();
|
2022-06-23 11:26:47 +00:00
|
|
|
|
2023-01-20 02:11:27 +00:00
|
|
|
if (text === "") {
|
|
|
|
return NotMuted;
|
|
|
|
}
|
2020-07-27 04:34:20 +00:00
|
|
|
|
2023-01-20 02:11:27 +00:00
|
|
|
for (const mutePattern of mutedWords) {
|
|
|
|
let mute: RegExp;
|
|
|
|
let matched: string[];
|
|
|
|
if (Array.isArray(mutePattern)) {
|
|
|
|
matched = mutePattern.filter((keyword) => keyword !== "");
|
2022-02-11 14:26:51 +00:00
|
|
|
|
2023-01-20 02:11:27 +00:00
|
|
|
if (matched.length === 0) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
mute = new RegExp(
|
|
|
|
`\\b${matched.map(escapeRegExp).join("\\b.*\\b")}\\b`,
|
|
|
|
"g",
|
|
|
|
);
|
2022-02-10 10:47:46 +00:00
|
|
|
} else {
|
2023-01-20 02:11:27 +00:00
|
|
|
const regexp = mutePattern.match(/^\/(.+)\/(.*)$/);
|
2022-02-10 10:47:46 +00:00
|
|
|
// This should never happen due to input sanitisation.
|
2023-01-20 02:11:27 +00:00
|
|
|
if (!regexp) {
|
|
|
|
console.warn(`Found invalid regex in word mutes: ${mutePattern}`);
|
|
|
|
continue;
|
2020-07-27 04:34:20 +00:00
|
|
|
}
|
2023-01-20 02:11:27 +00:00
|
|
|
mute = new RegExp(regexp[1], regexp[2]);
|
|
|
|
matched = [mutePattern];
|
2022-02-10 10:47:46 +00:00
|
|
|
}
|
2020-07-27 04:34:20 +00:00
|
|
|
|
2023-01-20 02:11:27 +00:00
|
|
|
try {
|
|
|
|
if (mute.test(text)) {
|
|
|
|
return { muted: true, matched };
|
|
|
|
}
|
|
|
|
} catch (err) {
|
|
|
|
// This should never happen due to input sanitisation.
|
|
|
|
}
|
|
|
|
}
|
2020-07-27 04:34:20 +00:00
|
|
|
}
|
|
|
|
|
2023-01-20 02:11:27 +00:00
|
|
|
return NotMuted;
|
2020-07-27 04:34:20 +00:00
|
|
|
}
|