Quick adaptions/cleanups for packet level checking.

This commit is contained in:
asofold 2014-07-15 23:57:53 +02:00
parent cdf79c854f
commit bb8b8fc1f2
3 changed files with 47 additions and 34 deletions

View File

@ -26,6 +26,7 @@ import fr.neatmonster.nocheatplus.utilities.ActionFrequency;
*/ */
public class MoveFrequency extends PacketAdapter implements Listener, JoinLeaveListener { public class MoveFrequency extends PacketAdapter implements Listener, JoinLeaveListener {
// TODO: Configuration.
// TODO: Optimized options (receive only, other?). // TODO: Optimized options (receive only, other?).
// TODO: Async version ? // TODO: Async version ?
@ -69,8 +70,8 @@ public class MoveFrequency extends PacketAdapter implements Listener, JoinLeaveL
removeName(player.getName()); removeName(player.getName());
} }
private ActionFrequency getFreq(String name) { private ActionFrequency getFreq(final String name) {
ActionFrequency freq = this.freqMap.get(name); final ActionFrequency freq = this.freqMap.get(name);
if (freq == null) { if (freq == null) {
return addName(name); return addName(name);
} else { } else {
@ -79,9 +80,9 @@ public class MoveFrequency extends PacketAdapter implements Listener, JoinLeaveL
} }
@Override @Override
public void onPacketReceiving(PacketEvent event) { public void onPacketReceiving(final PacketEvent event) {
// TODO: Add several (at least has look + has pos individually, maybe none/onground) // TODO: Add several (at least has look + has pos individually, maybe none/onground)
ActionFrequency freq = getFreq(event.getPlayer().getName()); final ActionFrequency freq = getFreq(event.getPlayer().getName());
freq.add(System.currentTimeMillis(), 1f); freq.add(System.currentTimeMillis(), 1f);
if (freq.score(1f) > 300) { if (freq.score(1f) > 300) {
event.setCancelled(true); event.setCancelled(true);

View File

@ -1,5 +1,6 @@
package fr.neatmonster.nocheatplus.net.protocollib; package fr.neatmonster.nocheatplus.net.protocollib;
import java.util.Arrays;
import java.util.LinkedList; import java.util.LinkedList;
import java.util.List; import java.util.List;
@ -25,18 +26,23 @@ public class ProtocolLibComponent implements DisableListener{
// Register with ProtocolLib // Register with ProtocolLib
final ProtocolManager protocolManager = ProtocolLibrary.getProtocolManager(); final ProtocolManager protocolManager = ProtocolLibrary.getProtocolManager();
LogUtil.logInfo("[NoCheatPlus] ProtocolLib seems to be available."); LogUtil.logInfo("[NoCheatPlus] ProtocolLib seems to be available.");
// Classes having a constructor with Plugin as argument.
List<Class<? extends PacketAdapter>> adapterClasses = Arrays.asList(
MoveFrequency.class,
WeatherDistance.class
);
for (Class<? extends PacketAdapter> clazz : adapterClasses) {
try { try {
PacketAdapter adapter = new MoveFrequency(plugin); // Construct a new instance using reflection.
PacketAdapter weatherAdapter = new WeatherDistance(plugin); PacketAdapter adapter = clazz.getDeclaredConstructor(Plugin.class).newInstance(plugin);
protocolManager.addPacketListener(adapter); protocolManager.addPacketListener(adapter);
protocolManager.addPacketListener(weatherAdapter);
registeredPacketAdapters.add(adapter); registeredPacketAdapters.add(adapter);
} catch (Throwable t) { } catch (Throwable t) {
LogUtil.logWarning("[NoCheatPlus] Could not register some packet-level hook."); LogUtil.logWarning("[NoCheatPlus] Could not register packet level hook: " + clazz.getSimpleName());
LogUtil.logWarning(t); // TODO: Maybe temporary. LogUtil.logWarning(t); // TODO: Maybe temporary.
} }
} }
}
@Override @Override
public void onDisable() { public void onDisable() {

View File

@ -1,37 +1,43 @@
package fr.neatmonster.nocheatplus.net.protocollib; package fr.neatmonster.nocheatplus.net.protocollib;
import org.bukkit.Location;
import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin;
import com.comphenix.protocol.PacketType; import com.comphenix.protocol.PacketType;
import com.comphenix.protocol.events.PacketAdapter; import com.comphenix.protocol.events.PacketAdapter;
import com.comphenix.protocol.events.PacketContainer; import com.comphenix.protocol.events.PacketContainer;
import com.comphenix.protocol.events.PacketEvent; import com.comphenix.protocol.events.PacketEvent;
import org.bukkit.Location; import com.comphenix.protocol.reflect.StructureModifier;
import org.bukkit.entity.Player;
import org.bukkit.plugin.Plugin; import fr.neatmonster.nocheatplus.utilities.TrigUtil;
public class WeatherDistance extends PacketAdapter { public class WeatherDistance extends PacketAdapter {
/** Maximum distance for thunder effects (squared). */
private static final double distSq = 512.0 * 512.0; // TODO: Maybe configurable.
public WeatherDistance(Plugin plugin) { public WeatherDistance(Plugin plugin) {
super(plugin, PacketType.Play.Server.NAMED_SOUND_EFFECT); super(plugin, PacketType.Play.Server.NAMED_SOUND_EFFECT);
} }
@Override @Override
public void onPacketSending(PacketEvent event) { public void onPacketSending(final PacketEvent event) {
PacketContainer packetContainer = event.getPacket(); final PacketContainer packetContainer = event.getPacket();
Player player = event.getPlayer(); final Player player = event.getPlayer();
String soundEffect = packetContainer.getStrings().read(0); // Compare sound effect name.
if (!packetContainer.getStrings().read(0).equals("ambient.weather.thunder")) {
if (!soundEffect.equals("ambient.weather.thunder"))
return; return;
}
double locX = packetContainer.getIntegers().read(0) / 8; final Location loc = player.getLocation(); // TODO: Use getLocation(useLoc) [synced if async].
double locY = packetContainer.getIntegers().read(1) / 8;
double locZ = packetContainer.getIntegers().read(2) / 8;
Location weatherLocation = new Location(player.getWorld(), locX, locY, locZ); // Compare distance of player to the weather location.
final StructureModifier<Integer> ints = packetContainer.getIntegers();
if (player.getLocation().distance(weatherLocation) > 512.0F) { if (TrigUtil.distanceSquared(ints.read(0) / 8, ints.read(1) / 8, ints.read(2) / 8, loc.getX(), loc.getY(), loc.getZ()) > distSq) {
event.setCancelled(true); event.setCancelled(true);
} }
} }
} }