2018-03-04 23:13:32 +01:00
|
|
|
package com.massivecraft.factions.cmd;
|
|
|
|
|
2018-03-31 18:46:37 +02:00
|
|
|
|
2018-03-26 23:43:15 +02:00
|
|
|
import com.massivecraft.factions.*;
|
2018-03-04 23:13:32 +01:00
|
|
|
import com.massivecraft.factions.struct.Permission;
|
2018-03-26 23:43:15 +02:00
|
|
|
import com.massivecraft.factions.struct.Relation;
|
2018-04-01 16:13:23 +02:00
|
|
|
import com.massivecraft.factions.util.Particles.ParticleEffect;
|
2018-04-04 05:20:30 +02:00
|
|
|
import com.massivecraft.factions.util.WarmUpUtil;
|
2018-04-07 23:29:24 +02:00
|
|
|
import com.massivecraft.factions.zcore.fperms.Access;
|
|
|
|
import com.massivecraft.factions.zcore.fperms.PermissableAction;
|
2018-03-04 23:13:32 +01:00
|
|
|
import com.massivecraft.factions.zcore.util.TL;
|
2018-03-26 23:43:15 +02:00
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
import org.bukkit.GameMode;
|
|
|
|
import org.bukkit.entity.Entity;
|
|
|
|
import org.bukkit.entity.Player;
|
|
|
|
|
2018-04-09 05:13:41 +02:00
|
|
|
import java.util.ConcurrentModificationException;
|
2018-03-27 15:17:55 +02:00
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.List;
|
2018-03-04 23:13:32 +01:00
|
|
|
|
|
|
|
public class CmdFly extends FCommand {
|
|
|
|
|
2018-03-26 23:43:15 +02:00
|
|
|
|
|
|
|
public static HashMap<String,Boolean> flyMap = new HashMap<String,Boolean>();
|
2018-03-31 04:22:06 +02:00
|
|
|
public static int id = -1;
|
|
|
|
public static int flyid = -1;
|
2018-03-04 23:13:32 +01:00
|
|
|
public CmdFly() {
|
|
|
|
super();
|
|
|
|
this.aliases.add("fly");
|
|
|
|
|
|
|
|
this.optionalArgs.put("on/off", "flip");
|
|
|
|
|
2018-03-04 23:16:17 +01:00
|
|
|
this.permission = Permission.FLY.node;
|
2018-03-04 23:13:32 +01:00
|
|
|
this.senderMustBeMember = true;
|
|
|
|
this.senderMustBeModerator = false;
|
|
|
|
}
|
|
|
|
|
2018-04-01 16:13:23 +02:00
|
|
|
public static void startParticles() {
|
|
|
|
id = Bukkit.getScheduler().scheduleSyncRepeatingTask(P.p, new Runnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
for (String name : flyMap.keySet()) {
|
|
|
|
Player player = Bukkit.getPlayer(name);
|
|
|
|
if (player == null) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!player.isFlying()) {
|
|
|
|
continue;
|
|
|
|
}
|
2018-04-14 04:05:43 +02:00
|
|
|
if (player.getGameMode() == GameMode.SPECTATOR){
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (FPlayers.getInstance().getByPlayer(player).isVanished()){
|
|
|
|
continue;
|
|
|
|
}
|
2018-04-01 16:13:23 +02:00
|
|
|
|
2018-04-14 04:05:43 +02:00
|
|
|
ParticleEffect.CLOUD.display((float) 0, (float) 0, (float) 0, (float) 0, 3, player.getLocation().add(0, -0.35, 0), 16);
|
2018-04-01 16:13:23 +02:00
|
|
|
}
|
|
|
|
if (flyMap.keySet().size() == 0) {
|
|
|
|
Bukkit.getScheduler().cancelTask(id);
|
|
|
|
id = -1;
|
|
|
|
}
|
|
|
|
}
|
2018-04-14 04:05:43 +02:00
|
|
|
}, 10L, 3L);
|
2018-04-01 16:13:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public static void startFlyCheck() {
|
|
|
|
flyid = Bukkit.getScheduler().scheduleSyncRepeatingTask(P.p, new Runnable() {
|
|
|
|
@Override
|
2018-04-09 05:13:41 +02:00
|
|
|
public void run() throws ConcurrentModificationException { //threw the exception for now, until I recode fly :( Cringe.
|
2018-04-07 23:29:24 +02:00
|
|
|
checkTaskState();
|
|
|
|
if (flyMap.keySet().size() != 0) {
|
2018-04-09 05:13:41 +02:00
|
|
|
for (String name : flyMap.keySet()) {
|
|
|
|
if (name == null) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
Player player = Bukkit.getPlayer(name);
|
|
|
|
if (player == null) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (!player.isFlying()) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
FPlayer fPlayer = FPlayers.getInstance().getByPlayer(player);
|
|
|
|
if (fPlayer == null) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (player.getGameMode() == GameMode.CREATIVE || player.getGameMode() == GameMode.SPECTATOR) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
Faction myFaction = fPlayer.getFaction();
|
|
|
|
if (myFaction.isWilderness()) {
|
2018-04-07 23:29:24 +02:00
|
|
|
fPlayer.setFlying(false);
|
|
|
|
flyMap.remove(name);
|
|
|
|
continue;
|
|
|
|
}
|
2018-04-09 05:13:41 +02:00
|
|
|
if (fPlayer.checkIfNearbyEnemies()) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
FLocation myFloc = new FLocation(player.getLocation());
|
|
|
|
Faction toFac = Board.getInstance().getFactionAt(myFloc);
|
|
|
|
if (Board.getInstance().getFactionAt(myFloc) != myFaction) {
|
|
|
|
if (!checkBypassPerms(fPlayer, player, toFac)) {
|
|
|
|
fPlayer.setFlying(false);
|
|
|
|
flyMap.remove(name);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
|
2018-04-09 05:13:41 +02:00
|
|
|
}
|
2018-04-01 16:13:23 +02:00
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
|
2018-04-01 16:13:23 +02:00
|
|
|
}
|
|
|
|
}, 20L, 20L);
|
|
|
|
}
|
|
|
|
|
2018-04-04 05:20:30 +02:00
|
|
|
private static boolean checkBypassPerms(FPlayer fplayer, Player player, Faction toFac) {
|
|
|
|
if (player.hasPermission("factions.fly.wilderness") && toFac.isWilderness()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (player.hasPermission("factions.fly.warzone") && toFac.isWarZone()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (player.hasPermission("factions.fly.safezone") && toFac.isSafeZone()) {
|
2018-04-01 16:13:23 +02:00
|
|
|
return true;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
Access access = toFac.getAccess(fplayer, PermissableAction.FLY);
|
|
|
|
if ((player.hasPermission("factions.fly.enemy") || access == Access.ALLOW) && toFac.getRelationTo(fplayer.getFaction()) == Relation.ENEMY) {
|
2018-04-04 05:20:30 +02:00
|
|
|
return true;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
if ((player.hasPermission("factions.fly.ally") || access == Access.ALLOW) && toFac.getRelationTo(fplayer.getFaction()) == Relation.ALLY) {
|
2018-04-04 05:20:30 +02:00
|
|
|
return true;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
if ((player.hasPermission("factions.fly.truce") || access == Access.ALLOW) && toFac.getRelationTo(fplayer.getFaction()) == Relation.TRUCE) {
|
2018-04-04 05:20:30 +02:00
|
|
|
return true;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
return ((player.hasPermission("factions.fly.neutral") || access == Access.ALLOW) && toFac.getRelationTo(fplayer.getFaction()) == Relation.NEUTRAL && !isSystemFaction(toFac));
|
2018-04-04 05:20:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isInFlightChecker(Player player) {
|
|
|
|
return flyMap.containsKey(player.getName());
|
2018-04-01 16:13:23 +02:00
|
|
|
}
|
|
|
|
|
2018-04-07 23:29:24 +02:00
|
|
|
public static Boolean isSystemFaction(Faction faction) {
|
|
|
|
return faction.isSafeZone() ||
|
|
|
|
faction.isWarZone() ||
|
|
|
|
faction.isWilderness();
|
|
|
|
}
|
|
|
|
|
2018-03-04 23:13:32 +01:00
|
|
|
@Override
|
|
|
|
public void perform() {
|
2018-03-26 23:43:15 +02:00
|
|
|
// Disabled by default.
|
|
|
|
if (!P.p.getConfig().getBoolean("enable-faction-flight", false)) {
|
|
|
|
fme.msg(TL.COMMAND_FLY_DISABLED);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
FLocation myfloc = new FLocation(me.getLocation());
|
|
|
|
Faction toFac = Board.getInstance().getFactionAt(myfloc);
|
|
|
|
if (Board.getInstance().getFactionAt(myfloc) != fme.getFaction()){
|
|
|
|
if (!me.hasPermission("factions.fly.wilderness") && toFac.isWilderness()) {
|
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!me.hasPermission("factions.fly.safezone") && toFac.isSafeZone()) {
|
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (!me.hasPermission("factions.fly.warzone") && toFac.isWarZone()) {
|
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
Access access = toFac.getAccess(fme, PermissableAction.FLY);
|
|
|
|
if ((!(me.hasPermission("factions.fly.enemy") || access == Access.ALLOW)) && toFac.getRelationTo(fme.getFaction()) == Relation.ENEMY) {
|
2018-03-26 23:43:15 +02:00
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
if (!(me.hasPermission("factions.fly.ally") || access == Access.ALLOW) && toFac.getRelationTo(fme.getFaction()) == Relation.ALLY) {
|
2018-03-26 23:43:15 +02:00
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
if (!(me.hasPermission("factions.fly.truce") || access == Access.ALLOW) && toFac.getRelationTo(fme.getFaction()) == Relation.TRUCE) {
|
2018-03-26 23:43:15 +02:00
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
2018-04-04 05:20:30 +02:00
|
|
|
|
2018-04-07 23:29:24 +02:00
|
|
|
if (!(me.hasPermission("factions.fly.neutral") || access == Access.ALLOW) && toFac.getRelationTo(fme.getFaction()) == Relation.NEUTRAL && !isSystemFaction(toFac)) {
|
2018-03-26 23:43:15 +02:00
|
|
|
fme.msg(TL.COMMAND_FLY_NO_ACCESS, Board.getInstance().getFactionAt(myfloc).getTag(fme));
|
|
|
|
return;
|
|
|
|
}
|
2018-04-04 05:20:30 +02:00
|
|
|
}
|
|
|
|
|
2018-03-26 23:43:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
List<Entity> entities = me.getNearbyEntities(16,256,16);
|
|
|
|
for (int i = 0; i <= entities.size() -1;i++)
|
|
|
|
{
|
|
|
|
if (entities.get(i) instanceof Player)
|
|
|
|
{
|
|
|
|
Player eplayer = (Player) entities.get(i);
|
|
|
|
FPlayer efplayer = FPlayers.getInstance().getByPlayer(eplayer);
|
|
|
|
if (efplayer.getRelationTo(fme) == Relation.ENEMY)
|
|
|
|
{
|
|
|
|
fme.msg(TL.COMMAND_FLY_CHECK_ENEMY);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-03-04 23:13:32 +01:00
|
|
|
if (args.size() == 0) {
|
2018-04-01 16:13:23 +02:00
|
|
|
toggleFlight(!fme.isFlying(), me);
|
2018-03-04 23:13:32 +01:00
|
|
|
} else if (args.size() == 1) {
|
2018-03-26 23:43:15 +02:00
|
|
|
toggleFlight(argAsBool(0),me);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-31 04:22:06 +02:00
|
|
|
public static void checkTaskState() {
|
2018-03-26 23:43:15 +02:00
|
|
|
if (flyMap.keySet().size() == 0) {
|
|
|
|
Bukkit.getScheduler().cancelTask(flyid);
|
|
|
|
flyid = -1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void toggleFlight(final boolean toggle, final Player player) {
|
2018-03-04 23:13:32 +01:00
|
|
|
if (!toggle) {
|
|
|
|
fme.setFlying(false);
|
2018-03-26 23:43:15 +02:00
|
|
|
flyMap.remove(player.getName());
|
2018-03-04 23:13:32 +01:00
|
|
|
return;
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
|
|
|
|
if (fme.canFlyAtLocation())
|
|
|
|
|
|
|
|
this.doWarmUp(WarmUpUtil.Warmup.FLIGHT, TL.WARMUPS_NOTIFY_FLIGHT, "Fly", new Runnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
fme.setFlying(true);
|
|
|
|
flyMap.put(player.getName(),true);
|
|
|
|
if (id == -1){
|
|
|
|
if (P.p.getConfig().getBoolean("ffly.Particles.Enabled")){
|
|
|
|
startParticles();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (flyid == -1){
|
|
|
|
startFlyCheck();
|
2018-03-26 23:43:15 +02:00
|
|
|
}
|
|
|
|
}
|
2018-04-07 23:29:24 +02:00
|
|
|
}, this.p.getConfig().getLong("warmups.f-fly", 0));
|
2018-03-04 23:13:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public TL getUsageTranslation() {
|
|
|
|
return TL.COMMAND_FLY_DESCRIPTION;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|