2011-10-09 21:57:43 +02:00
package com.massivecraft.factions.cmd ;
2011-03-19 13:00:03 +01:00
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 ;
2015-10-21 19:35:41 +02:00
import com.massivecraft.factions.cmd.type.TypeFaction ;
import com.massivecraft.factions.cmd.type.TypeMPlayer ;
2017-02-10 16:38:36 +01:00
import com.massivecraft.factions.entity.Faction ;
2013-04-22 10:05:03 +02:00
import com.massivecraft.factions.entity.MConf ;
2014-10-02 11:45:06 +02:00
import com.massivecraft.factions.entity.MFlag ;
2014-09-17 13:17:33 +02:00
import com.massivecraft.factions.entity.MPlayer ;
2014-06-04 16:47:01 +02:00
import com.massivecraft.factions.event.EventFactionsMembershipChange ;
import com.massivecraft.factions.event.EventFactionsMembershipChange.MembershipChangeReason ;
2015-02-12 12:00:55 +01:00
import com.massivecraft.massivecore.MassiveException ;
2015-09-08 19:18:45 +02:00
import com.massivecraft.massivecore.mson.Mson ;
2014-06-04 14:02:23 +02:00
import com.massivecraft.massivecore.util.Txt ;
2017-03-24 13:05:58 +01:00
import org.bukkit.ChatColor ;
2011-03-19 13:00:03 +01:00
2014-09-18 13:41:20 +02:00
public class CmdFactionsJoin extends FactionsCommand
2011-10-09 14:53:38 +02:00
{
2013-11-11 09:31:04 +01:00
// -------------------------------------------- //
// CONSTRUCT
// -------------------------------------------- //
2013-04-10 13:12:22 +02:00
public CmdFactionsJoin ( )
2011-10-09 14:53:38 +02:00
{
2015-10-21 19:35:41 +02:00
// Parameters
this . addParameter ( TypeFaction . get ( ) , " faction " ) ;
this . addParameter ( TypeMPlayer . get ( ) , " player " , " you " ) ;
2011-03-19 13:00:03 +01:00
}
2013-11-11 09:31:04 +01:00
// -------------------------------------------- //
// OVERRIDE
// -------------------------------------------- //
2011-03-19 13:00:03 +01:00
2011-06-21 07:38:31 +02:00
@Override
2015-02-12 12:00:55 +01:00
public void perform ( ) throws MassiveException
2011-10-09 14:53:38 +02:00
{
2013-04-19 14:08:45 +02:00
// Args
2015-05-06 17:04:35 +02:00
Faction faction = this . readArg ( ) ;
2011-03-19 13:00:03 +01:00
2015-05-06 17:04:35 +02:00
MPlayer mplayer = this . readArg ( msender ) ;
2014-09-17 13:29:58 +02:00
Faction mplayerFaction = mplayer . getFaction ( ) ;
2013-04-16 11:05:49 +02:00
2014-09-18 13:41:20 +02:00
boolean samePlayer = mplayer = = msender ;
2013-04-19 14:08:45 +02:00
// Validate
2013-04-09 12:56:29 +02:00
if ( ! samePlayer & & ! Perm . JOIN_OTHERS . has ( sender , false ) )
2011-10-09 14:53:38 +02:00
{
2012-02-26 19:29:44 +01:00
msg ( " <b>You do not have permission to move other players into a faction. " ) ;
2011-03-23 17:39:56 +01:00
return ;
2012-02-26 19:29:44 +01:00
}
2012-02-24 13:30:28 +01:00
2014-09-17 13:29:58 +02:00
if ( faction = = mplayerFaction )
2011-10-09 14:53:38 +02:00
{
2016-02-25 22:28:09 +01:00
String command = CmdFactions . get ( ) . cmdFactionsKick . getCommandLine ( mplayer . getName ( ) ) ;
2015-09-08 19:18:45 +02:00
// Mson creation
Mson alreadyMember = Mson . mson (
Mson . parse ( mplayer . describeTo ( msender , true ) ) ,
mson ( ( samePlayer ? " are " : " is " ) + " already a member of " + faction . getName ( msender ) + " . " ) . color ( ChatColor . YELLOW )
) ;
message ( alreadyMember . suggest ( command ) . tooltip ( Txt . parse ( " <i>Click to <c>%s<i>. " , command ) ) ) ;
2011-03-19 13:00:03 +01:00
return ;
}
2012-02-24 13:30:28 +01:00
2014-09-17 13:29:58 +02:00
if ( MConf . get ( ) . factionMemberLimit > 0 & & faction . getMPlayers ( ) . size ( ) > = MConf . get ( ) . factionMemberLimit )
2012-02-24 13:30:28 +01:00
{
2014-09-18 13:41:20 +02:00
msg ( " <b>!<white> The faction %s is at the limit of %d members, so %s cannot currently join. " , faction . getName ( msender ) , MConf . get ( ) . factionMemberLimit , mplayer . describeTo ( msender , false ) ) ;
2012-02-24 13:30:28 +01:00
return ;
}
2014-09-17 13:29:58 +02:00
if ( mplayerFaction . isNormal ( ) )
2011-10-09 14:53:38 +02:00
{
2016-02-25 22:28:09 +01:00
String command = CmdFactions . get ( ) . cmdFactionsLeave . getCommandLine ( mplayer . getName ( ) ) ;
2015-09-08 19:18:45 +02:00
// Mson creation
Mson leaveFirst = Mson . mson (
Mson . parse ( mplayer . describeTo ( msender , true ) ) ,
mson ( " must leave " + ( samePlayer ? " your " : " their " ) + " current faction first. " ) . color ( ChatColor . RED )
) ;
message ( leaveFirst . suggest ( command ) . tooltip ( Txt . parse ( " <i>Click to <c>%s<i>. " , command ) ) ) ;
2011-03-19 13:00:03 +01:00
return ;
}
2012-02-24 13:30:28 +01:00
2014-09-17 13:29:58 +02:00
if ( ! MConf . get ( ) . canLeaveWithNegativePower & & mplayer . getPower ( ) < 0 )
2011-10-09 14:53:38 +02:00
{
2014-09-18 13:41:20 +02:00
msg ( " <b>%s cannot join a faction with a negative power level. " , mplayer . describeTo ( msender , true ) ) ;
2011-05-29 23:41:50 +02:00
return ;
}
2012-02-24 13:30:28 +01:00
2016-02-02 19:03:11 +01:00
if ( ! ( faction . getFlag ( MFlag . getFlagOpen ( ) ) | | faction . isInvited ( mplayer ) | | msender . isOverriding ( ) ) )
2011-10-09 14:53:38 +02:00
{
2011-10-10 13:40:24 +02:00
msg ( " <i>This faction requires invitation. " ) ;
2012-02-26 19:29:44 +01:00
if ( samePlayer )
2013-04-19 14:08:45 +02:00
{
2014-09-17 13:29:58 +02:00
faction . msg ( " %s<i> tried to join your faction. " , mplayer . describeTo ( faction , true ) ) ;
2013-04-19 14:08:45 +02:00
}
2011-03-19 13:00:03 +01:00
return ;
}
2013-04-19 14:08:45 +02:00
// Event
2014-09-18 13:41:20 +02:00
EventFactionsMembershipChange membershipChangeEvent = new EventFactionsMembershipChange ( sender , msender , faction , MembershipChangeReason . JOIN ) ;
2013-04-19 14:08:45 +02:00
membershipChangeEvent . run ( ) ;
if ( membershipChangeEvent . isCancelled ( ) ) return ;
// Inform
2012-02-26 19:29:44 +01:00
if ( ! samePlayer )
2013-04-19 14:08:45 +02:00
{
2014-09-18 13:41:20 +02:00
mplayer . msg ( " <i>%s <i>moved you into the faction %s<i>. " , msender . describeTo ( mplayer , true ) , faction . getName ( mplayer ) ) ;
2013-04-19 14:08:45 +02:00
}
2014-09-17 13:29:58 +02:00
faction . msg ( " <i>%s <i>joined <lime>your faction<i>. " , mplayer . describeTo ( faction , true ) ) ;
2014-09-18 13:41:20 +02:00
msender . msg ( " <i>%s <i>successfully joined %s<i>. " , mplayer . describeTo ( msender , true ) , faction . getName ( msender ) ) ;
2013-01-06 21:44:29 +01:00
2013-04-19 14:08:45 +02:00
// Apply
2014-09-17 13:29:58 +02:00
mplayer . resetFactionData ( ) ;
mplayer . setFaction ( faction ) ;
2018-12-20 01:35:30 +01:00
mplayer . setRank ( faction . getLowestRank ( ) ) ;
2016-10-09 10:59:43 +02:00
2017-04-20 11:05:56 +02:00
faction . uninvite ( mplayer ) ;
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
// Derplog
2013-04-22 10:05:03 +02:00
if ( MConf . get ( ) . logFactionJoin )
2012-02-26 19:29:44 +01:00
{
if ( samePlayer )
2013-06-18 09:07:05 +02:00
{
2014-09-17 13:29:58 +02:00
Factions . get ( ) . log ( Txt . parse ( " %s joined the faction %s. " , mplayer . getName ( ) , faction . getName ( ) ) ) ;
2013-06-18 09:07:05 +02:00
}
2012-02-26 19:29:44 +01:00
else
2013-06-18 09:07:05 +02:00
{
2014-09-18 13:41:20 +02:00
Factions . get ( ) . log ( Txt . parse ( " %s moved the player %s into the faction %s. " , msender . getName ( ) , mplayer . getName ( ) , faction . getName ( ) ) ) ;
2013-06-18 09:07:05 +02:00
}
2012-02-26 19:29:44 +01:00
}
2011-03-19 13:00:03 +01:00
}
2013-11-11 09:31:04 +01:00
2011-03-19 13:00:03 +01:00
}