2011-10-09 21:57:43 +02:00
package com.massivecraft.factions.cmd ;
2011-03-19 13:00:03 +01:00
2012-03-02 02:16:45 +01:00
import org.bukkit.Bukkit ;
2013-04-09 13:15:25 +02:00
import com.massivecraft.factions.ConfServer ;
2013-01-06 21:44:29 +01:00
import com.massivecraft.factions.FPlayer ;
2013-04-09 13:22:23 +02:00
import com.massivecraft.factions.FPlayerColl ;
2011-07-18 22:06:02 +02:00
import com.massivecraft.factions.Faction ;
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 ;
2012-03-02 02:16:45 +01:00
import com.massivecraft.factions.event.FPlayerJoinEvent ;
2013-04-16 10:11:59 +02:00
import com.massivecraft.mcore.cmd.req.ReqHasPerm ;
2011-03-19 13:00:03 +01:00
2013-04-10 13:12:22 +02:00
public class CmdFactionsJoin extends FCommand
2011-10-09 14:53:38 +02:00
{
2013-04-10 13:12:22 +02:00
public CmdFactionsJoin ( )
2011-10-09 14:53:38 +02:00
{
super ( ) ;
2013-04-16 10:11:59 +02:00
this . addAliases ( " join " ) ;
2011-10-09 14:53:38 +02:00
2011-10-24 11:11:53 +02:00
this . requiredArgs . add ( " faction " ) ;
2012-02-26 19:29:44 +01:00
this . optionalArgs . put ( " player " , " you " ) ;
2011-03-22 18:48:09 +01:00
2013-04-16 10:11:59 +02:00
this . addRequirements ( ReqHasPerm . get ( Perm . JOIN . node ) ) ;
2011-03-19 13:00:03 +01:00
}
2011-06-21 07:38:31 +02:00
@Override
2011-10-09 14:53:38 +02:00
public void perform ( )
{
Faction faction = this . argAsFaction ( 0 ) ;
if ( faction = = null ) return ;
2011-03-19 13:00:03 +01:00
2012-02-26 19:29:44 +01:00
FPlayer fplayer = this . argAsBestFPlayerMatch ( 1 , fme , false ) ;
boolean samePlayer = fplayer = = fme ;
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
2012-02-26 19:29:44 +01:00
if ( faction = = fplayer . getFaction ( ) )
2011-10-09 14:53:38 +02:00
{
2012-02-26 19:29:44 +01:00
msg ( " <b>%s %s already a member of %s " , fplayer . describeTo ( fme , true ) , ( samePlayer ? " are " : " is " ) , faction . getTag ( fme ) ) ;
2011-03-19 13:00:03 +01:00
return ;
}
2012-02-24 13:30:28 +01:00
2013-04-09 13:15:25 +02:00
if ( ConfServer . factionMemberLimit > 0 & & faction . getFPlayers ( ) . size ( ) > = ConfServer . factionMemberLimit )
2012-02-24 13:30:28 +01:00
{
2013-04-09 13:15:25 +02:00
msg ( " <b>!<white> The faction %s is at the limit of %d members, so %s cannot currently join. " , faction . getTag ( fme ) , ConfServer . factionMemberLimit , fplayer . describeTo ( fme , false ) ) ;
2012-02-24 13:30:28 +01:00
return ;
}
2012-02-26 19:29:44 +01:00
if ( fplayer . hasFaction ( ) )
2011-10-09 14:53:38 +02:00
{
2012-02-26 19:29:44 +01:00
msg ( " <b>%s must leave %s current faction first. " , fplayer . describeTo ( fme , true ) , ( samePlayer ? " your " : " their " ) ) ;
2011-03-19 13:00:03 +01:00
return ;
}
2012-02-24 13:30:28 +01:00
2013-04-09 13:15:25 +02:00
if ( ! ConfServer . canLeaveWithNegativePower & & fplayer . getPower ( ) < 0 )
2011-10-09 14:53:38 +02:00
{
2012-02-26 19:29:44 +01:00
msg ( " <b>%s cannot join a faction with a negative power level. " , fplayer . describeTo ( fme , true ) ) ;
2011-05-29 23:41:50 +02:00
return ;
}
2012-02-24 13:30:28 +01:00
2013-04-11 11:44:55 +02:00
if ( ! ( faction . isOpen ( ) | | faction . isInvited ( fplayer ) | | fme . hasAdminMode ( ) | | Perm . JOIN_ANY . has ( sender , false ) ) )
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 )
faction . msg ( " %s<i> tried to join your faction. " , fplayer . describeTo ( faction , true ) ) ;
2011-03-19 13:00:03 +01:00
return ;
}
2012-03-13 15:48:34 +01:00
// if economy is enabled, they're not on the bypass list, and this command has a cost set, make sure they can pay
2013-04-09 13:15:25 +02:00
if ( samePlayer & & ! canAffordCommand ( ConfServer . econCostJoin , " to join a faction " ) ) return ;
Added basic support for iConomy, where most Factions commands can be made to cost (or give) money. For claiming land, there are some extra features. Each additional land claimed by default costs more than the last, with the multiplier being configurable. For example, the first claim might cost $30, the 2nd $45, the third $60, and so forth. When land is claimed from a weakened faction, there is a configurable bonus amount of money deducted from the cost of claiming the land, as an incentive; this number can be changed to a negative value to instead make it cost more to claim such land. When land is unclaimed, a configurable percentage of the cost of claiming the land can be refunded (defaults to 70% of the cost). The total value of a faction's claimed land is now shown in the info given by /f who [faction tag], along with the depreciated (refund) value.
2011-08-02 01:05:01 +02:00
2012-03-09 23:09:33 +01:00
// trigger the join event (cancellable)
2013-04-12 08:56:26 +02:00
FPlayerJoinEvent joinEvent = new FPlayerJoinEvent ( FPlayerColl . get ( ) . get ( me ) , faction , FPlayerJoinEvent . PlayerJoinReason . COMMAND ) ;
2012-03-02 02:16:45 +01:00
Bukkit . getServer ( ) . getPluginManager ( ) . callEvent ( joinEvent ) ;
if ( joinEvent . isCancelled ( ) ) return ;
2012-03-13 13:47:54 +01:00
2012-03-13 15:48:34 +01:00
// then make 'em pay (if applicable)
2013-04-09 13:15:25 +02:00
if ( samePlayer & & ! payForCommand ( ConfServer . econCostJoin , " to join a faction " , " for joining a faction " ) ) return ;
2012-03-13 15:48:34 +01:00
2013-04-09 13:15:25 +02:00
fme . setRole ( ConfServer . factionRankDefault ) ; // They have just joined a faction, start them out on the lowest rank (default config).
2012-03-13 13:47:54 +01:00
2012-02-26 19:29:44 +01:00
if ( ! samePlayer )
fplayer . msg ( " <i>%s moved you into the faction %s. " , fme . describeTo ( fplayer , true ) , faction . getTag ( fplayer ) ) ;
faction . msg ( " <i>%s joined your faction. " , fplayer . describeTo ( faction , true ) ) ;
2013-01-06 21:44:29 +01:00
fme . msg ( " <i>%s successfully joined %s. " , fplayer . describeTo ( fme , true ) , faction . getTag ( fme ) ) ;
2012-02-26 19:29:44 +01:00
fplayer . resetFactionData ( ) ;
fplayer . setFaction ( faction ) ;
2013-01-06 21:44:29 +01:00
2012-02-26 19:29:44 +01:00
faction . deinvite ( fplayer ) ;
2013-01-06 21:44:29 +01:00
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-09 13:15:25 +02:00
if ( ConfServer . logFactionJoin )
2012-02-26 19:29:44 +01:00
{
if ( samePlayer )
2013-04-09 13:12:13 +02:00
Factions . get ( ) . log ( " %s joined the faction %s. " , fplayer . getName ( ) , faction . getTag ( ) ) ;
2012-02-26 19:29:44 +01:00
else
2013-04-09 13:12:13 +02:00
Factions . get ( ) . log ( " %s moved the player %s into the faction %s. " , fme . getName ( ) , fplayer . getName ( ) , faction . getTag ( ) ) ;
2012-02-26 19:29:44 +01:00
}
2011-03-19 13:00:03 +01:00
}
}