SteamWar/BauSystem
Archiviert
13
0

Merge branch 'master' into edit-signs

Dieser Commit ist enthalten in:
Chaoscaot 2021-02-03 20:15:31 +01:00
Commit 9b70227f74
13 geänderte Dateien mit 439 neuen und 255 gelöschten Zeilen

Datei anzeigen

@ -19,19 +19,12 @@
package de.steamwar.bausystem.commands; package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.world.Region;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.block.BlockBurnEvent; import org.bukkit.event.block.BlockBurnEvent;
import org.bukkit.event.block.BlockSpreadEvent; import org.bukkit.event.block.BlockSpreadEvent;
public class CommandFire extends ToggleCommand { public class CommandFire extends RegionToggleCommand {
public CommandFire(){
super(true);
}
public static ToggleCommand getInstance(){
return getInstance(CommandFire.class);
}
@Override @Override
String getNoPermMessage() { String getNoPermMessage() {
@ -46,14 +39,34 @@ public class CommandFire extends ToggleCommand {
return "§aFeuerschaden aktiviert"; return "§aFeuerschaden aktiviert";
} }
@Override
boolean toggle(Region region) {
region.setFire(!region.isFire());
return region.isFire();
}
@Override
boolean toggleGlobal() {
Region.NoRegion.fire = !Region.NoRegion.fire;
return Region.NoRegion.fire;
}
@EventHandler @EventHandler
public void onFireDamage(BlockBurnEvent e) { public void onFireDamage(BlockBurnEvent e) {
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFire()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.fire) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onFireSpread(BlockSpreadEvent e){ public void onFireSpread(BlockSpreadEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFire()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.fire) e.setCancelled(true);
});
} }
} }

Datei anzeigen

