2011-10-09 21:57:43 +02:00
|
|
|
package com.massivecraft.factions.cmd;
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2013-04-09 13:15:25 +02:00
|
|
|
import com.massivecraft.factions.ConfServer;
|
2013-04-09 13:24:55 +02:00
|
|
|
import com.massivecraft.factions.FPerm;
|
2011-07-18 22:06:02 +02:00
|
|
|
import com.massivecraft.factions.FPlayer;
|
|
|
|
import com.massivecraft.factions.Faction;
|
2013-04-19 14:08:45 +02:00
|
|
|
import com.massivecraft.factions.FactionColl;
|
2013-04-09 13:00:09 +02:00
|
|
|
import com.massivecraft.factions.Factions;
|
2013-04-09 12:56:29 +02:00
|
|
|
import com.massivecraft.factions.Perm;
|
2013-04-09 13:24:55 +02:00
|
|
|
import com.massivecraft.factions.Rel;
|
2013-04-16 11:05:49 +02:00
|
|
|
import com.massivecraft.factions.cmd.arg.ARFPlayer;
|
2013-04-19 14:08:45 +02:00
|
|
|
import com.massivecraft.factions.event.FactionsEventMembershipChange;
|
|
|
|
import com.massivecraft.factions.event.FactionsEventMembershipChange.MembershipChangeReason;
|
2013-04-16 10:11:59 +02:00
|
|
|
import com.massivecraft.mcore.cmd.req.ReqHasPerm;
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2013-04-10 13:12:22 +02:00
|
|
|
public class CmdFactionsKick extends FCommand
|
2011-10-09 14:53:38 +02:00
|
|
|
{
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2013-04-10 13:12:22 +02:00
|
|
|
public CmdFactionsKick()
|
2011-10-09 14:53:38 +02:00
|
|
|
{
|
2013-04-16 10:11:59 +02:00
|
|
|
this.addAliases("kick");
|
2011-03-22 18:48:09 +01:00
|
|
|
|
2013-04-16 10:30:21 +02:00
|
|
|
this.addRequiredArg("player");
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2013-04-16 10:11:59 +02:00
|
|
|
this.addRequirements(ReqHasPerm.get(Perm.KICK.node));
|
2011-03-22 15:45:41 +01:00
|
|
|
}
|
|
|
|
|
2011-06-21 07:38:31 +02:00
|
|
|
@Override
|
2011-10-09 14:53:38 +02:00
|
|
|
public void perform()
|
2013-04-19 14:08:45 +02:00
|
|
|
{
|
|
|
|
// Arg
|
|
|
|
FPlayer fplayer = this.arg(1, ARFPlayer.getStartAny());
|
|
|
|
if (fplayer == null) return;
|
2011-03-22 15:45:41 +01:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
// Validate
|
|
|
|
if (fme == fplayer)
|
2011-10-09 14:53:38 +02:00
|
|
|
{
|
2011-10-10 13:40:24 +02:00
|
|
|
msg("<b>You cannot kick yourself.");
|
2013-04-16 11:27:03 +02:00
|
|
|
msg("<i>You might want to: %s", Factions.get().getOuterCmdFactions().cmdFactionsLeave.getUseageTemplate(false));
|
2011-03-22 15:45:41 +01:00
|
|
|
return;
|
|
|
|
}
|
2011-12-23 01:13:55 +01:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
if (fplayer.getRole() == Rel.LEADER && !(this.senderIsConsole || fme.isUsingAdminMode()))
|
2011-12-23 01:13:55 +01:00
|
|
|
{
|
|
|
|
msg("<b>The leader can not be kicked.");
|
|
|
|
return;
|
|
|
|
}
|
2011-07-09 05:06:55 +02:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
if ( ! ConfServer.canLeaveWithNegativePower && fplayer.getPower() < 0)
|
2011-10-09 14:53:38 +02:00
|
|
|
{
|
2011-10-25 21:18:08 +02:00
|
|
|
msg("<b>You cannot kick that member until their power is positive.");
|
|
|
|
return;
|
2011-03-22 15:45:41 +01:00
|
|
|
}
|
2011-10-25 21:18:08 +02:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
// FPerm
|
|
|
|
Faction fplayerFaction = fplayer.getFaction();
|
|
|
|
if (!FPerm.KICK.has(sender, fplayerFaction)) return;
|
2012-03-13 15:48:34 +01:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
// Event
|
|
|
|
FactionsEventMembershipChange event = new FactionsEventMembershipChange(sender, fplayer, FactionColl.get().getNone(), MembershipChangeReason.KICK);
|
|
|
|
event.run();
|
2012-03-02 02:16:45 +01:00
|
|
|
if (event.isCancelled()) return;
|
2012-03-13 15:48:34 +01:00
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
// Inform
|
|
|
|
fplayerFaction.msg("%s<i> kicked %s<i> from the faction! :O", fme.describeTo(fplayerFaction, true), fplayer.describeTo(fplayerFaction, true));
|
|
|
|
fplayer.msg("%s<i> kicked you from %s<i>! :O", fme.describeTo(fplayer, true), fplayerFaction.describeTo(fplayer));
|
|
|
|
if (fplayerFaction != myFaction)
|
2011-10-09 14:53:38 +02:00
|
|
|
{
|
2013-04-19 14:08:45 +02:00
|
|
|
fme.msg("<i>You kicked %s<i> from the faction %s<i>!", fplayer.describeTo(fme), fplayerFaction.describeTo(fme));
|
2011-05-29 23:41:50 +02:00
|
|
|
}
|
2011-07-09 05:06:55 +02:00
|
|
|
|
2013-04-09 13:15:25 +02:00
|
|
|
if (ConfServer.logFactionKick)
|
2013-04-19 14:08:45 +02:00
|
|
|
{
|
|
|
|
Factions.get().log((senderIsConsole ? "A console command" : fme.getName())+" kicked "+fplayer.getName()+" from the faction: "+fplayerFaction.getTag());
|
|
|
|
}
|
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
|
|
|
|
2013-04-19 14:08:45 +02:00
|
|
|
// Apply
|
|
|
|
if (fplayer.getRole() == Rel.LEADER)
|
|
|
|
{
|
|
|
|
fplayerFaction.promoteNewLeader();
|
|
|
|
}
|
|
|
|
fplayerFaction.setInvited(fplayer, false);
|
|
|
|
fplayer.resetFactionData();
|
2011-03-22 15:45:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|