You've already forked Arcturus-Morningstar-Extended
mirror of
https://github.com/duckietm/Arcturus-Morningstar-Extended.git
synced 2026-06-19 15:06:19 +00:00
🆙 wordfilter to set specific settings to prefix
This commit is contained in:
@@ -19,3 +19,8 @@ INSERT IGNORE INTO `emulator_settings` (`key`, `value`) VALUES
|
|||||||
('mentions.max.targets', '50'),
|
('mentions.max.targets', '50'),
|
||||||
('mentions.cooldown.ms', '3000'),
|
('mentions.cooldown.ms', '3000'),
|
||||||
('mentions.store.limit', '50');
|
('mentions.store.limit', '50');
|
||||||
|
|
||||||
|
|
||||||
|
ALTER TABLE `wordfilter`
|
||||||
|
ADD COLUMN `prefix_only` ENUM('0','1') NOT NULL DEFAULT '0'
|
||||||
|
COMMENT 'When 1, this word only applies to custom prefixes, not to chat/motto/guild.' AFTER `mute`;
|
||||||
@@ -4,6 +4,7 @@ import com.eu.habbo.Emulator;
|
|||||||
import com.eu.habbo.habbohotel.gameclients.GameClient;
|
import com.eu.habbo.habbohotel.gameclients.GameClient;
|
||||||
import com.eu.habbo.habbohotel.modtool.WordFilter;
|
import com.eu.habbo.habbohotel.modtool.WordFilter;
|
||||||
import com.eu.habbo.habbohotel.modtool.WordFilterWord;
|
import com.eu.habbo.habbohotel.modtool.WordFilterWord;
|
||||||
|
import com.eu.habbo.habbohotel.rooms.RoomChatMessageBubbles;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
@@ -21,30 +22,44 @@ public class FilterWordCommand extends Command {
|
|||||||
@Override
|
@Override
|
||||||
public boolean handle(GameClient gameClient, String[] params) throws Exception {
|
public boolean handle(GameClient gameClient, String[] params) throws Exception {
|
||||||
if (params.length < 2) {
|
if (params.length < 2) {
|
||||||
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_filterword.missing_word"));
|
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_filterword.missing_word"), RoomChatMessageBubbles.ALERT);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
String word = params[1];
|
String word = params[1];
|
||||||
|
|
||||||
|
// Optional trailing "prefix" keyword marks the word as prefix-only (blocks
|
||||||
|
// custom prefixes but not chat/motto/guild). Usage:
|
||||||
|
// :filterword <word> -> everywhere, default replacement
|
||||||
|
// :filterword <word> <replacement> -> everywhere
|
||||||
|
// :filterword <word> prefix -> prefix-only, default replacement
|
||||||
|
// :filterword <word> <replacement> prefix -> prefix-only
|
||||||
|
boolean prefixOnly = false;
|
||||||
String replacement = WordFilter.DEFAULT_REPLACEMENT;
|
String replacement = WordFilter.DEFAULT_REPLACEMENT;
|
||||||
if (params.length == 3) {
|
|
||||||
replacement = params[2];
|
if (params.length >= 3) {
|
||||||
|
if (params[params.length - 1].equalsIgnoreCase("prefix")) {
|
||||||
|
prefixOnly = true;
|
||||||
|
if (params.length >= 4) replacement = params[2];
|
||||||
|
} else {
|
||||||
|
replacement = params[2];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
WordFilterWord wordFilterWord = new WordFilterWord(word, replacement);
|
WordFilterWord wordFilterWord = new WordFilterWord(word, replacement, prefixOnly);
|
||||||
|
|
||||||
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO wordfilter (`key`, `replacement`) VALUES (?, ?)")) {
|
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO wordfilter (`key`, `replacement`, `prefix_only`) VALUES (?, ?, ?)")) {
|
||||||
statement.setString(1, word);
|
statement.setString(1, word);
|
||||||
statement.setString(2, replacement);
|
statement.setString(2, replacement);
|
||||||
|
statement.setString(3, prefixOnly ? "1" : "0");
|
||||||
statement.execute();
|
statement.execute();
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
LOGGER.error("Caught SQL exception", e);
|
LOGGER.error("Caught SQL exception", e);
|
||||||
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_filterword.error"));
|
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.error.cmd_filterword.error"), RoomChatMessageBubbles.ALERT);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.succes.cmd_filterword.added").replace("%word%", word).replace("%replacement%", replacement));
|
gameClient.getHabbo().whisper(Emulator.getTexts().getValue("commands.succes.cmd_filterword.added").replace("%word%", word).replace("%replacement%", replacement) + (prefixOnly ? " [prefix-only]" : ""), RoomChatMessageBubbles.ALERT);
|
||||||
Emulator.getGameEnvironment().getWordFilter().addWord(wordFilterWord);
|
Emulator.getGameEnvironment().getWordFilter().addWord(wordFilterWord);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -23,7 +23,6 @@ public class WordFilter {
|
|||||||
private static final Logger LOGGER = LoggerFactory.getLogger(WordFilter.class);
|
private static final Logger LOGGER = LoggerFactory.getLogger(WordFilter.class);
|
||||||
|
|
||||||
private static final Pattern DIACRITICS_AND_FRIENDS = Pattern.compile("[\\p{InCombiningDiacriticalMarks}\\p{IsLm}\\p{IsSk}]+");
|
private static final Pattern DIACRITICS_AND_FRIENDS = Pattern.compile("[\\p{InCombiningDiacriticalMarks}\\p{IsLm}\\p{IsSk}]+");
|
||||||
//Configuration. Loaded from database & updated accordingly.
|
|
||||||
public static boolean ENABLED_FRIENDCHAT = true;
|
public static boolean ENABLED_FRIENDCHAT = true;
|
||||||
public static String DEFAULT_REPLACEMENT = "bobba";
|
public static String DEFAULT_REPLACEMENT = "bobba";
|
||||||
protected THashSet<WordFilterWord> autoReportWords = new THashSet<>();
|
protected THashSet<WordFilterWord> autoReportWords = new THashSet<>();
|
||||||
@@ -63,10 +62,12 @@ public class WordFilter {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (word.autoReport)
|
if (!word.prefixOnly) {
|
||||||
this.autoReportWords.add(word);
|
if (word.autoReport)
|
||||||
else if (word.hideMessage)
|
this.autoReportWords.add(word);
|
||||||
this.hideMessageWords.add(word);
|
else if (word.hideMessage)
|
||||||
|
this.hideMessageWords.add(word);
|
||||||
|
}
|
||||||
|
|
||||||
this.words.add(word);
|
this.words.add(word);
|
||||||
}
|
}
|
||||||
@@ -146,6 +147,8 @@ public class WordFilter {
|
|||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
WordFilterWord word = (WordFilterWord) iterator.next();
|
WordFilterWord word = (WordFilterWord) iterator.next();
|
||||||
|
|
||||||
|
if (word.prefixOnly) continue;
|
||||||
|
|
||||||
if (StringUtils.containsIgnoreCase(filteredMessage, word.key)) {
|
if (StringUtils.containsIgnoreCase(filteredMessage, word.key)) {
|
||||||
if (habbo != null) {
|
if (habbo != null) {
|
||||||
if (Emulator.getPluginManager().fireEvent(new UserTriggerWordFilterEvent(habbo, word)).isCancelled())
|
if (Emulator.getPluginManager().fireEvent(new UserTriggerWordFilterEvent(habbo, word)).isCancelled())
|
||||||
@@ -179,6 +182,8 @@ public class WordFilter {
|
|||||||
while (iterator.hasNext()) {
|
while (iterator.hasNext()) {
|
||||||
WordFilterWord word = (WordFilterWord) iterator.next();
|
WordFilterWord word = (WordFilterWord) iterator.next();
|
||||||
|
|
||||||
|
if (word.prefixOnly) continue;
|
||||||
|
|
||||||
if (StringUtils.containsIgnoreCase(message, word.key)) {
|
if (StringUtils.containsIgnoreCase(message, word.key)) {
|
||||||
if (habbo != null) {
|
if (habbo != null) {
|
||||||
if (Emulator.getPluginManager().fireEvent(new UserTriggerWordFilterEvent(habbo, word)).isCancelled())
|
if (Emulator.getPluginManager().fireEvent(new UserTriggerWordFilterEvent(habbo, word)).isCancelled())
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ public class WordFilterWord {
|
|||||||
public final boolean hideMessage;
|
public final boolean hideMessage;
|
||||||
public final boolean autoReport;
|
public final boolean autoReport;
|
||||||
public final int muteTime;
|
public final int muteTime;
|
||||||
|
public final boolean prefixOnly;
|
||||||
|
|
||||||
public WordFilterWord(ResultSet set) throws SQLException {
|
public WordFilterWord(ResultSet set) throws SQLException {
|
||||||
this.key = set.getString("key");
|
this.key = set.getString("key");
|
||||||
@@ -16,13 +17,27 @@ public class WordFilterWord {
|
|||||||
this.hideMessage = set.getInt("hide") == 1;
|
this.hideMessage = set.getInt("hide") == 1;
|
||||||
this.autoReport = set.getInt("report") == 1;
|
this.autoReport = set.getInt("report") == 1;
|
||||||
this.muteTime = set.getInt("mute");
|
this.muteTime = set.getInt("mute");
|
||||||
|
this.prefixOnly = readBooleanColumn(set, "prefix_only");
|
||||||
}
|
}
|
||||||
|
|
||||||
public WordFilterWord(String key, String replacement) {
|
public WordFilterWord(String key, String replacement) {
|
||||||
|
this(key, replacement, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
public WordFilterWord(String key, String replacement, boolean prefixOnly) {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
this.replacement = replacement;
|
this.replacement = replacement;
|
||||||
this.hideMessage = false;
|
this.hideMessage = false;
|
||||||
this.autoReport = false;
|
this.autoReport = false;
|
||||||
this.muteTime = 0;
|
this.muteTime = 0;
|
||||||
|
this.prefixOnly = prefixOnly;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static boolean readBooleanColumn(ResultSet set, String column) {
|
||||||
|
try {
|
||||||
|
return set.getInt(column) == 1;
|
||||||
|
} catch (SQLException e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user