@ -1,6 +1,6 @@
/* /*
This file is a part of the SteamWar software. This file is a part of the SteamWar software.
Copyright (C) 2020 SteamWar.de-Serverteam Copyright (C) 2020 SteamWar.de-Serverteam
This program is free software: you can redistribute it and/or modify This program is free software: you can redistribute it and/or modify
@ -20,22 +20,14 @@
package de.steamwar.bausystem.commands; package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.world.Region; import de.steamwar.bausystem.world.Region;
import org.bukkit.entity.EntityType; import org.bukkit.Material;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.block.*; import org.bukkit.event.block.*;
import org.bukkit.event.entity.EntityChangeBlockEvent; import org.bukkit.event.entity.EntityChangeBlockEvent;
import org.bukkit.event.entity.EntitySpawnEvent; import org.bukkit.event.entity.EntitySpawnEvent;
import org.bukkit.event.inventory.InventoryMoveItemEvent; import org.bukkit.event.inventory.InventoryMoveItemEvent;
public class CommandFreeze extends ToggleCommand { public class CommandFreeze extends RegionToggleCommand {
public CommandFreeze(){
super(false);
}
public static ToggleCommand getInstance(){
return getInstance(CommandFreeze.class);
}
@Override @Override
String getNoPermMessage() { String getNoPermMessage() {
@ -50,48 +42,118 @@ public class CommandFreeze extends ToggleCommand {
return "§aWelt aufgetaut"; return "§aWelt aufgetaut";
} }
@Override
boolean toggle(Region region) {
region.setFreeze(!region.isFreeze());
return region.isFreeze();
}
@Override
boolean toggleGlobal() {
Region.NoRegion.freeze = !Region.NoRegion.freeze;
return Region.NoRegion.freeze;
}
@EventHandler @EventHandler
public void onEntitySpawn(EntitySpawnEvent e) { public void onEntitySpawn(EntitySpawnEvent e) {
e.setCancelled(true); Region.getRegion(e.getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
}
@EventHandler
public void onBlockCanBuild(BlockCanBuildEvent e) {
if (!e.isBuildable()) return;
Region.getRegion(e.getBlock().getLocation(), region -> {
if (!region.isFreeze()) {
return;
}
if (e.getMaterial() == Material.TNT) {
e.setBuildable(false);
e.getBlock().setType(Material.TNT, false);
}
}, () -> {
if (!Region.NoRegion.freeze) {
return;
}
if (e.getMaterial() == Material.TNT) {
e.setBuildable(false);
e.getBlock().setType(Material.TNT, false);
}
});
} }
@EventHandler @EventHandler
public void onEntityChangeBlock(EntityChangeBlockEvent e) { public void onEntityChangeBlock(EntityChangeBlockEvent e) {
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onPhysicsEvent(BlockPhysicsEvent e){ public void onPhysicsEvent(BlockPhysicsEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onPistonExtend(BlockPistonExtendEvent e){ public void onPistonExtend(BlockPistonExtendEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onPistonRetract(BlockPistonRetractEvent e){ public void onPistonRetract(BlockPistonRetractEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onBlockGrow(BlockGrowEvent e){ public void onBlockGrow(BlockGrowEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onRedstoneEvent(BlockRedstoneEvent e){ public void onRedstoneEvent(BlockRedstoneEvent e){
e.setNewCurrent(e.getOldCurrent()); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setNewCurrent(e.getOldCurrent());
}, () -> {
if (Region.NoRegion.freeze) e.setNewCurrent(e.getOldCurrent());
});
} }
@EventHandler @EventHandler
public void onBlockDispense(BlockDispenseEvent e){ public void onBlockDispense(BlockDispenseEvent e){
e.setCancelled(true); Region.getRegion(e.getBlock().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
@EventHandler @EventHandler
public void onInventoryMoveEvent(InventoryMoveItemEvent e){ public void onInventoryMoveEvent(InventoryMoveItemEvent e){
e.setCancelled(true); Region.getRegion(e.getDestination().getLocation(), region -> {
if (region.isFreeze()) e.setCancelled(true);
}, () -> {
if (Region.NoRegion.freeze) e.setCancelled(true);
});
} }
} }

Datei anzeigen

@ -20,12 +20,14 @@
package de.steamwar.bausystem.commands; package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.BauSystem; import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.world.Region;
import de.steamwar.core.TPSWatcher; import de.steamwar.core.TPSWatcher;
import de.steamwar.sql.BauweltMember; import de.steamwar.sql.BauweltMember;
import de.steamwar.sql.SteamwarUser; import de.steamwar.sql.SteamwarUser;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import java.util.List; import java.util.List;
@ -33,10 +35,18 @@ public class CommandInfo implements CommandExecutor {
@Override @Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) { public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
if (!(sender instanceof Player)) {
return false;
}
Player player = (Player) sender;
sender.sendMessage(BauSystem.PREFIX + "Besitzer: §e" + SteamwarUser.get(BauSystem.getOwnerID()).getUserName()); sender.sendMessage(BauSystem.PREFIX + "Besitzer: §e" + SteamwarUser.get(BauSystem.getOwnerID()).getUserName());
sender.sendMessage(BauSystem.PREFIX + "TNT-Schaden: " + CommandTNT.getTntMode().getName()); Region region = Region.getRegion(player.getLocation());
sender.sendMessage(BauSystem.PREFIX + "Feuerschaden: " + (CommandFire.getInstance().isOn() ? "§aAUS" : "§cAN")); if (region == null) {
sender.sendMessage(BauSystem.PREFIX + "Eingefroren: " + (CommandFreeze.getInstance().isOn() ? "§aJA" : "§cNEIN")); sender.sendMessage(BauSystem.PREFIX + "§eTNT§8: " + Region.NoRegion.tnt.getName() + " §eFire§8: " + (Region.NoRegion.fire ? "§aAUS" : "§cAN") + " §eFreeze§8: " + (Region.NoRegion.freeze ? "§aAN" : "§cAUS"));
} else {
sender.sendMessage(BauSystem.PREFIX + "§eTNT§8: " + region.getTntMode().getName() + " §eFire§8: " + (region.isFire() ? "§aAUS" : "§cAN") + " §eFreeze§8: " + (region.isFreeze() ? "§aAN" : "§cAUS"));
}
List<BauweltMember> members = BauweltMember.getMembers(BauSystem.getOwnerID()); List<BauweltMember> members = BauweltMember.getMembers(BauSystem.getOwnerID());
StringBuilder membermessage = new StringBuilder().append(BauSystem.PREFIX).append("Mitglieder: "); StringBuilder membermessage = new StringBuilder().append(BauSystem.PREFIX).append("Mitglieder: ");

Datei anzeigen

@ -45,28 +45,26 @@ public class CommandProtect implements CommandExecutor {
return false; return false;
} }
for(Region region : Region.getRegions()){ Region region = Region.getRegion(player.getLocation());
if(region.inRegion(player.getLocation()) && region.hasProtection()){ if (region == null || !region.hasProtection()) {
try { player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner (M)WG-Region");
Schematic schem = null; return false;
if(args.length > 0){ }
schem = Schematic.getSchemFromDB(args[0], player.getUniqueId()); try {
if(schem == null){ Schematic schem = null;
player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden"); if(args.length > 0){
return false; schem = Schematic.getSchemFromDB(args[0], player.getUniqueId());
} if(schem == null){
} player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden");
region.protect(schem); return false;
player.sendMessage(BauSystem.PREFIX + "§7Boden geschützt"); }
}catch(Exception e){ }
player.sendMessage(BauSystem.PREFIX + "§cFehler beim Schützen der Region"); region.protect(schem);
Bukkit.getLogger().log(Level.WARNING, "Failed protect", e); player.sendMessage(BauSystem.PREFIX + "§7Boden geschützt");
} }catch(Exception e){
return false; player.sendMessage(BauSystem.PREFIX + "§cFehler beim Schützen der Region");
} Bukkit.getLogger().log(Level.WARNING, "Failed protect", e);
} }
player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner (M)WG-Region");
return false; return false;
} }
} }

Datei anzeigen

@ -45,29 +45,27 @@ public class CommandReset implements CommandExecutor {
return false; return false;
} }
for(Region region : Region.getRegions()){ Region region = Region.getRegion(player.getLocation());
if(region.inRegion(player.getLocation())){ if (region == null) {
try { player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
if(args.length > 0){ return false;
Schematic schem = Schematic.getSchemFromDB(args[0], player.getUniqueId()); }
if(schem == null){ try {
player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden"); if(args.length > 0){
return false; Schematic schem = Schematic.getSchemFromDB(args[0], player.getUniqueId());
} if(schem == null){
region.reset(schem); player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden");
}else{ return false;
region.fastreset(); }
} region.reset(schem);
player.sendMessage(BauSystem.PREFIX + "§7Region zurückgesetzt"); }else{
}catch(Exception e){ region.fastreset();
player.sendMessage(BauSystem.PREFIX + "§cFehler beim Zurücksetzen der Region"); }
Bukkit.getLogger().log(Level.WARNING, "Failed reset", e); player.sendMessage(BauSystem.PREFIX + "§7Region zurückgesetzt");
} }catch(Exception e){
return false; player.sendMessage(BauSystem.PREFIX + "§cFehler beim Zurücksetzen der Region");
} Bukkit.getLogger().log(Level.WARNING, "Failed reset", e);
} }
player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
return false; return false;
} }
} }

Datei anzeigen

@ -23,8 +23,6 @@ import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission; import de.steamwar.bausystem.Permission;
import de.steamwar.bausystem.world.Region; import de.steamwar.bausystem.world.Region;
import de.steamwar.bausystem.world.Welt; import de.steamwar.bausystem.world.Welt;
import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.TextComponent;
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;
@ -36,15 +34,9 @@ import org.bukkit.event.entity.EntityExplodeEvent;
public class CommandTNT implements CommandExecutor, Listener { public class CommandTNT implements CommandExecutor, Listener {
private static TNTMode tntMode = Region.buildAreaEnabled() ? TNTMode.ONLY_TB : TNTMode.OFF;
public static TNTMode getTntMode() {
return tntMode;
}
public enum TNTMode { public enum TNTMode {
ON("§aan"), ON("§aan"),
ONLY_TB("§7nur §eTestblock"), ONLY_TB("§7Kein §eBaurahmen"),
OFF("§caus"); OFF("§caus");
private String name; private String name;
@ -76,7 +68,7 @@ public class CommandTNT implements CommandExecutor, Listener {
} }
private String getTestblockEnableMessage() { private String getTestblockEnableMessage() {
return "§aTNT-Schaden am Testblock aktiviert"; return "§aTNT-Schaden außerhalb Baurahmen aktiviert";
} }
private String getDamageMessage() { private String getDamageMessage() {
@ -93,74 +85,98 @@ public class CommandTNT implements CommandExecutor, Listener {
return false; return false;
} }
TNTMode requestedMode = null;
String requestedMessage = null;
if (args.length != 0) { if (args.length != 0) {
switch (args[0].toLowerCase()) { switch (args[0].toLowerCase()) {
case "an": case "an":
case "on": case "on":
tntMode = TNTMode.ON; requestedMode = TNTMode.ON;
sendToActionBar(getEnableMessage()); requestedMessage = getEnableMessage();
return false; break;
case "aus": case "aus":
case "off": case "off":
tntMode = TNTMode.OFF; requestedMode = TNTMode.OFF;
sendToActionBar(getDisableMessage()); requestedMessage = getDisableMessage();
return false; break;
case "testblock": case "testblock":
case "tb": case "tb":
if (!Region.buildAreaEnabled()) break; if (!Region.buildAreaEnabled()) break;
tntMode = TNTMode.ONLY_TB; requestedMode = TNTMode.ONLY_TB;
sendToActionBar(getTestblockEnableMessage()); requestedMessage = getTestblockEnableMessage();
return false; break;
default: default:
break; break;
} }
} }
switch (tntMode) { Region region = Region.getRegion(player.getLocation());
if (region == null) {
tntGlobalToggle(requestedMode, requestedMessage);
return false;
}
tntToggle(region, requestedMode, requestedMessage);
return false;
}
private void tntGlobalToggle(TNTMode requestedMode, String requestedMessage) {
if (requestedMode != null && requestedMode != TNTMode.ONLY_TB) {
Region.NoRegion.tnt = requestedMode;
RegionToggleCommand.actionBar(requestedMessage);
return;
}
switch (Region.NoRegion.tnt) {
case ON: case ON:
case ONLY_TB: case ONLY_TB:
tntMode = TNTMode.OFF; Region.NoRegion.tnt = TNTMode.OFF;
sendToActionBar(getDisableMessage()); RegionToggleCommand.actionBar(getDisableMessage());
break; break;
case OFF: case OFF:
if (Region.buildAreaEnabled()) { Region.NoRegion.tnt = TNTMode.ON;
tntMode = TNTMode.ONLY_TB; RegionToggleCommand.actionBar(getEnableMessage());
sendToActionBar(getTestblockEnableMessage()); break;
}
}
private void tntToggle(Region region, TNTMode requestedMode, String requestedMessage) {
if (requestedMode != null && region.hasTestblock()) {
region.setTntMode(requestedMode);
RegionToggleCommand.actionBar(region, requestedMessage);
return;
}
switch (region.getTntMode()) {
case ON:
case ONLY_TB:
region.setTntMode(TNTMode.OFF);
RegionToggleCommand.actionBar(region, getDisableMessage());
break;
case OFF:
if (Region.buildAreaEnabled() && region.hasTestblock()) {
region.setTntMode(TNTMode.ONLY_TB);
RegionToggleCommand.actionBar(region, getTestblockEnableMessage());
} else { } else {
tntMode = TNTMode.ON; region.setTntMode(TNTMode.ON);
sendToActionBar(getEnableMessage()); RegionToggleCommand.actionBar(region, getEnableMessage());
} }
break; break;
} }
return false;
} }
@EventHandler @EventHandler
public void onExplode(EntityExplodeEvent event) { public void onExplode(EntityExplodeEvent event) {
switch (tntMode) { event.blockList().removeIf(block -> {
case ON: Region region = Region.getRegion(block.getLocation());
break; if (region == null) {
case OFF: return Region.NoRegion.tnt == TNTMode.OFF;
event.blockList().clear(); }
break; if (region.getTntMode() == TNTMode.OFF) return true;
case ONLY_TB: if (region.getTntMode() == TNTMode.ON) return false;
boolean blocksDestroyed = event.blockList().removeIf(block -> { if (region.hasBuildRegion() && region.inBuildRegion(block.getLocation())) {
for (Region region : Region.getRegions()) { RegionToggleCommand.actionBar(region, getDamageMessage());
if (region.hasBuildRegion() && region.inBuildRegion(block.getLocation())) { return true;
return true; }
} return false;
} });
return false;
});
if (blocksDestroyed) {
sendToActionBar(getDamageMessage());
}
break;
}
}
private void sendToActionBar(String message) {
Bukkit.getOnlinePlayers().forEach(p -> p.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(message)));
} }
} }

Datei anzeigen

@ -45,28 +45,26 @@ public class CommandTestblock implements CommandExecutor {
return false; return false;
} }
for(Region region : Region.getRegions()){ Region region = Region.getRegion(player.getLocation());
if(region.inRegion(player.getLocation()) && region.hasTestblock()){ if (region == null || !region.hasTestblock()) {
try { player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
Schematic schem = null; return false;
if(args.length > 0){ }
schem = Schematic.getSchemFromDB(args[0], player.getUniqueId()); try {
if(schem == null){ Schematic schem = null;
player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden"); if(args.length > 0){
return false; schem = Schematic.getSchemFromDB(args[0], player.getUniqueId());
} if(schem == null){
} player.sendMessage(BauSystem.PREFIX + "§cSchematic nicht gefunden");
region.resetTestblock(schem); return false;
player.sendMessage(BauSystem.PREFIX + "§7Testblock zurückgesetzt"); }
}catch(Exception e){ }
player.sendMessage(BauSystem.PREFIX + "§cFehler beim Zurücksetzen des Testblocks"); region.resetTestblock(schem);
Bukkit.getLogger().log(Level.WARNING, "Failed testblock", e); player.sendMessage(BauSystem.PREFIX + "§7Testblock zurückgesetzt");
} }catch(Exception e){
return false; player.sendMessage(BauSystem.PREFIX + "§cFehler beim Zurücksetzen des Testblocks");
} Bukkit.getLogger().log(Level.WARNING, "Failed testblock", e);
} }
player.sendMessage(BauSystem.PREFIX + "§cDu befindest dich derzeit in keiner Region");
return false; return false;
} }
} }

Datei anzeigen

@ -0,0 +1,89 @@
/*
*
* This file is a part of the SteamWar software.
*
* Copyright (C) 2020 SteamWar.de-Serverteam
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
* /
*/
package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission;
import de.steamwar.bausystem.world.Region;
import de.steamwar.bausystem.world.Welt;
import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.TextComponent;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.event.Listener;
public abstract class RegionToggleCommand implements CommandExecutor, Listener {
public RegionToggleCommand() {
Bukkit.getPluginManager().registerEvents(this, BauSystem.getPlugin());
}
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
if(!(sender instanceof Player))
return false;
Player player = (Player) sender;
if (Welt.noPermission(player, Permission.world)){
player.sendMessage(BauSystem.PREFIX + getNoPermMessage());
return false;
}
Region region = Region.getRegion(player.getLocation());
if (region == null) {
if (toggleGlobal()) {
actionBar(getEnableMessage());
} else {
actionBar(getDisableMessage());
}
return false;
}
if (toggle(region)) {
actionBar(region, getEnableMessage());
} else {
actionBar(region, getDisableMessage());
}
return false;
}
public static void actionBar(Region region, String s) {
Bukkit.getOnlinePlayers().stream().filter(player -> region.inRegion(player.getLocation())).forEach(player -> player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(s)));
}
public static void actionBar(String s) {
Bukkit.getOnlinePlayers().stream().filter(player -> Region.getRegion(player.getLocation()) == null).forEach(player -> player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(s)));
}
abstract String getNoPermMessage();
abstract String getEnableMessage();
abstract String getDisableMessage();
/**
* {@code true} for {@link #getEnableMessage()}, {@code false} for {@link #getDisableMessage()}
*/
abstract boolean toggle(Region region);
abstract boolean toggleGlobal();
}

