TpsLimit #15
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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,9 +405,8 @@ class PacketProcessor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(source.isClosed()){
|
if(source.isClosed()){
|
||||||
endSpectating();
|
Bukkit.getScheduler().runTask(SpectateSystem.get(), this::endSpectating);
|
||||||
if(!source.async())
|
task.cancel();
|
||||||
task.cancel();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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<>();
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
29
src/de/steamwar/spectatesystem/commands/InspectCommand.java
Normale Datei
29
src/de/steamwar/spectatesystem/commands/InspectCommand.java
Normale Datei
@ -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;
|
||||||
|
}
|
||||||
|
}
|
@ -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.");
|
||||||
|
@ -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;
|
||||||
entities.put(internalId, this);
|
synchronized(entities){
|
||||||
|
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){
|
||||||
for(REntity entity : entities.values()){
|
synchronized(entities){
|
||||||
entity.sendToPlayer(player);
|
for(REntity entity : entities.values()){
|
||||||
entity.sendLocation(player);
|
entity.sendToPlayer(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,10 +69,12 @@ public abstract class REntity {
|
|||||||
|
|
||||||
public static void removeAll(){
|
public static void removeAll(){
|
||||||
int entity_counter = 0;
|
int entity_counter = 0;
|
||||||
while(!entities.isEmpty()){
|
synchronized (entities){
|
||||||
entity_counter++;
|
while(!entities.isEmpty()){
|
||||||
REntity entity = entities.values().iterator().next();
|
entity_counter++;
|
||||||
entity.remove();
|
REntity entity = entities.values().iterator().next();
|
||||||
|
entity.remove();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
System.out.println("Has to remove manually " + entity_counter + " entities!");
|
System.out.println("Has to remove manually " + entity_counter + " entities!");
|
||||||
}
|
}
|
||||||
@ -96,7 +98,9 @@ public abstract class REntity {
|
|||||||
connection.sendPacket(packet);
|
connection.sendPacket(packet);
|
||||||
}
|
}
|
||||||
Bukkit.getScheduler().runTask(SpectateSystem.get(), entity::die);
|
Bukkit.getScheduler().runTask(SpectateSystem.get(), entity::die);
|
||||||
entities.remove(internalId);
|
synchronized (entities){
|
||||||
|
entities.remove(internalId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void sneak(boolean sneaking) {
|
public void sneak(boolean sneaking) {
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
|
@ -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) {
|
||||||
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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:
|
||||||
|
In neuem Issue referenzieren
Einen Benutzer sperren