Files
Server/src/engine/util/KeyCloneAudit.java
T

118 lines
4.1 KiB
Java
Raw Normal View History

2023-01-21 10:04:34 -05:00
package engine.util;
2022-04-30 09:41:17 -04:00
import engine.gameManager.ConfigManager;
2022-04-30 09:41:17 -04:00
import engine.gameManager.DbManager;
2025-02-15 22:12:37 -06:00
import engine.gameManager.GroupManager;
2025-02-09 14:37:44 -06:00
import engine.gameManager.SessionManager;
import engine.net.client.ClientConnection;
2025-02-09 14:13:28 -06:00
import engine.net.client.Protocol;
2025-02-09 14:08:17 -06:00
import engine.net.client.msg.ClientNetMsg;
2025-02-09 14:37:44 -06:00
import engine.net.client.msg.TargetObjectMsg;
2022-04-30 09:41:17 -04:00
import engine.objects.Group;
import engine.objects.PlayerCharacter;
2025-02-09 15:23:52 -06:00
import engine.server.MBServerStatics;
2022-04-30 09:41:17 -04:00
import org.pmw.tinylog.Logger;
public enum KeyCloneAudit {
KEYCLONEAUDIT;
2025-02-15 22:12:37 -06:00
public static boolean auditChatMsg(PlayerCharacter pc, String message) {
2025-02-20 09:24:32 -06:00
if(pc.selectedUUID == 0)
return false;
int id = pc.selectedUUID;
String value = String.valueOf(id);
if(message.contains(value)) {
2025-02-16 08:58:49 -06:00
//targeting software detected
2025-02-15 22:12:37 -06:00
2025-02-16 08:58:49 -06:00
Group g = GroupManager.getGroup(pc);
2025-02-18 20:51:15 -06:00
if (g == null) {
try {
2025-02-20 09:27:02 -06:00
Logger.error("TARGET SOFTWARE DETECTED ON ACCOUNT: " + pc.getAccount().getUname());
2025-02-21 09:54:26 -06:00
DbManager.AccountQueries.SET_TRASH(pc.getAccount().getUname(), "TARGET");
pc.getClientConnection().forceDisconnect();
2025-02-18 20:51:15 -06:00
}catch(Exception e){
}
}else {
2025-02-18 20:37:30 -06:00
for (PlayerCharacter member : g.members) {
try {
2025-02-20 09:27:02 -06:00
Logger.error("TARGET SOFTWARE DETECTED ON ACCOUNT: " + member.getAccount().getUname());
2025-02-21 09:54:26 -06:00
DbManager.AccountQueries.SET_TRASH(member.getAccount().getUname(), "TARGET");
member.getClientConnection().forceDisconnect();
2025-02-18 20:51:15 -06:00
} catch (Exception e) {
2025-02-18 20:37:30 -06:00
}
}
2025-02-18 20:51:15 -06:00
}
2025-02-15 22:12:37 -06:00
return true;
}
return false;
}
2023-01-21 10:04:34 -05:00
public void audit(PlayerCharacter player, Group group) {
2022-04-30 09:41:17 -04:00
int machineCount = 0;
String machineID;
machineID = player.getClientConnection().machineID;
for (PlayerCharacter member : group.getMembers())
if (machineID.equals(member.getClientConnection().machineID))
machineCount = machineCount + 1;
2023-07-15 09:23:48 -04:00
if (machineCount > Integer.parseInt(ConfigManager.MB_WORLD_KEYCLONE_MAX.getValue())) {
Logger.error("Keyclone detected from: " + player.getAccount().getUname() +
" with machine count of: " + machineCount);
2025-02-21 09:54:26 -06:00
DbManager.AccountQueries.SET_TRASH(machineID,"MEMBERLIMIT");
2023-07-15 09:23:48 -04:00
}
2022-04-30 09:41:17 -04:00
}
2025-02-09 14:08:17 -06:00
2025-02-11 07:49:19 -06:00
public static void auditTargetMsg(ClientNetMsg msg) {
2025-02-09 15:23:52 -06:00
try {
2025-02-11 07:49:19 -06:00
TargetObjectMsg tarMsg = (TargetObjectMsg) msg;
2025-02-09 15:23:52 -06:00
ClientConnection origin = (ClientConnection) msg.getOrigin();
2025-02-18 20:47:10 -06:00
2025-02-09 15:23:52 -06:00
long now = System.currentTimeMillis();
2025-02-20 09:24:32 -06:00
if (PlayerCharacter.getPlayerCharacter(tarMsg.getTargetID()) == null)
2025-02-11 07:49:19 -06:00
return;
2025-02-18 20:47:10 -06:00
PlayerCharacter pc = origin.getPlayerCharacter();
2025-02-20 09:24:32 -06:00
pc.selectedUUID = tarMsg.getTargetID();
2025-02-18 20:47:10 -06:00
2025-02-21 18:02:22 -06:00
if(pc.getObjectUUID() == tarMsg.getTargetID())
return; //dont trigger for targeting yourself
2025-02-18 20:47:10 -06:00
2025-02-11 07:49:19 -06:00
if (System.currentTimeMillis() > origin.finalStrikeRefresh) {
origin.lastStrike = System.currentTimeMillis();
origin.strikes = 0;
origin.finalStrikes = 0;
origin.finalStrikeRefresh = System.currentTimeMillis();
}
// Calculate time since last target switch
long timeSinceLastTarget = now - origin.lastTargetSwitchTime;
origin.lastTargetSwitchTime = now;
if (timeSinceLastTarget < 150) {
origin.strikes++;
origin.finalStrikeRefresh = System.currentTimeMillis() + 1000L;
}
if (origin.strikes > 20) {
origin.finalStrikes++;
}
2025-02-21 09:54:26 -06:00
if (origin.finalStrikes > 3) {
origin.forceDisconnect();
DbManager.AccountQueries.SET_TRASH(pc.getAccount().getUname(), "TABSPEED");
Logger.error("TAB SPEED DETECTED ON ACCOUNT: " + pc.getAccount().getUname());
2025-02-09 14:37:44 -06:00
}
2025-02-09 15:23:52 -06:00
} catch (Exception e) {
2025-02-09 14:08:17 -06:00
2025-02-09 14:47:08 -06:00
}
2025-02-09 14:08:17 -06:00
}
2025-02-09 14:37:44 -06:00
2022-04-30 09:41:17 -04:00
}