Datei anzeigen

@ -1,87 +0,0 @@
/*
This file is a part of the SteamWar software.
Copyright (C) 2020 SteamWar.de-Serverteam
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
package de.steamwar.bausystem.commands;
import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.Permission;
import de.steamwar.bausystem.world.Welt;
import net.md_5.bungee.api.ChatMessageType;
import net.md_5.bungee.api.chat.TextComponent;
import org.bukkit.Bukkit;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import org.bukkit.event.HandlerList;
import org.bukkit.event.Listener;
import java.util.HashMap;
import java.util.Map;
public abstract class ToggleCommand implements CommandExecutor, Listener {
private static Map<Class<? extends ToggleCommand>, Boolean> enabled = new HashMap<>();
private static Map<Class<? extends ToggleCommand>, ToggleCommand> instance = new HashMap<>();
ToggleCommand(boolean on){
enabled.put(getClass(), false);
if(on)
toggle();
instance.put(getClass(), this);
}
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
if(!(sender instanceof Player))
return false;
Player player = (Player) sender;
if (Welt.noPermission(player, Permission.world)){
player.sendMessage(BauSystem.PREFIX + getNoPermMessage());
return false;
}
toggle();
return false;
}
static ToggleCommand getInstance(Class<? extends ToggleCommand> clazz){
return instance.get(clazz);
}
abstract String getNoPermMessage();
abstract String getEnableMessage();
abstract String getDisableMessage();
public boolean isOn(){
return enabled.get(getClass());
}
public void toggle(){
enabled.compute(getClass(), (clazz, value) -> !value);
if(enabled.get(getClass())){
Bukkit.getPluginManager().registerEvents(this, BauSystem.getPlugin());
Bukkit.getOnlinePlayers().forEach(player -> player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(getEnableMessage())));
}else{
HandlerList.unregisterAll(this);
Bukkit.getOnlinePlayers().forEach(player -> player.spigot().sendMessage(ChatMessageType.ACTION_BAR, TextComponent.fromLegacyText(getDisableMessage())));
}
}
}

Datei anzeigen

@ -19,8 +19,6 @@
package de.steamwar.bausystem.world; package de.steamwar.bausystem.world;
import de.steamwar.bausystem.commands.CommandFreeze;
import de.steamwar.bausystem.commands.CommandTNT;
import de.steamwar.bausystem.commands.CommandTPSLimiter; import de.steamwar.bausystem.commands.CommandTPSLimiter;
import de.steamwar.bausystem.tracer.record.RecordStateMachine; import de.steamwar.bausystem.tracer.record.RecordStateMachine;
import de.steamwar.core.TPSWatcher; import de.steamwar.core.TPSWatcher;
@ -61,8 +59,16 @@ public class BauScoreboard implements Listener {
strings.add("§1"); strings.add("§1");
strings.add("§eUhrzeit§8: §7" + new SimpleDateFormat("HH:mm:ss").format(Calendar.getInstance().getTime())); strings.add("§eUhrzeit§8: §7" + new SimpleDateFormat("HH:mm:ss").format(Calendar.getInstance().getTime()));
strings.add("§2"); strings.add("§2");
strings.add("§eTNT§8: " + CommandTNT.getTntMode().getName()); Region region = Region.getRegion(p.getLocation());
strings.add("§eFreeze§8: " + (CommandFreeze.getInstance().isOn() ? "§aan" : "§caus")); if (region != null) {
strings.add("§eTNT§8: " + region.getTntMode().getName());
strings.add("§eFreeze§8: " + (region.isFreeze() ? "§aan" : "§caus"));
strings.add("§eFire§8: " + (region.isFire() ? "§aaus" : "§can"));
} else {
strings.add("§eTNT§8: " + Region.NoRegion.tnt.getName());
strings.add("§eFreeze§8: " + (Region.NoRegion.freeze ? "§aan" : "§caus"));
strings.add("§eFire§8: " + (Region.NoRegion.fire ? "§aaus" : "§can"));
}
strings.add("§eTrace§8: " + RecordStateMachine.getRecordStatus().getName()); strings.add("§eTrace§8: " + RecordStateMachine.getRecordStatus().getName());
strings.add("§eLoader§8: " + (AutoLoader.hasLoader(p) ? "§aan" : "§caus")); strings.add("§eLoader§8: " + (AutoLoader.hasLoader(p) ? "§aan" : "§caus"));

Datei anzeigen

@ -20,6 +20,7 @@
package de.steamwar.bausystem.world; package de.steamwar.bausystem.world;
import com.sk89q.worldedit.extent.clipboard.Clipboard; import com.sk89q.worldedit.extent.clipboard.Clipboard;
import de.steamwar.bausystem.commands.CommandTNT.TNTMode;
import de.steamwar.core.Core; import de.steamwar.core.Core;
import de.steamwar.sql.NoClipboardException; import de.steamwar.sql.NoClipboardException;
import de.steamwar.sql.Schematic; import de.steamwar.sql.Schematic;
@ -32,6 +33,7 @@ import org.bukkit.configuration.file.YamlConfiguration;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.*; import java.util.*;
import java.util.function.Consumer;
import java.util.logging.Level; import java.util.logging.Level;
public class Region { public class Region {
@ -39,8 +41,11 @@ public class Region {
private static final List<Region> regions = new ArrayList<>(); private static final List<Region> regions = new ArrayList<>();
private static boolean buildArea = false; private static boolean buildArea = false;
public static boolean buildAreaEnabled() { public static class NoRegion {
return buildArea; private NoRegion() {}
public static TNTMode tnt = TNTMode.OFF;
public static boolean fire = false;
public static boolean freeze = false;
} }
static{ static{
@ -64,23 +69,95 @@ public class Region {
} }
} }
public static List<Region> getRegions(){ public static boolean buildAreaEnabled() {
return regions; return buildArea;
} }
public static Region getRegion(Location location) {
for (Region region : regions) {
if (region.inRegion(location)) return region;
}
return null;
}
public static void getRegion(Location location, Consumer<Region> regionConsumer, Runnable noRegion) {
boolean b = true;
for (Region region : regions) {
if (region.inRegion(location)) {
regionConsumer.accept(region);
b = false;
}
}
if (b) noRegion.run();
}
private final String name;
private final int minX; private final int minX;
private final int minY; private final int minY;
private final int minZ; private final int minZ;
private final Prototype prototype; private final Prototype prototype;
private final String optionsLinkedWith; // nullable
private Region linkedRegion = null; // nullable
private TNTMode tntMode = Region.buildAreaEnabled() ? TNTMode.ONLY_TB : TNTMode.OFF;
private boolean freeze = false;
private boolean fire = false;
private Region(ConfigurationSection config){ private Region(ConfigurationSection config){
name = config.getName();
minX = config.getInt("minX"); minX = config.getInt("minX");
minY = config.getInt("minY"); minY = config.getInt("minY");
minZ = config.getInt("minZ"); minZ = config.getInt("minZ");
prototype = Prototype.prototypes.get(config.getString("prototype")); prototype = Prototype.prototypes.get(config.getString("prototype"));
optionsLinkedWith = config.getString("optionsLinkedWith", null);
if (!hasTestblock()) tntMode = TNTMode.OFF;
regions.add(this); regions.add(this);
} }
private void setLinkedRegion(Consumer<Region> regionConsumer) {
if (optionsLinkedWith == null) {
return;
}
if (linkedRegion != null) {
regionConsumer.accept(linkedRegion);
return;
}
for (Region region : regions) {
if (region.name.equals(name)) {
linkedRegion = region;
regionConsumer.accept(linkedRegion);
return;
}
}
}
public TNTMode getTntMode() {
return tntMode;
}
public void setTntMode(TNTMode tntMode) {
this.tntMode = tntMode;
setLinkedRegion(region -> region.tntMode = tntMode);
}
public boolean isFreeze() {
return freeze;
}
public void setFreeze(boolean freeze) {
this.freeze = freeze;
setLinkedRegion(region -> region.freeze = freeze);
}
public boolean isFire() {
return fire;
}
public void setFire(boolean fire) {
this.fire = fire;
setLinkedRegion(region -> region.fire = fire);
}
public boolean inRegion(Location l){ public boolean inRegion(Location l){
return prototype.inRegion(this, l); return prototype.inRegion(this, l);
} }

Datei anzeigen

@ -40,7 +40,7 @@ import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.block.Action; import org.bukkit.event.block.Action;
import org.bukkit.event.block.BlockBreakEvent; import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.event.block.BlockPlaceEvent; import org.bukkit.event.block.BlockCanBuildEvent;
import org.bukkit.event.block.SignChangeEvent; import org.bukkit.event.block.SignChangeEvent;
import org.bukkit.event.player.PlayerCommandPreprocessEvent; import org.bukkit.event.player.PlayerCommandPreprocessEvent;
import org.bukkit.event.player.PlayerInteractEvent; import org.bukkit.event.player.PlayerInteractEvent;
@ -71,13 +71,13 @@ public class RegionListener implements Listener {
} }
@EventHandler(priority = EventPriority.LOWEST) @EventHandler(priority = EventPriority.LOWEST)
public void onBlockPlace(BlockPlaceEvent e) { public void onBlockCanBuild(BlockCanBuildEvent e) {
Player p = e.getPlayer(); Player p = e.getPlayer();
try{ try{
if (Welt.noPermission(p, Permission.build)){ if (Welt.noPermission(p, Permission.build)){
p.sendMessage(BauSystem.PREFIX + "§cDu darfst hier keine Blöcke platzieren"); p.sendMessage(BauSystem.PREFIX + "§cDu darfst hier keine Blöcke platzieren");
e.setCancelled(true); e.setBuildable(false);
} }
}catch(NullPointerException ex){ }catch(NullPointerException ex){
//ignored, caused by worldedit brushes //ignored, caused by worldedit brushes

Datei anzeigen

@ -20,8 +20,6 @@
package de.steamwar.bausystem.world; package de.steamwar.bausystem.world;
import de.steamwar.bausystem.BauSystem; import de.steamwar.bausystem.BauSystem;
import de.steamwar.bausystem.commands.CommandFire;
import de.steamwar.bausystem.commands.CommandFreeze;
import de.steamwar.bausystem.commands.CommandScript; import de.steamwar.bausystem.commands.CommandScript;
import de.steamwar.bausystem.commands.CommandTNT; import de.steamwar.bausystem.commands.CommandTNT;
import de.steamwar.bausystem.tracer.record.RecordStateMachine; import de.steamwar.bausystem.tracer.record.RecordStateMachine;
@ -153,6 +151,8 @@ public class ScriptListener implements Listener {
index = ifJumpIndex; index = ifJumpIndex;
} }
continue; continue;
default:
break;
} }
PlayerCommandPreprocessEvent preprocessEvent = new PlayerCommandPreprocessEvent(player, "/" + command); PlayerCommandPreprocessEvent preprocessEvent = new PlayerCommandPreprocessEvent(player, "/" + command);
@ -235,6 +235,8 @@ public class ScriptListener implements Listener {
case "--": case "--":
add(scriptExecutor, args[0], -1); add(scriptExecutor, args[0], -1);
return; return;
default:
break;
} }
setValue(scriptExecutor, args[0], args[1]); setValue(scriptExecutor, args[0], args[1]);
} }
@ -280,17 +282,19 @@ public class ScriptListener implements Listener {
} }
private static int getValue(ScriptExecutor scriptExecutor, String key) { private static int getValue(ScriptExecutor scriptExecutor, String key) {
Region region = Region.getRegion(scriptExecutor.player.getLocation());
switch (key) { switch (key) {
case "trace": case "trace":
return RecordStateMachine.getRecordStatus().isTracing() ? 1 : 0; return RecordStateMachine.getRecordStatus().isTracing() ? 1 : 0;
case "tnt": case "tnt":
return CommandTNT.getTntMode() == CommandTNT.TNTMode.OFF ? 0 : 1; return region == null || region.getTntMode() == CommandTNT.TNTMode.OFF ? 0 : 1;
case "freeze": case "freeze":
return CommandFreeze.getInstance().isOn() ? 1 : 0; return region == null || !region.isFreeze() ? 0 : 1;
case "fire": case "fire":
return CommandFire.getInstance().isOn() ? 1 : 0; return region == null || !region.isFire() ? 0 : 1;
default:
return scriptExecutor.variables.getOrDefault(key, 0);
} }
return scriptExecutor.variables.getOrDefault(key, 0);
} }
private static boolean isVariable(ScriptExecutor scriptExecutor, String key) { private static boolean isVariable(ScriptExecutor scriptExecutor, String key) {