2011-10-09 21:57:43 +02:00
|
|
|
package com.massivecraft.factions.cmd;
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2011-07-18 22:06:02 +02:00
|
|
|
import com.massivecraft.factions.Conf;
|
|
|
|
import com.massivecraft.factions.FPlayer;
|
|
|
|
import com.massivecraft.factions.Faction;
|
Additional logging, with new conf.json settings to enable/disable logging of specific events:
"logFactionCreate": true, - log faction creation
"logFactionDisband": true, - log factions being disbanded, by command or by circumstance
"logFactionJoin": true, - log player joining a faction
"logFactionKick": true, - log player being kicked from a faction
"logFactionLeave": true, - log player leaving a faction
"logLandClaims": true, - log land being claimed (including safe zone and war zone)
"logLandUnclaims": true, - log land being unclaimed (including safe zone and war zone)
"logMoneyTransactions": true, - log money being deposited, withdrawn, and otherwise transferred in relation to faction banks
Also a fix for a potential NPE from players logging out and Spout appearance handler referencing them afterwards
2011-10-23 19:50:02 +02:00
|
|
|
import com.massivecraft.factions.P;
|
2012-03-13 13:58:51 +01:00
|
|
|
import com.massivecraft.factions.event.FPlayerLeaveEvent;
|
2011-10-09 14:53:38 +02:00
|
|
|
import com.massivecraft.factions.struct.Permission;
|
2011-12-18 14:47:15 +01:00
|
|
|
import com.massivecraft.factions.struct.Role;
|
2014-04-04 20:55:21 +02:00
|
|
|
import org.bukkit.Bukkit;
|
|
|
|
|
|
|
|
public class CmdKick extends FCommand {
|
|
|
|
|
|
|
|
public CmdKick() {
|
|
|
|
super();
|
|
|
|
this.aliases.add("kick");
|
|
|
|
|
|
|
|
this.requiredArgs.add("player name");
|
|
|
|
//this.optionalArgs.put("", "");
|
|
|
|
|
|
|
|
this.permission = Permission.KICK.node;
|
|
|
|
this.disableOnLock = false;
|
|
|
|
|
|
|
|
senderMustBePlayer = true;
|
|
|
|
senderMustBeMember = false;
|
|
|
|
senderMustBeModerator = true;
|
|
|
|
senderMustBeAdmin = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void perform() {
|
|
|
|
FPlayer you = this.argAsBestFPlayerMatch(0);
|
2014-07-01 21:49:42 +02:00
|
|
|
if (you == null) { return; }
|
2014-04-04 20:55:21 +02:00
|
|
|
|
|
|
|
if (fme == you) {
|
|
|
|
msg("<b>You cannot kick yourself.");
|
|
|
|
msg("<i>You might want to: %s", p.cmdBase.cmdLeave.getUseageTemplate(false));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Faction yourFaction = you.getFaction();
|
|
|
|
|
|
|
|
// players with admin-level "disband" permission can bypass these requirements
|
|
|
|
if (!Permission.KICK_ANY.has(sender)) {
|
|
|
|
if (yourFaction != myFaction) {
|
|
|
|
msg("%s<b> is not a member of %s", you.describeTo(fme, true), myFaction.describeTo(fme));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (you.getRole().value >= fme.getRole().value) {
|
|
|
|
// TODO add more informative messages.
|
|
|
|
msg("<b>Your rank is too low to kick this player.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!Conf.canLeaveWithNegativePower && you.getPower() < 0) {
|
|
|
|
msg("<b>You cannot kick that member until their power is positive.");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// if economy is enabled, they're not on the bypass list, and this command has a cost set, make sure they can pay
|
2014-07-01 21:49:42 +02:00
|
|
|
if (!canAffordCommand(Conf.econCostKick, "to kick someone from the faction")) { return; }
|
2014-04-04 20:55:21 +02:00
|
|
|
|
|
|
|
// trigger the leave event (cancellable) [reason:kicked]
|
|
|
|
FPlayerLeaveEvent event = new FPlayerLeaveEvent(you, you.getFaction(), FPlayerLeaveEvent.PlayerLeaveReason.KICKED);
|
|
|
|
Bukkit.getServer().getPluginManager().callEvent(event);
|
2014-07-01 21:49:42 +02:00
|
|
|
if (event.isCancelled()) { return; }
|
2014-04-04 20:55:21 +02:00
|
|
|
|
|
|
|
// then make 'em pay (if applicable)
|
2014-07-01 21:49:42 +02:00
|
|
|
if (!payForCommand(Conf.econCostKick, "to kick someone from the faction", "for kicking someone from the faction")) {
|
2014-04-04 20:55:21 +02:00
|
|
|
return;
|
2014-07-01 21:49:42 +02:00
|
|
|
}
|
2014-04-04 20:55:21 +02:00
|
|
|
|
|
|
|
yourFaction.msg("%s<i> kicked %s<i> from the faction! :O", fme.describeTo(yourFaction, true), you.describeTo(yourFaction, true));
|
|
|
|
you.msg("%s<i> kicked you from %s<i>! :O", fme.describeTo(you, true), yourFaction.describeTo(you));
|
|
|
|
if (yourFaction != myFaction) {
|
|
|
|
fme.msg("<i>You kicked %s<i> from the faction %s<i>!", you.describeTo(fme), yourFaction.describeTo(fme));
|
|
|
|
}
|
|
|
|
|
2014-07-01 21:49:42 +02:00
|
|
|
if (Conf.logFactionKick) {
|
2014-04-04 20:55:21 +02:00
|
|
|
P.p.log((senderIsConsole ? "A console command" : fme.getName()) + " kicked " + you.getName() + " from the faction: " + yourFaction.getTag());
|
2014-07-01 21:49:42 +02:00
|
|
|
}
|
2014-04-04 20:55:21 +02:00
|
|
|
|
2014-07-01 21:49:42 +02:00
|
|
|
if (you.getRole() == Role.ADMIN) { yourFaction.promoteNewLeader(); }
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2014-04-04 20:55:21 +02:00
|
|
|
yourFaction.deinvite(you);
|
|
|
|
you.resetFactionData();
|
|
|
|
}
|
2011-12-18 14:47:15 +01:00
|
|
|
|
2011-03-22 15:45:41 +01:00
|
|
|
}
|