Brewery/src/com/dre/brewery/DistortChat.java
2019-11-13 22:07:22 +01:00

298 lines
8.9 KiB
Java

package com.dre.brewery;
import com.dre.brewery.api.events.PlayerChatDistortEvent;
import org.bukkit.event.block.SignChangeEvent;
import org.bukkit.event.player.AsyncPlayerChatEvent;
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class DistortChat {
// represends Words and letters, that are replaced in drunk players messages
public static List<DistortChat> words = new ArrayList<>();
public static List<String> commands;
public static List<String[]> ignoreText = new ArrayList<>();
public static Boolean doSigns;
public static Boolean log;
private static Map<String, Long> waitPlayers = new HashMap<>();
private String from;
private String to;
private String[] pre;
private Boolean match = false;
private int alcohol = 1;
private int percentage = 100;
public DistortChat(Map<?, ?> part) {
for (Map.Entry<?, ?> wordPart : part.entrySet()) {
String key = (String) wordPart.getKey();
if (wordPart.getValue() instanceof String) {
if (key.equalsIgnoreCase("replace")) {
this.from = (String) wordPart.getValue();
} else if (key.equalsIgnoreCase("to")) {
this.to = (String) wordPart.getValue();
} else if (key.equalsIgnoreCase("pre")) {
String fullPre = (String) wordPart.getValue();
this.pre = fullPre.split(",");
}
} else if (wordPart.getValue() instanceof Boolean) {
if (key.equalsIgnoreCase("match")) {
this.match = (Boolean) wordPart.getValue();
}
} else if (wordPart.getValue() instanceof Integer) {
if (key.equalsIgnoreCase("alcohol")) {
this.alcohol = (Integer) wordPart.getValue();
} else if (key.equalsIgnoreCase("percentage")) {
this.percentage = (Integer) wordPart.getValue();
}
}
}
if (this.from != null && this.to != null) {
words.add(this);
}
}
// Distort players words when he uses a command
public static void playerCommand(PlayerCommandPreprocessEvent event) {
BPlayer bPlayer = BPlayer.get(event.getPlayer());
if (bPlayer != null) {
if (commands != null && !commands.isEmpty() && !words.isEmpty()) {
String name = event.getPlayer().getName();
if (!waitPlayers.containsKey(name) || waitPlayers.get(name) + 500 < System.currentTimeMillis()) {
String chat = event.getMessage();
for (String command : commands) {
if (command.length() + 1 < chat.length()) {
if (Character.isSpaceChar(chat.charAt(command.length()))) {
if (chat.toLowerCase().startsWith(command.toLowerCase())) {
if (log) {
P.p.log(P.p.languageReader.get("Player_TriedToSay", name, chat));
}
String message = chat.substring(command.length() + 1);
String distorted = distortMessage(message, bPlayer.getDrunkeness());
PlayerChatDistortEvent call = new PlayerChatDistortEvent(event.isAsynchronous(), event.getPlayer(), bPlayer, message, distorted);
P.p.getServer().getPluginManager().callEvent(call);
if (call.isCancelled()) {
return;
}
distorted = call.getDistortedMessage();
event.setMessage(chat.substring(0, command.length() + 1) + distorted);
waitPlayers.put(name, System.currentTimeMillis());
return;
}
}
}
}
}
}
}
}
// Distort players words when he uses a command
public static void signWrite(SignChangeEvent event) {
BPlayer bPlayer = BPlayer.get(event.getPlayer());
if (bPlayer != null) {
if (!words.isEmpty()) {
int index = 0;
for (String message : event.getLines()) {
if (message.length() > 1) {
String distorted = distortMessage(message, bPlayer.getDrunkeness());
PlayerChatDistortEvent call = new PlayerChatDistortEvent(event.isAsynchronous(), event.getPlayer(), bPlayer, message, distorted);
P.p.getServer().getPluginManager().callEvent(call);
if (!call.isCancelled()) {
distorted = call.getDistortedMessage();
if (distorted.length() > 15) {
distorted = distorted.substring(0, 14);
}
event.setLine(index, distorted);
}
}
index++;
}
}
}
}
// Distort players words when he talks
public static void playerChat(AsyncPlayerChatEvent event) {
BPlayer bPlayer = BPlayer.get(event.getPlayer());
if (bPlayer != null) {
if (!words.isEmpty()) {
String message = event.getMessage();
if (log) {
P.p.log(P.p.languageReader.get("Player_TriedToSay", event.getPlayer().getName(), message));
}
String distorted = distortMessage(message, bPlayer.getDrunkeness());
PlayerChatDistortEvent call = new PlayerChatDistortEvent(event.isAsynchronous(), event.getPlayer(), bPlayer, message, distorted);
P.p.getServer().getPluginManager().callEvent(call);
if (call.isCancelled()) {
return;
}
distorted = call.getDistortedMessage();
event.setMessage(distorted);
}
}
}
// distorts a message, ignoring text enclosed in ignoreText letters
public static String distortMessage(String message, int drunkeness) {
if (!ignoreText.isEmpty()) {
for (String[] bypass : ignoreText) {
int indexStart = 0;
if (!bypass[0].equals("")) {
indexStart = message.indexOf(bypass[0]);
}
int indexEnd = message.length() - 1;
if (!bypass[1].equals("")) {
indexEnd = message.indexOf(bypass[1], indexStart + 2);
}
if (indexStart != -1 && indexEnd != -1) {
if (indexEnd > indexStart + 1) {
String ignoredMessage = message.substring(indexStart, indexEnd);
String msg0 = message.substring(0, indexStart);
String msg1 = message.substring(indexEnd);
if (msg0.length() > 1) {
msg0 = distortMessage(msg0, drunkeness);
}
if (msg1.length() > 1) {
msg1 = distortMessage(msg1, drunkeness);
}
return msg0 + ignoredMessage + msg1;
}
}
}
}
return distortString(message, drunkeness);
}
// distorts a message without checking ignoreText letters
private static String distortString(String message, int drunkeness) {
if (message.length() > 1) {
// Create our own reference to the words list, in case of config reload
List<DistortChat> words = DistortChat.words;
for (DistortChat word : words) {
if (word.alcohol <= drunkeness) {
message = word.distort(message);
}
}
}
return message;
}
// replace "percent"% of "from" -> "to" in "words", when the string before
// each "from" "match"es "pre"
// Not yet ignoring case :(
public String distort(String words) {
String from = this.from;
String to = this.to;
if (from.equalsIgnoreCase("-end")) {
from = words;
to = words + to;
} else if (from.equalsIgnoreCase("-start")) {
from = words;
to = to + words;
} else if (from.equalsIgnoreCase("-all")) {
from = words;
} else if (from.equalsIgnoreCase("-space")) {
from = " ";
} else if (from.equalsIgnoreCase("-random")) {
// inserts "to" on a random position in "words"
int charIndex = (int) (Math.random() * (words.length() - 1));
if (charIndex < words.length() / 2) {
from = words.substring(charIndex);
to = to + from;
} else {
from = words.substring(0, charIndex);
to = from + to;
}
}
if (words.contains(from)) {
// some characters (*,?) disturb split() which then throws
// PatternSyntaxException
try {
if (pre == null && percentage == 100) {
// All occurences of "from" need to be replaced
return words.replaceAll(from, to);
}
StringBuilder newWords = new StringBuilder();
if (words.endsWith(from)) {
// add space to end to recognize last occurence of "from"
words = words + " ";
}
// remove all "from" and split "words" there
String[] splitted = words.split(java.util.regex.Pattern.quote(from));
int index = 0;
String part;
// if there are occurences of "from"
if (splitted.length > 1) {
// - 1 because dont add "to" to the end of last part
while (index < splitted.length - 1) {
part = splitted[index];
// add current part of "words" to the output
newWords.append(part);
// check if the part ends with correct string
if (doesPreMatch(part) && Math.random() * 100.0 <= percentage) {
// add replacement
newWords.append(to);
} else {
// add original
newWords.append(from);
}
index++;
}
// add the last part to finish the sentence
part = splitted[index];
if (part.equals(" ")) {
// dont add the space to the end
return newWords.toString();
} else {
return newWords.append(part).toString();
}
}
} catch (java.util.regex.PatternSyntaxException e) {
// e.printStackTrace();
return words;
}
}
return words;
}
public boolean doesPreMatch(String part) {
boolean isBefore = !match;
if (pre != null) {
for (String pr : pre) {
if (part.endsWith(pr)) {
// If a match is wanted set isBefore to true, else to false
isBefore = match;
break;
}
}
} else {
isBefore = true;
}
return isBefore;
}
}