2011-10-09 21:57:43 +02:00
package com.massivecraft.factions.cmd ;
2011-09-24 03:22:53 +02:00
2013-04-09 13:15:25 +02:00
import com.massivecraft.factions.ConfServer ;
2013-04-16 11:05:49 +02:00
import com.massivecraft.factions.Faction ;
2013-04-09 12:56:29 +02:00
import com.massivecraft.factions.Perm ;
2013-04-16 11:05:49 +02:00
import com.massivecraft.factions.cmd.arg.ARFaction ;
2011-10-23 20:14:51 +02:00
import com.massivecraft.factions.iface.EconomyParticipator ;
2013-04-09 13:00:09 +02:00
import com.massivecraft.factions.Factions ;
2011-10-05 12:13:54 +02:00
import com.massivecraft.factions.integration.Econ ;
2013-04-16 11:05:49 +02:00
import com.massivecraft.mcore.cmd.arg.ARDouble ;
2013-04-16 10:11:59 +02:00
import com.massivecraft.mcore.cmd.req.ReqHasPerm ;
2013-04-10 10:32:04 +02:00
import com.massivecraft.mcore.util.Txt ;
2011-09-24 03:22:53 +02:00
2011-10-23 20:14:51 +02:00
import org.bukkit.ChatColor ;
2013-04-10 13:12:22 +02:00
public class CmdFactionsMoneyWithdraw extends FCommand
2011-10-09 14:53:38 +02:00
{
2013-04-10 13:12:22 +02:00
public CmdFactionsMoneyWithdraw ( )
2011-10-09 14:53:38 +02:00
{
2013-04-16 10:11:59 +02:00
this . addAliases ( " w " , " withdraw " ) ;
2011-09-24 03:22:53 +02:00
2013-04-16 10:30:21 +02:00
this . addRequiredArg ( " amount " ) ;
this . addOptionalArg ( " faction " , " you " ) ;
2011-10-09 14:53:38 +02:00
2013-04-16 10:11:59 +02:00
this . addRequirements ( ReqHasPerm . get ( Perm . MONEY_WITHDRAW . node ) ) ;
2011-10-13 16:07:07 +02:00
this . setHelpShort ( " withdraw money " ) ;
2011-09-24 03:22:53 +02:00
}
@Override
2011-10-09 14:53:38 +02:00
public void perform ( )
{
2013-04-16 11:05:49 +02:00
Double amount = this . arg ( 0 , ARDouble . get ( ) ) ;
if ( amount = = null ) return ;
Faction faction = this . arg ( 1 , ARFaction . get ( ) , myFaction ) ;
2011-10-13 14:41:07 +02:00
if ( faction = = null ) return ;
2013-04-16 11:05:49 +02:00
2012-01-17 02:38:14 +01:00
boolean success = Econ . transferMoney ( fme , faction , fme , amount ) ;
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 ( success & & ConfServer . logMoneyTransactions )
2013-04-10 10:32:04 +02:00
Factions . get ( ) . log ( ChatColor . stripColor ( Txt . parse ( " %s withdrew %s from the faction bank: %s " , fme . getName ( ) , Econ . moneyString ( amount ) , faction . describeTo ( null ) ) ) ) ;
2011-09-24 03:22:53 +02:00
}
}