2015-08-21 15:10:08 +02:00
/ * *
* Jobs Plugin for Bukkit
* Copyright ( C ) 2011 Zak Ford < zak . j . ford @gmail.com >
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
* /
package com.gamingmesh.jobs.config ;
import java.io.File ;
import java.io.IOException ;
import java.util.ArrayList ;
import java.util.Arrays ;
import java.util.List ;
import java.util.Locale ;
import org.bukkit.Bukkit ;
import org.bukkit.Location ;
import org.bukkit.World ;
import org.bukkit.configuration.Configuration ;
import org.bukkit.configuration.ConfigurationSection ;
import org.bukkit.configuration.file.YamlConfiguration ;
import org.bukkit.entity.Player ;
import org.bukkit.plugin.java.JavaPlugin ;
import com.gamingmesh.jobs.Jobs ;
import com.gamingmesh.jobs.resources.jfep.Parser ;
import com.gamingmesh.jobs.JobsPlugin ;
import com.gamingmesh.jobs.container.NameList ;
import com.gamingmesh.jobs.container.RestrictedArea ;
import com.gamingmesh.jobs.container.Schedule ;
import com.gamingmesh.jobs.container.Title ;
import com.gamingmesh.jobs.dao.JobsDAOMySQL ;
import com.gamingmesh.jobs.dao.JobsDAOSQLite ;
import com.gamingmesh.jobs.stuff.ChatColor ;
public class JobsConfiguration {
2015-09-10 12:41:19 +02:00
private JobsPlugin plugin ;
protected List < Title > titles = new ArrayList < Title > ( ) ;
protected ArrayList < RestrictedArea > restrictedAreas = new ArrayList < RestrictedArea > ( ) ;
public ArrayList < String > restrictedBlocks = new ArrayList < String > ( ) ;
public ArrayList < String > restrictedBlocksTimer = new ArrayList < String > ( ) ;
public ArrayList < Integer > restrictedPlaceBlocksTimer = new ArrayList < Integer > ( ) ;
public ArrayList < NameList > ListOfNames = new ArrayList < NameList > ( ) ;
public ArrayList < NameList > ListOfEntities = new ArrayList < NameList > ( ) ;
public ArrayList < NameList > ListOfEnchants = new ArrayList < NameList > ( ) ;
public ArrayList < NameList > ListOfColors = new ArrayList < NameList > ( ) ;
public List < Integer > BroadcastingLevelUpLevels = new ArrayList < Integer > ( ) ;
protected Locale locale ;
protected int savePeriod ;
protected boolean economyAsync ;
protected boolean isBroadcastingSkillups ;
protected boolean isBroadcastingLevelups ;
protected boolean payInCreative ;
protected boolean addXpPlayer ;
protected boolean hideJobsWithoutPermission ;
protected int maxJobs ;
protected boolean payNearSpawner ;
protected boolean modifyChat ;
protected int economyBatchDelay ;
protected boolean saveOnDisconnect ;
2015-09-17 17:28:23 +02:00
public boolean LocalOfflinePlayersData ;
public boolean LoggingUse ;
2015-09-10 12:41:19 +02:00
public boolean EconomyLimitUse , EconomyExpLimitUse , PayForRenaming , PayForEachCraft , SignsEnabled ,
SignsColorizeJobName , ShowToplistInScoreboard , useGlobalTimer , useCoreProtect , BlockPlaceUse ,
EnableAnounceMessage , useBlockPiston , useSilkTouchProtection , UseCustomNames , EconomyMoneyStop ,
EconomyExpStop , UseJobsBrowse , PreventSlimeSplit , PreventMagmaCubeSplit ;
public int EconomyLimitMoneyLimit , EconomyExpLimit ;
public int EconomyLimitTimeLimit , EconomyExpTimeLimit ;
public int EconomyLimitAnnouncmentDelay , EconomyLimitAnnouncmentExpDelay , globalblocktimer , CowMilkingTimer ,
CoreProtectInterval , BlockPlaceInterval , InfoUpdateInterval ;
public Double payNearSpawnerMultiplier , VIPpayNearSpawnerMultiplier , TreeFellerMultiplier , PetPay , VipPetPay ;
public String localeString ;
public boolean useBlockProtection ;
public boolean useBlockTimer ;
public boolean useBreederFinder , CancelCowMilking ;
public boolean fixAtMaxLevel , ToggleActionBar , TitleChangeChat , TitleChangeActionBar , LevelChangeChat ,
LevelChangeActionBar , SoundLevelupUse , SoundTitleChangeUse , UseServerAccount , EmptyServerAcountChat ,
EmptyServerAcountActionBar , JobsToggleEnabled , ShowTotalWorkers , ShowPenaltyBonus , useDynamicPayment ,
useGlobalBoostScheduler ;
public Integer levelLossPercentage , SoundLevelupVolume , SoundLevelupPitch , SoundTitleChangeVolume ,
SoundTitleChangePitch , ToplistInScoreboardInterval ;
public double BoostExp ;
public double BoostMoney ;
public double DynamicPaymentMaxPenalty ;
public double DynamicPaymentMaxBonus ;
public double TaxesAmount ;
public String SoundLevelupSound , SoundTitleChangeSound , ServerAcountName , ServertaxesAcountName ;
public ArrayList < String > keys ;
public String storageMethod ;
public boolean hideJobsInfoWithoutPermission ;
public boolean UseTaxes ;
public boolean TransferToServerAccount ;
public boolean TakeFromPlayersPayment ;
public Parser DynamicPaymentEquation ;
public List < Schedule > BoostSchedule = new ArrayList < Schedule > ( ) ;
public JobsConfiguration ( JobsPlugin plugin ) {
super ( ) ;
this . plugin = plugin ;
}
public String Colors ( String text ) {
return org . bukkit . ChatColor . translateAlternateColorCodes ( '&' , text ) ;
}
public String GetConfigString ( String path , String text , CommentedYamlConfiguration writer , YamlConfiguration conf , Boolean colorize ) {
conf . addDefault ( path , text ) ;
text = conf . getString ( path ) ;
if ( colorize )
text = Colors ( text ) ;
copySetting ( conf , writer , path ) ;
return text ;
}
/ * *
* Get how often in minutes to save job information
* @return how often in minutes to save job information
* /
public synchronized int getSavePeriod ( ) {
return savePeriod ;
}
/ * *
* Should we use asynchronous economy calls
* @return true - use async
* @return false - use sync
* /
public synchronized boolean isEconomyAsync ( ) {
return economyAsync ;
}
/ * *
* Function that tells if the system is set to broadcast on skill up
* @return true - broadcast on skill up
* @return false - do not broadcast on skill up
* /
public synchronized boolean isBroadcastingSkillups ( ) {
return isBroadcastingSkillups ;
}
/ * *
* Function that tells if the system is set to broadcast on level up
* @return true - broadcast on level up
* @return false - do not broadcast on level up
* /
public synchronized boolean isBroadcastingLevelups ( ) {
return isBroadcastingLevelups ;
}
/ * *
* Function that tells if the player should be paid while in creative
* @return true - pay in creative
* @return false - do not pay in creative
* /
public synchronized boolean payInCreative ( ) {
return payInCreative ;
}
/ * *
* Function to return the title for a given level
* @return the correct title
* @return null if no title matches
* /
public Title getTitleForLevel ( int level , String jobName ) {
Title title = null ;
for ( Title t : titles ) {
if ( title = = null ) {
if ( t . getLevelReq ( ) < = level ) {
title = t ;
}
} else {
if ( t . getLevelReq ( ) < = level & & t . getLevelReq ( ) > title . getLevelReq ( ) ) {
title = t ;
}
}
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
return title ;
}
public synchronized boolean addXpPlayer ( ) {
return addXpPlayer ;
}
/ * *
* Function to check if jobs should be hidden to players that lack permission to join the job
* @return
* /
public synchronized boolean getHideJobsWithoutPermission ( ) {
return hideJobsWithoutPermission ;
}
/ * *
* Function to return the maximum number of jobs a player can join
* @return
* /
public synchronized int getMaxJobs ( ) {
return maxJobs ;
}
/ * *
* Function to check if you get paid near a spawner is enabled
* @return true - you get paid
* @return false - you don ' t get paid
* /
public synchronized boolean payNearSpawner ( ) {
return payNearSpawner ;
}
/ * *
* Gets the area multiplier for the player
* @param player
* @return - the multiplier
* /
public synchronized double getRestrictedMultiplier ( Player player ) {
for ( RestrictedArea area : restrictedAreas ) {
if ( area . inRestrictedArea ( player ) )
return area . getMultiplier ( ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
return 1 . 0 ;
}
public synchronized boolean getModifyChat ( ) {
return modifyChat ;
}
public synchronized int getEconomyBatchDelay ( ) {
return economyBatchDelay ;
}
public synchronized boolean saveOnDisconnect ( ) {
return saveOnDisconnect ;
}
public synchronized Locale getLocale ( ) {
return locale ;
}
public synchronized void reload ( ) {
// general settings
loadGeneralSettings ( ) ;
// Load locale
loadLanguage ( ) ;
// title settings
loadTitleSettings ( ) ;
// restricted areas
loadRestrictedAreaSettings ( ) ;
// restricted blocks
loadRestrictedBlocks ( ) ;
// Item/Block/mobs name list
loadItemList ( ) ;
// Item/Block/mobs name list
2015-09-17 09:48:10 +02:00
com . gamingmesh . jobs . Signs . SignUtil . LoadSigns ( ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
// loadScheduler();
}
/ * *
* Method to load the general configuration
*
* loads from Jobs / generalConfig . yml
* /
private synchronized void loadGeneralSettings ( ) {
File f = new File ( plugin . getDataFolder ( ) , " generalConfig.yml " ) ;
YamlConfiguration config = YamlConfiguration . loadConfiguration ( f ) ;
CommentedYamlConfiguration writer = new CommentedYamlConfiguration ( ) ;
StringBuilder header = new StringBuilder ( ) ;
header . append ( " General configuration. " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
header . append ( " The general configuration for the jobs plugin mostly includes how often the plugin " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
header . append ( " saves user data (when the user is in the game), the storage method, whether " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
header . append ( " to broadcast a message to the server when a user goes up a skill level. " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
header . append ( " It also allows admins to set the maximum number of jobs a player can have at " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
header . append ( " any one time. " ) ;
header . append ( System . getProperty ( " line.separator " ) ) ;
config . options ( ) . copyDefaults ( true ) ;
writer . options ( ) . header ( header . toString ( ) ) ;
writer . addComment ( " locale-language " , " Default language. " , " Example: en, ru " , " File in locale folder with same name should exist. Example: messages_ru.yml " ) ;
localeString = getString ( " locale-language " , " en " , config , writer ) ;
try {
int i = localeString . indexOf ( '_' ) ;
if ( i = = - 1 ) {
locale = new Locale ( localeString ) ;
} else {
locale = new Locale ( localeString . substring ( 0 , i ) , localeString . substring ( i + 1 ) ) ;
}
} catch ( IllegalArgumentException e ) {
locale = Locale . getDefault ( ) ;
Jobs . getPluginLogger ( ) . warning ( " Invalid locale \" " + localeString + " \" defaulting to " + locale . getLanguage ( ) ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
writer . addComment ( " storage-method " , " storage method, can be MySQL, sqlite " ) ;
storageMethod = getString ( " storage-method " , " sqlite " , config , writer ) ;
if ( storageMethod . equalsIgnoreCase ( " mysql " ) ) {
startMysql ( ) ;
// } else if (storageMethod.equalsIgnoreCase("h2")) {
// File h2jar = new File(plugin.getDataFolder(), "h2.jar");
// Jobs.getPluginLogger().warning("H2 database no longer supported! Converting to SQLite.");
// if (!h2jar.exists()) {
// Jobs.getPluginLogger().info("H2 library not found, downloading...");
// try {
// FileDownloader.downloadFile(new URL("http://dev.bukkit.org/media/files/692/88/h2-1.3.171.jar"), h2jar);
// } catch (MalformedURLException e) {
// e.printStackTrace();
// } catch (IOException e) {
// Jobs.getPluginLogger().severe("Could not download database library!");
// }
// }
// if (plugin.isEnabled()) {
// try {
// Jobs.getJobsClassloader().addFile(h2jar);
// } catch (IOException e) {
// Jobs.getPluginLogger().severe("Could not load database library!");
// }
// if (plugin.isEnabled()) {
// try {
// JobsDAOH2.convertToSQLite();
// Jobs.setDAO(JobsDAOSQLite.initialize());
// config.set("storage-method", "sqlite");
// } catch (SQLException e) {
// Jobs.getPluginLogger().severe("Error when converting from H2 to SQLite!");
// e.printStackTrace();
// }
// }
// }
} else if ( storageMethod . equalsIgnoreCase ( " sqlite " ) ) {
startSqlite ( ) ;
} else {
Jobs . getPluginLogger ( ) . warning ( " Invalid storage method! Changing method to sqlite! " ) ;
config . set ( " storage-method " , " sqlite " ) ;
Jobs . setDAO ( JobsDAOSQLite . initialize ( ) ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
writer . addComment ( " mysql-username " , " Requires Mysql. " ) ;
getString ( " mysql-username " , " root " , config , writer ) ;
getString ( " mysql-password " , " " , config , writer ) ;
getString ( " mysql-hostname " , " localhost:3306 " , config , writer ) ;
getString ( " mysql-database " , " minecraft " , config , writer ) ;
getString ( " mysql-table-prefix " , " jobs_ " , config , writer ) ;
writer . addComment ( " save-period " , " How often in minutes you want it to save. This must be a non-zero number " ) ;
getInt ( " save-period " , 10 , config , writer ) ;
if ( config . getInt ( " save-period " ) < = 0 ) {
Jobs . getPluginLogger ( ) . severe ( " Save period must be greater than 0! Defaulting to 10 minutes! " ) ;
config . set ( " save-period " , 10 ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
savePeriod = config . getInt ( " save-period " ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " save-on-disconnect " , " Should player data be saved on disconnect? " ,
" Player data is always periodically auto-saved and autosaved during a clean shutdown. " ,
" Only enable this if you have a multi-server setup, or have a really good reason for enabling this. " , " Turning this on will decrease database performance. " ) ;
saveOnDisconnect = getBoolean ( " save-on-disconnect " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-17 17:28:23 +02:00
writer . addComment ( " Optimizations.UseLocalOfflinePlayersData " , " With this set to true, offline player data will be taken from local player data files " ,
" This will eliminate small lag spikes when request is being send to mojangs servers for offline players data " ,
" Theroticali this should work without issues, but if you havving some, just disable " ,
" But then you can feal some small (100-200ms) lag spikes while performings some jobs commands " ) ;
LocalOfflinePlayersData = getBoolean ( " Optimizations.UseLocalOfflinePlayersData " , true , config , writer ) ;
writer . addComment ( " Logging.Use " , " With this set to true all players jobs actions will be logged to database for easy to see statistics " ,
" This is still in development and in feature it will expand " ) ;
LoggingUse = getBoolean ( " Logging.Use " , false , config , writer ) ;
2015-09-10 12:41:19 +02:00
writer . addComment ( " broadcast.on-skill-up.use " , " Do all players get a message when somone goes up a skill level? " ) ;
isBroadcastingSkillups = getBoolean ( " broadcast.on-skill-up.use " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " broadcast.on-level-up.use " , " Do all players get a message when somone goes up a level? " ) ;
isBroadcastingLevelups = getBoolean ( " broadcast.on-level-up.use " , false , config , writer ) ;
writer . addComment ( " broadcast.on-level-up.levels " , " For what levels you want to broadcast message? Keep it at 0 if you want for all of them " ) ;
BroadcastingLevelUpLevels = getIntArray ( " broadcast.on-level-up.levels " , Arrays . asList ( 0 ) , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " max-jobs " , " Maximum number of jobs a player can join. " , " Use 0 for no maximum " ) ;
maxJobs = getInt ( " max-jobs " , 3 , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " hide-jobs-without-permission " , " Hide jobs from player if they lack the permission to join the job " ) ;
hideJobsWithoutPermission = getBoolean ( " hide-jobs-without-permission " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " hide-jobsinfo-without-permission " , " Hide jobs info from player if they lack the permission to join the job " ) ;
hideJobsInfoWithoutPermission = getBoolean ( " hide-jobsinfo-without-permission " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " enable-pay-near-spawner " , " Option to allow payment to be made when killing mobs from a spawner " ) ;
payNearSpawner = getBoolean ( " enable-pay-near-spawner " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " pay-near-spawner-multiplier " , " enable-pay-near-spawner should be enabled for this to work " ,
" 0.5 means that players will get only 50% exp/money from monsters spawned from spawner " ) ;
payNearSpawnerMultiplier = getDouble ( " pay-near-spawner-multiplier " , 1 . 0 , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " VIP-pay-near-spawner-multiplier " , " VIP multiplier to pay for monsters from spawners, this will ignore global multiplier " ,
" Use jobs.vipspawner permission node for this to be enabled " ) ;
VIPpayNearSpawnerMultiplier = getDouble ( " VIP-pay-near-spawner-multiplier " , 1 . 0 , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " enable-pay-creative " , " Option to allow payment to be made in creative mode " ) ;
payInCreative = getBoolean ( " enable-pay-creative " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " add-xp-player " , " Adds the Jobs xp recieved to the player's Minecraft XP bar " ) ;
addXpPlayer = getBoolean ( " add-xp-player " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " modify-chat " ,
" Modifys chat to add chat titles. If you're using a chat manager, you may add the tag {jobs} to your chat format and disable this. " ) ;
modifyChat = getBoolean ( " modify-chat " , true , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " UseCustomNames " , " Do you want to use custom item/block/mob/enchant/color names " ,
" With this set to true names like Stone:1 will be translated to Granite " , " Name list is in ItemList.yml file " ) ;
UseCustomNames = getBoolean ( " UseCustomNames " , true , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " economy-batch-delay " , " Changes how often, in seconds, players are paid out. Default is 5 seconds. " ,
" Setting this too low may cause tick lag. Increase this to improve economy performance (at the cost of delays in payment) " ) ;
economyBatchDelay = getInt ( " economy-batch-delay " , 5 , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " economy-async " , " Enable async economy calls. " , " Disabl this if you have issues with payments or your plugin is not thread safe. " ) ;
economyAsync = getBoolean ( " economy-async " , true , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
writer . addComment ( " Economy.DynamicPayment.use " , " Do you want to use dinamic payment dependent on how many players already working for jobs " ,
" This can help automaticaly lift up payments for not so popular jobs and lower for most popular ones " ) ;
useDynamicPayment = getBoolean ( " Economy.DynamicPayment.use " , false , config , writer ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
String maxExpEquationInput = getString ( " Economy.DynamicPayment.equation " , " ((totalworkers / totaljobs) - jobstotalplayers)/10.0 " , config , writer ) ;
try {
DynamicPaymentEquation = new Parser ( maxExpEquationInput ) ;
// test equation
DynamicPaymentEquation . setVariable ( " totalworkers " , 100 ) ;
DynamicPaymentEquation . setVariable ( " totaljobs " , 10 ) ;
DynamicPaymentEquation . setVariable ( " jobstotalplayers " , 10 ) ;
DynamicPaymentEquation . getValue ( ) ;
} catch ( Exception e ) {
Bukkit . getConsoleSender ( ) . sendMessage ( ChatColor . RED + " Dynamic payment equation has an invalid property. Disabling feature! " ) ;
useDynamicPayment = false ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
DynamicPaymentMaxPenalty = getDouble ( " Economy.DynamicPayment.MaxPenalty " , 25 . 0 , config , writer ) ;
DynamicPaymentMaxBonus = getDouble ( " Economy.DynamicPayment.MaxBonus " , 100 . 0 , config , writer ) ;
writer . addComment ( " Economy.EnabledJobsToglle " , " Do you want to enable jobs toggle by default " ) ;
JobsToggleEnabled = getBoolean ( " Economy.EnabledJobsToglle " , true , config , writer ) ;
writer . addComment ( " Economy.UseServerAcount " , " Server economy acount " , " With this enabled, players will get money from defined user (server account) " ,
" If this acount dont have enough money to pay for players for, player will get message " ) ;
UseServerAccount = getBoolean ( " Economy.UseServerAcount " , false , config , writer ) ;
writer . addComment ( " Economy.AcountName " , " Username should be with Correct capitalization " ) ;
ServerAcountName = getString ( " Economy.AcountName " , " Server " , config , writer ) ;
writer . addComment ( " Economy.Taxes.use " , " Do you want to use taxes feature for jobs payment " ) ;
UseTaxes = getBoolean ( " Economy.Taxes.use " , false , config , writer ) ;
writer . addComment ( " Economy.Taxes.AccountName " , " Username should be with Correct capitalization, it can be same as settup in server account before " ) ;
ServertaxesAcountName = getString ( " Economy.Taxes.AccountName " , " Server " , config , writer ) ;
writer . addComment ( " Economy.Taxes.Amount " , " Amount in percentage " ) ;
TaxesAmount = getDouble ( " Economy.Taxes.Amount " , 15 . 0 , config , writer ) ;
writer . addComment ( " Economy.Taxes.TransferToServerAccount " , " Do you want to transfer taxes to server account " ) ;
TransferToServerAccount = getBoolean ( " Economy.Taxes.TransferToServerAccount " , true , config , writer ) ;
writer . addComment ( " Economy.Taxes.TakeFromPlayersPayment " ,
" With this true, taxes will be taken from players payment and he will get less money than its shown in jobs info " ,
" When its false player will get full payment and server account will get taxes amount to hes account " ) ;
TakeFromPlayersPayment = getBoolean ( " Economy.Taxes.TakeFromPlayersPayment " , false , config , writer ) ;
writer . addComment ( " Economy.Limit.Money " , " Money gain limit " , " With this enabled, players will be limited how much they can make in defined time " ,
" Time in seconds: 60 = 1min, 3600 = 1 hour, 86400 = 24 hours " ) ;
EconomyLimitUse = getBoolean ( " Economy.Limit.Money.Use " , false , config , writer ) ;
writer . addComment ( " Economy.Limit.Money.StopWithExp " , " Do you want to stop money gain when exp limit reached? " ) ;
EconomyMoneyStop = getBoolean ( " Economy.Limit.Money.StopWithExp " , false , config , writer ) ;
EconomyLimitMoneyLimit = getInt ( " Economy.Limit.Money.MoneyLimit " , 500 , config , writer ) ;
writer . addComment ( " Economy.Limit.Money.TimeLimit " , " Time in seconds: 60 = 1min, 3600 = 1 hour, 86400 = 24 hours " ) ;
EconomyLimitTimeLimit = getInt ( " Economy.Limit.Money.TimeLimit " , 3600 , config , writer ) ;
writer . addComment ( " Economy.Limit.Money.AnnouncmentDelay " , " Delay between announcements about reached money limit " ,
" Keep this from 30 to 5 min (300), as players can get annoyed of constant message displaying " ) ;
EconomyLimitAnnouncmentDelay = getInt ( " Economy.Limit.Money.AnnouncmentDelay " , 30 , config , writer ) ;
writer . addComment ( " Economy.Limit.Exp " , " Exp gain limit " , " With this enabled, players will be limited how much they can get in defined time " ,
" Time in seconds: 60 = 1min, 3600 = 1 hour, 86400 = 24 hours " ) ;
EconomyExpLimitUse = getBoolean ( " Economy.Limit.Exp.Use " , false , config , writer ) ;
writer . addComment ( " Economy.Limit.Exp.StopWithMoney " , " Do you want to stop exp gain when money limit reached? " ) ;
EconomyExpStop = getBoolean ( " Economy.Limit.Exp.StopWithMoney " , false , config , writer ) ;
EconomyExpLimit = getInt ( " Economy.Limit.Exp.Limit " , 5000 , config , writer ) ;
writer . addComment ( " Economy.Limit.Exp.TimeLimit " , " Time in seconds: 60 = 1min, 3600 = 1 hour, 86400 = 24 hours " ) ;
EconomyExpTimeLimit = getInt ( " Economy.Limit.Exp.TimeLimit " , 3600 , config , writer ) ;
writer . addComment ( " Economy.Limit.Exp.AnnouncmentDelay " , " Delay between announcements about reached Exp limit " ,
" Keep this from 30 to 5 min (300), as players can get annoyed of constant message displaying " ) ;
EconomyLimitAnnouncmentExpDelay = getInt ( " Economy.Limit.Exp.AnnouncmentDelay " , 30 , config , writer ) ;
writer . addComment ( " Economy.Repair.PayForRenaming " , " Do you want to give money for only renaming items in anvil " ,
" Players will get full pay as they would for remairing two items when they only renaming one " ,
" This is not big issue, but if you want to disable it, you can " ) ;
PayForRenaming = getBoolean ( " Economy.Repair.PayForRenaming " , true , config , writer ) ;
writer . addComment ( " Economy.Crafting.PayForEachCraft " ,
" With this true, player will get money for all crafted items instead of each crafting action (like with old payment mechanic) " ,
" By default its false, as you can make ALOT of money if prices kept from old payment mechanics " ) ;
PayForEachCraft = getBoolean ( " Economy.Crafting.PayForEachCraft " , false , config , writer ) ;
writer . addComment ( " Economy.MilkingCow.CancelMilking " , " With this true, when timer is still going, cow milking event will be canceled " ,
" With this false, player will get bucket of milk, but still no payment " ) ;
CancelCowMilking = getBoolean ( " Economy.MilkingCow.CancelMilking " , false , config , writer ) ;
writer . addComment ( " Economy.MilkingCow.Timer " ,
" How ofter player can milk cows in seconds. Keep in mind that by default player can milk cow indefinetly and as often as he wants " ,
" Set to 0 if you want to disable timer " ) ;
CowMilkingTimer = getInt ( " Economy.MilkingCow.Timer " , 30 , config , writer ) * 1000 ;
writer . addComment ( " ExploitProtections.Coreprotect.Use " ,
" Requires to have CoreProtect plugin and there should be block place/break logging enabled in core protect config file. " ,
" This will prevent players from abusing by placing and breaking blocks again and again " , " This will work even after server restart " ) ;
useCoreProtect = getBoolean ( " ExploitProtections.Coreprotect.Use " , false , config , writer ) ;
writer . addComment ( " ExploitProtections.Coreprotect.TimeLimit " , " Time limit in minutes to protect blocks from repeating place/breake action. " ,
" 10080 equals to 7 days, keep it in reasonable time range " ) ;
CoreProtectInterval = getInt ( " ExploitProtections.Coreprotect.TimeLimit " , 604800 , config , writer ) ;
writer . addComment ( " ExploitProtections.Coreprotect.BlockPlace.Use " , " Do you want to use block place interval protection " ) ;
BlockPlaceUse = getBoolean ( " ExploitProtections.Coreprotect.BlockPlace.Use " , true , config , writer ) ;
EnableAnounceMessage = getBoolean ( " ExploitProtections.Coreprotect.BlockPlace.EnableAnounceMessage " , true , config , writer ) ;
writer . addComment ( " ExploitProtections.Coreprotect.BlockPlace.Interval " , " Time interval in seconds in how fast you can place block in same place. " ,
" Keep it on low interval, 3-5 sec will be enough to prevent fast block place in same place and dont annoy peps " ,
" Edit block list in restrictedBlocks.yml under PlacedBlockTimer " ) ;
BlockPlaceInterval = getInt ( " ExploitProtections.Coreprotect.BlockPlace.Interval " , 2 , config , writer ) ;
writer . addComment ( " ExploitProtections.General.PlaceAndBreakProtection " ,
" Enable blocks protection, like ore, from exploiting by placing and destroying same block again and again. " , " This works only until server restart " ,
" Modify restrictedBlocks.yml for blocks you want to protect " ) ;
useBlockProtection = getBoolean ( " ExploitProtections.General.PlaceAndBreakProtection " , true , config , writer ) ;
writer . addComment ( " ExploitProtections.General.SilkTouchProtection " , " Enable silk touch protection. " ,
" With this enabled players wont get paid for breaked blocks from restrictedblocks list with silk touch tool. " ) ;
useSilkTouchProtection = getBoolean ( " ExploitProtections.General.SilkTouchProtection " , false , config , writer ) ;
writer . addComment ( " ExploitProtections.General.StopPistonBlockMove " , " Enable piston moving blocks from restrictedblocks list. " ,
" If piston moves block then it will be like new block and BlockPlaceAndBreakProtection wont work properly " ,
" If you using core protect and its being logging piston block moving, then you can disable this " ) ;
useBlockPiston = getBoolean ( " ExploitProtections.General.StopPistonBlockMove " , true , config , writer ) ;
writer . addComment ( " ExploitProtections.General.BlocksTimer " , " Enable blocks timer protection. " ,
" Only enable if you want to protect block from beying broken to fast, useful for vegetables. " , " Modify restrictedBlocks.yml for blocks you want to protect " ) ;
useBlockTimer = getBoolean ( " ExploitProtections.General.BlocksTimer " , true , config , writer ) ;
writer . addComment ( " ExploitProtections.General.GlobalBlockTimer " , " All blocks will be protected X sec after player places it on ground. " ) ;
useGlobalTimer = getBoolean ( " ExploitProtections.General.GlobalBlockTimer.use " , false , config , writer ) ;
globalblocktimer = getInt ( " ExploitProtections.General.GlobalBlockTimer.timer " , 30 , config , writer ) ;
writer . addComment ( " ExploitProtections.General.PetPay " , " Do you want to pay when players pet kills monster/player " , " Can be exploited with mob farms " ,
" 0.2 means 20% of original reward " , " Optionaly you can give jobs.petpay permission node for specific players/ranks to get paid by VipPetPay multiplier " ) ;
PetPay = getDouble ( " ExploitProtections.General.PetPay " , 0 . 1 , config , writer ) ;
VipPetPay = getDouble ( " ExploitProtections.General.VipPetPay " , 1 . 0 , config , writer ) ;
writer . addComment ( " ExploitProtections.McMMO " , " McMMO abilities " ) ;
writer . addComment ( " ExploitProtections.McMMO.TreeFellerMultiplier " , " Players will get part of money from cutting trees with treefeller ability enabled. " ,
" 0.2 means 20% of original price " ) ;
TreeFellerMultiplier = getDouble ( " ExploitProtections.McMMO.TreeFellerMultiplier " , 0 . 2 , config , writer ) ;
2015-09-17 09:48:10 +02:00
writer . addComment ( " ExploitProtections.Spawner.PreventSlimeSplit " , " Prevent slime spliting when they are from spawner " ,
" Protects agains exploiting as new splited slimes is treated as naturaly spawned and not from spawner " ) ;
2015-09-10 12:41:19 +02:00
PreventSlimeSplit = getBoolean ( " ExploitProtections.Spawner.PreventSlimeSplit " , true , config , writer ) ;
writer . addComment ( " ExploitProtections.Spawner.PreventMagmaCubeSplit " , " Prevent magmacube spliting when they are from spawner " ) ;
PreventMagmaCubeSplit = getBoolean ( " ExploitProtections.Spawner.PreventMagmaCubeSplit " , true , config , writer ) ;
writer . addComment ( " use-breeder-finder " , " Breeder finder. " ,
" If you are not using breeding payment, you can disable this to save little resources. Really little. " ) ;
useBreederFinder = getBoolean ( " use-breeder-finder " , true , config , writer ) ;
writer . addComment ( " boost " , " Money exp boost with special permision. " , " You will need to add special permision for groups or players to have money/exp boost. " ,
" Use: jobs.boost.[jobname].money or jobs.boost.[jobname].exp or jobs.boost.[jobname].both for both of them with specific jobs name. " ,
" Use: jobs.boost.all.money or jobs.boost.all.exp or jobs.boost.all.both to get boost for all jobs " ,
" 1.25 means that player will get 25% more than others, you can set less than 1 to get less from anothers " ) ;
BoostExp = getDouble ( " boost.exp " , 1 . 25 , config , writer ) ;
BoostMoney = getDouble ( " boost.money " , 1 . 25 , config , writer ) ;
writer . addComment ( " old-job " , " Old job save " , " Players can leave job and return later with some level loss during that " ,
" You can fix players level if hes job level is at max level " ) ;
levelLossPercentage = getInt ( " old-job.level-loss-percentage " , 30 , config , writer ) ;
fixAtMaxLevel = getBoolean ( " old-job.fix-at-max-level " , true , config , writer ) ;
writer . addComment ( " ActionBars " , " Action bars " , " You can enable/disable togglebale message by player with /jobs toggle " ) ;
ToggleActionBar = getBoolean ( " ActionBars.Toggle " , true , config , writer ) ;
writer . addComment ( " ShowActionBars " , " You can enable/disable message shown for players in action bar " ) ;
TitleChangeActionBar = getBoolean ( " ShowActionBars.OnTitleChange " , true , config , writer ) ;
LevelChangeActionBar = getBoolean ( " ShowActionBars.OnLevelChange " , true , config , writer ) ;
EmptyServerAcountActionBar = getBoolean ( " ShowActionBars.OnEmptyServerAcount " , true , config , writer ) ;
writer . addComment ( " ShowChatMessage " , " Chat messages " , " You can enable/disable message shown for players in chat " ) ;
TitleChangeChat = getBoolean ( " ShowChatMessage.OnTitleChange " , true , config , writer ) ;
LevelChangeChat = getBoolean ( " ShowChatMessage.OnLevelChange " , true , config , writer ) ;
EmptyServerAcountChat = getBoolean ( " ShowChatMessage.OnEmptyServerAcount " , true , config , writer ) ;
writer . addComment ( " Sounds " , " Sounds " , " Extra sounds on some events " , " All sounds can be found in https://hub.spigotmc.org/javadocs/spigot/org/bukkit/Sound.html " ) ;
SoundLevelupUse = getBoolean ( " Sounds.LevelUp.use " , true , config , writer ) ;
SoundLevelupSound = getString ( " Sounds.LevelUp.sound " , " LEVEL_UP " , config , writer ) ;
SoundLevelupVolume = getInt ( " Sounds.LevelUp.volume " , 1 , config , writer ) ;
SoundLevelupPitch = getInt ( " Sounds.LevelUp.pitch " , 3 , config , writer ) ;
SoundTitleChangeUse = getBoolean ( " Sounds.TitleChange.use " , true , config , writer ) ;
SoundTitleChangeSound = getString ( " Sounds.TitleChange.sound " , " LEVEL_UP " , config , writer ) ;
SoundTitleChangeVolume = getInt ( " Sounds.TitleChange.volume " , 1 , config , writer ) ;
SoundTitleChangePitch = getInt ( " Sounds.TitleChange.pitch " , 3 , config , writer ) ;
writer . addComment ( " Signs " , " You can disable this to save SMALL amount of server resources " ) ;
SignsEnabled = getBoolean ( " Signs.Enable " , true , config , writer ) ;
SignsColorizeJobName = getBoolean ( " Signs.Colors.ColorizeJobName " , true , config , writer ) ;
writer . addComment ( " Signs.InfoUpdateInterval " ,
" This is interval in sec in which signs will be updated. This is not continues update, signs are updated only on levelup, job leave, job join or similar action. " ) ;
writer . addComment ( " Signs.InfoUpdateInterval " ,
" This is update for same job signs, to avoid huge lag if you have bunch of same type signs. Keep it from 1 to as many sec you want " ) ;
InfoUpdateInterval = getInt ( " Signs.InfoUpdateInterval " , 5 , config , writer ) ;
writer . addComment ( " Scoreboard.ShowToplist " , " This will enables to show top list in scoreboard instead of chat " ) ;
ShowToplistInScoreboard = getBoolean ( " Scoreboard.ShowToplist " , true , config , writer ) ;
writer . addComment ( " Scoreboard.interval " , " For how long to show scoreboard " ) ;
ToplistInScoreboardInterval = getInt ( " Scoreboard.interval " , 10 , config , writer ) ;
writer . addComment ( " JobsBrowse.ShowTotalWorkers " , " Do you want to show total amount of workers for job in jobs browse window " ) ;
ShowTotalWorkers = getBoolean ( " JobsBrowse.ShowTotalWorkers " , true , config , writer ) ;
writer . addComment ( " JobsBrowse.ShowPenaltyBonus " , " Do you want to show penalty and bonus in jobs browse window. Only works if this feature is enabled " ) ;
ShowPenaltyBonus = getBoolean ( " JobsBrowse.ShowPenaltyBonus " , true , config , writer ) ;
writer . addComment ( " Schedule.Boost.Enable " , " Do you want to enable scheduler for global boost " ) ;
useGlobalBoostScheduler = getBoolean ( " Schedule.Boost.Enable " , false , config , writer ) ;
// writer.addComment("Gui.UseJobsBrowse", "Do you want to use jobs browse gui instead of chat text");
// UseJobsBrowse = getBoolean("Gui.UseJobsBrowse", true, config, writer);
// Write back config
try {
writer . save ( f ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
}
}
public synchronized void startMysql ( ) {
File f = new File ( plugin . getDataFolder ( ) , " generalConfig.yml " ) ;
YamlConfiguration config = YamlConfiguration . loadConfiguration ( f ) ;
String legacyUrl = config . getString ( " mysql-url " ) ;
if ( legacyUrl ! = null ) {
String jdbcString = " jdbc:mysql:// " ;
if ( legacyUrl . toLowerCase ( ) . startsWith ( jdbcString ) ) {
legacyUrl = legacyUrl . substring ( jdbcString . length ( ) ) ;
String [ ] parts = legacyUrl . split ( " / " ) ;
if ( parts . length > = 2 ) {
config . set ( " mysql-hostname " , parts [ 0 ] ) ;
config . set ( " mysql-database " , parts [ 1 ] ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
}
String username = config . getString ( " mysql-username " ) ;
if ( username = = null ) {
Jobs . getPluginLogger ( ) . severe ( " mysql-username property invalid or missing " ) ;
}
String password = config . getString ( " mysql-password " ) ;
String hostname = config . getString ( " mysql-hostname " ) ;
String database = config . getString ( " mysql-database " ) ;
String prefix = config . getString ( " mysql-table-prefix " ) ;
if ( plugin . isEnabled ( ) )
Jobs . setDAO ( JobsDAOMySQL . initialize ( hostname , database , username , password , prefix ) ) ;
}
public synchronized void startSqlite ( ) {
Jobs . setDAO ( JobsDAOSQLite . initialize ( ) ) ;
}
public synchronized void copySetting ( Configuration reader , Configuration writer , String path ) {
writer . set ( path , reader . get ( path ) ) ;
}
/ * *
* Method to load the title configuration
*
* loads from Jobs / titleConfig . yml
* /
private synchronized void loadTitleSettings ( ) {
this . titles . clear ( ) ;
File f = new File ( plugin . getDataFolder ( ) , " titleConfig.yml " ) ;
YamlConfiguration conf = YamlConfiguration . loadConfiguration ( f ) ;
StringBuilder header = new StringBuilder ( ) . append ( " Title configuration " ) . append ( System . getProperty ( " line.separator " ) ) . append ( System . getProperty ( " line.separator " ) )
. append ( " Stores the titles people gain at certain levels. " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" Each title requres to have a name, short name (used when the player has more than " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" 1 job) the colour of the title and the level requrirement to attain the title. " ) . append ( System . getProperty ( " line.separator " ) ) . append ( System
. getProperty ( " line.separator " ) ) . append ( " It is recommended but not required to have a title at level 0. " ) . append ( System . getProperty (
" line.separator " ) ) . append ( System . getProperty ( " line.separator " ) ) . append ( " Titles are completely optional. " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " Posible variable are {level} to add current jobs level. " ) . append ( System . getProperty ( " line.separator " ) ) . append (
System . getProperty ( " line.separator " ) ) . append ( " Titles: " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " Apprentice: " ) . append (
System . getProperty ( " line.separator " ) ) . append ( " Name: Apprentice " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" ShortName: A " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " ChatColour: WHITE " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " levelReq: 0 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " Novice: " ) . append (
System . getProperty ( " line.separator " ) ) . append ( " Name: Novice " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" ShortName: N " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " ChatColour: GRAY " ) . append ( System
. getProperty ( " line.separator " ) ) . append ( " levelReq: 30 " ) . append ( System . getProperty ( " line.separator " ) )
. append ( " Journeyman: " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " Name: Journeyman " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" ShortName: J " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " ChatColour: GOLD " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" levelReq: 60 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " Master: " ) . append ( System . getProperty ( " line.separator " ) ) . append (
" Name: Master " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " ShortName: '{level} M' " ) . append ( System . getProperty ( " line.separator " ) )
. append ( " ChatColour: BLACK " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " levelReq: 90 " ) . append ( System . getProperty ( " line.separator " ) ) . append (
System . getProperty ( " line.separator " ) ) ;
conf . options ( ) . header ( header . toString ( ) ) ;
conf . options ( ) . copyDefaults ( true ) ;
conf . options ( ) . indent ( 2 ) ;
ConfigurationSection titleSection = conf . getConfigurationSection ( " Titles " ) ;
if ( titleSection = = null ) {
titleSection = conf . createSection ( " Titles " ) ;
}
for ( String titleKey : titleSection . getKeys ( false ) ) {
String jobName = null ;
String titleName = titleSection . getString ( titleKey + " .Name " ) ;
String titleShortName = titleSection . getString ( titleKey + " .ShortName " ) ;
ChatColor titleColor = ChatColor . matchColor ( titleSection . getString ( titleKey + " .ChatColour " , " " ) ) ;
int levelReq = titleSection . getInt ( titleKey + " .levelReq " , - 1 ) ;
if ( titleSection . isString ( titleKey + " .JobName " ) ) {
jobName = titleSection . getString ( titleKey + " .JobName " ) ;
}
if ( titleName = = null ) {
Jobs . getPluginLogger ( ) . severe ( " Title " + titleKey + " has an invalid Name property. Skipping! " ) ;
continue ;
}
if ( titleShortName = = null ) {
Jobs . getPluginLogger ( ) . severe ( " Title " + titleKey + " has an invalid ShortName property. Skipping! " ) ;
continue ;
}
if ( titleColor = = null ) {
Jobs . getPluginLogger ( ) . severe ( " Title " + titleKey + " has an invalid ChatColour property. Skipping! " ) ;
continue ;
}
if ( levelReq < = - 1 ) {
Jobs . getPluginLogger ( ) . severe ( " Title " + titleKey + " has an invalid levelReq property. Skipping! " ) ;
continue ;
}
this . titles . add ( new Title ( titleName , titleShortName , titleColor , levelReq , jobName ) ) ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
try {
conf . save ( f ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
}
}
/ * *
* Method to load the restricted areas configuration
*
* loads from Jobs / restrictedAreas . yml
* /
private synchronized void loadRestrictedAreaSettings ( ) {
this . restrictedAreas . clear ( ) ;
File f = new File ( plugin . getDataFolder ( ) , " restrictedAreas.yml " ) ;
YamlConfiguration conf = YamlConfiguration . loadConfiguration ( f ) ;
conf . options ( ) . indent ( 2 ) ;
conf . options ( ) . copyDefaults ( true ) ;
StringBuilder header = new StringBuilder ( ) ;
header . append ( " Restricted area configuration " ) ;
header . append ( System . getProperty ( " line.separator " ) ) . append ( System . getProperty ( " line.separator " ) ) . append (
" Configures restricted areas where you cannot get experience or money " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " when performing a job. " ) . append (
System . getProperty ( " line.separator " ) ) . append ( System . getProperty ( " line.separator " ) ) . append ( " The multiplier changes the experience/money gains in an area. " )
. append ( System . getProperty ( " line.separator " ) ) . append ( " A multiplier of 0.0 means no money or xp, while 0.5 means you will get half the normal money/exp " )
. append ( System . getProperty ( " line.separator " ) ) . append ( System . getProperty ( " line.separator " ) ) . append ( " restrictedareas: " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " area1: " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " world: 'world' " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " multiplier: 0.0 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " point1: " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " x: 125 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " y: 0 " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " z: 125 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " point2: " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " x: 150 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " y: 100 " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " z: 150 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " area2: " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " world: 'world_nether' " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " multiplier: 0.0 " )
. append ( System . getProperty ( " line.separator " ) ) . append ( " point1: " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " x: -100 " ) . append ( System
. getProperty ( " line.separator " ) ) . append ( " y: 0 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " z: -100 " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " point2: " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " x: -150 " ) . append ( System . getProperty (
" line.separator " ) ) . append ( " y: 100 " ) . append ( System . getProperty ( " line.separator " ) ) . append ( " z: -150 " ) ;
conf . options ( ) . header ( header . toString ( ) ) ;
ConfigurationSection areaSection = conf . getConfigurationSection ( " restrictedareas " ) ;
if ( areaSection ! = null ) {
for ( String areaKey : areaSection . getKeys ( false ) ) {
String worldName = conf . getString ( " restrictedareas. " + areaKey + " .world " ) ;
double multiplier = conf . getDouble ( " restrictedareas. " + areaKey + " .multiplier " , 0 . 0 ) ;
World world = Bukkit . getServer ( ) . getWorld ( worldName ) ;
if ( world = = null )
continue ;
Location point1 = new Location ( world , conf . getDouble ( " restrictedareas. " + areaKey + " .point1.x " , 0 . 0 ) , conf . getDouble ( " restrictedareas. " + areaKey
+ " .point1.y " , 0 . 0 ) , conf . getDouble ( " restrictedareas. " + areaKey + " .point1.z " , 0 . 0 ) ) ;
Location point2 = new Location ( world , conf . getDouble ( " restrictedareas. " + areaKey + " .point2.x " , 0 . 0 ) , conf . getDouble ( " restrictedareas. " + areaKey
+ " .point2.y " , 0 . 0 ) , conf . getDouble ( " restrictedareas. " + areaKey + " .point2.z " , 0 . 0 ) ) ;
this . restrictedAreas . add ( new RestrictedArea ( point1 , point2 , multiplier ) ) ;
}
}
try {
conf . save ( f ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
}
}
/ * *
* Method to load the restricted areas configuration
*
* loads from Jobs / restrictedAreas . yml
* /
private synchronized void loadRestrictedBlocks ( ) {
File f = new File ( plugin . getDataFolder ( ) , " restrictedBlocks.yml " ) ;
YamlConfiguration config = YamlConfiguration . loadConfiguration ( f ) ;
CommentedYamlConfiguration writer = new CommentedYamlConfiguration ( ) ;
config . options ( ) . copyDefaults ( true ) ;
writer . addComment ( " restrictedblocks " , " All block to be protected from place/break exploit. " , " This will prevent piston moving all blocks in list " ,
" Dont count in vegetables or any single click break blocks " ) ;
restrictedBlocks . add ( " 14 " ) ;
restrictedBlocks . add ( " 15 " ) ;
restrictedBlocks . add ( " 16 " ) ;
restrictedBlocks . add ( " 21 " ) ;
restrictedBlocks . add ( " 48 " ) ;
restrictedBlocks . add ( " 56 " ) ;
restrictedBlocks . add ( " 73 " ) ;
restrictedBlocks . add ( " 74 " ) ;
restrictedBlocks . add ( " 129 " ) ;
restrictedBlocks . add ( " 153 " ) ;
config . addDefault ( " restrictedblocks " , restrictedBlocks ) ;
restrictedBlocks = ( ArrayList < String > ) config . getStringList ( " restrictedblocks " ) ;
copySetting ( config , writer , " restrictedblocks " ) ;
writer . addComment ( " blockstimer " , " Block protected by timer in sec " ,
" 141-60 means that carrot can be harvested after 60 sec (remember to use id's from placed objects, not from your inventory) " ) ;
restrictedBlocksTimer . add ( " 2-60 " ) ;
restrictedBlocksTimer . add ( " 3-60 " ) ;
restrictedBlocksTimer . add ( " 6-60 " ) ;
restrictedBlocksTimer . add ( " 12-60 " ) ;
restrictedBlocksTimer . add ( " 18-60 " ) ;
restrictedBlocksTimer . add ( " 31-60 " ) ;
restrictedBlocksTimer . add ( " 32-60 " ) ;
restrictedBlocksTimer . add ( " 37-60 " ) ;
restrictedBlocksTimer . add ( " 38-60 " ) ;
restrictedBlocksTimer . add ( " 39-60 " ) ;
restrictedBlocksTimer . add ( " 40-60 " ) ;
restrictedBlocksTimer . add ( " 55-60 " ) ;
restrictedBlocksTimer . add ( " 59-60 " ) ;
restrictedBlocksTimer . add ( " 80-60 " ) ;
restrictedBlocksTimer . add ( " 81-60 " ) ;
restrictedBlocksTimer . add ( " 83-60 " ) ;
restrictedBlocksTimer . add ( " 103-60 " ) ;
restrictedBlocksTimer . add ( " 106-60 " ) ;
restrictedBlocksTimer . add ( " 111-60 " ) ;
restrictedBlocksTimer . add ( " 141-60 " ) ;
restrictedBlocksTimer . add ( " 142-60 " ) ;
restrictedBlocksTimer . add ( " 161-60 " ) ;
restrictedBlocksTimer . add ( " 171-60 " ) ;
restrictedBlocksTimer . add ( " 175-60 " ) ;
config . addDefault ( " blockstimer " , restrictedBlocksTimer ) ;
restrictedBlocksTimer = ( ArrayList < String > ) config . getStringList ( " blockstimer " ) ;
copySetting ( config , writer , " blockstimer " ) ;
writer . addComment ( " PlacedBlockTimer " , " Block place protected by timer in sec " , " For this to work CoreProtect plugin should be installed " ) ;
restrictedPlaceBlocksTimer . add ( 2 ) ;
restrictedPlaceBlocksTimer . add ( 3 ) ;
restrictedPlaceBlocksTimer . add ( 6 ) ;
restrictedPlaceBlocksTimer . add ( 12 ) ;
restrictedPlaceBlocksTimer . add ( 18 ) ;
restrictedPlaceBlocksTimer . add ( 31 ) ;
restrictedPlaceBlocksTimer . add ( 32 ) ;
restrictedPlaceBlocksTimer . add ( 37 ) ;
restrictedPlaceBlocksTimer . add ( 38 ) ;
restrictedPlaceBlocksTimer . add ( 39 ) ;
restrictedPlaceBlocksTimer . add ( 40 ) ;
restrictedPlaceBlocksTimer . add ( 55 ) ;
restrictedPlaceBlocksTimer . add ( 59 ) ;
restrictedPlaceBlocksTimer . add ( 80 ) ;
restrictedPlaceBlocksTimer . add ( 81 ) ;
restrictedPlaceBlocksTimer . add ( 83 ) ;
restrictedPlaceBlocksTimer . add ( 103 ) ;
restrictedPlaceBlocksTimer . add ( 106 ) ;
restrictedPlaceBlocksTimer . add ( 111 ) ;
restrictedPlaceBlocksTimer . add ( 141 ) ;
restrictedPlaceBlocksTimer . add ( 142 ) ;
restrictedPlaceBlocksTimer . add ( 161 ) ;
restrictedPlaceBlocksTimer . add ( 171 ) ;
restrictedPlaceBlocksTimer . add ( 175 ) ;
config . addDefault ( " PlacedBlockTimer " , restrictedPlaceBlocksTimer ) ;
restrictedPlaceBlocksTimer = ( ArrayList < Integer > ) config . getIntegerList ( " PlacedBlockTimer " ) ;
copySetting ( config , writer , " PlacedBlockTimer " ) ;
try {
writer . save ( f ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
}
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
/ * *
* Method to load the scheduler configuration
*
* loads from Jobs / schedule . yml
* /
public void loadScheduler ( ) {
File f = new File ( plugin . getDataFolder ( ) , " schedule.yml " ) ;
YamlConfiguration conf = YamlConfiguration . loadConfiguration ( f ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
conf . options ( ) . copyDefaults ( true ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! conf . contains ( " Boost " ) )
return ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
ArrayList < String > sections = new ArrayList < String > ( conf . getConfigurationSection ( " Boost " ) . getKeys ( false ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
for ( String OneSection : sections ) {
ConfigurationSection path = conf . getConfigurationSection ( " Boost. " + OneSection ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Enabled " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! conf . getConfigurationSection ( " Boost. " + OneSection ) . getBoolean ( " Enabled " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
Schedule sched = new Schedule ( ) ;
sched . setName ( OneSection ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " From " ) | | ! path . getString ( " From " ) . contains ( " : " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Until " ) | | ! path . getString ( " Until " ) . contains ( " : " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Days " ) | | ! path . isList ( " Days " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Jobs " ) | | ! path . isList ( " Jobs " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Exp " ) | | ! path . isDouble ( " Exp " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! path . contains ( " Money " ) | | ! path . isDouble ( " Money " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-17 09:48:10 +02:00
sched . setDays ( path . getStringList ( " Days " ) ) ;
sched . setJobs ( path . getStringList ( " Jobs " ) ) ;
sched . setFrom ( Integer . valueOf ( path . getString ( " From " ) . replace ( " : " , " " ) ) ) ;
sched . setUntil ( Integer . valueOf ( path . getString ( " Until " ) . replace ( " : " , " " ) ) ) ;
2015-09-10 12:41:19 +02:00
if ( path . contains ( " MessageOnStart " ) & & path . isList ( " MessageOnStart " ) )
2015-09-17 09:48:10 +02:00
sched . setMessageOnStart ( path . getStringList ( " MessageOnStart " ) , path . getString ( " From " ) , path . getString ( " Until " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( path . contains ( " BroadcastOnStart " ) )
sched . setBroadcastOnStart ( path . getBoolean ( " BroadcastOnStart " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( path . contains ( " MessageOnStop " ) & & path . isList ( " MessageOnStop " ) )
2015-09-17 09:48:10 +02:00
sched . setMessageOnStop ( path . getStringList ( " MessageOnStop " ) , path . getString ( " From " ) , path . getString ( " Until " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( path . contains ( " BroadcastOnStop " ) )
sched . setBroadcastOnStop ( path . getBoolean ( " BroadcastOnStop " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-17 09:48:10 +02:00
if ( path . contains ( " BroadcastInterval " ) )
sched . setBroadcastInterval ( path . getInt ( " BroadcastInterval " ) ) ;
if ( path . contains ( " BroadcastMessage " ) & & path . isList ( " BroadcastMessage " ) )
sched . setMessageToBroadcast ( path . getStringList ( " BroadcastMessage " ) , path . getString ( " From " ) , path . getString ( " Until " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
sched . setExpBoost ( path . getDouble ( " Exp " ) ) ;
sched . setMoneyBoost ( path . getDouble ( " Money " ) ) ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
BoostSchedule . add ( sched ) ;
2015-08-21 15:10:08 +02:00
}
// try {
// conf.save(f);
// } catch (IOException e) {
// e.printStackTrace();
// }
2015-09-10 12:41:19 +02:00
}
private Boolean getBoolean ( String path , Boolean boo , YamlConfiguration config , CommentedYamlConfiguration writer ) {
config . addDefault ( path , boo ) ;
copySetting ( config , writer , path ) ;
return config . getBoolean ( path ) ;
}
private int getInt ( String path , int boo , YamlConfiguration config , CommentedYamlConfiguration writer ) {
config . addDefault ( path , boo ) ;
copySetting ( config , writer , path ) ;
return config . getInt ( path ) ;
}
private List < Integer > getIntArray ( String path , List < Integer > boo , YamlConfiguration config , CommentedYamlConfiguration writer ) {
config . addDefault ( path , boo ) ;
copySetting ( config , writer , path ) ;
return config . getIntegerList ( path ) ;
}
private String getString ( String path , String boo , YamlConfiguration config , CommentedYamlConfiguration writer ) {
config . addDefault ( path , boo ) ;
copySetting ( config , writer , path ) ;
return config . getString ( path ) ;
}
private Double getDouble ( String path , Double boo , YamlConfiguration config , CommentedYamlConfiguration writer ) {
config . addDefault ( path , boo ) ;
copySetting ( config , writer , path ) ;
return config . getDouble ( path ) ;
}
private synchronized void loadItemList ( ) {
YmlMaker ItemFile = new YmlMaker ( ( JavaPlugin ) JobsPlugin . instance , " ItemList.yml " ) ;
ItemFile . saveDefaultConfig ( ) ;
List < String > section = ItemFile . getConfig ( ) . getStringList ( " ItemList " ) ;
ListOfNames . clear ( ) ;
for ( String one : section ) {
if ( ! one . contains ( " - " ) )
continue ;
if ( ! one . contains ( " = " ) )
continue ;
String meta = " " ;
String id = one . split ( " - " ) [ 0 ] ;
String part2 = one . split ( " - " ) [ 1 ] ;
String part3 = " " ;
part3 = part2 . split ( " = " ) [ 1 ] ;
part2 = part2 . split ( " = " ) [ 0 ] ;
if ( id . contains ( " : " ) ) {
meta = id . split ( " : " ) [ 1 ] ;
id = id . split ( " : " ) [ 0 ] ;
}
ListOfNames . add ( new NameList ( id , meta , part2 , part3 ) ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
section = ItemFile . getConfig ( ) . getStringList ( " EntityList " ) ;
ListOfEntities . clear ( ) ;
for ( String one : section ) {
if ( ! one . contains ( " - " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! one . contains ( " = " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
String meta = " " ;
String id = one . split ( " - " ) [ 0 ] ;
String part2 = one . split ( " - " ) [ 1 ] ;
String part3 = " " ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
part3 = part2 . split ( " = " ) [ 1 ] ;
part2 = part2 . split ( " = " ) [ 0 ] ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( id . contains ( " : " ) ) {
meta = id . split ( " : " ) [ 1 ] ;
id = id . split ( " : " ) [ 0 ] ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
ListOfEntities . add ( new NameList ( id , meta , part2 , part3 ) ) ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
section = ItemFile . getConfig ( ) . getStringList ( " EnchantList " ) ;
ListOfEnchants . clear ( ) ;
for ( String one : section ) {
if ( ! one . contains ( " - " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! one . contains ( " = " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
String id = one . split ( " - " ) [ 0 ] ;
String part2 = one . split ( " - " ) [ 1 ] ;
String part3 = " " ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
part3 = part2 . split ( " = " ) [ 1 ] ;
part2 = part2 . split ( " = " ) [ 0 ] ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
ListOfEnchants . add ( new NameList ( id , " " , part2 , part3 ) ) ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
section = ItemFile . getConfig ( ) . getStringList ( " ColorList " ) ;
ListOfColors . clear ( ) ;
for ( String one : section ) {
if ( ! one . contains ( " - " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if ( ! one . contains ( " = " ) )
continue ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
String id = one . split ( " - " ) [ 0 ] ;
String part2 = one . split ( " - " ) [ 1 ] ;
String part3 = " " ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
part3 = part2 . split ( " = " ) [ 1 ] ;
part2 = part2 . split ( " = " ) [ 0 ] ;
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
ListOfColors . add ( new NameList ( id , " " , part2 , part3 ) ) ;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
/ * *
* Method to load the language file configuration
*
* loads from Jobs / locale / messages_en . yml
* /
private synchronized void loadLanguage ( ) {
// Just copying default language files, except en, that one will be generated
List < String > languages = new ArrayList < String > ( ) ;
languages . add ( " lt " ) ;
languages . add ( " de " ) ;
languages . add ( " cs " ) ;
languages . add ( " fr " ) ;
languages . add ( " ru " ) ;
for ( String lang : languages ) {
YmlMaker langFile = new YmlMaker ( ( JavaPlugin ) JobsPlugin . instance , " locale " + File . separator + " messages_ " + lang + " .yml " ) ;
if ( langFile ! = null )
langFile . saveDefaultConfig ( ) ;
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
languages . clear ( ) ;
languages . add ( " en " ) ;
File customLocaleFile = new File ( plugin . getDataFolder ( ) , " locale " + File . separator + " messages_ " + localeString + " .yml " ) ;
if ( ! customLocaleFile . exists ( ) & & ! localeString . equalsIgnoreCase ( " en " ) )
languages . add ( localeString ) ;
for ( String lang : languages ) {
File f = new File ( plugin . getDataFolder ( ) , " locale " + File . separator + " messages_ " + lang + " .yml " ) ;
YamlConfiguration conf = YamlConfiguration . loadConfiguration ( f ) ;
CommentedYamlConfiguration writer = new CommentedYamlConfiguration ( ) ;
conf . options ( ) . copyDefaults ( true ) ;
GetConfigString ( " economy.error.nomoney " , " Sorry, no money left in national bank! " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.help.info " , " Boosts Money gain for all players " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.help.args " , " [jobname] [rate] " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.allreset " , " All money boost turned off " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.jobsboostreset " , " Money boost for %jobname% was turned off " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.nothingtoreset " , " Nothing to reset " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.boostalladded " , " Money boost of %boost% added for all jobs! " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.boostadded " , " Money boost of &e%boost% &aadded for &e%jobname%! " , writer , conf , true ) ;
GetConfigString ( " command.moneyboost.output.infostats " , " &c-----> &aMoney rate x%boost% enabled&c <------- " , writer , conf , true ) ;
GetConfigString ( " command.expboost.help.info " , " Boosts Exp gain for all players " , writer , conf , true ) ;
GetConfigString ( " command.expboost.help.args " , " [jobname] [rate] " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.allreset " , " All exp boost turned off " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.jobsboostreset " , " Exp boost for %jobname% was turned off " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.nothingtoreset " , " Nothing to reset " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.boostalladded " , " Exp boost of %boost% added for all jobs! " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.boostadded " , " Exp boost of &e%boost% &aadded for &e%jobname%! " , writer , conf , true ) ;
GetConfigString ( " command.expboost.output.infostats " , " &c-----> &aExp rate x%boost% enabled&c <------- " , writer , conf , true ) ;
GetConfigString ( " command.convert.help.info " ,
" Converts data base system from one system to another. if you currently running sqlite, this will convert to Mysql and vise versa. " , writer , conf , true ) ;
GetConfigString ( " command.convert.help.args " , " " , writer , conf , true ) ;
GetConfigString ( " command.limit.help.info " , " Shows payment limits for jobs " , writer , conf , true ) ;
GetConfigString ( " command.limit.help.args " , " " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.lefttime " , " &eTime left until money limit resets: &2%hour% &ehour &2%min% &emin &2%sec% &esec " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.moneylimit " , " &eMoney limit: &2%money%&e/&2%totalmoney% " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.leftexptime " , " &eTime left until Exp limit resets: &2%hour% &ehour &2%min% &emin &2%sec% &esec " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.explimit " , " &eExp limit: &2%exp%&e/&2%totalexp% " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.reachedlimit " , " &4You have reached money limit in given time! " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.reachedlimit2 " , " &eYou can check your limit with &2/jobs limit &ecommand " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.reachedExplimit " , " &4You have reached exp limit in given time! " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.reachedExplimit2 " , " &eYou can check your limit with &2/jobs limit &ecommand " , writer , conf , true ) ;
GetConfigString ( " command.limit.output.notenabled " , " &eMoney limit is not enabled " , writer , conf , true ) ;
GetConfigString ( " command.admin.error " , " There was an error in the command. " , writer , conf , true ) ;
GetConfigString ( " command.admin.success " , " Your command has been performed. " , writer , conf , true ) ;
GetConfigString ( " command.error.notNumber " , " &ePlease use numbers! " , writer , conf , true ) ;
GetConfigString ( " command.error.job " , " The job you have selected does not exist! " , writer , conf , true ) ;
GetConfigString ( " command.error.permission " , " You do not have permission to do that! " , writer , conf , true ) ;
GetConfigString ( " command.help.output.info " , " Type /jobs [cmd] ? for more information about a command. " , writer , conf , true ) ;
GetConfigString ( " command.help.output.usage " , " Usage: %usage% " , writer , conf , true ) ;
GetConfigString ( " command.stats.help.info " , " Show the level you are in each job you are part of. " , writer , conf , true ) ;
GetConfigString ( " command.stats.help.args " , " [playername] " , writer , conf , true ) ;
GetConfigString ( " command.stats.error.nojob " , " Please join a job first. " , writer , conf , true ) ;
GetConfigString ( " command.stats.output " , " lvl%joblevel% %jobname% : %jobxp%/%jobmaxxp% xp " , writer , conf , true ) ;
GetConfigString ( " command.archive.help.info " , " Shows all jobs saved in archive by user. " , writer , conf , true ) ;
GetConfigString ( " command.archive.help.args " , " [playername] " , writer , conf , true ) ;
GetConfigString ( " command.archive.error.nojob " , " There is no jobs saved. " , writer , conf , true ) ;
GetConfigString ( " command.archive.output " , " lvl %joblevel% (%getbackjoblevel%) %jobname% " , writer , conf , true ) ;
GetConfigString ( " command.give.help.info " , " Gives item by jobs name and item category name. Player name is optional " , writer , conf , true ) ;
GetConfigString ( " command.give.help.args " , " [playername] [jobname] [itemname] " , writer , conf , true ) ;
GetConfigString ( " command.give.output.notonline " , " &4Player [%playername%] is not online! " , writer , conf , true ) ;
GetConfigString ( " command.give.output.noitem " , " &4Cant find any item by given name! " , writer , conf , true ) ;
GetConfigString ( " command.info.help.title " , " &2*** &eJobs&2 *** " , writer , conf , true ) ;
GetConfigString ( " command.info.help.info " , " Show how much each job is getting paid and for what. " , writer , conf , true ) ;
GetConfigString ( " command.info.help.penalty " , " &eThis job have &c[penalty]% &epenalty because of too many players working in it. " , writer , conf , true ) ;
GetConfigString ( " command.info.help.bonus " , " &eThis job have &2[bonus]% &ebonus because not enough players working in it. " , writer , conf , true ) ;
GetConfigString ( " command.info.help.args " , " [jobname] [action] " , writer , conf , true ) ;
GetConfigString ( " command.info.help.actions " , " &eValid actions are: &f%actions% " , writer , conf , true ) ;
GetConfigString ( " command.info.help.max " , " - &emax level:&f " , writer , conf , true ) ;
GetConfigString ( " command.info.help.material " , " &7%material% " , writer , conf , true ) ;
GetConfigString ( " command.info.output.break.info " , " Break " , writer , conf , true ) ;
GetConfigString ( " command.info.output.break.none " , " %jobname% does not get money for breaking blocks. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.place.info " , " Place " , writer , conf , true ) ;
GetConfigString ( " command.info.output.place.none " , " %jobname% does not get money for placing blocks. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.kill.info " , " Kill " , writer , conf , true ) ;
GetConfigString ( " command.info.output.kill.none " , " %jobname% does not get money for killing monsters. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.fish.info " , " Fish " , writer , conf , true ) ;
GetConfigString ( " command.info.output.fish.none " , " %jobname% does not get money from fishing. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.craft.info " , " Craft " , writer , conf , true ) ;
GetConfigString ( " command.info.output.craft.none " , " %jobname% does not get money from crafting. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.smelt.info " , " Smelt " , writer , conf , true ) ;
GetConfigString ( " command.info.output.smelt.none " , " %jobname% does not get money from smelting. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.brew.info " , " Brew " , writer , conf , true ) ;
GetConfigString ( " command.info.output.brew.none " , " %jobname% does not get money from brewing. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.enchant.info " , " Enchant " , writer , conf , true ) ;
GetConfigString ( " command.info.output.enchant.none " , " %jobname% does not get money from enchanting. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.repair.info " , " Repair " , writer , conf , true ) ;
GetConfigString ( " command.info.output.repair.none " , " %jobname% does not get money from repairing. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.breed.info " , " Breed " , writer , conf , true ) ;
GetConfigString ( " command.info.output.breed.none " , " %jobname% does not get money from breeding. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.tame.info " , " Tame " , writer , conf , true ) ;
GetConfigString ( " command.info.output.tame.none " , " %jobname% does not get money from taming. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.milk.info " , " Milk " , writer , conf , true ) ;
GetConfigString ( " command.info.output.milk.none " , " %jobname% does not get money from milking cows. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.shear.info " , " Shear " , writer , conf , true ) ;
GetConfigString ( " command.info.output.shear.none " , " %jobname% does not get money from shearing sheeps. " , writer , conf , true ) ;
GetConfigString ( " command.info.output.custom-kill.info " , " Custom kill " , writer , conf , true ) ;
GetConfigString ( " command.info.output.custom-kill.none " , " %jobname% does not get money from custom player kills. " , writer , conf , true ) ;
GetConfigString ( " command.playerinfo.help.info " , " Show how much each job is getting paid and for what on another player. " , writer , conf , true ) ;
GetConfigString ( " command.playerinfo.help.args " , " [playername] [jobname] [action] " , writer , conf , true ) ;
GetConfigString ( " command.join.help.info " , " Join the selected job. " , writer , conf , true ) ;
GetConfigString ( " command.join.help.args " , " [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.join.error.alreadyin " , " You are already in the job %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.join.error.fullslots " , " You cannot join the job %jobname%, there are no slots available. " , writer , conf , true ) ;
GetConfigString ( " command.join.error.maxjobs " , " You have already joined too many jobs. " , writer , conf , true ) ;
GetConfigString ( " command.join.success " , " You have joined the job %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.leave.help.info " , " Leave the selected job. " , writer , conf , true ) ;
GetConfigString ( " command.leave.help.args " , " [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.leave.success " , " You have left the job %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.leaveall.help.info " , " Leave all your jobs. " , writer , conf , true ) ;
GetConfigString ( " command.leaveall.error.nojobs " , " You do not have any jobs to leave! " , writer , conf , true ) ;
GetConfigString ( " command.leaveall.success " , " You have left all your jobs. " , writer , conf , true ) ;
GetConfigString ( " command.browse.help.info " , " List the jobs available to you. " , writer , conf , true ) ;
GetConfigString ( " command.browse.error.nojobs " , " There are no jobs you can join. " , writer , conf , true ) ;
GetConfigString ( " command.browse.output.header " , " You are allowed to join the following jobs: " , writer , conf , true ) ;
GetConfigString ( " command.browse.output.footer " , " For more information type in /jobs info [JobName] " , writer , conf , true ) ;
GetConfigString ( " command.browse.output.totalWorkers " , " &7Workers: &e[amount] " , writer , conf , true ) ;
GetConfigString ( " command.browse.output.penalty " , " &4Penalty: &c[amount]% " , writer , conf , true ) ;
GetConfigString ( " command.browse.output.bonus " , " &2Bonus: &a[amount]% " , writer , conf , true ) ;
GetConfigString ( " command.fire.help.info " , " Fire the player from the job. " , writer , conf , true ) ;
GetConfigString ( " command.fire.help.args " , " [playername] [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.fire.error.nojob " , " Player does not have the job %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.fire.output.target " , " You have been fired from %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.fireall.help.info " , " Fire player from all their jobs. " , writer , conf , true ) ;
GetConfigString ( " command.fireall.help.args " , " [playername] " , writer , conf , true ) ;
GetConfigString ( " command.fireall.error.nojobs " , " Player does not have any jobs to be fired from! " , writer , conf , true ) ;
GetConfigString ( " command.fireall.output.target " , " You have been fired from all your jobs. " , writer , conf , true ) ;
GetConfigString ( " command.employ.help.info " , " Employ the player to the job. " , writer , conf , true ) ;
GetConfigString ( " command.employ.help.args " , " [playername] [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.employ.error.alreadyin " , " Player is already in the job %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.employ.output.target " , " You have been employed as a %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.top.help.info " , " Shows top 15 players by jobs name. " , writer , conf , true ) ;
GetConfigString ( " command.top.help.args " , " [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.top.error.nojob " , " Cant find any job with this name. " , writer , conf , true ) ;
GetConfigString ( " command.top.output.topline " , " &aTop&e 15 &aplayers by &e%jobname% &ajob " , writer , conf , true ) ;
GetConfigString ( " command.top.output.list " , " &e%number%&a. &e%playername% &alvl &e%level% &awith&e %exp% &aexp " , writer , conf , true ) ;
GetConfigString ( " command.top.output.prev " , " &e<<<<< Prev page &2| " , writer , conf , true ) ;
GetConfigString ( " command.top.output.next " , " &2|&e Next Page >>>> " , writer , conf , true ) ;
GetConfigString ( " command.top.output.show " , " &2Show from &e[from] &2until &e[until] &2top list " , writer , conf , true ) ;
GetConfigString ( " command.gtop.help.info " , " Shows top 15 players by global jobs level. " , writer , conf , true ) ;
GetConfigString ( " command.gtop.help.args " , " " , writer , conf , true ) ;
GetConfigString ( " command.gtop.error.nojob " , " Cant find any information. " , writer , conf , true ) ;
GetConfigString ( " command.gtop.output.topline " , " &aTop&e 15 &aplayers by global job level " , writer , conf , true ) ;
GetConfigString ( " command.gtop.output.list " , " &e%number%&a. &e%playername% &alvl &e%level% &awith&e %exp% &aexp " , writer , conf , true ) ;
GetConfigString ( " command.gtop.output.prev " , " &e<<<<< Prev page &2| " , writer , conf , true ) ;
GetConfigString ( " command.gtop.output.next " , " &2|&e Next Page >>>> " , writer , conf , true ) ;
GetConfigString ( " command.gtop.output.show " , " &2Show from &e[from] &2until &e[until] &2global top list " , writer , conf , true ) ;
2015-09-17 17:28:23 +02:00
GetConfigString ( " command.log.help.info " , " Shows statistics. " , writer , conf , true ) ;
GetConfigString ( " command.log.help.args " , " [playername] " , writer , conf , true ) ;
GetConfigString ( " command.log.output.topline " , " &7************************* &6%playername% &7************************* " , writer , conf , true ) ;
GetConfigString ( " command.log.output.list " , " &7* &6%number%. &3%action%: &6%item% &eqty: %qty% &6money: %money% &eexp: %exp% " , writer , conf , true ) ;
GetConfigString ( " command.log.output.bottomline " , " &7*********************************************************** " , writer , conf , true ) ;
GetConfigString ( " command.log.output.prev " , " &e<<<<< Prev page &2| " , writer , conf , true ) ;
GetConfigString ( " command.log.output.next " , " &2|&e Next Page >>>> " , writer , conf , true ) ;
GetConfigString ( " command.glog.help.info " , " Shows global statistics. " , writer , conf , true ) ;
GetConfigString ( " command.glog.help.args " , " " , writer , conf , true ) ;
GetConfigString ( " command.glog.output.topline " , " &7*********************** &6Global statistics &7*********************** " , writer , conf , true ) ;
GetConfigString ( " command.glog.output.list " , " &7* &6%number%. &3%username% &e%action%: &6%item% &eqty: %qty% &6money: %money% &eexp: %exp% " , writer , conf , true ) ;
GetConfigString ( " command.glog.output.bottomline " , " &7************************************************************** " , writer , conf , true ) ;
2015-09-10 12:41:19 +02:00
GetConfigString ( " command.transfer.help.info " , " Transfer a player's job from an old job to a new job. " , writer , conf , true ) ;
GetConfigString ( " command.transfer.help.args " , " [playername] [oldjob] [newjob] " , writer , conf , true ) ;
GetConfigString ( " command.transfer.output.target " , " You have been transferred from %oldjobname% to %newjobname%. " , writer , conf , true ) ;
GetConfigString ( " command.promote.help.info " , " Promote the player X levels in a job. " , writer , conf , true ) ;
GetConfigString ( " command.promote.help.args " , " [playername] [jobname] [levels] " , writer , conf , true ) ;
GetConfigString ( " command.promote.output.target " , " You have been promoted %levelsgained% levels in %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.demote.help.info " , " Demote the player X levels in a job. " , writer , conf , true ) ;
GetConfigString ( " command.demote.help.args " , " [playername] [jobname] [levels] " , writer , conf , true ) ;
GetConfigString ( " command.demote.output.target " , " You have been demoted %levelslost% levels in %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.grantxp.help.info " , " Grant the player X experience in a job. " , writer , conf , true ) ;
GetConfigString ( " command.grantxp.help.args " , " [playername] [jobname] [xp] " , writer , conf , true ) ;
GetConfigString ( " command.grantxp.output.target " , " You have been granted %xpgained% experience in %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.removexp.help.info " , " Remove X experience from the player in a job. " , writer , conf , true ) ;
GetConfigString ( " command.removexp.help.args " , " [playername] [jobname] [xp] " , writer , conf , true ) ;
GetConfigString ( " command.removexp.output.target " , " You have lost %xplost% experience in %jobname%. " , writer , conf , true ) ;
GetConfigString ( " command.signupdate.help.info " , " Manualy updates sign by its name " , writer , conf , true ) ;
GetConfigString ( " command.signupdate.help.args " , " [jobname] " , writer , conf , true ) ;
GetConfigString ( " command.reload.help.info " , " Reload configurations. " , writer , conf , true ) ;
GetConfigString ( " message.skillup.broadcast " , " %playername% has been promoted to a %titlename% %jobname%. " , writer , conf , true ) ;
GetConfigString ( " message.skillup.nobroadcast " , " Congratulations, you have been promoted to a %titlename% %jobname%. " , writer , conf , true ) ;
GetConfigString ( " message.levelup.broadcast " , " %playername% is now a level %joblevel% %jobname%. " , writer , conf , true ) ;
GetConfigString ( " message.levelup.nobroadcast " , " You are now a level %joblevel% %jobname%. " , writer , conf , true ) ;
GetConfigString ( " message.cowtimer " , " &eYou still need to wait &6%time% &esec to get paid for this job. " , writer , conf , true ) ;
GetConfigString ( " message.blocktimer " , " &eYou need to wait: &3[time] &esec more to get paid for this! " , writer , conf , true ) ;
GetConfigString ( " message.placeblocktimer " , " &eYou cant place block faster than &6[time] &esec interval in same place! " , writer , conf , true ) ;
GetConfigString ( " message.taxes " , " &3[amount] &eserver taxes where transfered to this account " , writer , conf , true ) ;
GetConfigString ( " message.boostStarted " , " &eJobs boost time have been started! " , writer , conf , true ) ;
GetConfigString ( " message.boostStoped " , " &eJobs boost time have been ended! " , writer , conf , true ) ;
GetConfigString ( " command.toggle.help.info " , " Toggles payment output on action bar. " , writer , conf , true ) ;
GetConfigString ( " command.toggle.output.turnedoff " , " &4This feature are turned off! " , writer , conf , true ) ;
GetConfigString ( " command.toggle.output.paid " , " &aYou got paid for &2[amount]&a and got &2[exp] &aexp " , writer , conf , true ) ;
GetConfigString ( " command.toggle.output.on " , " &aToggled: &aON " , writer , conf , true ) ;
GetConfigString ( " command.toggle.output.off " , " &aToggled: &4OFF " , writer , conf , true ) ;
GetConfigString ( " message.crafting.fullinventory " , " Your inventory is full! " , writer , conf , true ) ;
GetConfigString ( " signs.List " , " &0[number].&8[player]&7:&4[level] " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.1.1 " , " &b** &8First &b** " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.1.2 " , " &9[player] " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.1.3 " , " &8[level] level " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.1.4 " , " &b************ " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.2.1 " , " &b** &8Second &b** " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.2.2 " , " &9[player] " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.2.3 " , " &8[level] level " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.2.4 " , " &b************ " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.3.1 " , " &b** &8Third &b** " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.3.2 " , " &9[player] " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.3.3 " , " &8[level] level " , writer , conf , true ) ;
GetConfigString ( " signs.SpecialList.3.4 " , " &b************ " , writer , conf , true ) ;
GetConfigString ( " signs.cantcreate " , " &4You can't create this sign! " , writer , conf , true ) ;
2015-09-10 16:00:43 +02:00
GetConfigString ( " signs.cantdestroy " , " &4You can't destroy this sign! " , writer , conf , true ) ;
2015-09-10 12:41:19 +02:00
GetConfigString ( " signs.topline " , " &2[Jobs] " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.join " , " &2Join " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.leave " , " &4Leave " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.toggle " , " &2Toggle " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.top " , " &2Top " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.browse " , " &2Browse " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.stats " , " &2Stats " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.limit " , " &2Limit " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.info " , " &2Info " , writer , conf , true ) ;
GetConfigString ( " signs.secondline.archive " , " &2Archive " , writer , conf , true ) ;
//GetConfigString("scoreboard.clear", "&eIf you want to remove scoreboard, type &2/jobs top clear", writer, conf, true);
GetConfigString ( " scoreboard.topline " , " &2Top &e%jobname% " , writer , conf , true ) ;
GetConfigString ( " scoreboard.gtopline " , " &2Global top list " , writer , conf , true ) ;
GetConfigString ( " scoreboard.lines " , " &2%number%. &e%playername% " , writer , conf , true ) ;
keys = new ArrayList < String > ( conf . getConfigurationSection ( " signs.secondline " ) . getKeys ( false ) ) ;
// Write back config
try {
writer . save ( f ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
}
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
2015-08-21 15:10:08 +02:00
}