13
0

Merge branch 'master' into FixReplay

# Conflicts:
#	src/de/steamwar/spectatesystem/commands/ReplayCommand.java
Dieser Commit ist enthalten in:
yoyosource 2021-03-21 13:58:18 +01:00
Commit c9e1bb6a9e
13 geänderte Dateien mit 200 neuen und 114 gelöschten Zeilen

Datei anzeigen

@ -48,7 +48,7 @@ public class ConnectionAcceptor {
new FightserverConnection(socket.accept()); new FightserverConnection(socket.accept());
} }
} catch (IOException e) { } catch (IOException e) {
Bukkit.getLogger().log(Level.WARNING, "Stopping accepting connections", e); Bukkit.getLogger().log(Level.INFO, "Stopping accepting connections", e);
} }
} }
} }

Datei anzeigen

@ -20,6 +20,7 @@
package de.steamwar.spectatesystem; package de.steamwar.spectatesystem;
import com.sk89q.worldedit.EditSession; import com.sk89q.worldedit.EditSession;
import de.steamwar.spectatesystem.commands.InspectCommand;
import de.steamwar.spectatesystem.elements.*; import de.steamwar.spectatesystem.elements.*;
import de.steamwar.spectatesystem.util.BlockTextCreator; import de.steamwar.spectatesystem.util.BlockTextCreator;
import de.steamwar.spectatesystem.util.ColorConverter; import de.steamwar.spectatesystem.util.ColorConverter;
@ -43,6 +44,7 @@ import org.bukkit.scheduler.BukkitTask;
import java.io.EOFException; import java.io.EOFException;
import java.io.IOException; import java.io.IOException;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedList;
import java.util.Map; import java.util.Map;
import java.util.Objects; import java.util.Objects;
import java.util.logging.Level; import java.util.logging.Level;
@ -54,26 +56,53 @@ class PacketProcessor {
private final PacketSource source; private final PacketSource source;
private final BukkitTask task; private final BukkitTask task;
private final LinkedList<Runnable> syncList = new LinkedList<>();
public PacketProcessor(PacketSource source){ public PacketProcessor(PacketSource source){
this.source = source; this.source = source;
if(source.async()) if(source.async()) {
task = Bukkit.getScheduler().runTaskAsynchronously(SpectateSystem.get(), this::process); Bukkit.getScheduler().runTaskAsynchronously(SpectateSystem.get(), this::process);
else task = Bukkit.getScheduler().runTaskTimer(SpectateSystem.get(), this::runSync, 1, 1);
}else
task = Bukkit.getScheduler().runTaskTimer(SpectateSystem.get(), this::process, 1, 1); task = Bukkit.getScheduler().runTaskTimer(SpectateSystem.get(), this::process, 1, 1);
} }
private void playerJoins() throws IOException{ private void runSync() {
synchronized (syncList) {
for(Runnable runnable : syncList) {
try{
runnable.run();
}catch (Exception e) {
Bukkit.getLogger().log(Level.WARNING, "Failed to execute packet", e);
}
}
syncList.clear();
}
}
private void execSync(Runnable runnable){
if (!source.async()) {
runnable.run();
return;
}
synchronized (syncList) {
syncList.add(runnable);
}
}
private void playerJoins() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
int userId = source.rInt(); int userId = source.rInt();
SteamwarUser user = SteamwarUser.get(userId); SteamwarUser user = SteamwarUser.get(userId);
if(user == null) if(user == null)
throw new IOException("Unknown user " + userId); throw new IOException("Unknown user " + userId);
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> new RPlayer(user.getUUID(), user.getUserName(), entityId)); execSync(() -> new RPlayer(user.getUUID(), user.getUserName(), entityId));
} }
private void entityMoves() throws IOException{ private void entityMoves() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
double locX = source.rDouble(); double locX = source.rDouble();
double locY = source.rDouble(); double locY = source.rDouble();
@ -82,33 +111,33 @@ class PacketProcessor {
float yaw = source.rFloat(); float yaw = source.rFloat();
byte headYaw = source.rByte(); byte headYaw = source.rByte();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> REntity.getEntity(entityId).move(locX, locY, locZ, yaw, pitch, headYaw)); execSync(() -> REntity.getEntity(entityId).move(locX, locY, locZ, yaw, pitch, headYaw));
} }
private void entityDespawns() throws IOException{ private void entityDespawns() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> REntity.getEntity(entityId).remove()); execSync(() -> REntity.getEntity(entityId).remove());
} }
private void entitySneak() throws IOException { private void entitySneak() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
boolean sneaking = source.rBoolean(); boolean sneaking = source.rBoolean();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> REntity.getEntity(entityId).sneak(sneaking)); execSync(() -> REntity.getEntity(entityId).sneak(sneaking));
} }
private void entityAnimation() throws IOException { private void entityAnimation() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
byte animation = source.rByte(); byte animation = source.rByte();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> REntity.getEntity(entityId).animation(animation)); execSync(() -> REntity.getEntity(entityId).animation(animation));
} }
private void tntSpawn() throws IOException { private void tntSpawn() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
new RTnT(entityId); execSync(() -> new RTnT(entityId));
} }
private void entityVelocity() throws IOException { private void entityVelocity() throws IOException {
@ -118,7 +147,7 @@ class PacketProcessor {
double dY = source.rDouble(); double dY = source.rDouble();
double dZ = source.rDouble(); double dZ = source.rDouble();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> { execSync(() -> {
REntity entity = REntity.getEntity(entityId); REntity entity = REntity.getEntity(entityId);
if(entity != null) if(entity != null)
entity.setMotion(dX, dY, dZ); entity.setMotion(dX, dY, dZ);
@ -131,19 +160,19 @@ class PacketProcessor {
boolean enchanted = source.rBoolean(); boolean enchanted = source.rBoolean();
String slot = source.rString(); String slot = source.rString();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> ((RPlayer)REntity.getEntity(entityId)).setItem(item, enchanted, slot)); execSync(() -> ((RPlayer)REntity.getEntity(entityId)).setItem(item, enchanted, slot));
} }
private void arrowSpawn() throws IOException { private void arrowSpawn() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
new RArrow(entityId); execSync(() -> new RArrow(entityId));
} }
private void fireballSpawn() throws IOException { private void fireballSpawn() throws IOException {
int entityId = source.rInt(); int entityId = source.rInt();
new RFireball(entityId); execSync(() -> new RFireball(entityId));
} }
private void send(ChatMessageType type) throws IOException { private void send(ChatMessageType type) throws IOException {
@ -171,6 +200,23 @@ class PacketProcessor {
setBlock(x, y, z, blockState); setBlock(x, y, z, blockState);
} }
private void setBlock(int x, int y, int z, int blockState){
if(Config.ArenaMinX > x || Config.ArenaMaxX < x || Config.ArenaMinZ > z || Config.ArenaMaxZ < z)
return; //Outside of the arena
if (!InspectCommand.inspecting && Config.TechhiderActive && Config.HiddenBlocks.contains(blockState)) {
blockState = Config.ObfuscateWith;
}
IBlockData blockData = Objects.requireNonNull(Block.REGISTRY_ID.fromId(blockState));
execSync(() -> {
WorldServer cworld = ((CraftWorld)world).getHandle();
BlockPosition pos = new BlockPosition(x, y, z);
cworld.removeTileEntity(pos);
cworld.setTypeAndData(pos, blockData, 1042);
cworld.getChunkProvider().flagDirty(pos);
});
}
private void particle() throws IOException { private void particle() throws IOException {
double x = source.rDouble(); double x = source.rDouble();
double y = source.rDouble(); double y = source.rDouble();
@ -178,7 +224,7 @@ class PacketProcessor {
String particleName = source.rString(); String particleName = source.rString();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> world.spawnParticle(Particle.valueOf(particleName), x, y, z, 1)); execSync(() -> world.spawnParticle(Particle.valueOf(particleName), x, y, z, 1));
} }
private void sound() throws IOException { private void sound() throws IOException {
@ -195,7 +241,7 @@ class PacketProcessor {
Sound sound = Sound.valueOf(soundName); Sound sound = Sound.valueOf(soundName);
SoundCategory sCategory = SoundCategory.valueOf(soundCategory); SoundCategory sCategory = SoundCategory.valueOf(soundCategory);
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> world.playSound(new Location(world, x, y, z), sound, sCategory, volume, pitch)); execSync(() -> world.playSound(new Location(world, x, y, z), sound, sCategory, volume, pitch));
} }
private void soundAtPlayer() throws IOException { private void soundAtPlayer() throws IOException {
@ -206,21 +252,21 @@ class PacketProcessor {
Sound sound = Sound.valueOf(soundName); Sound sound = Sound.valueOf(soundName);
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> { execSync(() -> {
for(Player player : Bukkit.getOnlinePlayers()){ for(Player player : Bukkit.getOnlinePlayers()){
player.playSound(player.getLocation(), sound, volume, pitch); player.playSound(player.getLocation(), sound, volume, pitch);
} }
}); });
} }
private void pasteSchem(int cornerX, int cornerY, int cornerZ, boolean rotate, String prefix) throws IOException { private void pasteSchem(int pasteX, int cornerY, int pasteZ, int cornerX, int cornerZ, boolean rotate, String prefix) throws IOException {
int schemId = source.rInt(); int schemId = source.rInt();
Schematic schem = Schematic.getSchemFromDB(schemId); Schematic schem = Schematic.getSchemFromDB(schemId);
DyeColor c = ColorConverter.chat2dye(ChatColor.getByChar(ChatColor.getLastColors(prefix).replace("§", ""))); DyeColor c = ColorConverter.chat2dye(ChatColor.getByChar(ChatColor.getLastColors(prefix).replace("§", "")));
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> { execSync(() -> {
try { try {
EditSession e = Paster.pasteSchematic(schem, cornerX, cornerY, cornerZ, rotate); EditSession e = Paster.pasteSchematic(schem, pasteX, cornerY, pasteZ, rotate);
Paster.replaceTeamColor(e, c, cornerX, cornerY, cornerZ); Paster.replaceTeamColor(e, c, cornerX, cornerY, cornerZ);
} catch (NoClipboardException | IOException e) { } catch (NoClipboardException | IOException e) {
throw new SecurityException("Could not load Clipboard", e); throw new SecurityException("Could not load Clipboard", e);
@ -232,7 +278,7 @@ class PacketProcessor {
int blueId = source.rInt(); int blueId = source.rInt();
int redId = source.rInt(); int redId = source.rInt();
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> BlockTextCreator.pasteTeamNames(blueId, redId)); execSync(() -> BlockTextCreator.pasteTeamNames(blueId, redId));
} }
private void scoreboardTitle() throws IOException { private void scoreboardTitle() throws IOException {
@ -248,23 +294,6 @@ class PacketProcessor {
SpectateSystem.getScoreboard().addValue(key, value); SpectateSystem.getScoreboard().addValue(key, value);
} }
private void setBlock(int x, int y, int z, int blockState){
if(Config.ArenaMinX > x || Config.ArenaMaxX < x || Config.ArenaMinZ > z || Config.ArenaMaxZ < z)
return; //Outside of the arena
if (Config.TechhiderActive && Config.HiddenBlocks.contains(blockState)) {
blockState = Config.ObfuscateWith;
}
IBlockData blockData = Objects.requireNonNull(Block.REGISTRY_ID.fromId(blockState));
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> {
WorldServer cworld = ((CraftWorld)world).getHandle();
BlockPosition pos = new BlockPosition(x, y, z);
cworld.removeTileEntity(pos);
cworld.setTypeAndData(pos, blockData, 1042);
cworld.getChunkProvider().flagDirty(pos);
});
}
private void endSpectating(){ private void endSpectating(){
WorldLoader.reloadWorld(); WorldLoader.reloadWorld();
SpectateSystem.getScoreboard().setTitle("§eKein Kampf"); SpectateSystem.getScoreboard().setTitle("§eKein Kampf");
@ -339,10 +368,10 @@ class PacketProcessor {
send(ChatMessageType.SYSTEM); send(ChatMessageType.SYSTEM);
break; break;
case (byte) 0xB0: case (byte) 0xB0:
pasteSchem(Config.TeamBluePasteX, Config.TeamBlueCornerY, Config.TeamBluePasteZ, Config.TeamBlueRotate, Config.TeamBluePrefix); pasteSchem(Config.TeamBluePasteX, Config.TeamBlueCornerY, Config.TeamBluePasteZ, Config.TeamBlueCornerX, Config.TeamBlueCornerZ, Config.TeamBlueRotate, Config.TeamBluePrefix);
break; break;
case (byte) 0xB1: case (byte) 0xB1:
pasteSchem(Config.TeamRedPasteX, Config.TeamRedCornerY, Config.TeamRedPasteZ, Config.TeamRedRotate, Config.TeamRedPrefix); pasteSchem(Config.TeamRedPasteX, Config.TeamRedCornerY, Config.TeamRedPasteZ, Config.TeamRedCornerX, Config.TeamRedCornerZ, Config.TeamRedRotate, Config.TeamRedPrefix);
break; break;
case (byte) 0xB2: case (byte) 0xB2:
teams(); teams();
@ -376,8 +405,7 @@ class PacketProcessor {
} }
if(source.isClosed()){ if(source.isClosed()){
endSpectating(); Bukkit.getScheduler().runTask(SpectateSystem.get(), this::endSpectating);
if(!source.async())
task.cancel(); task.cancel();
} }
} }

Datei anzeigen

@ -26,6 +26,7 @@ import com.comphenix.protocol.wrappers.EnumWrappers;
import com.comphenix.protocol.wrappers.PlayerInfoData; import com.comphenix.protocol.wrappers.PlayerInfoData;
import com.comphenix.protocol.wrappers.WrappedChatComponent; import com.comphenix.protocol.wrappers.WrappedChatComponent;
import com.comphenix.protocol.wrappers.WrappedGameProfile; import com.comphenix.protocol.wrappers.WrappedGameProfile;
import de.steamwar.spectatesystem.commands.InspectCommand;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.GameMode; import org.bukkit.GameMode;
import org.bukkit.Location; import org.bukkit.Location;
@ -102,6 +103,9 @@ public class PlayerSetup {
} }
} }
Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> { Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> {
if(InspectCommand.inspecting)
return;
PacketContainer gm1packet = ProtocolLibrary.getProtocolManager().createPacket(PacketType.Play.Server.PLAYER_INFO); PacketContainer gm1packet = ProtocolLibrary.getProtocolManager().createPacket(PacketType.Play.Server.PLAYER_INFO);
gm1packet.getPlayerInfoAction().write(0, EnumWrappers.PlayerInfoAction.UPDATE_GAME_MODE); gm1packet.getPlayerInfoAction().write(0, EnumWrappers.PlayerInfoAction.UPDATE_GAME_MODE);
List<PlayerInfoData> playerInfoActions = new ArrayList<>(); List<PlayerInfoData> playerInfoActions = new ArrayList<>();

Datei anzeigen

@ -19,6 +19,7 @@
package de.steamwar.spectatesystem; package de.steamwar.spectatesystem;
import de.steamwar.spectatesystem.commands.InspectCommand;
import de.steamwar.spectatesystem.commands.ReplayCommand; import de.steamwar.spectatesystem.commands.ReplayCommand;
import de.steamwar.spectatesystem.elements.RScoreboard; import de.steamwar.spectatesystem.elements.RScoreboard;
import de.steamwar.spectatesystem.listener.PlayerListener; import de.steamwar.spectatesystem.listener.PlayerListener;
@ -26,14 +27,19 @@ import de.steamwar.spectatesystem.listener.CancelListener;
import de.steamwar.spectatesystem.listener.JoinListener; import de.steamwar.spectatesystem.listener.JoinListener;
import de.steamwar.spectatesystem.listener.PlayerSeatListener; import de.steamwar.spectatesystem.listener.PlayerSeatListener;
import de.steamwar.spectatesystem.util.WorldLoader; import de.steamwar.spectatesystem.util.WorldLoader;
import de.steamwar.sql.UserGroup;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import java.io.IOException; import java.io.IOException;
import java.util.EnumSet;
import java.util.Set;
import java.util.logging.Level; import java.util.logging.Level;
public class SpectateSystem extends JavaPlugin { public class SpectateSystem extends JavaPlugin {
public static final Set<UserGroup> allowedGroups = EnumSet.of(UserGroup.Admin, UserGroup.Developer, UserGroup.Moderator);
private static SpectateSystem instance; private static SpectateSystem instance;
private static RScoreboard scoreboard; private static RScoreboard scoreboard;
private ConnectionAcceptor acceptor; private ConnectionAcceptor acceptor;
@ -53,6 +59,7 @@ public class SpectateSystem extends JavaPlugin {
} }
Bukkit.getPluginCommand("replay").setExecutor(new ReplayCommand()); Bukkit.getPluginCommand("replay").setExecutor(new ReplayCommand());
Bukkit.getPluginCommand("inspect").setExecutor(new InspectCommand());
WorldLoader.configureForceLoad(); WorldLoader.configureForceLoad();
} }

Datei anzeigen

@ -0,0 +1,29 @@
package de.steamwar.spectatesystem.commands;
import de.steamwar.spectatesystem.SpectateSystem;
import de.steamwar.sql.SteamwarUser;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
public class InspectCommand implements CommandExecutor {
public static boolean inspecting = false;
@Override
public boolean onCommand(CommandSender sender, Command command, String alias, String[] args) {
if(sender instanceof Player){
Player player = (Player) sender;
SteamwarUser user = SteamwarUser.get(player.getUniqueId());
if(!SpectateSystem.allowedGroups.contains(user.getUserGroup())){
player.sendMessage("§eSteam§8War» §cUnbekannter Befehl.");
return false;
}
}
inspecting = !inspecting;
sender.sendMessage("Inspection: " + inspecting);
return false;
}
}

Datei anzeigen

@ -20,8 +20,8 @@
package de.steamwar.spectatesystem.commands; package de.steamwar.spectatesystem.commands;
import de.steamwar.spectatesystem.FightfileConnection; import de.steamwar.spectatesystem.FightfileConnection;
import de.steamwar.spectatesystem.SpectateSystem;
import de.steamwar.sql.SteamwarUser; import de.steamwar.sql.SteamwarUser;
import de.steamwar.sql.UserGroup;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
@ -29,44 +29,29 @@ import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import java.io.File; import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.util.EnumSet;
import java.util.Set;
import java.util.logging.Level; import java.util.logging.Level;
public class ReplayCommand implements CommandExecutor { public class ReplayCommand implements CommandExecutor {
private static final Set<UserGroup> allowedGroups = EnumSet.of(UserGroup.Admin, UserGroup.Developer, UserGroup.Moderator);
private static FightfileConnection fightfileConnection;
@Override @Override
public boolean onCommand(CommandSender sender, Command command, String alias, String[] args) { public boolean onCommand(CommandSender sender, Command command, String alias, String[] args) {
if(sender instanceof Player){ if(sender instanceof Player){
Player player = (Player) sender; Player player = (Player) sender;
SteamwarUser user = SteamwarUser.get(player.getUniqueId()); SteamwarUser user = SteamwarUser.get(player.getUniqueId());
if(!allowedGroups.contains(user.getUserGroup())){ if(!SpectateSystem.allowedGroups.contains(user.getUserGroup())){
player.sendMessage("§eSteam§8War» §cUnbekannter Befehl."); player.sendMessage("§eSteam§8War» §cUnbekannter Befehl.");
return false; return false;
} }
} }
if (fightfileConnection != null && fightfileConnection.isClosed()) {
sender.sendMessage("§eSteam§8War» §cBitte warte bis kein Replay gezeigt wird.");
return false;
}
if(args.length != 1){ if(args.length != 1){
sender.sendMessage("§eSteam§8War» §c/replay [Dateipfad]"); sender.sendMessage("§eSteam§8War» §c/replay [Dateipfad]");
return false; return false;
} }
try { try {
fightfileConnection = new FightfileConnection(new File(args[0] + (args[0].endsWith(".recording") ? "" : ".recording"))); new FightfileConnection(new File(args[0] + ".recording"));
} catch (FileNotFoundException e) {
Bukkit.getLogger().log(Level.WARNING, "Could not start reading file", e);
sender.sendMessage("§eSteam§8War» §cReplay konnte nicht gefunden werden.");
return false;
} catch (IOException e) { } catch (IOException e) {
Bukkit.getLogger().log(Level.WARNING, "Could not start reading file", e); Bukkit.getLogger().log(Level.WARNING, "Could not start reading file", e);
sender.sendMessage("§eSteam§8War» §cReplay konnte nicht gestartet werden."); sender.sendMessage("§eSteam§8War» §cReplay konnte nicht gestartet werden.");

Datei anzeigen

@ -41,7 +41,9 @@ public abstract class REntity {
protected REntity(int internalId, Entity entity){ protected REntity(int internalId, Entity entity){
this.internalId = internalId; this.internalId = internalId;
this.entity = entity; this.entity = entity;
synchronized(entities){
entities.put(internalId, this); entities.put(internalId, this);
}
for(Player player : Bukkit.getOnlinePlayers()){ for(Player player : Bukkit.getOnlinePlayers()){
sendToPlayer(player); sendToPlayer(player);
@ -49,17 +51,15 @@ public abstract class REntity {
} }
public static void playerJoins(Player player){ public static void playerJoins(Player player){
synchronized(entities){
for(REntity entity : entities.values()){ for(REntity entity : entities.values()){
entity.sendToPlayer(player); entity.sendToPlayer(player);
entity.sendLocation(player); entity.sendLocation(player);
} }
} }
}
protected static EntityLiving getShooter(){ protected static EntityLiving getShooter(){
for(REntity entity : entities.values()){
if(entity.entity instanceof EntityLiving)
return (EntityLiving) entity.entity;
}
return ((CraftPlayer)Bukkit.getOnlinePlayers().iterator().next()).getHandle(); return ((CraftPlayer)Bukkit.getOnlinePlayers().iterator().next()).getHandle();
} }
@ -69,11 +69,13 @@ public abstract class REntity {
public static void removeAll(){ public static void removeAll(){
int entity_counter = 0; int entity_counter = 0;
synchronized (entities){
while(!entities.isEmpty()){ while(!entities.isEmpty()){
entity_counter++; entity_counter++;
REntity entity = entities.values().iterator().next(); REntity entity = entities.values().iterator().next();
entity.remove(); entity.remove();
} }
}
System.out.println("Has to remove manually " + entity_counter + " entities!"); System.out.println("Has to remove manually " + entity_counter + " entities!");
} }
@ -96,8 +98,10 @@ public abstract class REntity {
connection.sendPacket(packet); connection.sendPacket(packet);
} }
Bukkit.getScheduler().runTask(SpectateSystem.get(), entity::die); Bukkit.getScheduler().runTask(SpectateSystem.get(), entity::die);
synchronized (entities){
entities.remove(internalId); entities.remove(internalId);
} }
}
public void sneak(boolean sneaking) { public void sneak(boolean sneaking) {
entity.setSneaking(sneaking); entity.setSneaking(sneaking);

Datei anzeigen

@ -23,18 +23,36 @@ import de.steamwar.scoreboard.SWScoreboard;
import de.steamwar.spectatesystem.Config; import de.steamwar.spectatesystem.Config;
import de.steamwar.spectatesystem.PlayerSetup; import de.steamwar.spectatesystem.PlayerSetup;
import de.steamwar.spectatesystem.SpectateSystem; import de.steamwar.spectatesystem.SpectateSystem;
import de.steamwar.spectatesystem.commands.InspectCommand;
import de.steamwar.spectatesystem.elements.REntity; import de.steamwar.spectatesystem.elements.REntity;
import de.steamwar.sql.SteamwarUser;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.event.player.PlayerJoinEvent;
import org.bukkit.event.player.PlayerLoginEvent;
import org.bukkit.event.player.PlayerQuitEvent; import org.bukkit.event.player.PlayerQuitEvent;
import org.bukkit.event.player.PlayerResourcePackStatusEvent;
public class JoinListener extends BasicListener { public class JoinListener extends BasicListener {
@EventHandler
public void onLogin(PlayerLoginEvent e){
Player player = e.getPlayer();
if(InspectCommand.inspecting){
SteamwarUser user = SteamwarUser.get(player.getUniqueId());
if(!SpectateSystem.allowedGroups.contains(user.getUserGroup())){
e.disallow(PlayerLoginEvent.Result.KICK_WHITELIST, "§eSteam§8War» §cDerzeit ist das Zuschauen nicht gestattet.");
}
}
}
@EventHandler @EventHandler
public void onJoin(PlayerJoinEvent e){ public void onJoin(PlayerJoinEvent e){
e.setJoinMessage(null); e.setJoinMessage(null);
Player player = e.getPlayer(); Player player = e.getPlayer();
player.setResourcePack("https://steamwar.de/antixray.zip");
player.teleport(Config.SpecSpawn); player.teleport(Config.SpecSpawn);
REntity.playerJoins(player); REntity.playerJoins(player);
PlayerSetup.playerJoins(player); PlayerSetup.playerJoins(player);
@ -49,4 +67,14 @@ public class JoinListener extends BasicListener {
PlayerSetup.playerLeaves(e.getPlayer()); PlayerSetup.playerLeaves(e.getPlayer());
e.setQuitMessage(null); e.setQuitMessage(null);
} }
@EventHandler
public void onResourcepack(PlayerResourcePackStatusEvent e){
if(e.getStatus() == PlayerResourcePackStatusEvent.Status.ACCEPTED || e.getStatus() == PlayerResourcePackStatusEvent.Status.SUCCESSFULLY_LOADED)
return;
Player player = e.getPlayer();
player.sendMessage("§eSteam§8War» §cAuf Eventserver kann nur mit dem SteamWar-Resourcepack beigetreten werden");
player.kickPlayer(null);
}
} }

Datei anzeigen

@ -22,6 +22,7 @@ package de.steamwar.spectatesystem.listener;
import de.steamwar.spectatesystem.Config; import de.steamwar.spectatesystem.Config;
import de.steamwar.spectatesystem.PlayerSetup; import de.steamwar.spectatesystem.PlayerSetup;
import de.steamwar.spectatesystem.SpectateSystem; import de.steamwar.spectatesystem.SpectateSystem;
import de.steamwar.spectatesystem.commands.InspectCommand;
import de.steamwar.spectatesystem.util.Region; import de.steamwar.spectatesystem.util.Region;
import net.md_5.bungee.api.ChatMessageType; import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.BaseComponent; import net.md_5.bungee.api.chat.BaseComponent;
@ -53,6 +54,9 @@ public class PlayerListener extends BasicListener {
} }
private void checkMovementInArena(PlayerMoveEvent event, Location to){ private void checkMovementInArena(PlayerMoveEvent event, Location to){
if(InspectCommand.inspecting)
return;
boolean inArenaY = to.getY() + 1.8 <= Config.upperArenaBorder; boolean inArenaY = to.getY() + 1.8 <= Config.upperArenaBorder;
boolean inBlueArea = inArenaY && Region.isIn2DRange(to, Config.TeamBlueCornerX, Config.TeamBlueCornerZ, Config.SchemsizeX, Config.SchemsizeZ, Config.BorderFromSchematic); boolean inBlueArea = inArenaY && Region.isIn2DRange(to, Config.TeamBlueCornerX, Config.TeamBlueCornerZ, Config.SchemsizeX, Config.SchemsizeZ, Config.BorderFromSchematic);
boolean inRedArea = inArenaY && Region.isIn2DRange(to, Config.TeamRedCornerX, Config.TeamRedCornerZ, Config.SchemsizeX, Config.SchemsizeZ, Config.BorderFromSchematic); boolean inRedArea = inArenaY && Region.isIn2DRange(to, Config.TeamRedCornerX, Config.TeamRedCornerZ, Config.SchemsizeX, Config.SchemsizeZ, Config.BorderFromSchematic);

Datei anzeigen

@ -20,6 +20,8 @@
package de.steamwar.spectatesystem.listener; package de.steamwar.spectatesystem.listener;
import org.bukkit.GameMode; import org.bukkit.GameMode;
import org.bukkit.Location;
import org.bukkit.Material;
import org.bukkit.block.data.Bisected; import org.bukkit.block.data.Bisected;
import org.bukkit.block.data.type.Stairs; import org.bukkit.block.data.type.Stairs;
import org.bukkit.entity.AbstractArrow; import org.bukkit.entity.AbstractArrow;
@ -49,6 +51,9 @@ public class PlayerSeatListener extends BasicListener {
if(event.getPlayer().isInsideVehicle()) if(event.getPlayer().isInsideVehicle())
event.getPlayer().getVehicle().remove(); event.getPlayer().getVehicle().remove();
if (event.getClickedBlock().getRelative(0, 1, 0).getType() != Material.AIR)
return;
Arrow arrow = (Arrow) event.getPlayer().getWorld().spawnEntity(event.getClickedBlock().getLocation().add(0.5, 0, 0.5), EntityType.ARROW); Arrow arrow = (Arrow) event.getPlayer().getWorld().spawnEntity(event.getClickedBlock().getLocation().add(0.5, 0, 0.5), EntityType.ARROW);
arrow.setGravity(false); arrow.setGravity(false);
arrow.setPickupStatus(AbstractArrow.PickupStatus.DISALLOWED); arrow.setPickupStatus(AbstractArrow.PickupStatus.DISALLOWED);

Datei anzeigen

@ -35,6 +35,7 @@ import com.sk89q.worldedit.world.World;
import com.sk89q.worldedit.world.block.BaseBlock; import com.sk89q.worldedit.world.block.BaseBlock;
import com.sk89q.worldedit.world.block.BlockTypes; import com.sk89q.worldedit.world.block.BlockTypes;
import de.steamwar.spectatesystem.Config; import de.steamwar.spectatesystem.Config;
import de.steamwar.spectatesystem.commands.InspectCommand;
import de.steamwar.sql.NoClipboardException; import de.steamwar.sql.NoClipboardException;
import de.steamwar.sql.Schematic; import de.steamwar.sql.Schematic;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
@ -90,7 +91,7 @@ public class Paster {
for(int y = 0; y < clipboard.getDimensions().getY(); y++){ for(int y = 0; y < clipboard.getDimensions().getY(); y++){
for(int z = 0; z < clipboard.getDimensions().getZ(); z++){ for(int z = 0; z < clipboard.getDimensions().getZ(); z++){
BlockVector3 blockPos = minimum.add(x, y, z); BlockVector3 blockPos = minimum.add(x, y, z);
if(Config.HiddenBlockTags.contains(BukkitAdapter.adapt(clipboard.getFullBlock(blockPos).getBlockType()).name())){ if(!InspectCommand.inspecting && Config.HiddenBlockTags.contains(BukkitAdapter.adapt(clipboard.getFullBlock(blockPos).getBlockType()).name())){
try { try {
clipboard.setBlock(blockPos, obfuscateWith); clipboard.setBlock(blockPos, obfuscateWith);
} catch (WorldEditException e) { } catch (WorldEditException e) {

Datei anzeigen

@ -19,18 +19,19 @@
package de.steamwar.spectatesystem.util; package de.steamwar.spectatesystem.util;
import de.steamwar.core.events.ChunkListener;
import de.steamwar.spectatesystem.Config; import de.steamwar.spectatesystem.Config;
import de.steamwar.spectatesystem.SpectateSystem; import de.steamwar.spectatesystem.SpectateSystem;
import de.steamwar.spectatesystem.elements.REntity; import de.steamwar.spectatesystem.elements.REntity;
import net.minecraft.server.v1_15_R1.BlockPosition; import net.minecraft.server.v1_15_R1.BlockPosition;
import net.minecraft.server.v1_15_R1.Blocks; import net.minecraft.server.v1_15_R1.Blocks;
import net.minecraft.server.v1_15_R1.IBlockData; import net.minecraft.server.v1_15_R1.Chunk;
import net.minecraft.server.v1_15_R1.WorldServer; import net.minecraft.server.v1_15_R1.WorldServer;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.WorldCreator; import org.bukkit.WorldCreator;
import org.bukkit.craftbukkit.v1_15_R1.CraftChunk;
import org.bukkit.craftbukkit.v1_15_R1.CraftWorld; import org.bukkit.craftbukkit.v1_15_R1.CraftWorld;
import org.bukkit.entity.Player;
public class WorldLoader { public class WorldLoader {
private WorldLoader(){} private WorldLoader(){}
@ -48,25 +49,21 @@ public class WorldLoader {
world.setKeepSpawnInMemory(true); world.setKeepSpawnInMemory(true);
} }
public static void reloadWorld(){ public static void reloadWorld() {
Bukkit.getScheduler().runTask(SpectateSystem.get(), () -> {
REntity.removeAll(); REntity.removeAll();
World backupWorld = new WorldCreator(world.getName() + "-backup").createWorld(); World backupWorld = new WorldCreator(world.getName() + "-backup").createWorld();
int delay = 1; fillTeamArea(Config.TeamBlueCornerX, Config.TeamBlueCornerY, Config.TeamBlueCornerZ, Config.SchemsizeX, Config.SchemsizeY, Config.SchemsizeZ);
Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> fillTeamArea(Config.TeamBlueCornerX, Config.TeamBlueCornerY, Config.TeamBlueCornerZ, Config.SchemsizeX, Config.SchemsizeY, Config.SchemsizeZ), delay++); fillTeamArea(Config.TeamRedCornerX, Config.TeamRedCornerY, Config.TeamRedCornerZ, Config.SchemsizeX, Config.SchemsizeY, Config.SchemsizeZ);
Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> fillTeamArea(Config.TeamRedCornerX, Config.TeamRedCornerY, Config.TeamRedCornerZ, Config.SchemsizeX, Config.SchemsizeY, Config.SchemsizeZ), delay++);
for(int cX = (int) Math.floor(Config.ArenaMinX / 16.0); cX <= (int) Math.floor(Config.ArenaMaxX / 16.0); cX++){ Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> {
for(int cZ = (int) Math.floor(Config.ArenaMinZ / 16.0); cZ <= (int) Math.floor(Config.ArenaMaxZ / 16.0); cZ++){ for(int cZ = (int) Math.floor(Config.ArenaMinZ / 16.0); cZ <= (int) Math.floor(Config.ArenaMaxZ / 16.0); cZ++){
int finalCX = cX; for(int cX = (int) Math.floor(Config.ArenaMinX / 16.0); cX <= (int) Math.floor(Config.ArenaMaxX / 16.0); cX++){
int finalCZ = cZ; reloadChunk(backupWorld, cX, cZ);
Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> reloadChunk(backupWorld, finalCX, finalCZ), delay++);
} }
} }
Bukkit.unloadWorld(world.getName() + "-backup", false);
Bukkit.getScheduler().runTaskLater(SpectateSystem.get(), () -> Bukkit.unloadWorld(world.getName() + "-backup", false), delay); }, 80);
});
} }
public static void fillTeamArea(int teamX, int teamY, int teamZ, int sizeX, int sizeY, int sizeZ){ public static void fillTeamArea(int teamX, int teamY, int teamZ, int sizeX, int sizeY, int sizeZ){
@ -83,24 +80,17 @@ public class WorldLoader {
} }
} }
public static void reloadChunk(World backupWorld, int cX, int cZ){ public static void reloadChunk(World backup, int x, int z){
WorldServer cworld = ((CraftWorld)world).getHandle(); Chunk chunk = ((CraftWorld) world).getHandle().getChunkAt(x, z);
WorldServer backup = ((CraftWorld) backupWorld).getHandle(); Chunk backupChunk = ((CraftWorld) backup).getHandle().getChunkAt(x, z);
net.minecraft.server.v1_15_R1.Chunk cchunk = ((CraftChunk) world.getChunkAt(cX, cZ)).getHandle(); System.arraycopy(backupChunk.getSections(), 0, chunk.getSections(), 0, chunk.getSections().length);
for(int y = 255; y >= 0; y--){ // y top down to reduce lightning calculations chunk.tileEntities.clear();
for(int x = cX * 16; x < (cX + 1) * 16; x++){ chunk.tileEntities.putAll(backupChunk.tileEntities);
for(int z = cZ * 16; z < (cZ + 1) * 16; z++){ chunk.heightMap.clear();
BlockPosition blockPos = new BlockPosition(x, y, z); chunk.heightMap.putAll(backupChunk.heightMap);
IBlockData backupBlock = backup.getType(blockPos); for(Player p : Bukkit.getOnlinePlayers()){
if(backupBlock == cworld.getType(blockPos)) ChunkListener.sendChunk(p, x, z);
continue;
cchunk.removeTileEntity(blockPos);
cworld.setTypeAndData(blockPos, backupBlock, 1042);
cworld.getChunkProvider().flagDirty(blockPos);
}
}
} }
} }
} }

Datei anzeigen

@ -5,9 +5,10 @@ version: "1.0"
api-version: "1.13" api-version: "1.13"
main: de.steamwar.spectatesystem.SpectateSystem main: de.steamwar.spectatesystem.SpectateSystem
load: POSTWORLD load: POSTWORLD
depends: depend:
- SpigotCore - SpigotCore
- WorldEdit - WorldEdit
- ProtocolLib - ProtocolLib
commands: commands:
replay: replay:
inspect: