package com.aionemu.gameserver.network;
import java.sql.Timestamp;
import java.util.HashMap;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.aionemu.gameserver.network.loginserver.LoginServer;
import com.aionemu.gameserver.network.loginserver.serverpackets.SM_MACBAN_CONTROL;
/**
* @author KID
*/
public class BannedMacManager {
private static BannedMacManager manager = new BannedMacManager();
private final Logger log = LoggerFactory.getLogger(BannedMacManager.class);
private final Map<String, BannedMacEntry> bannedList = new HashMap<>();
public static BannedMacManager getInstance() {
return manager;
}
public final void banAddress(String address, long newTime, String details) {
BannedMacEntry entry;
if (bannedList.containsKey(address)) {
if (bannedList.get(address).isActiveTill(newTime)) {
return;
} else {
entry = bannedList.get(address);
entry.updateTime(newTime);
}
} else
entry = new BannedMacEntry(address, newTime);
entry.setDetails(details);
bannedList.put(address, entry);
log.info("banned " + address + " to " + entry.getTime().toString() + " for " + details);
LoginServer.getInstance().sendPacket(new SM_MACBAN_CONTROL((byte) 1, address, newTime, details));
}
public final boolean unbanAddress(String address, String details) {
BannedMacEntry bannedMacEntry = bannedList.remove(address);
if (bannedMacEntry != null) {
log.info("unbanned " + address + " for " + details);
LoginServer.getInstance().sendPacket(new SM_MACBAN_CONTROL((byte) 0, address, 0, details));
return true;
} else
return false;
}
public final boolean isBanned(String address) {
BannedMacEntry bannedMacEntry = bannedList.get(address);
return bannedMacEntry != null && bannedMacEntry.isActive();
}
public final void dbLoad(String address, long time, String details) {
bannedList.put(address, new BannedMacEntry(address, new Timestamp(time), details));
}
public void onEnd() {
log.info("Loaded " + bannedList.size() + " banned mac addresses");
}
}